Attempt to fix memory leak
This commit is contained in:
parent
3c19b57643
commit
06d6055374
|
@ -1,61 +1,28 @@
|
||||||
local wibox = require("wibox")
|
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
local watch = require("awful.widget.watch")
|
local watch = require("awful.widget.watch")
|
||||||
|
local wibox = require("wibox")
|
||||||
|
|
||||||
-- acpi sample outputs
|
-- acpi sample outputs
|
||||||
-- Battery 0: Discharging, 75%, 01:51:38 remaining
|
-- Battery 0: Discharging, 75%, 01:51:38 remaining
|
||||||
-- Battery 0: Charging, 53%, 00:57:43 until charged
|
-- Battery 0: Charging, 53%, 00:57:43 until charged
|
||||||
|
|
||||||
local PATH_TO_ICONS = "/usr/share/icons/Arc/status/symbolic/"
|
local PATH_TO_ICONS = "/usr/share/icons/Arc/status/symbolic/"
|
||||||
local USERNAME = os.getenv("USER")
|
local HOME = os.getenv("HOME")
|
||||||
|
|
||||||
battery_widget = wibox.widget {
|
local battery_widget = wibox.widget {
|
||||||
{
|
{
|
||||||
id = "icon",
|
id = "icon",
|
||||||
widget = wibox.widget.imagebox,
|
widget = wibox.widget.imagebox,
|
||||||
resize = false
|
resize = false
|
||||||
},
|
},
|
||||||
layout = wibox.container.margin(_, 0, 0, 3),
|
layout = wibox.container.margin(_, 0, 0, 3)
|
||||||
set_image = function(self, path)
|
|
||||||
self.icon.image = path
|
|
||||||
end
|
|
||||||
}
|
}
|
||||||
|
|
||||||
watch(
|
|
||||||
"acpi", 10,
|
|
||||||
function(widget, stdout, stderr, exitreason, exitcode)
|
|
||||||
local batteryType
|
|
||||||
local _, status, charge_str, time = string.match(stdout, '(.+): (%a+), (%d?%d%d)%%,? ?.*')
|
|
||||||
local charge = tonumber(charge_str)
|
|
||||||
if (charge >= 0 and charge < 15) then
|
|
||||||
batteryType="battery-empty%s-symbolic"
|
|
||||||
if status ~= 'Charging' then
|
|
||||||
show_battery_warning()
|
|
||||||
end
|
|
||||||
elseif (charge >= 15 and charge < 40) then batteryType="battery-caution%s-symbolic"
|
|
||||||
elseif (charge >= 40 and charge < 60) then batteryType="battery-low%s-symbolic"
|
|
||||||
elseif (charge >= 60 and charge < 80) then batteryType="battery-good%s-symbolic"
|
|
||||||
elseif (charge >= 80 and charge <= 100) then batteryType="battery-full%s-symbolic"
|
|
||||||
end
|
|
||||||
if status == 'Charging' then
|
|
||||||
batteryType = string.format(batteryType,'-charging')
|
|
||||||
else
|
|
||||||
batteryType = string.format(batteryType,'')
|
|
||||||
end
|
|
||||||
widget.image = PATH_TO_ICONS .. batteryType .. ".svg"
|
|
||||||
|
|
||||||
-- Update popup text
|
|
||||||
-- TODO: Filter long lines
|
|
||||||
-- battery_popup.text = string.gsub(stdout, "\n$", "")
|
|
||||||
end,
|
|
||||||
battery_widget
|
|
||||||
)
|
|
||||||
|
|
||||||
-- Popup with battery info
|
-- Popup with battery info
|
||||||
-- One way of creating a pop-up notification - naughty.notify
|
-- One way of creating a pop-up notification - naughty.notify
|
||||||
local notification
|
local notification
|
||||||
function show_battery_status()
|
local function show_battery_status()
|
||||||
awful.spawn.easy_async([[bash -c 'acpi']],
|
awful.spawn.easy_async([[bash -c 'acpi']],
|
||||||
function(stdout, _, _, _)
|
function(stdout, _, _, _)
|
||||||
notification = naughty.notify{
|
notification = naughty.notify{
|
||||||
|
@ -67,11 +34,8 @@ function show_battery_status()
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
battery_widget:connect_signal("mouse::enter", function() show_battery_status() end)
|
|
||||||
battery_widget:connect_signal("mouse::leave", function() naughty.destroy(notification) end)
|
|
||||||
|
|
||||||
-- Alternative to naughty.notify - tooltip. You can compare both and choose the preferred one
|
-- Alternative to naughty.notify - tooltip. You can compare both and choose the preferred one
|
||||||
|
|
||||||
--battery_popup = awful.tooltip({objects = {battery_widget}})
|
--battery_popup = awful.tooltip({objects = {battery_widget}})
|
||||||
|
|
||||||
-- To use colors from beautiful theme put
|
-- To use colors from beautiful theme put
|
||||||
|
@ -79,10 +43,9 @@ battery_widget:connect_signal("mouse::leave", function() naughty.destroy(notific
|
||||||
-- beautiful.tooltip_fg = beautiful.fg_normal
|
-- beautiful.tooltip_fg = beautiful.fg_normal
|
||||||
-- beautiful.tooltip_bg = beautiful.bg_normal
|
-- beautiful.tooltip_bg = beautiful.bg_normal
|
||||||
|
|
||||||
--[[ Show warning notification ]]
|
local function show_battery_warning()
|
||||||
function show_battery_warning()
|
|
||||||
naughty.notify{
|
naughty.notify{
|
||||||
icon = "/home/" .. USERNAME .. "/.config/awesome/nichosi.png",
|
icon = HOME .. "/.config/awesome/nichosi.png",
|
||||||
icon_size=100,
|
icon_size=100,
|
||||||
text = "Huston, we have a problem",
|
text = "Huston, we have a problem",
|
||||||
title = "Battery is dying",
|
title = "Battery is dying",
|
||||||
|
@ -93,3 +56,35 @@ function show_battery_warning()
|
||||||
width = 300,
|
width = 300,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
watch("acpi", 10,
|
||||||
|
function(widget, stdout, stderr, exitreason, exitcode)
|
||||||
|
local batteryType
|
||||||
|
local _, status, charge_str, time = string.match(stdout, '(.+): (%a+), (%d?%d%d)%%,? ?.*')
|
||||||
|
local charge = tonumber(charge_str)
|
||||||
|
if (charge >= 0 and charge < 15) then
|
||||||
|
batteryType = "battery-empty%s-symbolic"
|
||||||
|
if status ~= 'Charging' then
|
||||||
|
show_battery_warning()
|
||||||
|
end
|
||||||
|
elseif (charge >= 15 and charge < 40) then batteryType = "battery-caution%s-symbolic"
|
||||||
|
elseif (charge >= 40 and charge < 60) then batteryType = "battery-low%s-symbolic"
|
||||||
|
elseif (charge >= 60 and charge < 80) then batteryType = "battery-good%s-symbolic"
|
||||||
|
elseif (charge >= 80 and charge <= 100) then batteryType = "battery-full%s-symbolic"
|
||||||
|
end
|
||||||
|
if status == 'Charging' then
|
||||||
|
batteryType = string.format(batteryType, '-charging')
|
||||||
|
else
|
||||||
|
batteryType = string.format(batteryType, '')
|
||||||
|
end
|
||||||
|
widget.icon:set_image(PATH_TO_ICONS .. batteryType .. ".svg")
|
||||||
|
|
||||||
|
-- Update popup text
|
||||||
|
-- battery_popup.text = string.gsub(stdout, "\n$", "")
|
||||||
|
end,
|
||||||
|
battery_widget)
|
||||||
|
|
||||||
|
battery_widget:connect_signal("mouse::enter", function() show_battery_status() end)
|
||||||
|
battery_widget:connect_signal("mouse::leave", function() naughty.destroy(notification) end)
|
||||||
|
|
||||||
|
return battery_widget
|
||||||
|
|
Loading…
Reference in New Issue