From 1a40333b9ea3a99fff772de35140c0269b3ccfc5 Mon Sep 17 00:00:00 2001 From: modk Date: Sun, 17 Jul 2016 12:11:10 +0200 Subject: [PATCH] menubar: Fix entry use count for categories Fix #999 --- lib/menubar/init.lua | 55 +++++++++++++++++++++++++++++++++----------- 1 file changed, 41 insertions(+), 14 deletions(-) diff --git a/lib/menubar/init.lua b/lib/menubar/init.lua index 011b47315..3be528ca0 100644 --- a/lib/menubar/init.lua +++ b/lib/menubar/init.lua @@ -231,6 +231,14 @@ local function menulist_update(query, scr) -- beginning to the table shownitems, and the ones that contain -- command in the middle to the table match_inside. + local count_table = load_count_table() + local command_list = {} + + local PRIO_NONE = 0 + local PRIO_HIG = 3 + local PRIO_LOW = 1 + local PRIO_NORMAL = 2 + -- Add the categories if menubar.show_categories then for _, v in pairs(menubar.menu_gen.all_categories) do @@ -238,40 +246,59 @@ local function menulist_update(query, scr) if not current_category and v.use then if string.match(v.name, pattern) then if string.match(v.name, "^" .. pattern) then - table.insert(shownitems, v) - else - table.insert(match_inside, v) + v.count = PRIO_NONE + v.prio = PRIO_NORMAL + + -- use count from count_table if present + if string.len(pattern) > 0 and count_table[v.name] ~= nil then + v.count = tonumber(count_table[v.name]) + end + + if string.match(v.name, "^" .. pattern) + or string.match(v.cmdline, "^" .. pattern) then + v.prio = PRIO_HIGH + else + v.prio = PRIO_NORMAL + end + + table.insert (command_list, v) end end end end end - local count_table = load_count_table() - local command_list = {} - -- Add the applications according to their name and cmdline for _, v in ipairs(menubar.menu_entries) do v.focused = false if not current_category or v.category == current_category then if string.match(v.name, pattern) or string.match(v.cmdline, pattern) then + + v.count = 0 + v.prio = PRIO_NONE + + -- use count from count_table if present + if string.len(pattern) > 0 and count_table[v.name] ~= nil then + v.count = tonumber(count_table[v.name]) + end + if string.match(v.name, "^" .. pattern) or string.match(v.cmdline, "^" .. pattern) then - - v.count = 0 - -- use count from count_table if present - if string.len(pattern) > 0 and count_table[v.name] ~= nil then - v.count = tonumber(count_table[v.name]) - end - - table.insert (command_list, v) + v.prio = PRIO_LOW + else + v.prio = PRIO_NONE end + + table.insert (command_list, v) end end end local function compare_counts(a,b) + if a.count == b.count then + return a.prio > b.prio + end return a.count > b.count end