From 4335ea2da8859b340757798f1909ade1616fda34 Mon Sep 17 00:00:00 2001 From: Shawn Bruce Date: Tue, 20 Apr 2021 09:18:50 -0400 Subject: [PATCH] Fix GPIO settings migration for BCM users. #200 --- octoprint_psucontrol/__init__.py | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/octoprint_psucontrol/__init__.py b/octoprint_psucontrol/__init__.py index ef8a03f..0b4159d 100644 --- a/octoprint_psucontrol/__init__.py +++ b/octoprint_psucontrol/__init__.py @@ -680,17 +680,10 @@ def on_settings_migrate(self, target, current=None): cur_invertsenseGPIOPin = self._settings.get_boolean(["invertsenseGPIOPin"]) cur_senseGPIOPinPUD = self._settings.get(["senseGPIOPinPUD"]) - if (cur_switchingMethod == 'GPIO' or cur_sensingMethod == 'GPIO') and cur_GPIOMode == 'BOARD': - # Convert BOARD pin numbers to BCM + if cur_switchingMethod == 'GPIO' or cur_sensingMethod == 'GPIO': + if cur_GPIOMode == 'BOARD': + # Convert BOARD pin numbers to BCM - try: - import RPi.GPIO as GPIO - _has_gpio = True - except (ImportError, RuntimeError) as e: - self._logger.error("Error importing RPi.GPIO. BOARD->BCM conversion will not occur. Error={}".format(e)) - _has_gpio = False - - if _has_gpio: def _gpio_board_to_bcm(pin): _pin_to_gpio_rev1 = [-1, -1, -1, 0, -1, 1, -1, 4, 14, -1, 15, 17, 18, 21, -1, 22, 23, -1, 24, 10, -1, 9, 25, 11, 8, -1, 7, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 ] _pin_to_gpio_rev2 = [-1, -1, -1, 2, -1, 3, -1, 4, 14, -1, 15, 17, 18, 27, -1, 22, 23, -1, 24, 10, -1, 9, 25, 11, 8, -1, 7, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 ] @@ -705,12 +698,19 @@ def _gpio_board_to_bcm(pin): return pin_to_gpio[pin] - if cur_switchingMethod == 'GPIO': + try: + import RPi.GPIO as GPIO + _has_gpio = True + except (ImportError, RuntimeError) as e: + self._logger.error("Error importing RPi.GPIO. BOARD->BCM conversion will not occur. Error={}".format(e)) + _has_gpio = False + + if cur_switchingMethod == 'GPIO' and _has_gpio: p = _gpio_board_to_bcm(cur_onoffGPIOPin) self._logger.info("Converting pin number from BOARD to BCM. onoffGPIOPin={} -> onoffGPIOPin={}".format(cur_onoffGPIOPin, p)) self._settings.set_int(["onoffGPIOPin"], p) - if cur_sensingMethod == 'GPIO': + if cur_sensingMethod == 'GPIO' and _has_gpio: p = _gpio_board_to_bcm(cur_senseGPIOPin) self._logger.info("Converting pin number from BOARD to BCM. senseGPIOPin={} -> senseGPIOPin={}".format(cur_senseGPIOPin, p)) self._settings.set_int(["senseGPIOPin"], p)