[fs] Deprecate io.popen
Also clarify unit prefix convention
This commit is contained in:
parent
c91167f954
commit
565d74cc8b
|
@ -20,7 +20,7 @@ Fixed:
|
||||||
- Deprecate the use of `io.popen` in following widgets:
|
- Deprecate the use of `io.popen` in following widgets:
|
||||||
* wifi_linux, wifiiw_linux, hwmontemp_linux
|
* wifi_linux, wifiiw_linux, hwmontemp_linux
|
||||||
* bat_freebsd, mem_freebsd, net_freebsd
|
* bat_freebsd, mem_freebsd, net_freebsd
|
||||||
* volume, gmail, mdir, mpd
|
* volume, gmail, mdir, mpd, fs
|
||||||
- [mpd] Lua 5.3 compatibility (for real this time); also correct a typo
|
- [mpd] Lua 5.3 compatibility (for real this time); also correct a typo
|
||||||
- [pkg,weather,contrib/btc] Allow function call without Awesome
|
- [pkg,weather,contrib/btc] Allow function call without Awesome
|
||||||
- [pkg] Use more updated front-ends for Debian/Ubuntu (apt) and Fedora (dnf)
|
- [pkg] Use more updated front-ends for Debian/Ubuntu (apt) and Fedora (dnf)
|
||||||
|
|
|
@ -236,6 +236,7 @@ Supported platforms: platform independent.
|
||||||
* Returns a table with string keys, using mount points as a base, e.g.
|
* Returns a table with string keys, using mount points as a base, e.g.
|
||||||
`${/ size_mb}`, `${/ size_gb}`, `${/ used_mb}`, `${/ used_gb}`, `${/ used_p}`,
|
`${/ size_mb}`, `${/ size_gb}`, `${/ used_mb}`, `${/ used_gb}`, `${/ used_p}`,
|
||||||
`${/ avail_mb}`, `${/ avail_gb}`, `${/ avail_p}`, `${/home size_mb}`, etc.
|
`${/ avail_mb}`, `${/ avail_gb}`, `${/ avail_p}`, `${/home size_mb}`, etc.
|
||||||
|
mb and gb refer to mebibyte and gibibyte respectively.
|
||||||
|
|
||||||
### vicious.widgets.gmail
|
### vicious.widgets.gmail
|
||||||
|
|
||||||
|
|
|
@ -6,50 +6,34 @@
|
||||||
|
|
||||||
-- {{{ Grab environment
|
-- {{{ Grab environment
|
||||||
local tonumber = tonumber
|
local tonumber = tonumber
|
||||||
local io = { popen = io.popen }
|
|
||||||
local setmetatable = setmetatable
|
local helpers = require"vicious.helpers"
|
||||||
local string = { match = string.match }
|
local spawn = require"vicious.spawn"
|
||||||
local helpers = require("vicious.helpers")
|
|
||||||
-- }}}
|
-- }}}
|
||||||
|
|
||||||
|
-- Mebibyte and gibibyte respectively, because backward compatibility
|
||||||
|
local UNIT = { mb = 1024, gb = 1024^2 }
|
||||||
|
|
||||||
-- FS: provides file system disk space usage
|
-- FS: provides file system disk space usage
|
||||||
-- vicious.widgets.fs
|
-- vicious.widgets.fs
|
||||||
local fs_all = {}
|
return helpers.setasyncall{
|
||||||
|
async = function(format, warg, callback)
|
||||||
|
local fs_info = {} -- Get data from df
|
||||||
|
spawn.with_line_callback_with_shell(
|
||||||
|
warg and "LC_ALL=C df -kP" or "LC_ALL=C df -klP",
|
||||||
|
{ stdout = function (line)
|
||||||
|
-- (1024-blocks) (Used) (Available) (Capacity)% (Mounted on)
|
||||||
|
local s, u, a, p, m = line:match(
|
||||||
|
"^.-%s+(%d+)%s+(%d+)%s+(%d+)%s+(%d+)%%%s+([%p%w]+)")
|
||||||
|
|
||||||
|
if u and m then -- Handle 1st line and broken regexp
|
||||||
|
helpers.uformat(fs_info, m .. " size", s, UNIT)
|
||||||
|
helpers.uformat(fs_info, m .. " used", u, UNIT)
|
||||||
|
helpers.uformat(fs_info, m .. " avail", a, UNIT)
|
||||||
|
|
||||||
-- Variable definitions
|
fs_info["{" .. m .. " used_p}"] = tonumber(p)
|
||||||
local unit = { ["mb"] = 1024, ["gb"] = 1024^2 }
|
fs_info["{" .. m .. " avail_p}"] = 100 - tonumber(p)
|
||||||
|
end
|
||||||
-- {{{ Filesystem widget type
|
end,
|
||||||
local function worker(format, warg)
|
output_done = function () callback(fs_info) end })
|
||||||
local cmd = "LC_ALL=C df -kP"
|
end }
|
||||||
if not warg then
|
|
||||||
-- List only local filesystems by default
|
|
||||||
cmd = cmd .. " -l"
|
|
||||||
end
|
|
||||||
|
|
||||||
local fs_info = {} -- Get data from df
|
|
||||||
local f = io.popen(cmd)
|
|
||||||
|
|
||||||
for line in f:lines() do -- Match: (size) (used)(avail)(use%) (mount)
|
|
||||||
local s = string.match(line, "^.-[%s]([%d]+)")
|
|
||||||
local u,a,p = string.match(line, "([%d]+)[%D]+([%d]+)[%D]+([%d]+)%%")
|
|
||||||
local m = string.match(line, "%%[%s]+([%p%w]+)")
|
|
||||||
|
|
||||||
if u and m then -- Handle 1st line and broken regexp
|
|
||||||
helpers.uformat(fs_info, m .. " size", s, unit)
|
|
||||||
helpers.uformat(fs_info, m .. " used", u, unit)
|
|
||||||
helpers.uformat(fs_info, m .. " avail", a, unit)
|
|
||||||
|
|
||||||
fs_info["{" .. m .. " used_p}"] = tonumber(p)
|
|
||||||
fs_info["{" .. m .. " avail_p}"] = 100 - tonumber(p)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
f:close()
|
|
||||||
|
|
||||||
return fs_info
|
|
||||||
end
|
|
||||||
-- }}}
|
|
||||||
|
|
||||||
return setmetatable(fs_all, { __call = function(_, ...) return worker(...) end })
|
|
||||||
|
|
Loading…
Reference in New Issue