X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka.git/blobdiff_plain/e1a58c650c176dc39b6de7948c6f52f996aee8cc..d63da131bcae0003e62be02edff7c1f22d4dda19:/src/adafruit_blinka/microcontroller/generic_linux/libgpiod_pin.py diff --git a/src/adafruit_blinka/microcontroller/generic_linux/libgpiod_pin.py b/src/adafruit_blinka/microcontroller/generic_linux/libgpiod_pin.py index 0d02308..db9007a 100644 --- a/src/adafruit_blinka/microcontroller/generic_linux/libgpiod_pin.py +++ b/src/adafruit_blinka/microcontroller/generic_linux/libgpiod_pin.py @@ -1,10 +1,16 @@ +"""A Pin class for use with libgpiod.""" try: import gpiod except ImportError: - raise ImportError("libgpiod Python bindings not found, please install and try again! See https://github.com/adafruit/Raspberry-Pi-Installer-Scripts/blob/master/libgpiod.sh") + raise ImportError( + "libgpiod Python bindings not found, please install and try again! See " + "https://github.com/adafruit/Raspberry-Pi-Installer-Scripts/blob/master/libgpiod.sh" + ) from ImportError + -# Pins dont exist in CPython so...lets make our own! class Pin: + """Pins dont exist in CPython so...lets make our own!""" + IN = 0 OUT = 1 LOW = 0 @@ -12,7 +18,7 @@ class Pin: PULL_NONE = 0 PULL_UP = 1 PULL_DOWN = 2 - _CONSUMER = 'adafruit_blinka' + _CONSUMER = "adafruit_blinka" id = None _value = LOW @@ -20,7 +26,7 @@ class Pin: def __init__(self, pin_id): self.id = pin_id - if type(pin_id) is tuple: + if isinstance(pin_id, tuple): self._num = int(pin_id[1]) self._chip = gpiod.Chip(str(pin_id[0]), gpiod.Chip.OPEN_BY_NUMBER) else: @@ -35,44 +41,50 @@ class Pin: return self.id == other def init(self, mode=IN, pull=None): + """Initialize the Pin""" if not self._line: self._line = self._chip.get_line(int(self._num)) - #print("init line: ", self.id, self._line) + # print("init line: ", self.id, self._line) - if mode != None: + if mode is not None: if mode == self.IN: flags = 0 - if pull != None: + if pull is not None: if pull == self.PULL_UP: - raise NotImplementedError("Internal pullups not supported in libgpiod, use physical resistor instead!") - elif pull == self.PULL_DOWN: - raise NotImplementedError("Internal pulldowns not supported in libgpiod, use physical resistor instead!") - else: - raise RuntimeError("Invalid pull for pin: %s" % self.id) + raise NotImplementedError( + "Internal pullups not supported in libgpiod, " + "use physical resistor instead!" + ) + if pull == self.PULL_DOWN: + raise NotImplementedError( + "Internal pulldowns not supported in libgpiod, " + "use physical resistor instead!" + ) + raise RuntimeError("Invalid pull for pin: %s" % self.id) self._mode = self.IN self._line.release() - self._line.request(consumer=self._CONSUMER, - type=gpiod.LINE_REQ_DIR_IN, - flags=flags) + self._line.request( + consumer=self._CONSUMER, type=gpiod.LINE_REQ_DIR_IN, flags=flags + ) elif mode == self.OUT: - if pull != None: + if pull is not None: raise RuntimeError("Cannot set pull resistor on output") self._mode = self.OUT self._line.release() - self._line.request(consumer=self._CONSUMER, - type=gpiod.LINE_REQ_DIR_OUT) + self._line.request(consumer=self._CONSUMER, type=gpiod.LINE_REQ_DIR_OUT) else: raise RuntimeError("Invalid mode for pin: %s" % self.id) def value(self, val=None): - if val != None: - if val in (self.LOW, self.HIGH): - self._value = val - self._line.set_value(val) - else: - raise RuntimeError("Invalid value for pin") - else: + """Set or return the Pin Value""" + if val is None: return self._line.get_value() + + if val in (self.LOW, self.HIGH): + self._value = val + self._line.set_value(val) + return None + raise RuntimeError("Invalid value for pin")