From 7fa3dc97c8494c0c9d17c5e1dd64ef89bc0486e5 Mon Sep 17 00:00:00 2001 From: Daniel Hahler Date: Mon, 12 Oct 2015 00:18:28 +0200 Subject: [PATCH] Optimize menubar.icon_theme.lookup_icon: do not look twice --- lib/menubar/icon_theme.lua | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/lib/menubar/icon_theme.lua b/lib/menubar/icon_theme.lua index e21e0d699..d8d3e740d 100644 --- a/lib/menubar/icon_theme.lua +++ b/lib/menubar/icon_theme.lua @@ -147,6 +147,7 @@ local directory_size_distance = function(self, subdirectory, icon_size) end local lookup_icon = function(self, icon_name, icon_size) + local checked_already = {} for _, subdir in ipairs(self.index_theme:get_subdirectories()) do for _, basedir in ipairs(self.base_directories) do for _, ext in ipairs(self.extensions) do @@ -156,6 +157,8 @@ local lookup_icon = function(self, icon_name, icon_size) icon_name, ext) if awful.util.file_readable(filename) then return filename + else + checked_already[filename] = true end end end @@ -170,19 +173,17 @@ local lookup_icon = function(self, icon_name, icon_size) local filename = string.format("%s/%s/%s/%s.%s", basedir, self.icon_theme_name, subdir, icon_name, ext) - local dist = directory_size_distance(self, subdir, icon_size) - if awful.util.file_readable(filename) and dist < minimal_size then - closest_filename = filename - minimal_size = dist + if not checked_already[filename] then + local dist = directory_size_distance(self, subdir, icon_size) + if awful.util.file_readable(filename) and dist < minimal_size then + closest_filename = filename + minimal_size = dist + end end end end end - if closest_filename then - return closest_filename - end - - return nil + return closest_filename end local find_icon_path_helper -- Gets called recursively.