From a5efce9d48b5d511cf33a8cb9e18561c5ce3dd6a Mon Sep 17 00:00:00 2001 From: MartinMueller2003 Date: Tue, 19 Mar 2024 10:22:52 -0400 Subject: [PATCH] More work on merging new and old configs. Turned off. restored files are used as is. --- ESPixelStick/ESPixelStick.ino | 3 +- ESPixelStick/src/input/InputMgr.cpp | 60 ++++++-- ESPixelStick/src/input/InputMgr.hpp | 1 + ESPixelStick/src/output/OutputMgr.cpp | 192 ++++++++++++++++++++------ ESPixelStick/src/output/OutputMgr.hpp | 3 +- 5 files changed, 200 insertions(+), 59 deletions(-) diff --git a/ESPixelStick/ESPixelStick.ino b/ESPixelStick/ESPixelStick.ino index c6dee0267..b1bda0a1f 100644 --- a/ESPixelStick/ESPixelStick.ino +++ b/ESPixelStick/ESPixelStick.ino @@ -173,7 +173,7 @@ void setup() // TestHeap(uint32_t(10)); // DEBUG_V(""); FileMgr.Begin(); - +#ifdef SUPPORT_CONFIG_MERGE if(FileMgr.FlashFileExists (RestoredConfigFileName)) { // DEBUG_V("Setting Restored Config flag to true"); @@ -183,6 +183,7 @@ void setup() { // DEBUG_V("Setting Restored Config flag to false"); } +#endif // def SUPPORT_CONFIG_MERGE // Load configuration from the File System and set Hostname // TestHeap(uint32_t(15)); // DEBUG_V(String("LoadConfig Heap: ") + String(ESP.getFreeHeap())); diff --git a/ESPixelStick/src/input/InputMgr.cpp b/ESPixelStick/src/input/InputMgr.cpp index c71591456..4b076c3e4 100644 --- a/ESPixelStick/src/input/InputMgr.cpp +++ b/ESPixelStick/src/input/InputMgr.cpp @@ -265,13 +265,14 @@ void c_InputMgr::CreateNewConfig () // do we create a clean config or do we merge from a restored config? if(RestoredConfig) { - // DEBUG_V("Merge a Restored Config"); + DEBUG_V("Merge a Restored Input Config"); // read the existing file and add to it as needed FileMgr.ReadFlashFile(ConfigFileName, JsonConfigDoc); } if(!JsonConfigDoc.containsKey(CN_input_config)) { + DEBUG_V("Add missing input config fields"); JsonConfigDoc.createNestedObject(CN_input_config); } JsonObject JsonConfig = JsonConfigDoc[CN_input_config]; @@ -746,16 +747,16 @@ void c_InputMgr::ProcessButtonActions (c_ExternalInput::InputValue_t value) } // ProcessButtonActions //----------------------------------------------------------------------------- -/* - check the contents of the config and send - the proper portion of the config to the currently instantiated channels -*/ -bool c_InputMgr::ProcessJsonConfig (JsonObject & jsonConfig) +bool c_InputMgr::FindJsonChannelConfig (JsonObject& jsonConfig, + e_InputChannelIds ChanId, + JsonObject& ChanConfig) { // DEBUG_START; bool Response = false; + // DEBUG_V (); - // DEBUG_V ("InputDataBufferSize: " + String (InputDataBufferSize)); + // extern void PrettyPrint(JsonObject & jsonStuff, String Name); + // PrettyPrint(jsonConfig, "ProcessJsonConfig"); do // once { @@ -805,21 +806,52 @@ bool c_InputMgr::ProcessJsonConfig (JsonObject & jsonConfig) JsonObject InputChannelArray = InputChannelMgrData[CN_channels]; // DEBUG_V (""); + // get access to the channel config + if (false == InputChannelArray.containsKey (String (ChanId))) + { + // if not, flag an error and stop processing + logcon (String (F ("No Input Settings Found for Channel '")) + ChanId + String (F ("'. Using Defaults"))); + continue; + } + ChanConfig = InputChannelArray[String(ChanId)]; + // DEBUG_V (); + + // all went well + Response = true; + + } while (false); + + // DEBUG_END; + return Response; + +} // FindChannelJsonConfig + +//----------------------------------------------------------------------------- +/* + check the contents of the config and send + the proper portion of the config to the currently instantiated channels +*/ +bool c_InputMgr::ProcessJsonConfig (JsonObject & jsonConfig) +{ + // DEBUG_START; + bool Response = false; + + // DEBUG_V ("InputDataBufferSize: " + String (InputDataBufferSize)); + + do // once + { // for each Input channel for (uint32_t ChannelIndex = uint32_t (InputChannelId_Start); ChannelIndex < uint32_t (InputChannelId_End); ChannelIndex++) { - // get access to the channel config - if (false == InputChannelArray.containsKey (String (ChannelIndex))) + JsonObject InputChannelConfig; + // DEBUG_V (""); + if(!FindJsonChannelConfig(jsonConfig, e_InputChannelIds(ChannelIndex), InputChannelConfig)) { - // if not, flag an error and stop processing - logcon (String (F ("No Input Settings Found for Channel '")) + ChannelIndex + String (F ("'. Using Defaults"))); + DEBUG_V("Did not find the desired channel configuration"); continue; } - JsonObject InputChannelConfig = InputChannelArray[String (ChannelIndex)]; - // DEBUG_V (""); - // set a default value for channel type uint32_t ChannelType = uint32_t (InputType_Default); setFromJSON (ChannelType, InputChannelConfig, CN_type); diff --git a/ESPixelStick/src/input/InputMgr.hpp b/ESPixelStick/src/input/InputMgr.hpp index 8f1a18eaf..040ddb320 100644 --- a/ESPixelStick/src/input/InputMgr.hpp +++ b/ESPixelStick/src/input/InputMgr.hpp @@ -111,6 +111,7 @@ class c_InputMgr void CreateJsonConfig (JsonObject & jsonConfig); bool ProcessJsonChannelConfig (JsonObject & jsonConfig, uint32_t ChannelIndex); bool InputTypeIsAllowedOnChannel (e_InputType type, e_InputChannelIds ChannelId); + bool FindJsonChannelConfig (JsonObject& jsonConfig, e_InputChannelIds ChanId, JsonObject& ChanConfig); String ConfigFileName; bool rebootNeeded = false; diff --git a/ESPixelStick/src/output/OutputMgr.cpp b/ESPixelStick/src/output/OutputMgr.cpp index 4a6371d5a..1e6dc58d9 100644 --- a/ESPixelStick/src/output/OutputMgr.cpp +++ b/ESPixelStick/src/output/OutputMgr.cpp @@ -245,7 +245,7 @@ void c_OutputMgr::Begin () if (0 == OutputChannelId_End) { - logcon("ERROR: No output Channels defined. Rebooting"); + logcon("ERROR: No compiled output Channels defined. Rebooting"); RequestReboot(100000); break; } @@ -267,15 +267,15 @@ void c_OutputMgr::Begin () // DEBUG_V(String("init index: ") + String(index) + " Done"); } + // DEBUG_V("load up the configuration from the saved file. This also starts the drivers"); + LoadConfig(); + if(RestoredConfig) { // DEBUG_V("create a merged config"); CreateNewConfig(); } - // DEBUG_V("load up the configuration from the saved file. This also starts the drivers"); - LoadConfig(); - // Preset the output memory memset((void*)&OutputBuffer[0], 0x00, sizeof(OutputBuffer)); @@ -293,7 +293,7 @@ void c_OutputMgr::Begin () //----------------------------------------------------------------------------- void c_OutputMgr::CreateJsonConfig (JsonObject& jsonConfig) { - // DEBUG_START; + DEBUG_START; // extern void PrettyPrint (JsonObject&, String); // PrettyPrint (jsonConfig, String ("jsonConfig")); @@ -320,13 +320,12 @@ void c_OutputMgr::CreateJsonConfig (JsonObject& jsonConfig) String sChannelId = String(CurrentChannel.pOutputChannelDriver->GetOutputChannelId()); if (true == OutputMgrChannelsData.containsKey (sChannelId)) { - // DEBUG_V (); + // DEBUG_V (String("Channel Exists: ") + sChannelId); ChannelConfigData = OutputMgrChannelsData[sChannelId]; } else { - // add our section header - // DEBUG_V (); + // DEBUG_V (String ("add our channel section header. Chan: ") + sChannelId); ChannelConfigData = OutputMgrChannelsData.createNestedObject (sChannelId); } @@ -337,13 +336,12 @@ void c_OutputMgr::CreateJsonConfig (JsonObject& jsonConfig) JsonObject ChannelConfigByTypeData; if (true == ChannelConfigData.containsKey (String (DriverTypeId))) { + // DEBUG_V (String("Channel Type Data exists for chan: ") + sChannelId + " Type: " + DriverTypeId); ChannelConfigByTypeData = ChannelConfigData[DriverTypeId]; - // DEBUG_V (); } else { - // add our section header - // DEBUG_V (); + // DEBUG_V (String("Add Channel Type Data for chan: ") + sChannelId + " Type: " + DriverTypeId); ChannelConfigByTypeData = ChannelConfigData.createNestedObject (DriverTypeId); } @@ -356,7 +354,7 @@ void c_OutputMgr::CreateJsonConfig (JsonObject& jsonConfig) // Populate the driver name String DriverName = ""; CurrentChannel.pOutputChannelDriver->GetDriverName(DriverName); - // DEBUG_V (String ("DriverName: ") + DriverName); + DEBUG_V (String ("DriverName: ") + DriverName); ChannelConfigByTypeData[CN_type] = DriverName; @@ -376,7 +374,7 @@ void c_OutputMgr::CreateJsonConfig (JsonObject& jsonConfig) // PrettyPrint (jsonConfig, String ("jsonConfig")); // smile. Your done - // DEBUG_END; + DEBUG_END; } // CreateJsonConfig //----------------------------------------------------------------------------- @@ -403,11 +401,13 @@ void c_OutputMgr::CreateNewConfig () { logcon("Merging Restored Output Config File"); FileMgr.ReadFlashFile(ConfigFileName, JsonConfigDoc); + // extern void PrettyPrint(DynamicJsonDocument & jsonStuff, String Name); + // PrettyPrint(JsonConfigDoc, "New OutputMgr"); } if(!JsonConfigDoc.containsKey(CN_output_config)) { - // DEBUG_V("Create a new output config area."); + DEBUG_V("Create a new output config structure."); JsonConfigDoc.createNestedObject (CN_output_config); } JsonObject JsonConfig = JsonConfigDoc[CN_output_config]; @@ -416,7 +416,24 @@ void c_OutputMgr::CreateNewConfig () JsonConfig[CN_cfgver] = CurrentConfigVersion; JsonConfig[CN_MaxChannels] = sizeof(OutputBuffer); - // Collect the all ports disabled config first + e_OutputType SavedOutputTypes[OutputChannelId_End]; + DEBUG_V("Collect the restored config channel types"); + for (DriverInfo_t & CurrentOutputChannelDriver : OutputChannelDrivers) + { + e_OutputChannelIds ChanId = CurrentOutputChannelDriver.DriverId; + + JsonObject OutputChannelConfig; + if(!FindJsonChannelConfig(JsonConfigDoc, ChanId, e_OutputType::OutputType_End, OutputChannelConfig)) + { + DEBUG_V(String("Could not find channel config for channel: ") + String(ChanId)); + continue; + } + + setFromJSON (SavedOutputTypes[ChanId], OutputChannelConfig, CN_type); + DEBUG_V(String("Saved channel: ") + String(ChanId) + " Type: " + String(SavedOutputTypes[ChanId])); + } + + DEBUG_V("Collect the all ports disabled config first"); CreateJsonConfig (JsonConfig); // DEBUG_V ("for each output type"); @@ -428,6 +445,34 @@ void c_OutputMgr::CreateNewConfig () { // DEBUG_V (String("DriverId: ") + String(CurrentOutputChannelDriver.DriverId)); InstantiateNewOutputChannel(CurrentOutputChannelDriver, CurrentOutputType.id, false); + if(RestoredConfig) + { + JsonObject OutputChannelConfig; + if(!FindJsonChannelConfig(JsonConfigDoc, CurrentOutputChannelDriver.DriverId, e_OutputType::OutputType_End, OutputChannelConfig)) + { + DEBUG_V(String("Could not find channel config for channel: ") + String(CurrentOutputChannelDriver.DriverId)); + } + else + { + uint32_t ChannelType = CurrentOutputType.id; + // DEBUG_V (); + + // do we have a configuration for the channel type? + if (false == OutputChannelConfig.containsKey (String (ChannelType))) + { + // if not, flag an error and stop processing + continue; + } + + DEBUG_V (); + + JsonObject OutputChannelDriverConfig = OutputChannelConfig[String (ChannelType)]; + // PrettyPrint(OutputChannelConfig, "ProcessJson Channel Config"); + + CurrentOutputChannelDriver.pOutputChannelDriver->SetConfig(OutputChannelDriverConfig); + } + } + // DEBUG_V (); } // end for each interface @@ -449,11 +494,24 @@ void c_OutputMgr::CreateNewConfig () // DEBUG_V (); } // end for each output type - // DEBUG_V ("leave the outputs disabled"); - for (auto & CurrentOutputChannelDriver : OutputChannelDrivers) + if(RestoredConfig) + { + DEBUG_V ("Restore the outputs"); + for (DriverInfo_t & CurrentOutputChannelDriver : OutputChannelDrivers) + { + InstantiateNewOutputChannel(CurrentOutputChannelDriver, + SavedOutputTypes[CurrentOutputChannelDriver.DriverId], + false); + } + } + else { - InstantiateNewOutputChannel(CurrentOutputChannelDriver, e_OutputType::OutputType_Disabled); - }// end for each interface + // DEBUG_V ("leave the outputs disabled"); + for (auto & CurrentOutputChannelDriver : OutputChannelDrivers) + { + InstantiateNewOutputChannel(CurrentOutputChannelDriver, e_OutputType::OutputType_Disabled); + }// end for each interface + } // PrettyPrint(JsonConfig, "Complete OutputMgr"); @@ -1022,12 +1080,10 @@ void c_OutputMgr::LoadConfig () // PrettyPrint(JsonConfigDoc, "OM Load Config"); // DEBUG_V (); - JsonObject JsonConfig = JsonConfigDoc.as (); - // extern void PrettyPrint(JsonObject & jsonStuff, String Name); // PrettyPrint(JsonConfig, "OM Load Config"); // DEBUG_V (); - this->ProcessJsonConfig(JsonConfig); + this->ProcessJsonConfig(JsonConfigDoc); // DEBUG_V (); })) { @@ -1051,21 +1107,13 @@ void c_OutputMgr::LoadConfig () } // LoadConfig //----------------------------------------------------------------------------- -/* - check the contents of the config and send - the proper portion of the config to the currently instantiated channels - - needs - ref to data from config file - returns - true - config was properly processes - false - config had an error. -*/ -bool c_OutputMgr::ProcessJsonConfig (JsonObject& jsonConfig) +bool c_OutputMgr::FindJsonChannelConfig (DynamicJsonDocument& jsonConfig, + e_OutputChannelIds ChanId, + e_OutputType Type, + JsonObject& ChanConfig) { // DEBUG_START; bool Response = false; - // DEBUG_V (); // extern void PrettyPrint(JsonObject & jsonStuff, String Name); @@ -1073,9 +1121,9 @@ bool c_OutputMgr::ProcessJsonConfig (JsonObject& jsonConfig) do // once { - if (false == jsonConfig.containsKey (CN_output_config)) + if (!jsonConfig.containsKey (CN_output_config)) { - logcon(String(MN_16) + MN_18); + logcon(String(MN_16) + MN_18); break; } JsonObject OutputChannelMgrData = jsonConfig[CN_output_config]; @@ -1095,7 +1143,7 @@ bool c_OutputMgr::ProcessJsonConfig (JsonObject& jsonConfig) } // do we have a channel configuration array? - if (false == OutputChannelMgrData.containsKey (CN_channels)) + if (!OutputChannelMgrData.containsKey (CN_channels)) { // if not, flag an error and stop processing logcon(String(MN_16) + MN_18); @@ -1104,17 +1152,75 @@ bool c_OutputMgr::ProcessJsonConfig (JsonObject& jsonConfig) JsonObject OutputChannelArray = OutputChannelMgrData[CN_channels]; // DEBUG_V (); + // get access to the channel config + if (false == OutputChannelArray.containsKey(String(ChanId))) + { + // if not, flag an error and stop processing + logcon(String(MN_16) + ChanId + MN_18); + break; + } + + // do we need to go deeper into the config? + if(e_OutputType::OutputType_End == Type) + { + // only looking for the overall channel config + ChanConfig = OutputChannelArray[String(ChanId)]; + Response = true; + break; + } + // go deeper and get the config for the specific channel type + + // DEBUG_V (); + JsonObject OutputChannelConfig = OutputChannelArray[String(ChanId)]; + + // do we have a configuration for the channel type? + if (!OutputChannelConfig.containsKey (String (Type))) + { + // Not found + logcon(String(MN_16) + ChanId + MN_18); + break; + } + + // DEBUG_V (); + // PrettyPrint(OutputChannelConfig, "ProcessJson Channel Config"); + + ChanConfig = OutputChannelConfig[String (Type)]; + // DEBUG_V (); + // PrettyPrint(ChanConfig, "ProcessJson Channel Driver Config before driver create"); + // DEBUG_V (); + + // all went well + Response = true; + + } while (false); + + // DEBUG_END; + return Response; + +} // FindChannelJsonConfig + +//----------------------------------------------------------------------------- +bool c_OutputMgr::ProcessJsonConfig (DynamicJsonDocument& jsonConfig) +{ + // DEBUG_START; + bool Response = false; + + // DEBUG_V (); + + // extern void PrettyPrint(JsonObject & jsonStuff, String Name); + // PrettyPrint(jsonConfig, "ProcessJsonConfig"); + + do // once + { // for each output channel for (auto & CurrentOutputChannelDriver : OutputChannelDrivers) { - // get access to the channel config - if (false == OutputChannelArray.containsKey(String(CurrentOutputChannelDriver.DriverId).c_str())) + JsonObject OutputChannelConfig; + if(!FindJsonChannelConfig (jsonConfig, CurrentOutputChannelDriver.DriverId, e_OutputType::OutputType_End, OutputChannelConfig)) { - // if not, flag an error and stop processing - logcon(String(MN_16) + CurrentOutputChannelDriver.DriverId + MN_18); - break; + DEBUG_V(String("cant find config for channel: ") + String(CurrentOutputChannelDriver.DriverId)); + continue; } - JsonObject OutputChannelConfig = OutputChannelArray[String(CurrentOutputChannelDriver.DriverId).c_str()]; // DEBUG_V (); // extern void PrettyPrint (JsonObject& jsonStuff, String Name); diff --git a/ESPixelStick/src/output/OutputMgr.hpp b/ESPixelStick/src/output/OutputMgr.hpp index 21e28040a..15d8ee205 100644 --- a/ESPixelStick/src/output/OutputMgr.hpp +++ b/ESPixelStick/src/output/OutputMgr.hpp @@ -238,12 +238,13 @@ class c_OutputMgr bool IsOutputPaused = false; bool BuildingNewConfig = false; - bool ProcessJsonConfig (JsonObject & jsonConfig); + bool ProcessJsonConfig (DynamicJsonDocument & jsonConfig); void CreateJsonConfig (JsonObject & jsonConfig); void UpdateDisplayBufferReferences (void); void InstantiateNewOutputChannel(DriverInfo_t &ChannelIndex, e_OutputType NewChannelType, bool StartDriver = true); void CreateNewConfig(); void SetSerialUart(); + bool FindJsonChannelConfig (DynamicJsonDocument& jsonConfig, e_OutputChannelIds ChanId, e_OutputType Type, JsonObject& ChanConfig); String ConfigFileName;