mirror of
https://github.com/fairyglade/ly.git
synced 2026-02-04 00:14:55 +00:00
Don't forget to allocate :D
Signed-off-by: AnErrupTion <anerruption@disroot.org>
This commit is contained in:
@@ -17,7 +17,6 @@ entry_ini: ?Ini(Entry) = null,
|
|||||||
file_name: []const u8 = "",
|
file_name: []const u8 = "",
|
||||||
name: []const u8 = "",
|
name: []const u8 = "",
|
||||||
xdg_session_desktop: ?[]const u8 = null,
|
xdg_session_desktop: ?[]const u8 = null,
|
||||||
xdg_session_desktop_owned: bool = false,
|
|
||||||
xdg_desktop_names: ?[]const u8 = null,
|
xdg_desktop_names: ?[]const u8 = null,
|
||||||
cmd: ?[]const u8 = null,
|
cmd: ?[]const u8 = null,
|
||||||
specifier: []const u8 = "",
|
specifier: []const u8 = "",
|
||||||
|
|||||||
11
src/main.zig
11
src/main.zig
@@ -1251,11 +1251,10 @@ fn crawl(session: *Session, lang: Lang, path: []const u8, display_server: Displa
|
|||||||
});
|
});
|
||||||
errdefer entry_ini.deinit();
|
errdefer entry_ini.deinit();
|
||||||
|
|
||||||
const file_name = std.fs.path.stem(item.name);
|
const file_name = try session.label.allocator.dupe(u8, std.fs.path.stem(item.name));
|
||||||
const entry = entry_ini.data.@"Desktop Entry";
|
const entry = entry_ini.data.@"Desktop Entry";
|
||||||
var maybe_xdg_session_desktop: ?[]const u8 = null;
|
var maybe_xdg_session_desktop: ?[]const u8 = null;
|
||||||
var maybe_xdg_desktop_names: ?[]const u8 = null;
|
var maybe_xdg_desktop_names: ?[]const u8 = null;
|
||||||
var xdg_session_desktop_owned = false;
|
|
||||||
|
|
||||||
// Prepare the XDG_SESSION_DESKTOP and XDG_CURRENT_DESKTOP environment
|
// Prepare the XDG_SESSION_DESKTOP and XDG_CURRENT_DESKTOP environment
|
||||||
// variables here
|
// variables here
|
||||||
@@ -1269,18 +1268,14 @@ fn crawl(session: *Session, lang: Lang, path: []const u8, display_server: Displa
|
|||||||
} else if (display_server != .custom) {
|
} else if (display_server != .custom) {
|
||||||
// If DesktopNames is empty, and this isn't a custom session entry,
|
// If DesktopNames is empty, and this isn't a custom session entry,
|
||||||
// we'll take the name of the session file
|
// we'll take the name of the session file
|
||||||
if (file_name.len > 0) {
|
if (file_name.len > 0) maybe_xdg_session_desktop = file_name;
|
||||||
maybe_xdg_session_desktop = try session.label.allocator.dupe(u8, file_name);
|
|
||||||
xdg_session_desktop_owned = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
try session.addEnvironment(.{
|
try session.addEnvironment(.{
|
||||||
.entry_ini = entry_ini,
|
.entry_ini = entry_ini,
|
||||||
.file_name = std.fs.path.stem(item.name),
|
.file_name = file_name,
|
||||||
.name = entry.Name,
|
.name = entry.Name,
|
||||||
.xdg_session_desktop = maybe_xdg_session_desktop,
|
.xdg_session_desktop = maybe_xdg_session_desktop,
|
||||||
.xdg_session_desktop_owned = xdg_session_desktop_owned,
|
|
||||||
.xdg_desktop_names = maybe_xdg_desktop_names,
|
.xdg_desktop_names = maybe_xdg_desktop_names,
|
||||||
.cmd = entry.Exec,
|
.cmd = entry.Exec,
|
||||||
.specifier = switch (display_server) {
|
.specifier = switch (display_server) {
|
||||||
|
|||||||
@@ -29,9 +29,7 @@ pub fn init(allocator: Allocator, buffer: *TerminalBuffer, user_list: *UserList)
|
|||||||
pub fn deinit(self: *Session) void {
|
pub fn deinit(self: *Session) void {
|
||||||
for (self.label.list.items) |*env| {
|
for (self.label.list.items) |*env| {
|
||||||
if (env.environment.entry_ini) |*entry_ini| entry_ini.deinit();
|
if (env.environment.entry_ini) |*entry_ini| entry_ini.deinit();
|
||||||
if (env.environment.xdg_session_desktop_owned) {
|
self.label.allocator.free(env.environment.file_name);
|
||||||
self.label.allocator.free(env.environment.xdg_session_desktop.?);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
self.label.deinit();
|
self.label.deinit();
|
||||||
|
|||||||
Reference in New Issue
Block a user