bumblebee-status/bumblebee/modules/sensors.py

59 lines
1.9 KiB
Python
Raw Normal View History

# -*- coding: UTF-8 -*-
# pylint: disable=C0111,R0903
2017-04-19 11:36:35 +00:00
"""Displays sensor temperature
Requires the following executable:
* sensors
Parameters:
* sensors.match: Line to match against output of 'sensors -u' (default: temp1_input)
2017-04-19 11:36:35 +00:00
* sensors.match_number: which of the matches you want (default -1: last match).
"""
import re
import bumblebee.input
import bumblebee.output
import bumblebee.engine
class Module(bumblebee.engine.Module):
def __init__(self, engine, config):
super(Module, self).__init__(engine, config,
bumblebee.output.Widget(full_text=self.temperature))
self._temperature = "unknown"
self._mhz = "n/a"
2017-04-19 11:36:35 +00:00
pattern = self.parameter("match", "temp1_input")
pattern_string = r"^\s*{}:\s*([\d.]+)$".format(pattern)
2017-04-19 11:36:35 +00:00
self._match_number = int(self.parameter("match_number", "-1"))
self._pattern = re.compile(pattern_string, re.MULTILINE)
engine.input.register_callback(self, button=bumblebee.input.LEFT_MOUSE, cmd="xsensors")
def get_temp(self):
temperatures = bumblebee.util.execute("sensors -u")
matching_temp = self._pattern.findall(temperatures)
temperature = "unknown"
2017-04-19 11:36:35 +00:00
if matching_temp:
2017-04-20 22:18:11 +00:00
temperature = int(float(matching_temp[self._match_number]))
2017-04-19 11:36:35 +00:00
return temperature
def get_mhz( self ):
output = open("/proc/cpuinfo").read()
m = re.search(r"cpu MHz\s+:\s+(\d+)", output)
mhz = int(m.group(1))
if mhz < 1000:
return "{} MHz".format(mhz)
else:
return "{:0.01f} GHz".format(float(mhz)/1000.0)
def temperature(self, _):
return u"{}°c @ {}".format(self._temperature, self._mhz)
2017-04-19 11:36:35 +00:00
def update(self, widgets):
self._temperature = self.get_temp()
self._mhz = self.get_mhz()
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4