receive pocsag messages in pickled form

This commit is contained in:
Jakob Ketterl 2021-09-10 15:38:36 +02:00
parent bf37dee78b
commit 72f925e537

View File

@ -1,38 +1,15 @@
from csdr.module import ThreadModule from csdr.module import PickleModule
from pycsdr.types import Format
import pickle
import logging import logging
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
class PocsagParser(ThreadModule): class PocsagParser(PickleModule):
def getInputFormat(self) -> Format: def process(self, meta):
return Format.CHAR
def getOutputFormat(self) -> Format:
return Format.CHAR
def run(self):
while self.doRun:
data = self.reader.read()
if data is None:
self.doRun = False
else:
for frame in self.parse(data.tobytes()):
self.writer.write(pickle.dumps(frame))
def parse(self, raw):
for line in raw.split(b"\n"):
if not len(line):
continue
try: try:
fields = line.decode("ascii", "replace").split(";")
meta = {v[0]: "".join(v[1:]) for v in map(lambda x: x.split(":"), fields) if v[0] != ""}
if "address" in meta: if "address" in meta:
meta["address"] = int(meta["address"]) meta["address"] = int(meta["address"])
meta["mode"] = "Pocsag" meta["mode"] = "Pocsag"
yield meta return meta
except Exception: except Exception:
logger.exception("Exception while parsing Pocsag message") logger.exception("Exception while parsing Pocsag message")