summaryrefslogtreecommitdiff
path: root/src/cmd/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/cmd/lib')
-rw-r--r--src/cmd/lib/types.zig25
1 files changed, 22 insertions, 3 deletions
diff --git a/src/cmd/lib/types.zig b/src/cmd/lib/types.zig
index c1ce3c7..f663a64 100644
--- a/src/cmd/lib/types.zig
+++ b/src/cmd/lib/types.zig
@@ -32,6 +32,13 @@ pub const OutputCapture = struct {
}
};
+pub const StdoutOutputCapture = struct {
+ pub fn write(self: *StdoutOutputCapture, data: []const u8) !void {
+ _ = self;
+ try std.io.getStdOut().writeAll(data);
+ }
+};
+
pub const InputSource = struct {
data: []const u8,
position: usize,
@@ -65,18 +72,30 @@ pub const InputSource = struct {
}
};
+pub const OutputWriter = union(enum) {
+ capture: *OutputCapture,
+ stdout: *StdoutOutputCapture,
+
+ pub fn write(self: *OutputWriter, data: []const u8) !void {
+ switch (self.*) {
+ .capture => |capture| try capture.write(data),
+ .stdout => |stdout| try stdout.write(data),
+ }
+ }
+};
+
pub const ExecuteCommandFn = *const fn (Command, Allocator, ?*OutputCapture, ?*InputSource) anyerror!CommandStatus;
pub const CommandContext = struct {
allocator: Allocator,
- output_capture: ?*OutputCapture,
+ output_writer: OutputWriter,
input_source: ?*InputSource,
execute_command: ExecuteCommandFn,
- pub fn init(allocator: Allocator, output_capture: ?*OutputCapture, input_source: ?*InputSource, execute_command: ExecuteCommandFn) CommandContext {
+ pub fn init(allocator: Allocator, output_writer: OutputWriter, input_source: ?*InputSource, execute_command: ExecuteCommandFn) CommandContext {
return CommandContext{
.allocator = allocator,
- .output_capture = output_capture,
+ .output_writer = output_writer,
.input_source = input_source,
.execute_command = execute_command,
};