From 674120786c340a3e6b4caf366331ae8f7346d687 Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Thu, 16 Nov 2017 15:30:15 +0100 Subject: [PATCH] menubar.utils: Use gears.files.subdirectory_cache This does not use the "detect changes" feature of subdirectory_cache, but still it makes menubar.utils a bit nicer, which is of course nice. Signed-off-by: Uli Schlachter --- lib/menubar/utils.lua | 53 +++++++------------------------------------ 1 file changed, 8 insertions(+), 45 deletions(-) diff --git a/lib/menubar/utils.lua b/lib/menubar/utils.lua index a6a8579b8..9ac5e6247 100644 --- a/lib/menubar/utils.lua +++ b/lib/menubar/utils.lua @@ -364,53 +364,16 @@ end -- with the resulting list of menu entries as argument. -- @tparam table callback.programs Paths of found .desktop files. function utils.parse_dir(dir_path, callback) - - local function get_readable_path(file) - return file:get_path() or file:get_uri() - end - - local function parser(file, programs) - -- Except for "NONE" there is also NOFOLLOW_SYMLINKS - local query = gio.FILE_ATTRIBUTE_STANDARD_NAME .. "," .. gio.FILE_ATTRIBUTE_STANDARD_TYPE - local enum, err = file:async_enumerate_children(query, gio.FileQueryInfoFlags.NONE) - if not enum then - gdebug.print_warning(get_readable_path(file) .. ": " .. tostring(err)) - return - end - local files_per_call = 100 -- Actual value is not that important - while true do - local list, enum_err = enum:async_next_files(files_per_call) - if enum_err then - gdebug.print_error(get_readable_path(file) .. ": " .. tostring(enum_err)) - return - end - for _, info in ipairs(list) do - local file_type = info:get_file_type() - local file_child = enum:get_child(info) - if file_type == 'REGULAR' then - local path = file_child:get_path() - if path then - local success, program = pcall(utils.parse_desktop_file, path) - if not success then - gdebug.print_error("Error while reading '" .. path .. "': " .. program) - elseif program then - table.insert(programs, program) - end - end - elseif file_type == 'DIRECTORY' then - parser(file_child, programs) - end - end - if #list == 0 then - break - end - end - enum:async_close() - end - gio.Async.start(do_protected_call)(function() local result = {} - parser(gio.File.new_for_path(dir_path), result) + for path in pairs(gfs.subdirectory_cache.async_new(dir_path).known_paths) do + local success, program = pcall(utils.parse_desktop_file, path) + if not success then + gdebug.print_error("Error while reading '" .. path .. "': " .. program) + elseif program then + table.insert(result, program) + end + end call_callback(callback, result) end) end