From 7afd8e3179fb4ca9cb081876f047d9f4fb4c6cb0 Mon Sep 17 00:00:00 2001 From: Daniel Hahler Date: Sun, 11 Oct 2015 19:53:00 +0200 Subject: [PATCH] get_icon_lookup_path: only return readable/existing dirs --- lib/menubar/utils.lua | 42 +++++++++++++++++++++++++++++++----------- 1 file changed, 31 insertions(+), 11 deletions(-) diff --git a/lib/menubar/utils.lua b/lib/menubar/utils.lua index 16a65f8a..e56c7227 100644 --- a/lib/menubar/utils.lua +++ b/lib/menubar/utils.lua @@ -67,29 +67,48 @@ local function is_format_supported(icon_file) end local icon_lookup_path = nil +--- Get a list of icon lookup paths. +-- @treturn table A list of directories, without trailing slash. local function get_icon_lookup_path() if not icon_lookup_path then + local add_if_readable = function(t, path) + if awful_util.dir_readable(path) then + table.insert(t, path) + end + end icon_lookup_path = {} local icon_theme_paths = {} local icon_theme = theme.icon_theme local paths = glib.get_system_data_dirs() table.insert(paths, 1, glib.get_user_data_dir()) - table.insert(paths, 1, glib.get_home_dir() .. '/.icons') - for k,dir in ipairs(paths)do - if icon_theme then - table.insert(icon_theme_paths, dir..'/icons/' .. icon_theme .. '/') + table.insert(paths, 1, glib.build_filenamev({glib.get_home_dir(), + '.icons'})) + for k,dir in ipairs(paths) do + local icons_dir = glib.build_filenamev({dir, 'icons'}) + if awful_util.dir_readable(icons_dir) then + if icon_theme then + add_if_readable(icon_theme_paths, + glib.build_filenamev({icons_dir, + icon_theme})) + end + -- Fallback theme. + add_if_readable(icon_theme_paths, + glib.build_filenamev({icons_dir, 'hicolor'})) end - table.insert(icon_theme_paths, dir..'/icons/hicolor/') -- fallback theme end for i, icon_theme_directory in ipairs(icon_theme_paths) do for j, size in ipairs(all_icon_sizes) do - table.insert(icon_lookup_path, icon_theme_directory .. size .. '/apps/') + add_if_readable(icon_lookup_path, + glib.build_filenamev({icon_theme_directory, + size, 'apps'})) end end for k,dir in ipairs(paths)do -- lowest priority fallbacks - table.insert(icon_lookup_path, dir..'/pixmaps/') - table.insert(icon_lookup_path, dir..'/icons/') + add_if_readable(icon_lookup_path, + glib.build_filenamev({dir, 'pixmaps'})) + add_if_readable(icon_lookup_path, + glib.build_filenamev({dir, 'icons'})) end end return icon_lookup_path @@ -109,14 +128,15 @@ function utils.lookup_icon(icon_file) return awful_util.file_readable(icon_file) and icon_file or nil else for i, directory in ipairs(get_icon_lookup_path()) do - if is_format_supported(icon_file) and awful_util.file_readable(directory .. icon_file) then - return directory .. icon_file + if is_format_supported(icon_file) and + awful_util.file_readable(directory .. "/" .. icon_file) then + return directory .. "/" .. icon_file else -- Icon is probably specified without path and format, -- like 'firefox'. Try to add supported extensions to -- it and see if such file exists. for _, format in ipairs(icon_formats) do - local possible_file = directory .. icon_file .. "." .. format + local possible_file = directory .. "/" .. icon_file .. "." .. format if awful_util.file_readable(possible_file) then return possible_file end