]> Repositories - hackapet/Adafruit_Blinka.git/commitdiff
Fix threading issue that stopped Blinka from working on MicroPython
authorMelissa LeBlanc-Williams <melissa@adafruit.com>
Tue, 14 Jul 2020 20:52:50 +0000 (13:52 -0700)
committerMelissa LeBlanc-Williams <melissa@adafruit.com>
Tue, 14 Jul 2020 20:52:50 +0000 (13:52 -0700)
src/busio.py

index 5456f65becb42e3964e43ae15a4c504662827065..279bd46f80ba4910aff9e1518d54c70c482f5cc7 100755 (executable)
@@ -7,7 +7,10 @@ See `CircuitPython:busio` in CircuitPython for more details.
 * Author(s): cefn
 """
 
 * Author(s): cefn
 """
 
-import threading
+try:
+    import threading
+except ImportError:
+    threading = None
 
 import adafruit_platformdetect.constants.boards as ap_board
 import adafruit_platformdetect.constants.chips as ap_chip
 
 import adafruit_platformdetect.constants.boards as ap_board
 import adafruit_platformdetect.constants.chips as ap_chip
@@ -69,8 +72,8 @@ class I2C(Lockable):
                     (scl, sda), i2cPorts
                 )
             )
                     (scl, sda), i2cPorts
                 )
             )
-
-        self._lock = threading.RLock()
+        if threading is not None:
+            self._lock = threading.RLock()
 
     def deinit(self):
         """Deinitialization"""
 
     def deinit(self):
         """Deinitialization"""
@@ -80,11 +83,13 @@ class I2C(Lockable):
             pass
 
     def __enter__(self):
             pass
 
     def __enter__(self):
-        self._lock.acquire()
+        if threading is not None:
+            self._lock.acquire()
         return self
 
     def __exit__(self, exc_type, exc_value, traceback):
         return self
 
     def __exit__(self, exc_type, exc_value, traceback):
-        self._lock.release()
+        if threading is not None:
+            self._lock.release()
         self.deinit()
 
     def scan(self):
         self.deinit()
 
     def scan(self):