summaryrefslogtreecommitdiff
path: root/src/shell.zig
diff options
context:
space:
mode:
authorLucas Faria Mendes <lucas.oliveira1676@etec.sp.gov.br>2025-12-05 08:40:08 +0000
committerLucas Faria Mendes <lucas.oliveira1676@etec.sp.gov.br>2025-12-05 08:40:08 +0000
commitb92ef57d9cfb3b8b51848d3a2940b0b2251c0529 (patch)
tree0ad31ed29a5175bf142e45a5d93a9a37b2ad4c41 /src/shell.zig
parent379cdbd946dfb035e61f96653db618cba4906864 (diff)
downloadshell-zig-b92ef57d9cfb3b8b51848d3a2940b0b2251c0529.tar.gz
shell-zig-b92ef57d9cfb3b8b51848d3a2940b0b2251c0529.zip
codecrafters submit [skip ci]
Diffstat (limited to 'src/shell.zig')
-rw-r--r--src/shell.zig8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/shell.zig b/src/shell.zig
index fd72288..5a848af 100644
--- a/src/shell.zig
+++ b/src/shell.zig
@@ -24,7 +24,7 @@ pub fn executeCommand(
if (std.mem.eql(u8, cmd_name, "exit")) return builtins.executeExit();
if (std.mem.eql(u8, cmd_name, "history")) {
- // Check if args contain -r flag for reading from file
+ // Check if args contain -r or -w flag for reading/writing file
if (args) |a| {
const trimmed = std.mem.trim(u8, a, " ");
if (std.mem.startsWith(u8, trimmed, "-r ")) {
@@ -33,6 +33,12 @@ pub fn executeCommand(
try builtins.executeHistoryRead(allocator, stdout, file_path, history);
}
return .continue_loop;
+ } else if (std.mem.startsWith(u8, trimmed, "-w ")) {
+ const file_path = std.mem.trim(u8, trimmed[3..], " ");
+ if (file_path.len > 0) {
+ try builtins.executeHistoryWrite(stdout, file_path, history.items);
+ }
+ return .continue_loop;
}
}