diff options
| author | Sviatoslav Sydorenko <wk@sydorenko.org.ua> | 2019-06-03 16:35:40 +0200 | 
|---|---|---|
| committer | streetturtle <streetturtle@gmail.com> | 2019-09-02 15:45:17 -0400 | 
| commit | b41daeb9b2fd0206124740b165bcb8254a84c7b4 (patch) | |
| tree | 9a11b1ccfc0a990b84032112efb244ab0886cb99 /weather-widget | |
| parent | 54500cf15d1272ee63edd44de695c6e803f570ce (diff) | |
Query weather with async timeouts
Fixes #81
Diffstat (limited to 'weather-widget')
| -rw-r--r-- | weather-widget/weather.lua | 80 | 
1 files changed, 40 insertions, 40 deletions
diff --git a/weather-widget/weather.lua b/weather-widget/weather.lua index deeff61..0899b8f 100644 --- a/weather-widget/weather.lua +++ b/weather-widget/weather.lua @@ -6,8 +6,8 @@  -- @copyright 2018 Pavel Makhov  ------------------------------------------------- -local http = require("socket.http")  local socket = require("socket") +local http = require("socket.http")  local ltn12 = require("ltn12")  local json = require("json")  local naughty = require("naughty") @@ -109,47 +109,47 @@ local function worker(args)          return directions[math.floor((degrees % 360) / 22.5) + 1]      end -    local weather_timer = gears.timer({ timeout = 60 }) -    local resp - -    weather_timer:connect_signal("timeout", function() -        local resp_json = {} -        local res, status = http.request{ -            url=weather_api_url, -            sink=ltn12.sink.table(resp_json), -            -- ref: -            -- http://w3.impa.br/~diego/software/luasocket/old/luasocket-2.0/http.html -            create=function() -                -- ref: https://stackoverflow.com/a/6021774/595220 -                local req_sock = socket.tcp() -                -- 't' — overall timeout -                req_sock:settimeout(0.2, 't') -                -- 'b' — block timeout -                req_sock:settimeout(0.001, 'b') -                return req_sock -            end -        } -        if (resp_json ~= nil) then -            resp_json = table.concat(resp_json) +local weather_timer = gears.timer({ timeout = 60 }) +local resp + +weather_timer:connect_signal("timeout", function () +    local resp_json = {} +    local res, status = http.request{ +        url=weather_api_url, +        sink=ltn12.sink.table(resp_json), +        -- ref: +        -- http://w3.impa.br/~diego/software/luasocket/old/luasocket-2.0/http.html +        create=function() +            -- ref: https://stackoverflow.com/a/6021774/595220 +            local req_sock = socket.tcp() +            -- 't' — overall timeout +            req_sock:settimeout(0.2, 't') +            -- 'b' — block timeout +            req_sock:settimeout(0.001, 'b') +            return req_sock          end +    } +    if (resp_json ~= nil) then +        resp_json = table.concat(resp_json) +    end -        if (status ~= 200 and resp_json ~= nil) then -            local err_resp = json.decode(resp_json) -            naughty.notify { -                title = 'Weather Widget Error', -                text = err_resp.message, -                preset = naughty.config.presets.critical, -            } -        elseif (resp_json ~= nil and resp_json ~= '') then -            resp = json.decode(resp_json) -            icon_widget.image = path_to_icons .. icon_map[resp.weather[1].icon] -            temp_widget:set_text(string.gsub(resp.main.temp, "%.%d+", "") -                    .. '°' -                    .. (units == 'metric' and 'C' or 'F')) -        end -    end) -    weather_timer:start() -    weather_timer:emit_signal("timeout") +    if (status ~= 200 and resp_json ~= nil and resp_json ~= '') then +        local err_resp = json.decode(resp_json) +        naughty.notify{ +            title = 'Weather Widget Error', +            text = err_resp.message, +            preset = naughty.config.presets.critical, +        } +    elseif (resp_json ~= nil and resp_json ~= '') then +        resp = json.decode(resp_json) +        icon_widget.image = path_to_icons .. icon_map[resp.weather[1].icon] +        temp_widget:set_text(string.gsub(resp.main.temp, "%.%d+", "") +                .. '°' +                .. (secrets.weather_widget_units == 'metric' and 'C' or 'F')) +    end +end) +weather_timer:start() +weather_timer:emit_signal("timeout")      --- Notification with weather information. Popups when mouse hovers over the icon      local notification  | 
