mpd and yawn widget are now asynchronous
This commit is contained in:
parent
c14436760d
commit
e00ee3436e
3 changed files with 133 additions and 128 deletions
|
@ -13,6 +13,8 @@
|
||||||
-- ...synchronously
|
-- ...synchronously
|
||||||
-- wwidget.text = asyncshell.demand('wscript -Kiev', 5):read("*l") or "Error"
|
-- wwidget.text = asyncshell.demand('wscript -Kiev', 5):read("*l") or "Error"
|
||||||
|
|
||||||
|
-- This makes things faster, but puts weight on sysload and is more cpu demanding.
|
||||||
|
|
||||||
local spawn = require('awful.util').spawn
|
local spawn = require('awful.util').spawn
|
||||||
|
|
||||||
asyncshell = {}
|
asyncshell = {}
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
local helpers = require("lain.helpers")
|
local helpers = require("lain.helpers")
|
||||||
|
local async = require("lain.asyncshell")
|
||||||
|
|
||||||
local escape_f = require("awful.util").escape
|
local escape_f = require("awful.util").escape
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
|
@ -50,56 +51,54 @@ local function worker(args)
|
||||||
helpers.set_map("current mpd track", nil)
|
helpers.set_map("current mpd track", nil)
|
||||||
|
|
||||||
function mpd.update()
|
function mpd.update()
|
||||||
mpd_now = {
|
async.request(echo .. " | curl --connect-timeout 1 -fsm 3 " .. mpdh, function (f)
|
||||||
state = "N/A",
|
mpd_now = {
|
||||||
file = "N/A",
|
state = "N/A",
|
||||||
artist = "N/A",
|
file = "N/A",
|
||||||
title = "N/A",
|
artist = "N/A",
|
||||||
album = "N/A",
|
title = "N/A",
|
||||||
date = "N/A"
|
album = "N/A",
|
||||||
}
|
date = "N/A"
|
||||||
|
}
|
||||||
|
|
||||||
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
|
||||||
for line in f:lines() do
|
if k == "state" then mpd_now.state = v
|
||||||
for k, v in string.gmatch(line, "([%w]+):[%s](.*)$") do
|
elseif k == "file" then mpd_now.file = v
|
||||||
if k == "state" then mpd_now.state = v
|
elseif k == "Artist" then mpd_now.artist = escape_f(v)
|
||||||
elseif k == "file" then mpd_now.file = v
|
elseif k == "Title" then mpd_now.title = escape_f(v)
|
||||||
elseif k == "Artist" then mpd_now.artist = escape_f(v)
|
elseif k == "Album" then mpd_now.album = escape_f(v)
|
||||||
elseif k == "Title" then mpd_now.title = escape_f(v)
|
elseif k == "Date" then mpd_now.date = escape_f(v)
|
||||||
elseif k == "Album" then mpd_now.album = escape_f(v)
|
end
|
||||||
elseif k == "Date" then mpd_now.date = escape_f(v)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
f:close()
|
mpd_notification_preset.text = string.format("%s (%s) - %s\n%s", mpd_now.artist,
|
||||||
|
mpd_now.album, mpd_now.date, mpd_now.title)
|
||||||
|
widget = mpd.widget
|
||||||
|
settings()
|
||||||
|
|
||||||
mpd_notification_preset.text = string.format("%s (%s) - %s\n%s", mpd_now.artist,
|
if mpd_now.state == "play"
|
||||||
mpd_now.album, mpd_now.date, mpd_now.title)
|
|
||||||
widget = mpd.widget
|
|
||||||
settings()
|
|
||||||
|
|
||||||
if mpd_now.state == "play"
|
|
||||||
then
|
|
||||||
if mpd_now.title ~= helpers.get_map("current mpd track")
|
|
||||||
then
|
then
|
||||||
helpers.set_map("current mpd track", mpd_now.title)
|
if mpd_now.title ~= helpers.get_map("current mpd track")
|
||||||
|
then
|
||||||
|
helpers.set_map("current mpd track", mpd_now.title)
|
||||||
|
|
||||||
os.execute(string.format("%s %q %q %d %q", mpdcover, music_dir,
|
os.execute(string.format("%s %q %q %d %q", mpdcover, music_dir,
|
||||||
mpd_now.file, cover_size, default_art))
|
mpd_now.file, cover_size, default_art))
|
||||||
|
|
||||||
mpd.id = naughty.notify({
|
mpd.id = naughty.notify({
|
||||||
preset = mpd_notification_preset,
|
preset = mpd_notification_preset,
|
||||||
icon = "/tmp/mpdcover.png",
|
icon = "/tmp/mpdcover.png",
|
||||||
replaces_id = mpd.id,
|
replaces_id = mpd.id,
|
||||||
screen = client.focus and client.focus.screen or 1
|
screen = client.focus and client.focus.screen or 1
|
||||||
}).id
|
}).id
|
||||||
|
end
|
||||||
|
elseif mpd_now.state ~= "pause"
|
||||||
|
then
|
||||||
|
helpers.set_map("current mpd track", nil)
|
||||||
end
|
end
|
||||||
elseif mpd_now.state ~= "pause"
|
end)
|
||||||
then
|
|
||||||
helpers.set_map("current mpd track", nil)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
helpers.newtimer("mpd", timeout, mpd.update)
|
helpers.newtimer("mpd", timeout, mpd.update)
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
local newtimer = require("lain.helpers").newtimer
|
local newtimer = require("lain.helpers").newtimer
|
||||||
|
local async = require("lain.asyncshell")
|
||||||
|
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
|
@ -47,99 +48,102 @@ yawn_notification_preset = {}
|
||||||
|
|
||||||
local function fetch_weather()
|
local function fetch_weather()
|
||||||
local url = api_url .. units_set .. city_id
|
local url = api_url .. units_set .. city_id
|
||||||
local f = io.popen("curl --connect-timeout 1 -fsm 3 '" .. url .. "'" )
|
local cmd = "curl --connect-timeout 1 -fsm 3 '" .. url .. "'"
|
||||||
local text = f:read("*a")
|
|
||||||
f:close()
|
|
||||||
|
|
||||||
-- In case of no connection or invalid city ID
|
async.request(cmd, function(f)
|
||||||
-- widgets won't display
|
local text = f:read("*a")
|
||||||
if text == "" or text:match("City not found")
|
|
||||||
then
|
|
||||||
yawn.icon:set_image(icon_path .. "na.png")
|
|
||||||
if text == "" then
|
|
||||||
weather_data = "Service not available at the moment."
|
|
||||||
yawn.widget:set_text(" N/A ")
|
|
||||||
else
|
|
||||||
weather_data = "City not found!\n" ..
|
|
||||||
"Are you sure " .. city_id ..
|
|
||||||
" is your Yahoo city ID?"
|
|
||||||
yawn.widget:set_text(" ? ")
|
|
||||||
end
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Processing raw data
|
|
||||||
weather_data = text:gsub("<.->", "")
|
|
||||||
weather_data = weather_data:match("Current Conditions:.-Full") or ""
|
|
||||||
|
|
||||||
-- may still happens in case of bad connectivity
|
|
||||||
if weather_data == "" then
|
|
||||||
yawn.icon:set_image(icon_path .. "na.png")
|
|
||||||
yawn.widget:set_text(" ? ")
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
weather_data = weather_data:gsub("Current Conditions:.-\n", "Now: ")
|
|
||||||
weather_data = weather_data:gsub("Forecast:.-\n", "")
|
|
||||||
weather_data = weather_data:gsub("\nFull", "")
|
|
||||||
weather_data = weather_data:gsub("[\n]$", "")
|
|
||||||
weather_data = weather_data:gsub(" [-] " , ": ")
|
|
||||||
weather_data = weather_data:gsub("[.]", ",")
|
|
||||||
weather_data = weather_data:gsub("High: ", "")
|
|
||||||
weather_data = weather_data:gsub(" Low: ", " - ")
|
|
||||||
|
|
||||||
-- Getting info for text widget
|
|
||||||
local now = weather_data:sub(weather_data:find("Now:")+5,
|
|
||||||
weather_data:find("\n")-1)
|
|
||||||
forecast = now:sub(1, now:find(",")-1)
|
|
||||||
units = now:sub(now:find(",")+2, -2)
|
|
||||||
|
|
||||||
-- Day/Night icon change
|
|
||||||
local hour = tonumber(os.date("%H"))
|
|
||||||
sky = icon_path
|
|
||||||
|
|
||||||
if forecast == "Clear" or
|
|
||||||
forecast == "Fair" or
|
|
||||||
forecast == "Partly Cloudy" or
|
|
||||||
forecast == "Mostly Cloudy"
|
|
||||||
then
|
|
||||||
if hour >= 6 and hour <= 18
|
|
||||||
then
|
|
||||||
sky = sky .. "Day"
|
|
||||||
else
|
|
||||||
sky = sky .. "Night"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
sky = sky .. forecast:gsub(" ", ""):gsub("/", "") .. ".png"
|
|
||||||
|
|
||||||
-- In case there's no defined icon for current forecast
|
|
||||||
if io.open(sky) == nil then
|
|
||||||
sky = icon_path .. "na.png"
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Localization
|
|
||||||
local f = io.open(localizations_path .. language, "r")
|
|
||||||
if language:find("en_") == nil and f ~= nil
|
|
||||||
then
|
|
||||||
f:close()
|
f:close()
|
||||||
for line in io.lines(localizations_path .. language)
|
|
||||||
do
|
-- In case of no connection or invalid city ID
|
||||||
word = string.sub(line, 1, line:find("|")-1)
|
-- widgets won't display
|
||||||
translation = string.sub(line, line:find("|")+1)
|
if text == "" or text:match("City not found")
|
||||||
weather_data = string.gsub(weather_data, word, translation)
|
then
|
||||||
|
yawn.icon:set_image(icon_path .. "na.png")
|
||||||
|
if text == "" then
|
||||||
|
weather_data = "Service not available at the moment."
|
||||||
|
yawn.widget:set_text(" N/A ")
|
||||||
|
else
|
||||||
|
weather_data = "City not found!\n" ..
|
||||||
|
"Are you sure " .. city_id ..
|
||||||
|
" is your Yahoo city ID?"
|
||||||
|
yawn.widget:set_text(" ? ")
|
||||||
|
end
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
-- Finally setting infos
|
-- Processing raw data
|
||||||
yawn.icon:set_image(sky)
|
weather_data = text:gsub("<.->", "")
|
||||||
widget = yawn.widget
|
weather_data = weather_data:match("Current Conditions:.-Full") or ""
|
||||||
|
|
||||||
_data = weather_data:match(": %S.-,") or weather_data
|
-- may still happens in case of bad connectivity
|
||||||
forecast = _data:gsub(": ", ""):gsub(",", "")
|
if weather_data == "" then
|
||||||
units = units:gsub(" ", "")
|
yawn.icon:set_image(icon_path .. "na.png")
|
||||||
|
yawn.widget:set_text(" ? ")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
settings()
|
weather_data = weather_data:gsub("Current Conditions:.-\n", "Now: ")
|
||||||
|
weather_data = weather_data:gsub("Forecast:.-\n", "")
|
||||||
|
weather_data = weather_data:gsub("\nFull", "")
|
||||||
|
weather_data = weather_data:gsub("[\n]$", "")
|
||||||
|
weather_data = weather_data:gsub(" [-] " , ": ")
|
||||||
|
weather_data = weather_data:gsub("[.]", ",")
|
||||||
|
weather_data = weather_data:gsub("High: ", "")
|
||||||
|
weather_data = weather_data:gsub(" Low: ", " - ")
|
||||||
|
|
||||||
|
-- Getting info for text widget
|
||||||
|
local now = weather_data:sub(weather_data:find("Now:")+5,
|
||||||
|
weather_data:find("\n")-1)
|
||||||
|
forecast = now:sub(1, now:find(",")-1)
|
||||||
|
units = now:sub(now:find(",")+2, -2)
|
||||||
|
|
||||||
|
-- Day/Night icon change
|
||||||
|
local hour = tonumber(os.date("%H"))
|
||||||
|
sky = icon_path
|
||||||
|
|
||||||
|
if forecast == "Clear" or
|
||||||
|
forecast == "Fair" or
|
||||||
|
forecast == "Partly Cloudy" or
|
||||||
|
forecast == "Mostly Cloudy"
|
||||||
|
then
|
||||||
|
if hour >= 6 and hour <= 18
|
||||||
|
then
|
||||||
|
sky = sky .. "Day"
|
||||||
|
else
|
||||||
|
sky = sky .. "Night"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
sky = sky .. forecast:gsub(" ", ""):gsub("/", "") .. ".png"
|
||||||
|
|
||||||
|
-- In case there's no defined icon for current forecast
|
||||||
|
if io.open(sky) == nil then
|
||||||
|
sky = icon_path .. "na.png"
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Localization
|
||||||
|
local f = io.open(localizations_path .. language, "r")
|
||||||
|
if language:find("en_") == nil and f ~= nil
|
||||||
|
then
|
||||||
|
f:close()
|
||||||
|
for line in io.lines(localizations_path .. language)
|
||||||
|
do
|
||||||
|
word = string.sub(line, 1, line:find("|")-1)
|
||||||
|
translation = string.sub(line, line:find("|")+1)
|
||||||
|
weather_data = string.gsub(weather_data, word, translation)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Finally setting infos
|
||||||
|
yawn.icon:set_image(sky)
|
||||||
|
widget = yawn.widget
|
||||||
|
|
||||||
|
_data = weather_data:match(": %S.-,") or weather_data
|
||||||
|
forecast = _data:gsub(": ", ""):gsub(",", "")
|
||||||
|
units = units:gsub(" ", "")
|
||||||
|
|
||||||
|
settings()
|
||||||
|
end)
|
||||||
end
|
end
|
||||||
|
|
||||||
function yawn.hide()
|
function yawn.hide()
|
||||||
|
|
Loading…
Add table
Reference in a new issue