X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/a575c4ba6016c3fdedfe0e33e08ba297c7fe754d..a174e09a069059645ef800bbe7d18256420a2e13:/src/digitalio.py diff --git a/src/digitalio.py b/src/digitalio.py old mode 100644 new mode 100755 index 635db1e..84aeebd --- a/src/digitalio.py +++ b/src/digitalio.py @@ -1,28 +1,46 @@ -from machine import Pin -from adafruit_blinka.agnostic import board as boardId -from adafruit_blinka import Enum,ContextManaged +""" +`digitalio` - Digital input and output control +================================================= + +See `CircuitPython:digitalio` in CircuitPython for more details. + +* Author(s): cefn +""" +from adafruit_blinka.agnostic import board as boardId +if boardId == "raspi_3" or boardId == "raspi_2": + from adafruit_blinka.microcontroller.raspi_23.pin import Pin +else: + from machine import Pin +from adafruit_blinka import Enum, ContextManaged class DriveMode(Enum): - PUSH_PULL=None - OPEN_DRAIN=None + PUSH_PULL = None + OPEN_DRAIN = None + + DriveMode.PUSH_PULL = DriveMode() DriveMode.OPEN_DRAIN = DriveMode() class Direction(Enum): - INPUT=None - OUTPUT=None + INPUT = None + OUTPUT = None + + Direction.INPUT = Direction() Direction.OUTPUT = Direction() class Pull(Enum): - UP=None - DOWN=None + UP = None + DOWN = None #NONE=None + + Pull.UP = Pull() Pull.DOWN = Pull() + #Pull.NONE = Pull() @@ -90,7 +108,8 @@ class DigitalInOut(ContextManaged): if hasattr(Pin, "PULL_DOWN"): self._pin.init(mode=Pin.IN, pull=Pin.PULL_DOWN) else: - raise NotImplementedError("{} unsupported on {}".format(Pull.DOWN, boardId)) + raise NotImplementedError("{} unsupported on {}".format( + Pull.DOWN, boardId)) elif pul is None: self._pin.init(mode=Pin.IN, pull=None) else: @@ -112,5 +131,3 @@ class DigitalInOut(ContextManaged): self._pin.init(mode=Pin.OPEN_DRAIN) elif mod is DriveMode.PUSH_PULL: self._pin.init(mode=Pin.OUT) - -# __all__ = ['DigitalInOut', 'DriveMode', 'Direction','Pull']