Remove usage of std.c.stat() for xauth code

Signed-off-by: AnErrupTion <anerruption@disroot.org>
This commit is contained in:
AnErrupTion 2025-08-30 02:09:51 +02:00
parent 0a9ceca822
commit 36e220e2ff
No known key found for this signature in database
2 changed files with 23 additions and 21 deletions

View File

@ -307,35 +307,37 @@ fn getXPid(display_num: u8) !i32 {
fn createXauthFile(pwd: [:0]const u8) ![]const u8 { fn createXauthFile(pwd: [:0]const u8) ![]const u8 {
var xauth_buf: [100]u8 = undefined; var xauth_buf: [100]u8 = undefined;
var xauth_dir: [:0]const u8 = undefined; var xauth_dir: []const u8 = undefined;
const xdg_rt_dir = std.posix.getenv("XDG_RUNTIME_DIR"); const xdg_rt_dir = std.posix.getenv("XDG_RUNTIME_DIR");
var xauth_file: []const u8 = "lyxauth"; var xauth_file: []const u8 = "lyxauth";
if (xdg_rt_dir == null) { if (xdg_rt_dir == null) no_rt_dir: {
const xdg_cfg_home = std.posix.getenv("XDG_CONFIG_HOME"); const xdg_cfg_home = std.posix.getenv("XDG_CONFIG_HOME");
var sb: std.c.Stat = undefined; if (xdg_cfg_home == null) no_cfg_home: {
if (xdg_cfg_home == null) { xauth_dir = try std.fmt.bufPrint(&xauth_buf, "{s}/.config", .{pwd});
xauth_dir = try std.fmt.bufPrintZ(&xauth_buf, "{s}/.config", .{pwd});
_ = std.c.stat(xauth_dir, &sb); var dir = std.fs.cwd().openDir(xauth_dir, .{}) catch {
const mode = sb.mode & std.posix.S.IFMT; // xauth_dir isn't a directory
if (mode == std.posix.S.IFDIR) {
xauth_dir = try std.fmt.bufPrintZ(&xauth_buf, "{s}/ly", .{xauth_dir});
} else {
xauth_dir = pwd; xauth_dir = pwd;
xauth_file = ".lyxauth"; xauth_file = ".lyxauth";
} break :no_cfg_home;
};
dir.close();
// xauth_dir is a directory, use it to store Xauthority
xauth_dir = try std.fmt.bufPrint(&xauth_buf, "{s}/ly", .{xauth_dir});
} else { } else {
xauth_dir = try std.fmt.bufPrintZ(&xauth_buf, "{s}/ly", .{xdg_cfg_home.?}); xauth_dir = try std.fmt.bufPrint(&xauth_buf, "{s}/ly", .{xdg_cfg_home.?});
} }
_ = std.c.stat(xauth_dir, &sb); const file = std.fs.cwd().openFile(xauth_dir, .{}) catch break :no_rt_dir;
const mode = sb.mode & std.posix.S.IFMT; file.close();
if (mode != std.posix.S.IFDIR) {
// xauth_dir is a file, create the parent directory
std.posix.mkdir(xauth_dir, 777) catch { std.posix.mkdir(xauth_dir, 777) catch {
xauth_dir = pwd; xauth_dir = pwd;
xauth_file = ".lyxauth"; xauth_file = ".lyxauth";
}; };
}
} else { } else {
xauth_dir = xdg_rt_dir.?; xauth_dir = xdg_rt_dir.?;
} }

View File

@ -540,7 +540,7 @@ pub fn main() !void {
var format_buf: [16:0]u8 = undefined; var format_buf: [16:0]u8 = undefined;
var clock_buf: [32:0]u8 = undefined; var clock_buf: [32:0]u8 = undefined;
// We need the slice/c-string returned by `bufPrintZ`. // We need the slice/c-string returned by `bufPrintZ`.
const format: [:0]const u8 = try std.fmt.bufPrintZ(&format_buf, "{s}{s}{s}{s}", .{ const format = try std.fmt.bufPrintZ(&format_buf, "{s}{s}{s}{s}", .{
if (config.bigclock_12hr) "%I" else "%H", if (config.bigclock_12hr) "%I" else "%H",
":%M", ":%M",
if (config.bigclock_seconds) ":%S" else "", if (config.bigclock_seconds) ":%S" else "",