Merge branch '0_15' into blending-styles
This commit is contained in:
		| @@ -332,7 +332,7 @@ class Animated_Staircase : public Usermod { | ||||
|       }; | ||||
|       // NOTE: this *WILL* return TRUE if all the pins are set to -1. | ||||
|       //       this is *BY DESIGN*. | ||||
|       if (!pinManager.allocateMultiplePins(pins, 4, PinOwner::UM_AnimatedStaircase)) { | ||||
|       if (!PinManager::allocateMultiplePins(pins, 4, PinOwner::UM_AnimatedStaircase)) { | ||||
|         topPIRorTriggerPin = -1; | ||||
|         topEchoPin = -1; | ||||
|         bottomPIRorTriggerPin = -1; | ||||
| @@ -513,10 +513,10 @@ class Animated_Staircase : public Usermod { | ||||
|             (oldBottomAPin != bottomPIRorTriggerPin) || | ||||
|             (oldBottomBPin != bottomEchoPin)) { | ||||
|           changed = true; | ||||
|           pinManager.deallocatePin(oldTopAPin, PinOwner::UM_AnimatedStaircase); | ||||
|           pinManager.deallocatePin(oldTopBPin, PinOwner::UM_AnimatedStaircase); | ||||
|           pinManager.deallocatePin(oldBottomAPin, PinOwner::UM_AnimatedStaircase); | ||||
|           pinManager.deallocatePin(oldBottomBPin, PinOwner::UM_AnimatedStaircase); | ||||
|           PinManager::deallocatePin(oldTopAPin, PinOwner::UM_AnimatedStaircase); | ||||
|           PinManager::deallocatePin(oldTopBPin, PinOwner::UM_AnimatedStaircase); | ||||
|           PinManager::deallocatePin(oldBottomAPin, PinOwner::UM_AnimatedStaircase); | ||||
|           PinManager::deallocatePin(oldBottomBPin, PinOwner::UM_AnimatedStaircase); | ||||
|         } | ||||
|         if (changed) setup(); | ||||
|       } | ||||
|   | ||||
| @@ -18,7 +18,7 @@ Before compiling, you have to make the following modifications: | ||||
| Edit `usermods_list.cpp`: | ||||
| 1. Open `wled00/usermods_list.cpp` | ||||
| 2. add `#include "../usermods/Animated_Staircase/Animated_Staircase.h"` to the top of the file | ||||
| 3. add `usermods.add(new Animated_Staircase());` to the end of the `void registerUsermods()` function. | ||||
| 3. add `UsermodManager::add(new Animated_Staircase());` to the end of the `void registerUsermods()` function. | ||||
|  | ||||
| You can configure usermod using the Usermods settings page. | ||||
| Please enter GPIO pins for PIR or ultrasonic sensors (trigger and echo). | ||||
|   | ||||
| @@ -200,7 +200,7 @@ class UsermodBattery : public Usermod | ||||
|         bool success = false; | ||||
|         DEBUG_PRINTLN(F("Allocating battery pin...")); | ||||
|         if (batteryPin >= 0 && digitalPinToAnalogChannel(batteryPin) >= 0)  | ||||
|           if (pinManager.allocatePin(batteryPin, false, PinOwner::UM_Battery)) { | ||||
|           if (PinManager::allocatePin(batteryPin, false, PinOwner::UM_Battery)) { | ||||
|             DEBUG_PRINTLN(F("Battery pin allocation succeeded.")); | ||||
|             success = true; | ||||
|           } | ||||
| @@ -561,7 +561,7 @@ class UsermodBattery : public Usermod | ||||
|           if (newBatteryPin != batteryPin)  | ||||
|           { | ||||
|             // deallocate pin | ||||
|             pinManager.deallocatePin(batteryPin, PinOwner::UM_Battery); | ||||
|             PinManager::deallocatePin(batteryPin, PinOwner::UM_Battery); | ||||
|             batteryPin = newBatteryPin; | ||||
|             // initialise | ||||
|             setup(); | ||||
|   | ||||
| @@ -71,7 +71,7 @@ class MyExampleUsermod : public Usermod { | ||||
|     //   #endif | ||||
|     //  in setup() | ||||
|     //   #ifdef USERMOD_EXAMPLE | ||||
|     //   UM = (MyExampleUsermod*) usermods.lookup(USERMOD_ID_EXAMPLE); | ||||
|     //   UM = (MyExampleUsermod*) UsermodManager::lookup(USERMOD_ID_EXAMPLE); | ||||
|     //   #endif | ||||
|     //  somewhere in loop() or other member method | ||||
|     //   #ifdef USERMOD_EXAMPLE | ||||
|   | ||||
| @@ -59,10 +59,10 @@ void registerUsermods() | ||||
|    * || || || | ||||
|    * \/ \/ \/ | ||||
|    */ | ||||
|   //usermods.add(new MyExampleUsermod()); | ||||
|   //usermods.add(new UsermodTemperature()); | ||||
|   //usermods.add(new UsermodRenameMe()); | ||||
|   usermods.add(new FixUnreachableNetServices()); | ||||
|   //UsermodManager::add(new MyExampleUsermod()); | ||||
|   //UsermodManager::add(new UsermodTemperature()); | ||||
|   //UsermodManager::add(new UsermodRenameMe()); | ||||
|   UsermodManager::add(new FixUnreachableNetServices()); | ||||
|  | ||||
| } | ||||
| ``` | ||||
|   | ||||
| @@ -30,7 +30,7 @@ class LDR_Dusk_Dawn_v2 : public Usermod { | ||||
|     void setup() { | ||||
|       // register ldrPin | ||||
|       if ((ldrPin >= 0) && (digitalPinToAnalogChannel(ldrPin) >= 0)) { | ||||
|         if(!pinManager.allocatePin(ldrPin, false, PinOwner::UM_LDR_DUSK_DAWN)) ldrEnabled = false; // pin already in use -> disable usermod | ||||
|         if(!PinManager::allocatePin(ldrPin, false, PinOwner::UM_LDR_DUSK_DAWN)) ldrEnabled = false; // pin already in use -> disable usermod | ||||
|         else pinMode(ldrPin, INPUT);                                                               // alloc success -> configure pin for input | ||||
|       } else ldrEnabled = false;                                                                   // invalid pin -> disable usermod | ||||
|       initDone = true; | ||||
| @@ -110,7 +110,7 @@ class LDR_Dusk_Dawn_v2 : public Usermod { | ||||
|  | ||||
|       if (initDone && (ldrPin != oldLdrPin)) { | ||||
|          // pin changed - un-register previous pin, register new pin | ||||
|         if (oldLdrPin >= 0) pinManager.deallocatePin(oldLdrPin, PinOwner::UM_LDR_DUSK_DAWN); | ||||
|         if (oldLdrPin >= 0) PinManager::deallocatePin(oldLdrPin, PinOwner::UM_LDR_DUSK_DAWN); | ||||
|         setup();             // setup new pin | ||||
|       } | ||||
|       return configComplete; | ||||
| @@ -139,7 +139,7 @@ class LDR_Dusk_Dawn_v2 : public Usermod { | ||||
|       //LDR_Off_Count.add(ldrOffCount); | ||||
|  | ||||
|       //bool pinValid = ((ldrPin >= 0) && (digitalPinToAnalogChannel(ldrPin) >= 0)); | ||||
|       //if (pinManager.getPinOwner(ldrPin) != PinOwner::UM_LDR_DUSK_DAWN) pinValid = false; | ||||
|       //if (PinManager::getPinOwner(ldrPin) != PinOwner::UM_LDR_DUSK_DAWN) pinValid = false; | ||||
|       //JsonArray LDR_valid = user.createNestedArray(F("LDR pin")); | ||||
|       //LDR_valid.add(ldrPin); | ||||
|       //LDR_valid.add(pinValid ? F(" OK"): F(" invalid")); | ||||
|   | ||||
| @@ -52,7 +52,7 @@ class MyUsermod : public Usermod { | ||||
|  | ||||
|   void togglePIRSensor() { | ||||
|     #ifdef USERMOD_PIR_SENSOR_SWITCH | ||||
|     PIRsensorSwitch *PIRsensor = (PIRsensorSwitch::*) usermods.lookup(USERMOD_ID_PIRSWITCH); | ||||
|     PIRsensorSwitch *PIRsensor = (PIRsensorSwitch::*) UsermodManager::lookup(USERMOD_ID_PIRSWITCH); | ||||
|     if (PIRsensor != nullptr) { | ||||
|       PIRsensor->EnablePIRsensor(!PIRsensor->PIRsensorEnabled()); | ||||
|     } | ||||
|   | ||||
| @@ -375,7 +375,7 @@ void PIRsensorSwitch::setup() | ||||
|     sensorPinState[i] = LOW; | ||||
|     if (PIRsensorPin[i] < 0) continue; | ||||
|     // pin retrieved from cfg.json (readFromConfig()) prior to running setup() | ||||
|     if (pinManager.allocatePin(PIRsensorPin[i], false, PinOwner::UM_PIR)) { | ||||
|     if (PinManager::allocatePin(PIRsensorPin[i], false, PinOwner::UM_PIR)) { | ||||
|       // PIR Sensor mode INPUT_PULLDOWN | ||||
|       #ifdef ESP8266 | ||||
|       pinMode(PIRsensorPin[i], PIRsensorPin[i]==16 ? INPUT_PULLDOWN_16 : INPUT_PULLUP); // ESP8266 has INPUT_PULLDOWN on GPIO16 only | ||||
| @@ -564,7 +564,7 @@ bool PIRsensorSwitch::readFromConfig(JsonObject &root) | ||||
|     DEBUG_PRINTLN(F(" config loaded.")); | ||||
|   } else { | ||||
|     for (int i = 0; i < PIR_SENSOR_MAX_SENSORS; i++) | ||||
|       if (oldPin[i] >= 0) pinManager.deallocatePin(oldPin[i], PinOwner::UM_PIR); | ||||
|       if (oldPin[i] >= 0) PinManager::deallocatePin(oldPin[i], PinOwner::UM_PIR); | ||||
|     setup(); | ||||
|     DEBUG_PRINTLN(F(" config (re)loaded.")); | ||||
|   } | ||||
|   | ||||
| @@ -75,7 +75,7 @@ class PWMFanUsermod : public Usermod { | ||||
|     static const char _lock[]; | ||||
|  | ||||
|     void initTacho(void) { | ||||
|       if (tachoPin < 0 || !pinManager.allocatePin(tachoPin, false, PinOwner::UM_Unspecified)){ | ||||
|       if (tachoPin < 0 || !PinManager::allocatePin(tachoPin, false, PinOwner::UM_Unspecified)){ | ||||
|         tachoPin = -1; | ||||
|         return; | ||||
|       } | ||||
| @@ -88,7 +88,7 @@ class PWMFanUsermod : public Usermod { | ||||
|     void deinitTacho(void) { | ||||
|       if (tachoPin < 0) return; | ||||
|       detachInterrupt(digitalPinToInterrupt(tachoPin)); | ||||
|       pinManager.deallocatePin(tachoPin, PinOwner::UM_Unspecified); | ||||
|       PinManager::deallocatePin(tachoPin, PinOwner::UM_Unspecified); | ||||
|       tachoPin = -1; | ||||
|     } | ||||
|  | ||||
| @@ -111,7 +111,7 @@ class PWMFanUsermod : public Usermod { | ||||
|  | ||||
|     // https://randomnerdtutorials.com/esp32-pwm-arduino-ide/ | ||||
|     void initPWMfan(void) { | ||||
|       if (pwmPin < 0 || !pinManager.allocatePin(pwmPin, true, PinOwner::UM_Unspecified)) { | ||||
|       if (pwmPin < 0 || !PinManager::allocatePin(pwmPin, true, PinOwner::UM_Unspecified)) { | ||||
|         enabled = false; | ||||
|         pwmPin = -1; | ||||
|         return; | ||||
| @@ -121,7 +121,7 @@ class PWMFanUsermod : public Usermod { | ||||
|       analogWriteRange(255); | ||||
|       analogWriteFreq(WLED_PWM_FREQ); | ||||
|       #else | ||||
|       pwmChannel = pinManager.allocateLedc(1); | ||||
|       pwmChannel = PinManager::allocateLedc(1); | ||||
|       if (pwmChannel == 255) { //no more free LEDC channels | ||||
|         deinitPWMfan(); return; | ||||
|       } | ||||
| @@ -136,9 +136,9 @@ class PWMFanUsermod : public Usermod { | ||||
|     void deinitPWMfan(void) { | ||||
|       if (pwmPin < 0) return; | ||||
|  | ||||
|       pinManager.deallocatePin(pwmPin, PinOwner::UM_Unspecified); | ||||
|       PinManager::deallocatePin(pwmPin, PinOwner::UM_Unspecified); | ||||
|       #ifdef ARDUINO_ARCH_ESP32 | ||||
|       pinManager.deallocateLedc(pwmChannel, 1); | ||||
|       PinManager::deallocateLedc(pwmChannel, 1); | ||||
|       #endif | ||||
|       pwmPin = -1; | ||||
|     } | ||||
| @@ -191,9 +191,9 @@ class PWMFanUsermod : public Usermod { | ||||
|     void setup() override { | ||||
|       #ifdef USERMOD_DALLASTEMPERATURE    | ||||
|       // This Usermod requires Temperature usermod | ||||
|       tempUM = (UsermodTemperature*) usermods.lookup(USERMOD_ID_TEMPERATURE); | ||||
|       tempUM = (UsermodTemperature*) UsermodManager::lookup(USERMOD_ID_TEMPERATURE); | ||||
|       #elif defined(USERMOD_SHT) | ||||
|       tempUM = (ShtUsermod*) usermods.lookup(USERMOD_ID_SHT); | ||||
|       tempUM = (ShtUsermod*) UsermodManager::lookup(USERMOD_ID_SHT); | ||||
|       #endif | ||||
|       initTacho(); | ||||
|       initPWMfan(); | ||||
|   | ||||
| @@ -9,6 +9,6 @@ | ||||
| void registerUsermods() | ||||
| { | ||||
| #ifdef USERMOD_SN_PHOTORESISTOR | ||||
|   usermods.add(new Usermod_SN_Photoresistor()); | ||||
|   UsermodManager::add(new Usermod_SN_Photoresistor()); | ||||
| #endif | ||||
| } | ||||
| @@ -138,10 +138,10 @@ class St7789DisplayUsermod : public Usermod { | ||||
|     void setup() override | ||||
|     { | ||||
|         PinManagerPinType spiPins[] = { { spi_mosi, true }, { spi_miso, false}, { spi_sclk, true } }; | ||||
|         if (!pinManager.allocateMultiplePins(spiPins, 3, PinOwner::HW_SPI)) { enabled = false; return; } | ||||
|         if (!PinManager::allocateMultiplePins(spiPins, 3, PinOwner::HW_SPI)) { enabled = false; return; } | ||||
|         PinManagerPinType displayPins[] = { { TFT_CS, true}, { TFT_DC, true}, { TFT_RST, true }, { TFT_BL, true } }; | ||||
|         if (!pinManager.allocateMultiplePins(displayPins, sizeof(displayPins)/sizeof(PinManagerPinType), PinOwner::UM_FourLineDisplay)) { | ||||
|             pinManager.deallocateMultiplePins(spiPins, 3, PinOwner::HW_SPI); | ||||
|         if (!PinManager::allocateMultiplePins(displayPins, sizeof(displayPins)/sizeof(PinManagerPinType), PinOwner::UM_FourLineDisplay)) { | ||||
|             PinManager::deallocateMultiplePins(spiPins, 3, PinOwner::HW_SPI); | ||||
|             enabled = false; | ||||
|             return; | ||||
|         } | ||||
|   | ||||
| @@ -73,7 +73,7 @@ class UsermodTemperature : public Usermod { | ||||
|     void publishHomeAssistantAutodiscovery(); | ||||
| #endif | ||||
|  | ||||
|     static UsermodTemperature* _instance; // to overcome nonstatic getTemperatureC() method and avoid usermods.lookup(USERMOD_ID_TEMPERATURE); | ||||
|     static UsermodTemperature* _instance; // to overcome nonstatic getTemperatureC() method and avoid UsermodManager::lookup(USERMOD_ID_TEMPERATURE); | ||||
|  | ||||
|   public: | ||||
|  | ||||
| @@ -223,14 +223,14 @@ void UsermodTemperature::setup() { | ||||
|     // config says we are enabled | ||||
|     DEBUG_PRINTLN(F("Allocating temperature pin...")); | ||||
|     // pin retrieved from cfg.json (readFromConfig()) prior to running setup() | ||||
|     if (temperaturePin >= 0 && pinManager.allocatePin(temperaturePin, true, PinOwner::UM_Temperature)) { | ||||
|     if (temperaturePin >= 0 && PinManager::allocatePin(temperaturePin, true, PinOwner::UM_Temperature)) { | ||||
|       oneWire = new OneWire(temperaturePin); | ||||
|       if (oneWire->reset()) { | ||||
|         while (!findSensor() && retries--) { | ||||
|           delay(25); // try to find sensor | ||||
|         } | ||||
|       } | ||||
|       if (parasite && pinManager.allocatePin(parasitePin, true, PinOwner::UM_Temperature)) { | ||||
|       if (parasite && PinManager::allocatePin(parasitePin, true, PinOwner::UM_Temperature)) { | ||||
|         pinMode(parasitePin, OUTPUT); | ||||
|         digitalWrite(parasitePin, LOW); // deactivate power (close MOSFET) | ||||
|       } else { | ||||
| @@ -423,9 +423,9 @@ bool UsermodTemperature::readFromConfig(JsonObject &root) { | ||||
|       DEBUG_PRINTLN(F("Re-init temperature.")); | ||||
|       // deallocate pin and release memory | ||||
|       delete oneWire; | ||||
|       pinManager.deallocatePin(temperaturePin, PinOwner::UM_Temperature); | ||||
|       PinManager::deallocatePin(temperaturePin, PinOwner::UM_Temperature); | ||||
|       temperaturePin = newTemperaturePin; | ||||
|       pinManager.deallocatePin(parasitePin, PinOwner::UM_Temperature); | ||||
|       PinManager::deallocatePin(parasitePin, PinOwner::UM_Temperature); | ||||
|       // initialise | ||||
|       setup(); | ||||
|     } | ||||
| @@ -461,13 +461,13 @@ const char UsermodTemperature::_domoticzIDX[]  PROGMEM = "domoticz-idx"; | ||||
| const char UsermodTemperature::_sensor[]       PROGMEM = "sensor"; | ||||
| const char UsermodTemperature::_temperature[]  PROGMEM = "temperature"; | ||||
| const char UsermodTemperature::_Temperature[]  PROGMEM = "/temperature"; | ||||
| const char UsermodTemperature::_data_fx[]      PROGMEM = "Temperature@Min,Max;;!;01;pal=54"; | ||||
| const char UsermodTemperature::_data_fx[]      PROGMEM = "Temperature@Min,Max;;!;01;pal=54,sx=255,ix=0"; | ||||
|  | ||||
| static uint16_t mode_temperature() { | ||||
|   float low  = mapf((float)SEGMENT.speed, 0.f, 255.f, -150.f, 149.9f);    // default: 0°C, range: -15°C to 15°C | ||||
|   float high = mapf((float)SEGMENT.intensity, 0.f, 255.f, 150.f, 450.f);  // default: 30°C, range 15°C to 45°C | ||||
|   float temp = constrain(UsermodTemperature::getInstance()->getTemperatureC()*10.f, low, high);   // get a little better resolution | ||||
|   unsigned i = map(temp, (unsigned)low, (unsigned)high, 0, 255); | ||||
|   float low  = roundf(mapf((float)SEGMENT.speed, 0.f, 255.f, -150.f, 150.f));    // default: 15°C, range: -15°C to 15°C | ||||
|   float high = roundf(mapf((float)SEGMENT.intensity, 0.f, 255.f, 300.f, 600.f));  // default: 30°C, range 30°C to 60°C | ||||
|   float temp = constrain(UsermodTemperature::getInstance()->getTemperatureC()*10.f, low, high);   // get a little better resolution (*10) | ||||
|   unsigned i = map(roundf(temp), (unsigned)low, (unsigned)high, 0, 248); | ||||
|   SEGMENT.fill(SEGMENT.color_from_palette(i, false, false, 255)); | ||||
|   return FRAMETIME; | ||||
| } | ||||
|   | ||||
| @@ -194,8 +194,8 @@ class I2SSource : public AudioSource { | ||||
|     virtual void initialize(int8_t i2swsPin = I2S_PIN_NO_CHANGE, int8_t i2ssdPin = I2S_PIN_NO_CHANGE, int8_t i2sckPin = I2S_PIN_NO_CHANGE, int8_t mclkPin = I2S_PIN_NO_CHANGE) { | ||||
|       DEBUGSR_PRINTLN(F("I2SSource:: initialize().")); | ||||
|       if (i2swsPin != I2S_PIN_NO_CHANGE && i2ssdPin != I2S_PIN_NO_CHANGE) { | ||||
|         if (!pinManager.allocatePin(i2swsPin, true, PinOwner::UM_Audioreactive) || | ||||
|             !pinManager.allocatePin(i2ssdPin, false, PinOwner::UM_Audioreactive)) { // #206 | ||||
|         if (!PinManager::allocatePin(i2swsPin, true, PinOwner::UM_Audioreactive) || | ||||
|             !PinManager::allocatePin(i2ssdPin, false, PinOwner::UM_Audioreactive)) { // #206 | ||||
|           DEBUGSR_PRINTF("\nAR: Failed to allocate I2S pins: ws=%d, sd=%d\n",  i2swsPin, i2ssdPin);  | ||||
|           return; | ||||
|         } | ||||
| @@ -203,7 +203,7 @@ class I2SSource : public AudioSource { | ||||
|  | ||||
|       // i2ssckPin needs special treatment, since it might be unused on PDM mics | ||||
|       if (i2sckPin != I2S_PIN_NO_CHANGE) { | ||||
|         if (!pinManager.allocatePin(i2sckPin, true, PinOwner::UM_Audioreactive)) { | ||||
|         if (!PinManager::allocatePin(i2sckPin, true, PinOwner::UM_Audioreactive)) { | ||||
|           DEBUGSR_PRINTF("\nAR: Failed to allocate I2S pins: sck=%d\n",  i2sckPin);  | ||||
|           return; | ||||
|         } | ||||
| @@ -249,7 +249,7 @@ class I2SSource : public AudioSource { | ||||
|       // Reserve the master clock pin if provided | ||||
|       _mclkPin = mclkPin; | ||||
|       if (mclkPin != I2S_PIN_NO_CHANGE) { | ||||
|         if(!pinManager.allocatePin(mclkPin, true, PinOwner::UM_Audioreactive)) {  | ||||
|         if(!PinManager::allocatePin(mclkPin, true, PinOwner::UM_Audioreactive)) {  | ||||
|           DEBUGSR_PRINTF("\nAR: Failed to allocate I2S pin: MCLK=%d\n",  mclkPin);  | ||||
|           return; | ||||
|         } else | ||||
| @@ -307,11 +307,11 @@ class I2SSource : public AudioSource { | ||||
|         DEBUGSR_PRINTF("Failed to uninstall i2s driver: %d\n", err); | ||||
|         return; | ||||
|       } | ||||
|       if (_pinConfig.ws_io_num   != I2S_PIN_NO_CHANGE) pinManager.deallocatePin(_pinConfig.ws_io_num,   PinOwner::UM_Audioreactive); | ||||
|       if (_pinConfig.data_in_num != I2S_PIN_NO_CHANGE) pinManager.deallocatePin(_pinConfig.data_in_num, PinOwner::UM_Audioreactive); | ||||
|       if (_pinConfig.bck_io_num  != I2S_PIN_NO_CHANGE) pinManager.deallocatePin(_pinConfig.bck_io_num,  PinOwner::UM_Audioreactive); | ||||
|       if (_pinConfig.ws_io_num   != I2S_PIN_NO_CHANGE) PinManager::deallocatePin(_pinConfig.ws_io_num,   PinOwner::UM_Audioreactive); | ||||
|       if (_pinConfig.data_in_num != I2S_PIN_NO_CHANGE) PinManager::deallocatePin(_pinConfig.data_in_num, PinOwner::UM_Audioreactive); | ||||
|       if (_pinConfig.bck_io_num  != I2S_PIN_NO_CHANGE) PinManager::deallocatePin(_pinConfig.bck_io_num,  PinOwner::UM_Audioreactive); | ||||
|       // Release the master clock pin | ||||
|       if (_mclkPin != I2S_PIN_NO_CHANGE) pinManager.deallocatePin(_mclkPin, PinOwner::UM_Audioreactive); | ||||
|       if (_mclkPin != I2S_PIN_NO_CHANGE) PinManager::deallocatePin(_mclkPin, PinOwner::UM_Audioreactive); | ||||
|     } | ||||
|  | ||||
|     virtual void getSamples(float *buffer, uint16_t num_samples) { | ||||
| @@ -589,7 +589,7 @@ class I2SAdcSource : public I2SSource { | ||||
|     void initialize(int8_t audioPin, int8_t = I2S_PIN_NO_CHANGE, int8_t = I2S_PIN_NO_CHANGE, int8_t = I2S_PIN_NO_CHANGE) { | ||||
|       DEBUGSR_PRINTLN(F("I2SAdcSource:: initialize().")); | ||||
|       _myADCchannel = 0x0F; | ||||
|       if(!pinManager.allocatePin(audioPin, false, PinOwner::UM_Audioreactive)) { | ||||
|       if(!PinManager::allocatePin(audioPin, false, PinOwner::UM_Audioreactive)) { | ||||
|          DEBUGSR_PRINTF("failed to allocate GPIO for audio analog input: %d\n", audioPin); | ||||
|         return; | ||||
|       } | ||||
| @@ -717,7 +717,7 @@ class I2SAdcSource : public I2SSource { | ||||
|     } | ||||
|  | ||||
|     void deinitialize() { | ||||
|       pinManager.deallocatePin(_audioPin, PinOwner::UM_Audioreactive); | ||||
|       PinManager::deallocatePin(_audioPin, PinOwner::UM_Audioreactive); | ||||
|       _initialized = false; | ||||
|       _myADCchannel = 0x0F; | ||||
|        | ||||
|   | ||||
| @@ -86,6 +86,6 @@ Example **usermods_list.cpp**: | ||||
|  | ||||
| void registerUsermods() | ||||
| { | ||||
|   usermods.add(new MPU6050Driver()); | ||||
|   UsermodManager::add(new MPU6050Driver()); | ||||
| } | ||||
| ``` | ||||
|   | ||||
| @@ -163,7 +163,7 @@ class GyroSurge : public Usermod { | ||||
|     void loop() { | ||||
|       // get IMU data | ||||
|       um_data_t *um_data; | ||||
|       if (!usermods.getUMData(&um_data, USERMOD_ID_IMU)) { | ||||
|       if (!UsermodManager::getUMData(&um_data, USERMOD_ID_IMU)) { | ||||
|         // Apply max | ||||
|         strip.getSegment(0).fadeToBlackBy(max); | ||||
|         return; | ||||
|   | ||||
| @@ -164,7 +164,7 @@ class MPU6050Driver : public Usermod { | ||||
|       if (i2c_scl<0 || i2c_sda<0) { DEBUG_PRINTLN(F("MPU6050: I2C is no good."));  return; } | ||||
|       // Check the interrupt pin | ||||
|       if (config.interruptPin >= 0) { | ||||
|         irqBound = pinManager.allocatePin(config.interruptPin, false, PinOwner::UM_IMU); | ||||
|         irqBound = PinManager::allocatePin(config.interruptPin, false, PinOwner::UM_IMU); | ||||
|         if (!irqBound) { DEBUG_PRINTLN(F("MPU6050: IRQ pin already in use.")); return; } | ||||
|         pinMode(config.interruptPin, INPUT); | ||||
|       }; | ||||
| @@ -408,7 +408,7 @@ class MPU6050Driver : public Usermod { | ||||
|         // Previously loaded and config changed | ||||
|         if (irqBound && ((old_cfg.interruptPin != config.interruptPin) || !config.enabled)) { | ||||
|           detachInterrupt(old_cfg.interruptPin); | ||||
|           pinManager.deallocatePin(old_cfg.interruptPin, PinOwner::UM_IMU);             | ||||
|           PinManager::deallocatePin(old_cfg.interruptPin, PinOwner::UM_IMU);             | ||||
|           irqBound = false; | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -19,7 +19,7 @@ Example `usermods_list.cpp`: | ||||
|  | ||||
| void registerUsermods() | ||||
| { | ||||
|   usermods.add(new UsermodMqttSwitch()); | ||||
|   UsermodManager::add(new UsermodMqttSwitch()); | ||||
| } | ||||
| ``` | ||||
|  | ||||
|   | ||||
| @@ -41,7 +41,7 @@ When a relay is switched, a message is published: | ||||
|  | ||||
| ## Usermod installation | ||||
|  | ||||
| 1. Register the usermod by adding `#include "../usermods/multi_relay/usermod_multi_relay.h"` at the top and `usermods.add(new MultiRelay());` at the bottom of `usermods_list.cpp`. | ||||
| 1. Register the usermod by adding `#include "../usermods/multi_relay/usermod_multi_relay.h"` at the top and `UsermodManager::add(new MultiRelay());` at the bottom of `usermods_list.cpp`. | ||||
| or | ||||
| 2. Use `#define USERMOD_MULTI_RELAY` in wled.h or `-D USERMOD_MULTI_RELAY` in your platformio.ini | ||||
|  | ||||
| @@ -90,9 +90,9 @@ void registerUsermods() | ||||
|    * || || || | ||||
|    * \/ \/ \/ | ||||
|    */ | ||||
|   //usermods.add(new MyExampleUsermod()); | ||||
|   //usermods.add(new UsermodTemperature()); | ||||
|   usermods.add(new MultiRelay()); | ||||
|   //UsermodManager::add(new MyExampleUsermod()); | ||||
|   //UsermodManager::add(new UsermodTemperature()); | ||||
|   UsermodManager::add(new MultiRelay()); | ||||
|  | ||||
| } | ||||
| ``` | ||||
|   | ||||
| @@ -516,7 +516,7 @@ void MultiRelay::setup() { | ||||
|       if (!_relay[i].external) _relay[i].state = !offMode; | ||||
|       state |= (uint8_t)(_relay[i].invert ? !_relay[i].state : _relay[i].state) << pin; | ||||
|     } else if (_relay[i].pin<100 && _relay[i].pin>=0) { | ||||
|       if (pinManager.allocatePin(_relay[i].pin,true, PinOwner::UM_MultiRelay)) { | ||||
|       if (PinManager::allocatePin(_relay[i].pin,true, PinOwner::UM_MultiRelay)) { | ||||
|         if (!_relay[i].external) _relay[i].state = !offMode; | ||||
|         switchRelay(i, _relay[i].state); | ||||
|         _relay[i].active = false; | ||||
| @@ -817,7 +817,7 @@ bool MultiRelay::readFromConfig(JsonObject &root) { | ||||
|     // deallocate all pins 1st | ||||
|     for (int i=0; i<MULTI_RELAY_MAX_RELAYS; i++) | ||||
|       if (oldPin[i]>=0 && oldPin[i]<100) { | ||||
|         pinManager.deallocatePin(oldPin[i], PinOwner::UM_MultiRelay); | ||||
|         PinManager::deallocatePin(oldPin[i], PinOwner::UM_MultiRelay); | ||||
|       } | ||||
|     // allocate new pins | ||||
|     setup(); | ||||
|   | ||||
| @@ -112,15 +112,15 @@ class PixelsDiceTrayUsermod : public Usermod { | ||||
|     SetSPIPinsFromMacros(); | ||||
|     PinManagerPinType spiPins[] = { | ||||
|         {spi_mosi, true}, {spi_miso, false}, {spi_sclk, true}}; | ||||
|     if (!pinManager.allocateMultiplePins(spiPins, 3, PinOwner::HW_SPI)) { | ||||
|     if (!PinManager::allocateMultiplePins(spiPins, 3, PinOwner::HW_SPI)) { | ||||
|       enabled = false; | ||||
|     } else { | ||||
|       PinManagerPinType displayPins[] = { | ||||
|           {TFT_CS, true}, {TFT_DC, true}, {TFT_RST, true}, {TFT_BL, true}}; | ||||
|       if (!pinManager.allocateMultiplePins( | ||||
|       if (!PinManager::allocateMultiplePins( | ||||
|               displayPins, sizeof(displayPins) / sizeof(PinManagerPinType), | ||||
|               PinOwner::UM_FourLineDisplay)) { | ||||
|         pinManager.deallocateMultiplePins(spiPins, 3, PinOwner::HW_SPI); | ||||
|         PinManager::deallocateMultiplePins(spiPins, 3, PinOwner::HW_SPI); | ||||
|         enabled = false; | ||||
|       } | ||||
|     } | ||||
|   | ||||
| @@ -29,13 +29,13 @@ class PwmOutput { | ||||
|         return; | ||||
|  | ||||
|       DEBUG_PRINTF("pwm_output[%d]: setup to freq %d\n", pin_, freq_); | ||||
|       if (!pinManager.allocatePin(pin_, true, PinOwner::UM_PWM_OUTPUTS)) | ||||
|       if (!PinManager::allocatePin(pin_, true, PinOwner::UM_PWM_OUTPUTS)) | ||||
|         return; | ||||
|        | ||||
|       channel_ = pinManager.allocateLedc(1); | ||||
|       channel_ = PinManager::allocateLedc(1); | ||||
|       if (channel_ == 255) { | ||||
|         DEBUG_PRINTF("pwm_output[%d]: failed to quire ledc\n", pin_); | ||||
|         pinManager.deallocatePin(pin_, PinOwner::UM_PWM_OUTPUTS); | ||||
|         PinManager::deallocatePin(pin_, PinOwner::UM_PWM_OUTPUTS); | ||||
|         return; | ||||
|       } | ||||
|  | ||||
| @@ -49,9 +49,9 @@ class PwmOutput { | ||||
|       DEBUG_PRINTF("pwm_output[%d]: close\n", pin_); | ||||
|       if (!enabled_) | ||||
|         return; | ||||
|       pinManager.deallocatePin(pin_, PinOwner::UM_PWM_OUTPUTS); | ||||
|       PinManager::deallocatePin(pin_, PinOwner::UM_PWM_OUTPUTS); | ||||
|       if (channel_ != 255) | ||||
|         pinManager.deallocateLedc(channel_, 1); | ||||
|         PinManager::deallocateLedc(channel_, 1); | ||||
|       channel_ = 255; | ||||
|       duty_ = 0.0f; | ||||
|       enabled_ = false; | ||||
|   | ||||
| @@ -129,7 +129,7 @@ class QuinLEDAnPentaUsermod : public Usermod | ||||
|     void initOledDisplay() | ||||
|     { | ||||
|       PinManagerPinType pins[5] = { { oledSpiClk, true }, { oledSpiData, true }, { oledSpiCs, true }, { oledSpiDc, true }, { oledSpiRst, true } }; | ||||
|       if (!pinManager.allocateMultiplePins(pins, 5, PinOwner::UM_QuinLEDAnPenta)) { | ||||
|       if (!PinManager::allocateMultiplePins(pins, 5, PinOwner::UM_QuinLEDAnPenta)) { | ||||
|         DEBUG_PRINTF("[%s] OLED pin allocation failed!\n", _name); | ||||
|         oledEnabled = oledInitDone = false; | ||||
|         return; | ||||
| @@ -164,11 +164,11 @@ class QuinLEDAnPentaUsermod : public Usermod | ||||
|         oledDisplay->clear(); | ||||
|       } | ||||
|  | ||||
|       pinManager.deallocatePin(oledSpiClk, PinOwner::UM_QuinLEDAnPenta); | ||||
|       pinManager.deallocatePin(oledSpiData, PinOwner::UM_QuinLEDAnPenta); | ||||
|       pinManager.deallocatePin(oledSpiCs, PinOwner::UM_QuinLEDAnPenta); | ||||
|       pinManager.deallocatePin(oledSpiDc, PinOwner::UM_QuinLEDAnPenta); | ||||
|       pinManager.deallocatePin(oledSpiRst, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(oledSpiClk, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(oledSpiData, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(oledSpiCs, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(oledSpiDc, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(oledSpiRst, PinOwner::UM_QuinLEDAnPenta); | ||||
|  | ||||
|       delete oledDisplay; | ||||
|  | ||||
| @@ -184,7 +184,7 @@ class QuinLEDAnPentaUsermod : public Usermod | ||||
|     void initSht30TempHumiditySensor() | ||||
|     { | ||||
|       PinManagerPinType pins[2] = { { shtSda, true }, { shtScl, true } }; | ||||
|       if (!pinManager.allocateMultiplePins(pins, 2, PinOwner::UM_QuinLEDAnPenta)) { | ||||
|       if (!PinManager::allocateMultiplePins(pins, 2, PinOwner::UM_QuinLEDAnPenta)) { | ||||
|         DEBUG_PRINTF("[%s] SHT30 pin allocation failed!\n", _name); | ||||
|         shtEnabled = shtInitDone = false; | ||||
|         return; | ||||
| @@ -212,8 +212,8 @@ class QuinLEDAnPentaUsermod : public Usermod | ||||
|         sht30TempHumidSensor->reset(); | ||||
|       } | ||||
|  | ||||
|       pinManager.deallocatePin(shtSda, PinOwner::UM_QuinLEDAnPenta); | ||||
|       pinManager.deallocatePin(shtScl, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(shtSda, PinOwner::UM_QuinLEDAnPenta); | ||||
|       PinManager::deallocatePin(shtScl, PinOwner::UM_QuinLEDAnPenta); | ||||
|  | ||||
|       delete sht30TempHumidSensor; | ||||
|  | ||||
|   | ||||
| @@ -40,7 +40,7 @@ class RgbRotaryEncoderUsermod : public Usermod | ||||
|     void initRotaryEncoder() | ||||
|     { | ||||
|       PinManagerPinType pins[2] = { { eaIo, false }, { ebIo, false } }; | ||||
|       if (!pinManager.allocateMultiplePins(pins, 2, PinOwner::UM_RGBRotaryEncoder)) { | ||||
|       if (!PinManager::allocateMultiplePins(pins, 2, PinOwner::UM_RGBRotaryEncoder)) { | ||||
|         eaIo = -1; | ||||
|         ebIo = -1; | ||||
|         cleanup(); | ||||
| @@ -108,11 +108,11 @@ class RgbRotaryEncoderUsermod : public Usermod | ||||
|     { | ||||
|       // Only deallocate pins if we allocated them ;) | ||||
|       if (eaIo != -1) { | ||||
|         pinManager.deallocatePin(eaIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|         PinManager::deallocatePin(eaIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|         eaIo = -1; | ||||
|       } | ||||
|       if (ebIo != -1) { | ||||
|         pinManager.deallocatePin(ebIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|         PinManager::deallocatePin(ebIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|         ebIo = -1; | ||||
|       } | ||||
|  | ||||
| @@ -303,8 +303,8 @@ class RgbRotaryEncoderUsermod : public Usermod | ||||
|           } | ||||
|  | ||||
|           if (eaIo != oldEaIo || ebIo != oldEbIo || stepsPerClick != oldStepsPerClick || incrementPerClick != oldIncrementPerClick) { | ||||
|             pinManager.deallocatePin(oldEaIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|             pinManager.deallocatePin(oldEbIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|             PinManager::deallocatePin(oldEaIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|             PinManager::deallocatePin(oldEbIo, PinOwner::UM_RGBRotaryEncoder); | ||||
|              | ||||
|             delete rotaryEncoder; | ||||
|             initRotaryEncoder(); | ||||
|   | ||||
| @@ -45,7 +45,7 @@ class UsermodSdCard : public Usermod { | ||||
|         { configPinPico, true } | ||||
|         }; | ||||
|  | ||||
|         if (!pinManager.allocateMultiplePins(pins, 4, PinOwner::UM_SdCard)) { | ||||
|         if (!PinManager::allocateMultiplePins(pins, 4, PinOwner::UM_SdCard)) { | ||||
|             DEBUG_PRINTF("[%s] SD (SPI) pin allocation failed!\n", _name); | ||||
|             sdInitDone = false; | ||||
|             return; | ||||
| @@ -75,10 +75,10 @@ class UsermodSdCard : public Usermod { | ||||
|         SD_ADAPTER.end(); | ||||
|  | ||||
|         DEBUG_PRINTF("[%s] deallocate pins!\n", _name); | ||||
|         pinManager.deallocatePin(configPinSourceSelect, PinOwner::UM_SdCard); | ||||
|         pinManager.deallocatePin(configPinSourceClock,  PinOwner::UM_SdCard); | ||||
|         pinManager.deallocatePin(configPinPoci,         PinOwner::UM_SdCard); | ||||
|         pinManager.deallocatePin(configPinPico,         PinOwner::UM_SdCard); | ||||
|         PinManager::deallocatePin(configPinSourceSelect, PinOwner::UM_SdCard); | ||||
|         PinManager::deallocatePin(configPinSourceClock,  PinOwner::UM_SdCard); | ||||
|         PinManager::deallocatePin(configPinPoci,         PinOwner::UM_SdCard); | ||||
|         PinManager::deallocatePin(configPinPico,         PinOwner::UM_SdCard); | ||||
|  | ||||
|         sdInitDone = false; | ||||
|       } | ||||
|   | ||||
| @@ -385,7 +385,7 @@ public: | ||||
|     _setAllFalse(); | ||||
|  | ||||
|     #ifdef USERMOD_SN_PHOTORESISTOR | ||||
|       ptr = (Usermod_SN_Photoresistor*) usermods.lookup(USERMOD_ID_SN_PHOTORESISTOR); | ||||
|       ptr = (Usermod_SN_Photoresistor*) UsermodManager::lookup(USERMOD_ID_SN_PHOTORESISTOR); | ||||
|     #endif | ||||
|     DEBUG_PRINTLN(F("Setup done")); | ||||
|   } | ||||
|   | ||||
| @@ -103,7 +103,7 @@ class AutoSaveUsermod : public Usermod { | ||||
|       #ifdef USERMOD_FOUR_LINE_DISPLAY     | ||||
|       // This Usermod has enhanced functionality if | ||||
|       // FourLineDisplayUsermod is available. | ||||
|       display = (FourLineDisplayUsermod*) usermods.lookup(USERMOD_ID_FOUR_LINE_DISP); | ||||
|       display = (FourLineDisplayUsermod*) UsermodManager::lookup(USERMOD_ID_FOUR_LINE_DISP); | ||||
|       #endif | ||||
|       initDone = true; | ||||
|       if (enabled && applyAutoSaveOnBoot) applyPreset(autoSavePreset); | ||||
|   | ||||
| @@ -543,7 +543,7 @@ void FourLineDisplayUsermod::setup() { | ||||
|       type = NONE; | ||||
|     } else { | ||||
|       PinManagerPinType cspins[3] = { { ioPin[0], true }, { ioPin[1], true }, { ioPin[2], true } }; | ||||
|       if (!pinManager.allocateMultiplePins(cspins, 3, PinOwner::UM_FourLineDisplay)) { type = NONE; } | ||||
|       if (!PinManager::allocateMultiplePins(cspins, 3, PinOwner::UM_FourLineDisplay)) { type = NONE; } | ||||
|     } | ||||
|   } else { | ||||
|     if (i2c_scl<0 || i2c_sda<0) { type=NONE; } | ||||
| @@ -569,7 +569,7 @@ void FourLineDisplayUsermod::setup() { | ||||
|   if (nullptr == u8x8) { | ||||
|     DEBUG_PRINTLN(F("Display init failed.")); | ||||
|     if (isSPI) { | ||||
|       pinManager.deallocateMultiplePins((const uint8_t*)ioPin, 3, PinOwner::UM_FourLineDisplay); | ||||
|       PinManager::deallocateMultiplePins((const uint8_t*)ioPin, 3, PinOwner::UM_FourLineDisplay); | ||||
|     } | ||||
|     type = NONE; | ||||
|     return; | ||||
| @@ -1307,7 +1307,7 @@ bool FourLineDisplayUsermod::readFromConfig(JsonObject& root) { | ||||
|       bool isSPI = (type == SSD1306_SPI || type == SSD1306_SPI64 || type == SSD1309_SPI64); | ||||
|       bool newSPI = (newType == SSD1306_SPI || newType == SSD1306_SPI64 || newType == SSD1309_SPI64); | ||||
|       if (isSPI) { | ||||
|         if (pinsChanged || !newSPI) pinManager.deallocateMultiplePins((const uint8_t*)oldPin, 3, PinOwner::UM_FourLineDisplay); | ||||
|         if (pinsChanged || !newSPI) PinManager::deallocateMultiplePins((const uint8_t*)oldPin, 3, PinOwner::UM_FourLineDisplay); | ||||
|         if (!newSPI) { | ||||
|           // was SPI but is no longer SPI | ||||
|           if (i2c_scl<0 || i2c_sda<0) { newType=NONE; } | ||||
| @@ -1315,7 +1315,7 @@ bool FourLineDisplayUsermod::readFromConfig(JsonObject& root) { | ||||
|           // still SPI but pins changed | ||||
|           PinManagerPinType cspins[3] = { { ioPin[0], true }, { ioPin[1], true }, { ioPin[2], true } }; | ||||
|           if (ioPin[0]<0 || ioPin[1]<0 || ioPin[1]<0) { newType=NONE; } | ||||
|           else if (!pinManager.allocateMultiplePins(cspins, 3, PinOwner::UM_FourLineDisplay)) { newType=NONE; } | ||||
|           else if (!PinManager::allocateMultiplePins(cspins, 3, PinOwner::UM_FourLineDisplay)) { newType=NONE; } | ||||
|         } | ||||
|       } else if (newSPI) { | ||||
|         // was I2C but is now SPI | ||||
| @@ -1324,7 +1324,7 @@ bool FourLineDisplayUsermod::readFromConfig(JsonObject& root) { | ||||
|         } else { | ||||
|           PinManagerPinType pins[3] = { { ioPin[0], true }, { ioPin[1], true }, { ioPin[2], true } }; | ||||
|           if (ioPin[0]<0 || ioPin[1]<0 || ioPin[1]<0) { newType=NONE; } | ||||
|           else if (!pinManager.allocateMultiplePins(pins, 3, PinOwner::UM_FourLineDisplay)) { newType=NONE; } | ||||
|           else if (!PinManager::allocateMultiplePins(pins, 3, PinOwner::UM_FourLineDisplay)) { newType=NONE; } | ||||
|         } | ||||
|       } else { | ||||
|         // just I2C type changed | ||||
|   | ||||
| @@ -489,7 +489,7 @@ void RotaryEncoderUIUsermod::setup() | ||||
|       enabled = false; | ||||
|       return; | ||||
|     } else { | ||||
|       if (pinIRQ >= 0 && pinManager.allocatePin(pinIRQ, false, PinOwner::UM_RotaryEncoderUI)) { | ||||
|       if (pinIRQ >= 0 && PinManager::allocatePin(pinIRQ, false, PinOwner::UM_RotaryEncoderUI)) { | ||||
|         pinMode(pinIRQ, INPUT_PULLUP); | ||||
|         attachInterrupt(pinIRQ, i2cReadingISR, FALLING); // RISING, FALLING, CHANGE, ONLOW, ONHIGH | ||||
|         DEBUG_PRINTLN(F("Interrupt attached.")); | ||||
| @@ -502,7 +502,7 @@ void RotaryEncoderUIUsermod::setup() | ||||
|     } | ||||
|   } else { | ||||
|     PinManagerPinType pins[3] = { { pinA, false }, { pinB, false }, { pinC, false } }; | ||||
|     if (pinA<0 || pinB<0 || !pinManager.allocateMultiplePins(pins, 3, PinOwner::UM_RotaryEncoderUI)) { | ||||
|     if (pinA<0 || pinB<0 || !PinManager::allocateMultiplePins(pins, 3, PinOwner::UM_RotaryEncoderUI)) { | ||||
|       pinA = pinB = pinC = -1; | ||||
|       enabled = false; | ||||
|       return; | ||||
| @@ -525,7 +525,7 @@ void RotaryEncoderUIUsermod::setup() | ||||
| #ifdef USERMOD_FOUR_LINE_DISPLAY | ||||
|   // This Usermod uses FourLineDisplayUsermod for the best experience. | ||||
|   // But it's optional. But you want it. | ||||
|   display = (FourLineDisplayUsermod*) usermods.lookup(USERMOD_ID_FOUR_LINE_DISP); | ||||
|   display = (FourLineDisplayUsermod*) UsermodManager::lookup(USERMOD_ID_FOUR_LINE_DISP); | ||||
|   if (display != nullptr) { | ||||
|     display->setMarkLine(1, 0); | ||||
|   } | ||||
| @@ -1138,14 +1138,14 @@ bool RotaryEncoderUIUsermod::readFromConfig(JsonObject &root) { | ||||
|       if (oldPcf8574) { | ||||
|         if (pinIRQ >= 0) { | ||||
|           detachInterrupt(pinIRQ); | ||||
|           pinManager.deallocatePin(pinIRQ, PinOwner::UM_RotaryEncoderUI); | ||||
|           PinManager::deallocatePin(pinIRQ, PinOwner::UM_RotaryEncoderUI); | ||||
|           DEBUG_PRINTLN(F("Deallocated old IRQ pin.")); | ||||
|         } | ||||
|         pinIRQ = newIRQpin<100 ? newIRQpin : -1; // ignore PCF8574 pins | ||||
|       } else { | ||||
|         pinManager.deallocatePin(pinA, PinOwner::UM_RotaryEncoderUI); | ||||
|         pinManager.deallocatePin(pinB, PinOwner::UM_RotaryEncoderUI); | ||||
|         pinManager.deallocatePin(pinC, PinOwner::UM_RotaryEncoderUI); | ||||
|         PinManager::deallocatePin(pinA, PinOwner::UM_RotaryEncoderUI); | ||||
|         PinManager::deallocatePin(pinB, PinOwner::UM_RotaryEncoderUI); | ||||
|         PinManager::deallocatePin(pinC, PinOwner::UM_RotaryEncoderUI); | ||||
|         DEBUG_PRINTLN(F("Deallocated old pins.")); | ||||
|       } | ||||
|       pinA = newDTpin; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaz Kristan
					Blaz Kristan