X-Git-Url: https://sigrok.org/gitweb/?a=blobdiff_plain;f=decoders%2Fcommon%2Fsrdhelper%2Fmod.py;h=6c45af98b7ae9232b8d115caafa6478801436d20;hb=db18ba49bcbe38a9a67297207d821bf0e1e9dc4c;hp=4871205f08261aad2786a175ee2fe48687f5941a;hpb=4539e9ca58966ce3c9cad4801b16c315e86ace01;p=libsigrokdecode.git diff --git a/decoders/common/srdhelper/mod.py b/decoders/common/srdhelper/mod.py index 4871205..6c45af9 100644 --- a/decoders/common/srdhelper/mod.py +++ b/decoders/common/srdhelper/mod.py @@ -1,7 +1,7 @@ ## ## This file is part of the libsigrokdecode project. ## -## Copyright (C) 2012-2014 Uwe Hermann +## Copyright (C) 2012-2020 Uwe Hermann ## ## This program is free software; you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by @@ -17,6 +17,68 @@ ## along with this program; if not, see . ## +from enum import Enum, IntEnum, unique +from itertools import chain +import re + # Return the specified BCD number (max. 8 bits) as integer. def bcd2int(b): return (b & 0x0f) + ((b >> 4) * 10) + +def bin2int(s: str): + return int('0b' + s, 2) + +def bitpack(bits): + return sum([b << i for i, b in enumerate(bits)]) + +def bitunpack(num, minbits=0): + res = [] + while num or minbits > 0: + res.append(num & 1) + num >>= 1 + minbits -= 1 + return tuple(res) + +@unique +class SrdStrEnum(Enum): + @classmethod + def from_list(cls, name, l): + # Keys are limited/converted to [A-Z0-9_], values can be any string. + items = [(re.sub('[^A-Z0-9_]', '_', l[i]), l[i]) for i in range(len(l))] + return cls(name, items) + + @classmethod + def from_str(cls, name, s): + return cls.from_list(name, s.split()) + +@unique +class SrdIntEnum(IntEnum): + @classmethod + def _prefix(cls, p): + return tuple([a.value for a in cls if a.name.startswith(p)]) + + @classmethod + def prefixes(cls, prefix_list): + if isinstance(prefix_list, str): + prefix_list = prefix_list.split() + return tuple(chain(*[cls._prefix(p) for p in prefix_list])) + + @classmethod + def _suffix(cls, s): + return tuple([a.value for a in cls if a.name.endswith(s)]) + + @classmethod + def suffixes(cls, suffix_list): + if isinstance(suffix_list, str): + suffix_list = suffix_list.split() + return tuple(chain(*[cls._suffix(s) for s in suffix_list])) + + @classmethod + def from_list(cls, name, l): + # Manually construct (Python 3.4 is missing the 'start' argument). + # Python defaults to start=1, but we want start=0. + return cls(name, [(l[i], i) for i in range(len(l))]) + + @classmethod + def from_str(cls, name, s): + return cls.from_list(name, s.split())