[volume_linux] Use awful.spawn.easy_async instead of io.popen
This commit is contained in:
parent
1d96075f6c
commit
e643de1375
|
@ -5,9 +5,10 @@
|
||||||
|
|
||||||
-- {{{ Grab environment
|
-- {{{ Grab environment
|
||||||
local tonumber = tonumber
|
local tonumber = tonumber
|
||||||
local io = { popen = io.popen }
|
|
||||||
local setmetatable = setmetatable
|
local setmetatable = setmetatable
|
||||||
local string = { match = string.match }
|
local string = { match = string.match }
|
||||||
|
local table = { concat = table.concat }
|
||||||
|
|
||||||
local helpers = require("vicious.helpers")
|
local helpers = require("vicious.helpers")
|
||||||
local spawn = require("vicious.spawn")
|
local spawn = require("vicious.spawn")
|
||||||
-- }}}
|
-- }}}
|
||||||
|
@ -17,52 +18,35 @@ local spawn = require("vicious.spawn")
|
||||||
-- vicious.widgets.volume
|
-- vicious.widgets.volume
|
||||||
local volume_linux = {}
|
local volume_linux = {}
|
||||||
|
|
||||||
local STATES = { on = '🔉', off = '🔈' }
|
-- {{{ Volume widget type
|
||||||
|
local STATE = { on = '🔉', off = '🔈' }
|
||||||
|
|
||||||
|
local function parse(stdout, stderr, exitreason, exitcode)
|
||||||
|
-- Capture mixer control state, e.g. [ 42 % ] [ on ]
|
||||||
|
local volume, state = string.match(stdout, "%[([%d]+)%%%].*%[([%l]*)%]")
|
||||||
|
-- Handle mixers without data
|
||||||
|
if volume == nil then return { 0, STATE.off } end
|
||||||
|
|
||||||
|
if state == "" and volume == "0" -- handle mixers without mute
|
||||||
|
or state == "off" then -- handle muted mixers
|
||||||
|
return { tonumber(volume), STATE.off }
|
||||||
|
else
|
||||||
|
return { tonumber(volume), STATE.on }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function volume_linux.async(format, warg, callback)
|
function volume_linux.async(format, warg, callback)
|
||||||
if not warg then return callback{} end
|
if not warg then return callback{} end
|
||||||
|
if type(warg) ~= "table" then warg = { warg } end
|
||||||
|
spawn.easy_async("amixer -M get " .. table.concat(warg, " "),
|
||||||
|
function (...) callback(parse(...)) end)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- {{{ Volume widget type
|
|
||||||
local function worker(format, warg)
|
local function worker(format, warg)
|
||||||
if not warg then return end
|
local ret
|
||||||
|
volume_linux.async(format, warg, function (volume) ret = volume end)
|
||||||
local mixer_state = {
|
while ret == nil do end
|
||||||
["on"] = "♫", -- "",
|
return ret
|
||||||
["off"] = "♩" -- "M"
|
|
||||||
}
|
|
||||||
|
|
||||||
if type(warg) ~= "table" then
|
|
||||||
warg = { warg }
|
|
||||||
end
|
|
||||||
|
|
||||||
local cmd = "amixer -M get "
|
|
||||||
for _, arg in ipairs(warg) do
|
|
||||||
cmd = cmd .. " " .. helpers.shellquote(arg)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Get mixer control contents
|
|
||||||
local f = io.popen(cmd)
|
|
||||||
local mixer = f:read("*all")
|
|
||||||
f:close()
|
|
||||||
|
|
||||||
-- Capture mixer control state: [5%] ... ... [on]
|
|
||||||
local volu, mute = string.match(mixer, "([%d]+)%%.*%[([%l]*)")
|
|
||||||
-- Handle mixers without data
|
|
||||||
if volu == nil then
|
|
||||||
return {0, mixer_state["off"]}
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Handle mixers without mute
|
|
||||||
if mute == "" and volu == "0"
|
|
||||||
-- Handle mixers that are muted
|
|
||||||
or mute == "off" then
|
|
||||||
mute = mixer_state["off"]
|
|
||||||
else
|
|
||||||
mute = mixer_state["on"]
|
|
||||||
end
|
|
||||||
|
|
||||||
return {tonumber(volu), mute}
|
|
||||||
end
|
end
|
||||||
-- }}}
|
-- }}}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue