From 4fff609df9d7e3718f8e2ae618e1d24aeb3ebfc1 Mon Sep 17 00:00:00 2001 From: Squibid Date: Sun, 23 Nov 2025 17:08:44 -0500 Subject: [PATCH] generate if branching for modifier keys at comptime --- src/lua/input.zig | 20 ++++---------------- 1 file changed, 4 insertions(+), 16 deletions(-) diff --git a/src/lua/input.zig b/src/lua/input.zig index 5ecea31..8b42796 100644 --- a/src/lua/input.zig +++ b/src/lua/input.zig @@ -14,22 +14,10 @@ fn parse_modkeys(modStr: []const u8) wlr.Keyboard.ModifierMask { var it = std.mem.splitScalar(u8, modStr, '|'); var modifiers = wlr.Keyboard.ModifierMask{}; while (it.next()) |m| { - if (std.mem.eql(u8, m, "shift")) { - modifiers.shift = true; - } else if (std.mem.eql(u8, m, "caps")) { - modifiers.caps = true; - } else if (std.mem.eql(u8, m, "ctrl")) { - modifiers.ctrl = true; - } else if (std.mem.eql(u8, m, "alt")) { - modifiers.alt = true; - } else if (std.mem.eql(u8, m, "mod2")) { - modifiers.mod2 = true; - } else if (std.mem.eql(u8, m, "mod3")) { - modifiers.mod3 = true; - } else if (std.mem.eql(u8, m, "logo")) { - modifiers.logo = true; - } else if (std.mem.eql(u8, m, "mod5")) { - modifiers.mod5 = true; + inline for (std.meta.fields(@TypeOf(modifiers))) |f| { + if (f.type == bool and std.mem.eql(u8, m, f.name)) { + @field(modifiers, f.name) = true; + } } }