aboutsummaryrefslogtreecommitdiff
path: root/lib/python/Components/Converter
diff options
context:
space:
mode:
authorFelix Domke <tmbinc@elitedvb.net>2006-06-26 18:33:13 +0000
committerFelix Domke <tmbinc@elitedvb.net>2006-06-26 18:33:13 +0000
commit4b8c8a054ffa5cf8bf15ad1a6cafaa07c14432e2 (patch)
tree3a43024e5c2048f3f048480685951ccd40edccdb /lib/python/Components/Converter
parent60c8087aa78a5fa24617b0f2ef86fa54f6083101 (diff)
downloadenigma2-4b8c8a054ffa5cf8bf15ad1a6cafaa07c14432e2.tar.gz
enigma2-4b8c8a054ffa5cf8bf15ad1a6cafaa07c14432e2.zip
add FrontendStatus source, add converter to SNR/AGC/BER bar and text
Diffstat (limited to 'lib/python/Components/Converter')
-rw-r--r--lib/python/Components/Converter/FrontendInfo.py59
-rw-r--r--lib/python/Components/Converter/Makefile.am4
2 files changed, 60 insertions, 3 deletions
diff --git a/lib/python/Components/Converter/FrontendInfo.py b/lib/python/Components/Converter/FrontendInfo.py
new file mode 100644
index 00000000..a1064b97
--- /dev/null
+++ b/lib/python/Components/Converter/FrontendInfo.py
@@ -0,0 +1,59 @@
+from Components.Converter.Converter import Converter
+
+class FrontendInfo(Converter, object):
+ BER = 0
+ SNR = 1
+ AGC = 2
+ LOCK = 3
+
+ def __init__(self, type, *args, **kwargs):
+ Converter.__init__(self)
+ if type == "BER":
+ self.type = self.BER
+ elif type == "SNR":
+ self.type = self.SNR
+ elif type == "AGC":
+ self.type = self.AGC
+ else:
+ self.type = self.LOCK
+
+ def getText(self):
+ assert self.type != self.LOCK, "the text output of FrontendInfo cannot be used for lock info"
+ if self.type == self.BER: # as count
+ count = self.source.ber
+ if count is not None:
+ return str(count)
+ else:
+ return "N/A"
+ elif self.type == self.AGC:
+ percent = self.source.agc
+ elif self.type == self.SNR:
+ percent = self.source.snr
+
+ if percent is None:
+ return "N/A"
+
+ return "%d %%" % (percent * 100 / 65536)
+
+ def getBool(self):
+ assert self.type == LOCK, "the boolean output of FrontendInfo can only be used for lock info"
+ return self.source.lock
+
+ text = property(getText)
+
+ bool = property(getBool)
+
+ def getValue(self):
+ assert self.type != self.LOCK, "the value/range output of FrontendInfo can not be used for lock info"
+ if self.type == self.AGC:
+ return self.source.agc or 0
+ elif self.type == self.SNR:
+ return self.source.snr or 0
+ elif self.type == self.BER:
+ if self.BER < self.range:
+ return self.BER or 0
+ else:
+ return self.range
+
+ range = 65536
+ value = property(getValue)
diff --git a/lib/python/Components/Converter/Makefile.am b/lib/python/Components/Converter/Makefile.am
index d449bccb..59cb068f 100644
--- a/lib/python/Components/Converter/Makefile.am
+++ b/lib/python/Components/Converter/Makefile.am
@@ -2,6 +2,4 @@ installdir = $(LIBDIR)/enigma2/python/Components/Converter
install_PYTHON = \
__init__.py ClockToText.py Converter.py EventName.py StaticText.py EventTime.py \
- Poll.py RemainingToText.py StringList.py ServiceName.py
-
-
+ Poll.py RemainingToText.py StringList.py ServiceName.py FrontendInfo.py