[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
|
||||
local tonumber = tonumber
|
||||
local io = { popen = io.popen }
|
||||
local setmetatable = setmetatable
|
||||
local string = { match = string.match }
|
||||
local table = { concat = table.concat }
|
||||
|
||||
local helpers = require("vicious.helpers")
|
||||
local spawn = require("vicious.spawn")
|
||||
-- }}}
|
||||
|
@ -17,52 +18,35 @@ local spawn = require("vicious.spawn")
|
|||
-- vicious.widgets.volume
|
||||
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)
|
||||
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
|
||||
|
||||
-- {{{ Volume widget type
|
||||
local function worker(format, warg)
|
||||
if not warg then return end
|
||||
|
||||
local mixer_state = {
|
||||
["on"] = "♫", -- "",
|
||||
["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}
|
||||
local ret
|
||||
volume_linux.async(format, warg, function (volume) ret = volume end)
|
||||
while ret == nil do end
|
||||
return ret
|
||||
end
|
||||
-- }}}
|
||||
|
||||
|
|
Loading…
Reference in New Issue