From e4e846906d342e0ffdb3fcd8815ed01596f0f215 Mon Sep 17 00:00:00 2001 From: dobry kod <147148803+dobrykod@users.noreply.github.com> Date: Mon, 9 Oct 2023 08:20:51 +0200 Subject: [PATCH 1/2] [GPIO] Fix taking wrong branch in GPIO_Monitor10xSec when MCP/PCF plugin is disabled --- src/src/ESPEasyCore/ESPEasyGPIO.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/src/ESPEasyCore/ESPEasyGPIO.cpp b/src/src/ESPEasyCore/ESPEasyGPIO.cpp index a705befb0e..ed74ace126 100644 --- a/src/src/ESPEasyCore/ESPEasyGPIO.cpp +++ b/src/src/ESPEasyCore/ESPEasyGPIO.cpp @@ -426,18 +426,18 @@ void GPIO_Monitor10xSec() currentState = GPIO_Read_Switch_State(gpioPort, it->second.mode); eventString = F("GPIO"); break; - case PLUGIN_MCP_INT: #ifdef USES_P009 + case PLUGIN_MCP_INT: currentState = GPIO_MCP_Read(gpioPort); eventString = F("MCP"); -#endif break; - case PLUGIN_PCF_INT: +#endif #ifdef USES_P019 + case PLUGIN_PCF_INT: currentState = GPIO_PCF_Read(gpioPort); eventString = F("PCF"); -#endif break; +#endif default: caseFound=false; break; From 25b10d76ca11d121ce062556d0390d63377f9aba Mon Sep 17 00:00:00 2001 From: dobry kod <147148803+dobrykod@users.noreply.github.com> Date: Mon, 9 Oct 2023 08:21:04 +0200 Subject: [PATCH 2/2] [GPIO] Fix response to Status command --- src/src/Commands/GPIO.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/src/Commands/GPIO.cpp b/src/src/Commands/GPIO.cpp index 0254c79609..27ec533ed5 100644 --- a/src/src/Commands/GPIO.cpp +++ b/src/src/Commands/GPIO.cpp @@ -288,6 +288,7 @@ const __FlashStringHelper * Command_GPIO_Status(struct EventStruct *event, const { bool sendStatusFlag; pluginID_t pluginID; + int8_t value = -1; switch (tolower(parseString(Line, 2).charAt(0))) { @@ -298,13 +299,15 @@ const __FlashStringHelper * Command_GPIO_Status(struct EventStruct *event, const #ifdef USES_P009 case 'm': // mcp pluginID = PLUGIN_MCP; - sendStatusFlag = GPIO_MCP_Read(event->Par2) == -1; + value = GPIO_MCP_Read(event->Par2); + sendStatusFlag = value == -1; break; #endif #ifdef USES_P019 case 'p': // pcf pluginID = PLUGIN_PCF; - sendStatusFlag = GPIO_PCF_Read(event->Par2) == -1; + value = GPIO_PCF_Read(event->Par2); + sendStatusFlag = value == -1; break; #endif default: @@ -318,7 +321,7 @@ const __FlashStringHelper * Command_GPIO_Status(struct EventStruct *event, const } const uint32_t key = createKey(pluginID, event->Par2); // WARNING: 'status' uses Par2 instead of Par1 String dummy; - SendStatusOnlyIfNeeded(event, sendStatusFlag, key, dummy, 0); + SendStatusOnlyIfNeeded(event, sendStatusFlag, key, dummy, value); return return_command_success_flashstr(); }