mirror of https://github.com/lcpz/lain.git
Add a card attribute for alsa and alsabar
Currently alsa.lua and alsabar.lua do not support the amixer command line option "-c" which allows defining which card to use. For at least new Dell E-series laptops, the card is not the default (0) and therefore this functionality is required for these widgets to work.
This commit is contained in:
parent
bbd552f5bf
commit
5a1a02a63d
|
@ -12,7 +12,8 @@ local newtimer = require("lain.helpers").newtimer
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
|
||||||
local io = { popen = io.popen }
|
local io = { popen = io.popen }
|
||||||
local string = { match = string.match }
|
local string = { match = string.match,
|
||||||
|
format = string.format }
|
||||||
|
|
||||||
local setmetatable = setmetatable
|
local setmetatable = setmetatable
|
||||||
|
|
||||||
|
@ -22,6 +23,7 @@ local alsa = {}
|
||||||
|
|
||||||
local function worker(args)
|
local function worker(args)
|
||||||
local args = args or {}
|
local args = args or {}
|
||||||
|
local card = args.card or "0"
|
||||||
local timeout = args.timeout or 5
|
local timeout = args.timeout or 5
|
||||||
local channel = args.channel or "Master"
|
local channel = args.channel or "Master"
|
||||||
local settings = args.settings or function() end
|
local settings = args.settings or function() end
|
||||||
|
@ -29,7 +31,7 @@ local function worker(args)
|
||||||
alsa.widget = wibox.widget.textbox('')
|
alsa.widget = wibox.widget.textbox('')
|
||||||
|
|
||||||
function alsa.update()
|
function alsa.update()
|
||||||
local f = assert(io.popen('amixer -M get ' .. channel))
|
local f = assert(io.popen(string.format("amixer -c %s -M get %s", card, channel)))
|
||||||
local mixer = f:read("*a")
|
local mixer = f:read("*a")
|
||||||
f:close()
|
f:close()
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,7 @@ local setmetatable = setmetatable
|
||||||
-- ALSA volume bar
|
-- ALSA volume bar
|
||||||
-- lain.widgets.alsabar
|
-- lain.widgets.alsabar
|
||||||
local alsabar = {
|
local alsabar = {
|
||||||
|
card = "0",
|
||||||
channel = "Master",
|
channel = "Master",
|
||||||
step = "5%",
|
step = "5%",
|
||||||
|
|
||||||
|
@ -97,6 +98,7 @@ local function worker(args)
|
||||||
local ticks_size = args.ticks_size or 7
|
local ticks_size = args.ticks_size or 7
|
||||||
local vertical = args.vertical or false
|
local vertical = args.vertical or false
|
||||||
|
|
||||||
|
alsabar.card = args.card or alsabar.card
|
||||||
alsabar.channel = args.channel or alsabar.channel
|
alsabar.channel = args.channel or alsabar.channel
|
||||||
alsabar.step = args.step or alsabar.step
|
alsabar.step = args.step or alsabar.step
|
||||||
alsabar.colors = args.colors or alsabar.colors
|
alsabar.colors = args.colors or alsabar.colors
|
||||||
|
@ -115,7 +117,7 @@ local function worker(args)
|
||||||
|
|
||||||
function alsabar.update()
|
function alsabar.update()
|
||||||
-- Get mixer control contents
|
-- Get mixer control contents
|
||||||
local f = io.popen("amixer -M get " .. alsabar.channel)
|
local f = assert(io.popen(string.format("amixer -c %s -M get %s", alsabar.card, alsabar.channel)))
|
||||||
local mixer = f:read("*a")
|
local mixer = f:read("*a")
|
||||||
f:close()
|
f:close()
|
||||||
|
|
||||||
|
@ -129,7 +131,6 @@ local function worker(args)
|
||||||
|
|
||||||
alsabar._current_level = tonumber(volu)
|
alsabar._current_level = tonumber(volu)
|
||||||
alsabar.bar:set_value(alsabar._current_level / 100)
|
alsabar.bar:set_value(alsabar._current_level / 100)
|
||||||
|
|
||||||
if not mute and tonumber(volu) == 0 or mute == "off"
|
if not mute and tonumber(volu) == 0 or mute == "off"
|
||||||
then
|
then
|
||||||
alsabar._muted = true
|
alsabar._muted = true
|
||||||
|
@ -154,15 +155,15 @@ local function worker(args)
|
||||||
awful.util.spawn(alsabar.mixer)
|
awful.util.spawn(alsabar.mixer)
|
||||||
end),
|
end),
|
||||||
awful.button ({}, 3, function()
|
awful.button ({}, 3, function()
|
||||||
awful.util.spawn(string.format("amixer set %s toggle", alsabar.channel))
|
awful.util.spawn(string.format("amixer -c %s set %s toggle", alsabar.card, alsabar.channel))
|
||||||
alsabar.update()
|
alsabar.update()
|
||||||
end),
|
end),
|
||||||
awful.button ({}, 4, function()
|
awful.button ({}, 4, function()
|
||||||
awful.util.spawn(string.format("amixer set %s %s+", alsabar.channel, alsabar.step))
|
awful.util.spawn(string.format("amixer -c %s set %s %s+", alsabar.card, alsabar.channel, alsabar.step))
|
||||||
alsabar.update()
|
alsabar.update()
|
||||||
end),
|
end),
|
||||||
awful.button ({}, 5, function()
|
awful.button ({}, 5, function()
|
||||||
awful.util.spawn(string.format("amixer set %s %s-", alsabar.channel, alsabar.step))
|
awful.util.spawn(string.format("amixer -c %s set %s %s-", alsabar.card, alsabar.channel, alsabar.step))
|
||||||
alsabar.update()
|
alsabar.update()
|
||||||
end)
|
end)
|
||||||
))
|
))
|
||||||
|
|
Loading…
Reference in New Issue