aboutsummaryrefslogtreecommitdiff
path: root/src/command/focus_output.zig
diff options
context:
space:
mode:
authorIsaac Freund <ifreund@ifreund.xyz>2020-05-26 22:55:07 +0200
committerIsaac Freund <ifreund@ifreund.xyz>2020-05-31 21:04:25 +0200
commitd9ca9db5a49f0af2f6bef6f198b28a8d29808e6d (patch)
treeebeb7de70a63bfff951e9eaa069f7885aa34a2dc /src/command/focus_output.zig
parent9cd61f75903a83e56538ae3d69e7c2f3d2e6ca10 (diff)
downloadriver-d9ca9db5a49f0af2f6bef6f198b28a8d29808e6d.tar.gz
river-d9ca9db5a49f0af2f6bef6f198b28a8d29808e6d.tar.xz
Rework commands to be string based
This allows for significantly more flexibility and should make implementing the bind command possible.
Diffstat (limited to 'src/command/focus_output.zig')
-rw-r--r--src/command/focus_output.zig15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/command/focus_output.zig b/src/command/focus_output.zig
index 02b7999..b11664f 100644
--- a/src/command/focus_output.zig
+++ b/src/command/focus_output.zig
@@ -19,14 +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");
/// Focus either the next or the previous output, depending on the bool passed.
/// Does nothing if there is only one output.
-pub fn focusOutput(seat: *Seat, arg: Arg) void {
- const direction = arg.direction;
+pub fn focusOutput(
+ 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 the noop output is focused, there are no other outputs to switch to
if (seat.focused_output == &root.noop_output) {