]>
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:
local newtimer = require("lain.helpers").newtimer
local read_pipe = require("lain.helpers").read_pipe
local newtimer = require("lain.helpers").newtimer
local read_pipe = require("lain.helpers").read_pipe
+local spairs = require("lain.helpers").spairs
local wibox = require("wibox")
local wibox = require("wibox")
+local awful = require("awful")
local util = require("lain.util")
local io = { popen = io.popen }
local util = require("lain.util")
local io = { popen = io.popen }
local pairs = pairs
local string = { len = string.len,
match = string.match }
local pairs = pairs
local string = { len = string.len,
match = string.match }
-local table = { sort = table.sort }
local setmetatable = setmetatable
-- Maildir check
-- lain.widgets.maildir
local setmetatable = setmetatable
-- Maildir check
-- lain.widgets.maildir
-local maildir = { total = 0 }
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
+ local ext_mail_cmd = args.external_mail_cmd
maildir.widget = wibox.widget.textbox('')
function update()
maildir.widget = wibox.widget.textbox('')
function update()
+ if ext_mail_cmd then
+ awful.util.spawn(ext_mail_cmd)
+ end
+
-- Find pathes to mailboxes.
local p = io.popen("find " .. mailpath ..
-- Find pathes to mailboxes.
local p = io.popen("find " .. mailpath ..
- " -mindepth 1 -maxdepth 1 -type d" ..
+ " -mindepth 1 -maxdepth 2 -type d" ..
" -not -name .git")
local boxes = {}
repeat
" -not -name .git")
local boxes = {}
repeat
"-not -name '.*' -printf a")
-- Strip off leading mailpath.
"-not -name '.*' -printf a")
-- Strip off leading mailpath.
- local box = string.match(line, mailpath .. "/*([^/]+ )")
+ local box = string.match(line, mailpath .. "/(.* )")
local nummails = string.len(mailstring)
if nummails > 0
then
local nummails = string.len(mailstring)
if nummails > 0
then
until line == nil
p:close()
until line == nil
p:close()
-- Count the total number of mails irrespective of where it was found
total = 0
-- Count the total number of mails irrespective of where it was found
total = 0
- for box, number in pairs(boxes)
+ for box, number in s pairs(boxes)
do
-- Add this box only if it's not to be ignored.
if not util.element_in_table(box, ignore_boxes)
do
-- Add this box only if it's not to be ignored.
if not util.element_in_table(box, ignore_boxes)
- if maildir.total ~= total then
- widget = maildir.widget
- settings()
- end
+ widget = maildir.widget
+ settings()
end
newtimer(mailpath, timeout, update, true)
end
newtimer(mailpath, timeout, update, true)