From d9ca9db5a49f0af2f6bef6f198b28a8d29808e6d Mon Sep 17 00:00:00 2001 From: Isaac Freund Date: Tue, 26 May 2020 22:55:07 +0200 Subject: Rework commands to be string based This allows for significantly more flexibility and should make implementing the bind command possible. --- src/command/send_to_output.zig | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'src/command/send_to_output.zig') diff --git a/src/command/send_to_output.zig b/src/command/send_to_output.zig index 7e0bbbf..de92f6f 100644 --- a/src/command/send_to_output.zig +++ b/src/command/send_to_output.zig @@ -19,16 +19,23 @@ const std = @import("std"); const c = @import("../c.zig"); -const Arg = @import("../Command.zig").Arg; +const Error = @import("../command.zig").Error; +const Direction = @import("../command.zig").Direction; const Output = @import("../Output.zig"); const Seat = @import("../Seat.zig"); /// Send the focused view to the the next or the previous output, depending on /// the bool passed. Does nothing if there is only one output. -pub fn sendToOutput(seat: *Seat, arg: Arg) void { - @import("../log.zig").Log.Debug.log("send to output", .{}); - - const direction = arg.direction; +pub fn sendToOutput( + allocator: *std.mem.Allocator, + seat: *Seat, + args: []const []const u8, + failure_message: *[]const u8, +) Error!void { + if (args.len < 2) return Error.NotEnoughArguments; + if (args.len > 2) return Error.TooManyArguments; + + const direction = try Direction.parse(args[1]); const root = &seat.input_manager.server.root; if (seat.focused_view) |view| { -- cgit v1.2.3