X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/a575c4ba6016c3fdedfe0e33e08ba297c7fe754d..a9ee7f0410d4b718a4f3c4f82ec7bdae98a176d6:/src/digitalio.py?ds=inline diff --git a/src/digitalio.py b/src/digitalio.py old mode 100644 new mode 100755 index 635db1e..ab9b761 --- a/src/digitalio.py +++ b/src/digitalio.py @@ -1,28 +1,53 @@ -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_id, detector + +# pylint: disable=ungrouped-imports,wrong-import-position + +if detector.chip.BCM2XXX: + from adafruit_blinka.microcontroller.bcm283x.pin import Pin +elif detector.chip.AM33XX: + from adafruit_blinka.microcontroller.am335x.pin import Pin +elif detector.chip.SUN8I: + from adafruit_blinka.microcontroller.allwinner_h3.pin import Pin +elif detector.chip.STM32: + 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 +115,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, board_id)) elif pul is None: self._pin.init(mode=Pin.IN, pull=None) else: @@ -112,5 +138,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']