- local mympdupdate = function()
- local function set_nompd()
- if shadow
- then
- mympd:set_text('')
- else
- mympd:set_markup(markup(header_color, " mpd "), markup(color , "off "))
- end
- end
-
- local mpd_state = {
- ["{state}"] = "N/A",
- ["{file}"] = "N/A",
- ["{Artist}"] = "N/A",
- ["{Title}"] = "N/A",
- ["{Album}"] = "N/A",
- ["{Date}"] = "N/A"
- }
-
- -- Get data from MPD server
- local f = io.popen(echo .. " | curl --connect-timeout 1 -fsm 3 " .. mpdh)
-
- for line in f:lines() do
- for k, v in string.gmatch(line, "([%w]+):[%s](.*)$") do
- if k == "state" then mpd_state["{"..k.."}"] = v
- elseif k == "file" then mpd_state["{"..k.."}"] = v
- elseif k == "Artist" then mpd_state["{"..k.."}"] = awful.util.escape(v)
- elseif k == "Title" then mpd_state["{"..k.."}"] = awful.util.escape(v)
- elseif k == "Album" then mpd_state["{"..k.."}"] = awful.util.escape(v)
- elseif k == "Date" then mpd_state["{"..k.."}"] = awful.util.escape(v)
+ function mpd.update()
+ async.request(echo .. " | curl --connect-timeout 1 -fsm 3 " .. mpdh, function (f)
+ mpd_now = {
+ state = "N/A",
+ file = "N/A",
+ artist = "N/A",
+ title = "N/A",
+ album = "N/A",
+ date = "N/A",
+ time = "N/A",
+ elapsed = "N/A"
+ }
+
+ for line in f:lines() do
+ for k, v in string.gmatch(line, "([%w]+):[%s](.*)$") do
+ if k == "state" then mpd_now.state = v
+ elseif k == "file" then mpd_now.file = v
+ elseif k == "Artist" then mpd_now.artist = escape_f(v)
+ elseif k == "Title" then mpd_now.title = escape_f(v)
+ elseif k == "Album" then mpd_now.album = escape_f(v)
+ elseif k == "Date" then mpd_now.date = escape_f(v)
+ elseif k == "Time" then mpd_now.time = v
+ elseif k == "elapsed" then mpd_now.elapsed = string.match(v, "%d+")
+ end