-- MPD infos
-- lain.widgets.mpd
-local mpd = helpers.make_widget_textbox()
+local mpd = {}
local function worker(args)
local args = args or {}
local music_dir = args.music_dir or os.getenv("HOME") .. "/Music"
local cover_pattern = args.cover_pattern or "*\\.(jpg|jpeg|png|gif)$"
local cover_size = args.cover_size or 100
- local default_art = args.default_art or ""
+ local default_art = args.default_art
local notify = args.notify or "on"
local followtag = args.followtag or false
local settings = args.settings or function() end
local mpdh = string.format("telnet://%s:%s", host, port)
local echo = string.format("printf \"%sstatus\\ncurrentsong\\nclose\\n\"", password)
- local cmd = string.format("%s -c '%s | curl --connect-timeout 1 -fsm 3 %s'", shell, echo, mpdh)
+ local cmd = string.format("%s | curl --connect-timeout 1 -fsm 3 %s", echo, mpdh)
+
+ mpd.widget = wibox.widget.textbox()
mpd_notification_preset = { title = "Now playing", timeout = 6 }
helpers.set_map("current mpd track", nil)
function mpd.update()
- helpers.async(cmd, function(f)
+ helpers.async({ shell, "-c", cmd }, function(f)
mpd_now = {
random_mode = false,
single_mode = false,
preset = mpd_notification_preset,
icon = default_art,
icon_size = cover_size,
- replaces_id = mpd.id,
+ replaces_id = mpd.id
}
if not string.match(mpd_now.file, "http.*://") then -- local file instead of http stream
local path = string.format("%s/%s", music_dir, string.match(mpd_now.file, ".*/"))
- local cover = string.format("%s -c \"find '%s' -maxdepth 1 -type f | egrep -i -m1 '%s'\"", shell, path, cover_pattern)
- helpers.async(cover, function(current_icon)
+ local cover = string.format("find '%s' -maxdepth 1 -type f | egrep -i -m1 '%s'", path:gsub("'", "'\\''"), cover_pattern)
+ helpers.async({ shell, "-c", cover }, function(current_icon)
common.icon = current_icon:gsub("\n", "")
+ if #common.icon == 0 then common.icon = nil end
mpd.id = naughty.notify(common).id
end)
else
end)
end
- helpers.newtimer("mpd", timeout, mpd.update)
+ mpd.timer = helpers.newtimer("mpd", timeout, mpd.update, true, true)
return mpd
end