X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/eb8cec907a50f3fd6df4b14ae10b910444017f92..7d60073c29c91354038e0c0307ce4bf3537d84a1:/widgets/maildir.lua?ds=sidebyside diff --git a/widgets/maildir.lua b/widgets/maildir.lua index 00ab771..246341f 100644 --- a/widgets/maildir.lua +++ b/widgets/maildir.lua @@ -11,7 +11,9 @@ local newtimer = require("lain.helpers").newtimer local wibox = require("wibox") -local io = io +local util = require("lain.util") + +local io = { popen = io.popen } local os = { getenv = os.getenv } local pairs = pairs local string = { len = string.len, @@ -24,14 +26,14 @@ local setmetatable = setmetatable -- lain.widgets.maildir local maildir = {} -function worker(args) +local function worker(args) local args = args or {} local timeout = args.timeout or 60 local mailpath = args.mailpath or os.getenv("HOME") .. "/Mail" local ignore_boxes = args.ignore_boxes or {} local settings = args.settings or function() end - widget = wibox.widget.textbox('') + maildir.widget = wibox.widget.textbox('') function update() -- Find pathes to mailboxes. @@ -51,7 +53,7 @@ function worker(args) local np = io.popen("find " .. line .. "/new -mindepth 1 -type f " .. "-not -name '.*' -printf a") - local mailstring = np:read("*all") + local mailstring = np:read("*a") -- Strip off leading mailpath. local box = string.match(line, mailpath .. "/*([^/]+)") @@ -66,15 +68,16 @@ function worker(args) table.sort(boxes) newmail = "no mail" + --Count the total number of mails irrespective of where it was found + total = 0 - local count = 0 for box, number in pairs(boxes) do - count = count + 1 -- Add this box only if it's not to be ignored. if not util.element_in_table(box, ignore_boxes) then - if newmail == "" + total = total + number + if newmail == "no mail" then newmail = box .. "(" .. number .. ")" else @@ -84,12 +87,12 @@ function worker(args) end end + widget = maildir.widget settings() end newtimer(mailpath, timeout, update, true) - - return widget + return maildir.widget end return setmetatable(maildir, { __call = function(_, ...) return worker(...) end })