2009-09-29 22:33:19 +02:00
|
|
|
---------------------------------------------------
|
|
|
|
-- Licensed under the GNU General Public License v2
|
|
|
|
-- * (c) 2009, Adrian C. <anrxc.sysphere.org>
|
|
|
|
---------------------------------------------------
|
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
|
|
|
|
|
|
|
-- {{{ Grab environment
|
|
|
|
local type = type
|
|
|
|
local ipairs = ipairs
|
|
|
|
local io = { open = io.open }
|
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
|
|
|
local math = { floor = math.floor }
|
|
|
|
local table = { insert = table.insert }
|
|
|
|
-- }}}
|
|
|
|
|
|
|
|
|
2009-07-30 04:44:22 +02:00
|
|
|
-- Disk I/O: provides I/O statistics for requested storage devices
|
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
|
|
|
module("vicious.dio")
|
|
|
|
|
|
|
|
|
|
|
|
-- Initialise function tables
|
|
|
|
local disk_usage = {}
|
|
|
|
local disk_total = {}
|
|
|
|
|
|
|
|
-- {{{ Disk I/O widget type
|
2009-08-07 17:41:10 +02:00
|
|
|
local function worker(format, disk)
|
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
|
|
|
-- Get /proc/diskstats
|
|
|
|
local f = io.open("/proc/diskstats")
|
|
|
|
local disk_lines = {}
|
|
|
|
|
|
|
|
for line in f:lines() do
|
|
|
|
if line:match("("..disk..")%s") then
|
|
|
|
-- Todo: find a way to do this
|
|
|
|
--for stat in line:gmatch("%s([%d]+)") do
|
|
|
|
-- table.insert(disk_lines, stat)
|
|
|
|
--end
|
|
|
|
--
|
|
|
|
-- Skip first two matches
|
|
|
|
local stat = line:gmatch("%s([%d]+)")
|
|
|
|
stat()
|
|
|
|
stat()
|
|
|
|
-- Store the rest
|
|
|
|
for i = 1, 11 do
|
|
|
|
table.insert(disk_lines, stat())
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
f:close()
|
|
|
|
|
|
|
|
-- Ensure tables are initialized correctly
|
|
|
|
while #disk_total < #disk_lines do
|
|
|
|
table.insert(disk_total, 0)
|
|
|
|
end
|
|
|
|
|
|
|
|
local diff_total = {}
|
|
|
|
|
|
|
|
for i, v in ipairs(disk_lines) do
|
|
|
|
-- Diskstats are absolute, substract our last reading
|
|
|
|
diff_total[i] = v - disk_total[i]
|
|
|
|
|
|
|
|
-- Store totals
|
|
|
|
disk_total[i] = v
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Calculate I/O
|
|
|
|
disk_usage["{raw}"] = diff_total[7] + diff_total[3]
|
|
|
|
-- Divide "sectors read" by 2 and 1024 to get KB and MB
|
|
|
|
disk_usage["{kb}"] = math.floor(diff_total[7] + diff_total[3])/2
|
|
|
|
disk_usage["{mb}"] = math.floor(diff_total[7] + diff_total[3])/1024
|
|
|
|
|
|
|
|
return disk_usage
|
|
|
|
end
|
|
|
|
-- }}}
|
2009-08-01 23:11:41 +02:00
|
|
|
|
|
|
|
setmetatable(_M, { __call = function(_, ...) return worker(...) end })
|