diff --git a/include/classes/IoTSensor.h b/include/classes/IoTSensor.h index 34d6969e..e790cff5 100644 --- a/include/classes/IoTSensor.h +++ b/include/classes/IoTSensor.h @@ -25,5 +25,11 @@ class IoTSensor { unsigned long _interval; }; +struct ModuleInfo +{ + void* apiToComponent; + String defConfig; +}; + //extern IoTSensor* myIoTSensor; //модулям не нужно знать эту переменную \ No newline at end of file diff --git a/src/ESPConfiguration.cpp b/src/ESPConfiguration.cpp index a6891696..7564c4cd 100644 --- a/src/ESPConfiguration.cpp +++ b/src/ESPConfiguration.cpp @@ -1,12 +1,7 @@ #include "ESPConfiguration.h" std::vector iotSensors; -void* getAPI(String subtype, String params); - -//============================================================================================ -//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора -extern void* getAPI_AnalogAdc(String params); -//============================================================================================ +ModuleInfo getAPI(String subtype, String params); void configure(String path) { File file = seekFile(path); @@ -22,7 +17,7 @@ void configure(String path) { SerialPrint(F("E"), F("Config"), "json error " + subtype); continue; } else { - myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement); + myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement).apiToComponent; if (myIoTSensor) { iotSensors.push_back(myIoTSensor); createWidget(jsonArrayElement); diff --git a/src/modules/API.cpp b/src/modules/API.cpp index be4fe2d4..5eb53404 100644 --- a/src/modules/API.cpp +++ b/src/modules/API.cpp @@ -2,18 +2,22 @@ //============================================================================================ //здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора -void* getAPI_AnalogAdc(String subtype, String params); -void* getAPI_ds18b20(String subtype, String params); +ModuleInfo getAPI_AnalogAdc(String subtype, String params); +ModuleInfo getAPI_ds18b20(String subtype, String params); //============================================================================================ -void* getAPI(String subtype, String params) { - void* tmpAPI; +ModuleInfo getAPI(String subtype, String params) { + ModuleInfo tmpMi; + String defConfig = ""; //=============================================================================================================== //здесь нужно скопировать строку еще раз и вставить ее ниже, переименовав AnalogAdc на название вашего сенсора - if ((tmpAPI = getAPI_AnalogAdc(subtype, params)) != nullptr) return tmpAPI; + if ((tmpMi = getAPI_AnalogAdc(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig; //================================================================================================================ - if ((tmpAPI = getAPI_ds18b20(subtype, params)) != nullptr) return tmpAPI; + if ((tmpMi = getAPI_ds18b20(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig; - return nullptr; + + + tmpMi.defConfig = defConfig; + return tmpMi; } \ No newline at end of file diff --git a/src/modules/AnalogAdc.cpp b/src/modules/AnalogAdc.cpp index df806dd8..0766751d 100644 --- a/src/modules/AnalogAdc.cpp +++ b/src/modules/AnalogAdc.cpp @@ -46,10 +46,13 @@ class AnalogAdc : public IoTSensor { //после замены названия сенсора, на функцию можно не обращать внимания //если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть //создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20) -void* getAPI_AnalogAdc(String subtype, String param) { +ModuleInfo getAPI_AnalogAdc(String subtype, String param) { + ModuleInfo mi; + mi.apiToComponent = nullptr; + mi.defConfig = "конфин такой вот джисон"; if (subtype == F("AnalogAdc")) { - return new AnalogAdc(param); - } else { - return nullptr; + mi.apiToComponent = new AnalogAdc(param); } + + return mi; } diff --git a/src/modules/ds18b20.cpp b/src/modules/ds18b20.cpp index 74fb434f..fe5d19cb 100644 --- a/src/modules/ds18b20.cpp +++ b/src/modules/ds18b20.cpp @@ -82,10 +82,13 @@ class ds18b20 : public IoTSensor { //после замены названия сенсора, на функцию можно не обращать внимания //если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть //создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20) -void* getAPI_ds18b20(String subtype, String param) { - if (subtype == F("ds18b20")) { - return new ds18b20(param); - } else { - return nullptr; - } +ModuleInfo getAPI_ds18b20(String subtype, String param) { + ModuleInfo mi; + mi.apiToComponent = nullptr; + mi.defConfig = "конфин такой вот джисон"; + if (subtype == F("AnalogAdc")) { + mi.apiToComponent = new ds18b20(param); + } + + return mi; }