bumblebee-status/bumblebee/modules/memory.py
Tobias Witek 4e648cf009 [modules] Add module-specific configuration
Big oversight in my previous commits: Widgets need to be able to have
specific configurations (i.e. the path for different instances of the
"disk" module has to be different).

To account for that, it is now possible to assign an "alias" to a module
instance using ":" (for example: -m "disk:home"). This alias is then
used for the configuration parameter resolution automatically, for
example:

-m disk:home -p home.path=/home

As a consequence, parameter names in the module code are now relative to
the module, which means: shorter!
2016-11-05 14:26:02 +01:00

40 lines
1.2 KiB
Python

import psutil
import bumblebee.module
import bumblebee.util
def usage():
return "memory"
def notes():
return "Warning is at 20% available RAM, Critical at 10%."
def description():
return "Shows available RAM, total amount of RAM and the percentage of available RAM."
class Module(bumblebee.module.Module):
def __init__(self, output, config, alias):
super(Module, self).__init__(output, config, alias)
self._mem = psutil.virtual_memory()
# TODO
# output.add_callback(module=self.__module__, button=1,
# cmd="gnome-system-monitor")
def widgets(self):
self._mem = psutil.virtual_memory()
used = self._mem.total - self._mem.available
return bumblebee.output.Widget(self, "{}/{} ({:05.02f}%)".format(
bumblebee.util.bytefmt(used),
bumblebee.util.bytefmt(self._mem.total),
self._mem.percent)
)
def warning(self, widget):
return self._mem.percent < self._config.parameter("warning", 20)
def critical(self, widget):
return self._mem.percent < self._config.parameter("critical", 10)
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4