Import of vicious source tree.
Vicious is a modular widget library for 'awesome' window manager,
derived from the 'Wicked' widget library.
Summary of changes:
* Original wicked code modularized
* Widgets ported from Wicked:
- CPU, MEM, FS, NET, Date, Uptime, MPD
* CPU widget rewritten, uses pattern matching
* MEM widget rewritten, uses pattern matching
- Swap widget merged with MEM widget type
* FS widget rewritten, uses pattern matching
- Also fixed padding in the process
* NET widget rewritten, uses pattern matching
* MPD widget rewritten, a bit more versatile
* Removed deprecated helper functions
* Widgets written for Vicious:
- Thermal, Battery, Mbox, OrgMode, Volume, Entropy,
Disk I/O, System Load, Wireless, Pacman, Maildir
2009-07-29 17:59:32 +02:00
|
|
|
----------------------------------------------------------
|
|
|
|
-- Licensed under the GNU General Public License version 2
|
|
|
|
-- * Copyright (C) 2009 Adrian C. <anrxc_sysphere_org>
|
|
|
|
-- * Derived from Maildir Biff Widget, by Fredrik Ax
|
|
|
|
----------------------------------------------------------
|
|
|
|
|
|
|
|
-- {{{ Grab environment
|
|
|
|
local io = { popen = io.popen }
|
2009-08-01 23:11:41 +02:00
|
|
|
local setmetatable = setmetatable
|
Import of vicious source tree.
Vicious is a modular widget library for 'awesome' window manager,
derived from the 'Wicked' widget library.
Summary of changes:
* Original wicked code modularized
* Widgets ported from Wicked:
- CPU, MEM, FS, NET, Date, Uptime, MPD
* CPU widget rewritten, uses pattern matching
* MEM widget rewritten, uses pattern matching
- Swap widget merged with MEM widget type
* FS widget rewritten, uses pattern matching
- Also fixed padding in the process
* NET widget rewritten, uses pattern matching
* MPD widget rewritten, a bit more versatile
* Removed deprecated helper functions
* Widgets written for Vicious:
- Thermal, Battery, Mbox, OrgMode, Volume, Entropy,
Disk I/O, System Load, Wireless, Pacman, Maildir
2009-07-29 17:59:32 +02:00
|
|
|
-- }}}
|
|
|
|
|
|
|
|
|
|
|
|
-- Mdir: provides a number of new and unread messages in a Maildir structure
|
|
|
|
module("vicious.mdir")
|
|
|
|
|
|
|
|
|
|
|
|
-- {{{ Maildir widget type
|
|
|
|
function worker(format, mdir)
|
2009-07-31 20:40:36 +02:00
|
|
|
-- Like with the mbox count widget, we would benefit from the
|
|
|
|
-- LuaFileSystem library. However, we didn't rely on extra
|
|
|
|
-- libraries to this point so we won't start now. Widgets like
|
|
|
|
-- this one are not agressive like CPU or NET, so we can keep it
|
|
|
|
-- simple, find is OK with me if we execute every >60s
|
Import of vicious source tree.
Vicious is a modular widget library for 'awesome' window manager,
derived from the 'Wicked' widget library.
Summary of changes:
* Original wicked code modularized
* Widgets ported from Wicked:
- CPU, MEM, FS, NET, Date, Uptime, MPD
* CPU widget rewritten, uses pattern matching
* MEM widget rewritten, uses pattern matching
- Swap widget merged with MEM widget type
* FS widget rewritten, uses pattern matching
- Also fixed padding in the process
* NET widget rewritten, uses pattern matching
* MPD widget rewritten, a bit more versatile
* Removed deprecated helper functions
* Widgets written for Vicious:
- Thermal, Battery, Mbox, OrgMode, Volume, Entropy,
Disk I/O, System Load, Wireless, Pacman, Maildir
2009-07-29 17:59:32 +02:00
|
|
|
--
|
|
|
|
-- Initialise counters
|
|
|
|
local newcount = 0
|
|
|
|
local curcount = 0
|
|
|
|
|
|
|
|
-- Recursively find new messages
|
|
|
|
local fnew = io.popen("find " .. mdir .. " -type f -wholename '*/new/*'")
|
|
|
|
for line in fnew:lines() do
|
|
|
|
newcount = newcount + 1
|
|
|
|
end
|
|
|
|
fnew:close()
|
|
|
|
|
|
|
|
-- Recursively find "old" messages lacking the Seen flag
|
|
|
|
local fcur = io.popen("find " .. mdir .. " -type f -regex '.*/cur/.*2,[^S]*$'")
|
|
|
|
for line in fcur:lines() do
|
|
|
|
curcount = curcount + 1
|
|
|
|
end
|
|
|
|
fcur:close()
|
|
|
|
|
|
|
|
return {newcount, curcount}
|
|
|
|
end
|
|
|
|
-- }}}
|
2009-08-01 23:11:41 +02:00
|
|
|
|
|
|
|
setmetatable(_M, { __call = function(_, ...) return worker(...) end })
|