X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/7a4d6f5ffa594603ef83bc8b0e9945d12e082490..912bd26ede8901c98fd8d7a35f8493ee448109ad:/widgets/sysload.lua diff --git a/widgets/sysload.lua b/widgets/sysload.lua index 8583ccb..9472235 100644 --- a/widgets/sysload.lua +++ b/widgets/sysload.lua @@ -7,16 +7,11 @@ --]] -local markup = require("lain.util.markup") local helpers = require("lain.helpers") - -local awful = require("awful") -local beautiful = require("beautiful") local wibox = require("wibox") -local io = io -local string = { format = string.format, - match = string.match } +local io = { open = io.open } +local string = { match = string.match } local setmetatable = setmetatable @@ -24,47 +19,39 @@ local setmetatable = setmetatable -- lain.widgets.sysload local sysload = {} -function worker(args) +local function worker(args) local args = args or {} - local refresh_timeout = args.refresh_timeout or 5 - local show_all = args.show_all or false - local header = args.header or " Load " - local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF" - local color = args.color or beautiful.fg_focus or header_color - local app = args.app or "top" + local timeout = args.timeout or 1 + local settings = args.settings or function() end - local mysysload = wibox.widget.textbox() + sysload.widget = wibox.widget.textbox('') + helpers.set_map("load_1", 0) + helpers.set_map("load_5", 0) + helpers.set_map("load_15", 0) - local mysysloadupdate = function() + function update() local f = io.open("/proc/loadavg") local ret = f:read("*all") f:close() - if show_all + load_1, load_5, load_15 = string.match(ret, "([^%s]+) ([^%s]+) ([^%s]+)") + + if load_1 ~= helpers.get_map("load_1") + or load_5 ~= helpers.get_map("load_5") + or load_15 ~= helpers.get_map("load_15") then - local a, b, c = string.match(ret, "([^%s]+) ([^%s]+) ([^%s]+)") - mysysload:set_text(string.format("%s %s %s", a, b, c)) - else - local a = string.match(ret, "([^%s]+) ") - mysysload:set_text(string.format("%s", a)) + widget = sysload.widget + settings() + + helpers.set_map("load_1", load_1) + helpers.set_map("load_5", load_5) + helpers.set_map("load_15", load_15) end - mysysload:set_markup(markup(header_color, header) .. - markup(color, mysysload._layout.text .. " ")) end - local mysysloadtimer = timer({ timeout = refresh_timeout }) - mysysloadtimer:connect_signal("timeout", mysysloadupdate) - mysysloadtimer:start() - mysysloadtimer:emit_signal("timeout") - - mysysload:buttons(awful.util.table.join( - awful.button({}, 0, - function() - helpers.run_in_terminal(app) - end) - )) + helpers.newtimer("sysload", timeout, update) - return mysysload + return sysload.widget end return setmetatable(sysload, { __call = function(_, ...) return worker(...) end })