]> git.madduck.net Git - etc/awesome.git/commitdiff

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

modified: widgets/weather.lua - seems fixed datetime calculation
authorAleksandr Beliaev <trap000d@gmail.com>
Tue, 31 May 2016 02:05:44 +0000 (14:05 +1200)
committerAleksandr Beliaev <trap000d@gmail.com>
Tue, 31 May 2016 02:05:44 +0000 (14:05 +1200)
widgets/weather.lua

index 3512f229ad7cb89b0d57bb725c85c510b24ff8c2..84c1564ee49c585c1d3f05d1a52ca62837737c0c 100644 (file)
@@ -39,6 +39,7 @@ local function worker(args)
     local forecast_call         = args.forecast_call or "curl -s 'http://api.openweathermap.org/data/2.5/forecast/daily?id=%s&units=%s&lang=%s&cnt=%s&APPID=%s'"
     local city_id               = args.city_id or 0 -- placeholder
     local utc                   = args.utc or 0
     local forecast_call         = args.forecast_call or "curl -s 'http://api.openweathermap.org/data/2.5/forecast/daily?id=%s&units=%s&lang=%s&cnt=%s&APPID=%s'"
     local city_id               = args.city_id or 0 -- placeholder
     local utc                   = args.utc or 0
+
     local units                 = args.units or "metric"
     local lang                  = args.lang or "en"
     local cnt                   = args.cnt or 5
     local units                 = args.units or "metric"
     local lang                  = args.lang or "en"
     local cnt                   = args.cnt or 5
@@ -120,19 +121,31 @@ local function worker(args)
 
     function weather.update()
         local cmd = string.format(current_call, city_id, units, lang, APPID)
 
     function weather.update()
         local cmd = string.format(current_call, city_id, units, lang, APPID)
+        local utc_midnight_cmd   = ("date -u -d 'today 00:00:00' +'%%s'")
+
         async.request(cmd, function(f)
             local pos, err, icon
             weather_now, pos, err = json.decode(f, 1, nil)
 
             if not err and weather_now and tonumber(weather_now["cod"]) == 200 then
                 -- weather icon based on localtime
         async.request(cmd, function(f)
             local pos, err, icon
             weather_now, pos, err = json.decode(f, 1, nil)
 
             if not err and weather_now and tonumber(weather_now["cod"]) == 200 then
                 -- weather icon based on localtime
+
                 now     = os.time()
                 now     = os.time()
+                utc_midnight   = string.gsub(read_pipe(string.format(utc_midnight_cmd)), "\n", "")
+
+                if utc > 0 then
+                    if (now  - (utc * 3600)) >= tonumber(utc_midnight) then 
+                       now = now - 86400
+                    end
+                else
+                    if (now  - (utc * 3600)) <= tonumber(utc_midnight) then 
+                       now = now + 86400
+                    end
+                end
                 sunrise = tonumber(weather_now["sys"]["sunrise"])
                 sunset  = tonumber(weather_now["sys"]["sunset"])
                 icon    = weather_now["weather"][1]["icon"]
 
                 sunrise = tonumber(weather_now["sys"]["sunrise"])
                 sunset  = tonumber(weather_now["sys"]["sunset"])
                 icon    = weather_now["weather"][1]["icon"]
 
-                if sunrise <= (now-86400) then now = now - 86400 end
-
                 if sunrise <= now and now <= sunset then
                     icon = string.gsub(icon, "n", "d")
                 else
                 if sunrise <= now and now <= sunset then
                     icon = string.gsub(icon, "n", "d")
                 else