mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-07-21 19:26:09 +03:00
Merge pull request #2064 from jcollie/kitty-graphics-shared-memory
kitty graphics: add support for shared memory transfer medium
This commit is contained in:
@ -75,9 +75,13 @@ pub const LoadingImage = struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var abs_buf: [std.fs.max_path_bytes]u8 = undefined;
|
var abs_buf: [std.fs.max_path_bytes]u8 = undefined;
|
||||||
const path = posix.realpath(cmd.data, &abs_buf) catch |err| {
|
const path = switch (t.medium) {
|
||||||
|
.direct => unreachable, // handled above
|
||||||
|
.file, .temporary_file => posix.realpath(cmd.data, &abs_buf) catch |err| {
|
||||||
log.warn("failed to get absolute path: {}", .{err});
|
log.warn("failed to get absolute path: {}", .{err});
|
||||||
return error.InvalidData;
|
return error.InvalidData;
|
||||||
|
},
|
||||||
|
.shared_memory => cmd.data,
|
||||||
};
|
};
|
||||||
|
|
||||||
// Depending on the medium, load the data from the path.
|
// Depending on the medium, load the data from the path.
|
||||||
@ -98,17 +102,63 @@ pub const LoadingImage = struct {
|
|||||||
t: command.Transmission,
|
t: command.Transmission,
|
||||||
path: []const u8,
|
path: []const u8,
|
||||||
) !void {
|
) !void {
|
||||||
// We require libc for this for shm_open
|
// windows is currently unsupported, does it support shm?
|
||||||
if (comptime !builtin.link_libc) return error.UnsupportedMedium;
|
if (comptime builtin.target.os.tag == .windows) {
|
||||||
|
|
||||||
// Todo: support shared memory
|
|
||||||
_ = self;
|
|
||||||
_ = alloc;
|
|
||||||
_ = t;
|
|
||||||
_ = path;
|
|
||||||
return error.UnsupportedMedium;
|
return error.UnsupportedMedium;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// libc is required for shm_open
|
||||||
|
if (comptime !builtin.link_libc) {
|
||||||
|
return error.UnsupportedMedium;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Since we're only supporting posix then max_path_bytes should
|
||||||
|
// be enough to stack allocate the path.
|
||||||
|
var buf: [std.fs.max_path_bytes]u8 = undefined;
|
||||||
|
const pathz = std.fmt.bufPrintZ(&buf, "{s}", .{path}) catch return error.InvalidData;
|
||||||
|
|
||||||
|
const fd = std.c.shm_open(pathz, @as(c_int, @bitCast(std.c.O{ .ACCMODE = .RDONLY })), 0);
|
||||||
|
switch (std.posix.errno(fd)) {
|
||||||
|
.SUCCESS => {},
|
||||||
|
else => |err| {
|
||||||
|
log.warn("unable to open shared memory {s}: {}", .{ path, err });
|
||||||
|
return error.InvalidData;
|
||||||
|
},
|
||||||
|
}
|
||||||
|
defer _ = std.c.close(fd);
|
||||||
|
defer _ = std.c.shm_unlink(pathz);
|
||||||
|
|
||||||
|
const stat = std.posix.fstat(fd) catch |err| {
|
||||||
|
log.warn("unable to fstat shared memory {s}: {}", .{ path, err });
|
||||||
|
return error.InvalidData;
|
||||||
|
};
|
||||||
|
if (stat.size <= 0) return error.InvalidData;
|
||||||
|
|
||||||
|
const size: usize = @intCast(stat.size);
|
||||||
|
|
||||||
|
const map = std.posix.mmap(
|
||||||
|
null,
|
||||||
|
size,
|
||||||
|
std.c.PROT.READ,
|
||||||
|
std.c.MAP{ .TYPE = .SHARED },
|
||||||
|
fd,
|
||||||
|
0,
|
||||||
|
) catch |err| {
|
||||||
|
log.warn("unable to mmap shared memory {s}: {}", .{ path, err });
|
||||||
|
return error.InvalidData;
|
||||||
|
};
|
||||||
|
defer std.posix.munmap(map);
|
||||||
|
|
||||||
|
const start: usize = @intCast(t.offset);
|
||||||
|
const end: usize = if (t.size > 0) @min(
|
||||||
|
@as(usize, @intCast(t.offset)) + @as(usize, @intCast(t.size)),
|
||||||
|
size,
|
||||||
|
) else size;
|
||||||
|
|
||||||
|
assert(self.data.items.len == 0);
|
||||||
|
try self.data.appendSlice(alloc, map[start..end]);
|
||||||
|
}
|
||||||
|
|
||||||
/// Reads the data from a temporary file and returns it. This allocates
|
/// Reads the data from a temporary file and returns it. This allocates
|
||||||
/// and does not free any of the data, so the caller must free it.
|
/// and does not free any of the data, so the caller must free it.
|
||||||
///
|
///
|
||||||
|
Reference in New Issue
Block a user