Merge pull request #502 from rockorager/xtversion

terminal: respond to XTVERSION query
This commit is contained in:
Mitchell Hashimoto
2023-09-20 17:22:24 -07:00
committed by GitHub
2 changed files with 38 additions and 17 deletions

View File

@ -607,28 +607,32 @@ pub fn Stream(comptime Handler: type) type {
),
},
// DECSCUSR - Select Cursor Style
// TODO: test
'q' => switch (action.intermediates.len) {
1 => cursor: {
if (action.intermediates[0] != ' ') {
1 => switch (action.intermediates[0]) {
// DECSCUSR - Select Cursor Style
// TODO: test
' ' => {
if (@hasDecl(T, "setCursorStyle")) try self.handler.setCursorStyle(
switch (action.params.len) {
0 => ansi.CursorStyle.default,
1 => @enumFromInt(action.params[0]),
else => {
log.warn("invalid set curor style command: {}", .{action});
return;
},
},
) else log.warn("unimplemented CSI callback: {}", .{action});
},
// XTVERSION
'>' => {
if (@hasDecl(T, "reportXtversion")) try self.handler.reportXtversion();
},
else => {
log.warn(
"ignoring unimplemented CSI q with intermediates: {s}",
.{action.intermediates},
);
break :cursor;
}
if (@hasDecl(T, "setCursorStyle")) try self.handler.setCursorStyle(
switch (action.params.len) {
0 => ansi.CursorStyle.default,
1 => @enumFromInt(action.params[0]),
else => {
log.warn("invalid set curor style command: {}", .{action});
return;
},
},
) else log.warn("unimplemented CSI callback: {}", .{action});
},
},
else => log.warn(

View File

@ -1688,6 +1688,23 @@ const StreamHandler = struct {
self.terminal.screen.kitty_keyboard.set(mode, flags);
}
pub fn reportXtversion(
self: *StreamHandler,
) !void {
log.debug("reporting XTVERSION: ghostty {s}", .{build_config.version_string});
var msg: termio.Message = .{ .write_small = .{} };
const resp = try std.fmt.bufPrint(
&msg.write_small.data,
"\x1BP>|{s} {s}\x07",
.{
"ghostty",
build_config.version_string,
},
);
msg.write_small.len = @intCast(resp.len);
self.messageWriter(msg);
}
//-------------------------------------------------------------------------
// OSC