refactor: render event type in keybindview

This commit is contained in:
CJ van den Berg 2025-12-10 17:19:04 +01:00
parent ba8148a5c8
commit fe03d0dab4
Signed by: neurocyte
GPG key ID: 8EB1E1BB660E3FB9
2 changed files with 44 additions and 11 deletions

View file

@ -675,7 +675,16 @@ const BindingSet = struct {
const key_event = input.KeyEvent.from_message(event, keypress, keypress_shifted, text, modifiers); const key_event = input.KeyEvent.from_message(event, keypress, keypress_shifted, text, modifiers);
if (self.process_key_event(key_event) catch |e| return tp.exit_error(e, @errorReturnTrace())) |binding| { if (self.process_key_event(key_event) catch |e| return tp.exit_error(e, @errorReturnTrace())) |binding| {
if (enable_match_events) if (enable_match_events)
self.send_match_event(key_event, binding); self.send_match_event(if (key_event.event != input.event.release)
globals.current_sequence.items
else
&[_]KeyEvent{key_event}, binding.commands);
if (key_event.event != input.event.release) {
globals.current_sequence.clearRetainingCapacity();
globals.current_sequence_egc.clearRetainingCapacity();
}
for (binding.commands) |*cmd| try cmd.execute(); for (binding.commands) |*cmd| try cmd.execute();
} }
} else if (try m.match(.{"F"})) { } else if (try m.match(.{"F"})) {
@ -727,11 +736,7 @@ const BindingSet = struct {
for (self.press.items) |*binding| { for (self.press.items) |*binding| {
switch (binding.match(globals.current_sequence.items)) { switch (binding.match(globals.current_sequence.items)) {
.matched => { .matched => return binding,
globals.current_sequence.clearRetainingCapacity();
globals.current_sequence_egc.clearRetainingCapacity();
return binding;
},
.match_possible => { .match_possible => {
all_matches_impossible = false; all_matches_impossible = false;
}, },
@ -774,21 +779,21 @@ const BindingSet = struct {
} }
} }
fn send_match_event(self: *const @This(), key_event: KeyEvent, binding: *const Binding) void { fn send_match_event(self: *const @This(), key_events: []const KeyEvent, cmds: []Command) void {
var buf: [tp.max_message_size]u8 = undefined; var buf: [tp.max_message_size]u8 = undefined;
var stream: std.Io.Writer = .fixed(&buf); var stream: std.Io.Writer = .fixed(&buf);
var key_event_buf: [256]u8 = undefined; var key_event_buf: [256]u8 = undefined;
var key_event_str: std.Io.Writer = .fixed(&key_event_buf); var key_event_str: std.Io.Writer = .fixed(&key_event_buf);
key_event_str.print("{f}", .{key_event}) catch return; key_event_str.print("{f}", .{key_event_sequence_long_fmt(key_events)}) catch return;
cbor.writeArrayHeader(&stream, 5) catch return; cbor.writeArrayHeader(&stream, 5) catch return;
cbor.writeValue(&stream, "K") catch return; cbor.writeValue(&stream, "K") catch return;
cbor.writeValue(&stream, get_namespace()) catch return; cbor.writeValue(&stream, get_namespace()) catch return;
cbor.writeValue(&stream, self.config_section) catch return; cbor.writeValue(&stream, self.config_section) catch return;
cbor.writeValue(&stream, key_event_str.buffered()) catch return; cbor.writeValue(&stream, key_event_str.buffered()) catch return;
cbor.writeArrayHeader(&stream, binding.commands.len) catch return; cbor.writeArrayHeader(&stream, cmds.len) catch return;
for (binding.commands) |cmd| { for (cmds) |cmd| {
cbor.writeArrayHeader(&stream, 2) catch return; cbor.writeArrayHeader(&stream, 2) catch return;
cbor.writeValue(&stream, cmd.command) catch return; cbor.writeValue(&stream, cmd.command) catch return;
stream.writeAll(cmd.args) catch return; stream.writeAll(cmd.args) catch return;
@ -921,14 +926,42 @@ const KeyEventSequenceFmt = struct {
} }
}; };
const KeyEventSequenceLongFmt = struct {
key_events: []const KeyEvent,
pub fn format(self: @This(), writer: anytype) !void {
var first = true;
for (self.key_events) |key_event| {
if (first) {
first = false;
} else {
try writer.print(" ", .{});
}
if (key_event.event == input.event.press) {
try writer.print("{f}", .{input.key_event_short_fmt(key_event)});
} else {
try writer.print("{f}:{f}", .{ input.event_fmt(key_event.event), input.key_event_short_fmt(key_event) });
}
}
}
};
pub fn key_event_sequence_fmt(key_events: []const KeyEvent) KeyEventSequenceFmt { pub fn key_event_sequence_fmt(key_events: []const KeyEvent) KeyEventSequenceFmt {
return .{ .key_events = key_events }; return .{ .key_events = key_events };
} }
pub fn key_event_sequence_long_fmt(key_events: []const KeyEvent) KeyEventSequenceLongFmt {
return .{ .key_events = key_events };
}
pub fn current_key_event_sequence_fmt() KeyEventSequenceFmt { pub fn current_key_event_sequence_fmt() KeyEventSequenceFmt {
return .{ .key_events = globals.current_sequence.items }; return .{ .key_events = globals.current_sequence.items };
} }
pub fn current_key_event_sequence_long_fmt() KeyEventSequenceLongFmt {
return .{ .key_events = globals.current_sequence.items };
}
pub fn current_integer_argument() ?usize { pub fn current_integer_argument() ?usize {
return integer_argument; return integer_argument;
} }

View file

@ -95,7 +95,7 @@ fn keybind_match(self: *Self, _: tp.pid_ref, m: tp.message) MessageFilter.Error!
defer result.deinit(); defer result.deinit();
const writer = &result.writer; const writer = &result.writer;
writer.print("{s}:{s} {s} -> ", .{ namespace, section, key_event }) catch return true; writer.print("{s}:{s} {s} => ", .{ namespace, section, key_event }) catch return true;
cbor.toJsonWriter(cmds, writer, .{}) catch return true; cbor.toJsonWriter(cmds, writer, .{}) catch return true;
const ts = time.microTimestamp(); const ts = time.microTimestamp();