]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/maildir.lua
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
--[[
Licensed under GNU General Public License v2
--[[
Licensed under GNU General Public License v2
-local newtimer = require("lain.helpers").newtimer
-
-local wibox = require("wibox")
-
-local io = io
-local os = { getenv = os.getenv }
-local pairs = pairs
-local string = { len = string.len,
- match = string.match }
-local table = { sort = table.sort }
-
-local setmetatable = setmetatable
+local awful = require("awful")
+local wibox = require("wibox")
+local helpers = require("lain.helpers")
+local io = { popen = io.popen }
+local os = { getenv = os.getenv }
+local string = { format = string.format,
+ match = string.match }
+local setmetatable = setmetatable
+-- Maildir check (synchronous)
+local maildir = helpers.make_widget_textbox()
local function worker(args)
local args = args or {}
local function worker(args)
local args = args or {}
local mailpath = args.mailpath or os.getenv("HOME") .. "/Mail"
local ignore_boxes = args.ignore_boxes or {}
local settings = args.settings or function() end
local mailpath = args.mailpath or os.getenv("HOME") .. "/Mail"
local ignore_boxes = args.ignore_boxes or {}
local settings = args.settings or function() end
- maildir.widget = wibox.widget.textbox('')
+ function maildir.update()
+ if cmd then helpers.async({ awful.util.shell, "-c", cmd }, function() end) end
-- Find pathes to mailboxes.
-- Find pathes to mailboxes.
- local p = io.popen("find " .. mailpath ..
- " -mindepth 1 -maxdepth 1 -type d" ..
- " -not -name .git")
+ local p = io.popen(string.format("find %s -mindepth 1 -maxdepth 2 -type d -not -name .git", mailpath))
local boxes = {}
repeat
line = p:read("*l")
local boxes = {}
repeat
line = p:read("*l")
-- Find all files in the "new" subdirectory. For each
-- file, print a single character (no newline). Don't
-- match files that begin with a dot.
-- Afterwards the length of this string is the number of
-- new mails in that box.
-- Find all files in the "new" subdirectory. For each
-- file, print a single character (no newline). Don't
-- match files that begin with a dot.
-- Afterwards the length of this string is the number of
-- new mails in that box.
- local np = io.popen("find " .. line ..
- "/new -mindepth 1 -type f " ..
- "-not -name '.*' -printf a")
- local mailstring = np:read("*all")
+ local mailstring = helpers.read_pipe(string.format("find %s /new -mindepth 1 -type f -not -name '.*' -printf a", line))
-- Strip off leading mailpath.
-- Strip off leading mailpath.
- local box = string.match(line, mailpath .. "/*([^/]+ )")
- local nummails = string.len(mailstring)
- if nummails > 0
- then
+ local box = string.match(line, mailpath .. "/(.* )")
+ local nummails = #mailstring
+
+ if nummails > 0 then
boxes[box] = nummails
end
end
boxes[box] = nummails
end
end
- until line == nil
-
- table.sort(boxes)
+ until not line
+ p:close()
+ local newmail = "no mail"
+ local total = 0
- local count = 0
- for box, number in pairs(boxes)
- do
- count = count + 1
+ for box, number in helpers.spairs(boxes) do
-- Add this box only if it's not to be ignored.
-- Add this box only if it's not to be ignored.
- if not util.element_in_table(box, ignore_boxes)
- then
- if newmail == ""
- then
- newmail = box .. "(" .. number .. ")"
+ if not helpers.element_in_table(box, ignore_boxes) then
+ total = total + number
+ if newmail == "no mail" then
+ newmail = string.format("%s(%s)", box, number)
- newmail = newmail .. ", " ..
- box .. "(" .. number .. ")"
+ newmail = string.format("%s, %s(%s)", newmail, box, number)
- newtimer(mailpath, timeout, update, true)
- return maildir.widget
+ maildir.timer = helpers.newtimer(mailpath, timeout, maildir.update, true, true)
+
+ return maildir
end
return setmetatable(maildir, { __call = function(_, ...) return worker(...) end })
end
return setmetatable(maildir, { __call = function(_, ...) return worker(...) end })