From 8c8ac1d8009504ed0828ba4d3a931dc6bc02f893 Mon Sep 17 00:00:00 2001 From: biver Date: Wed, 23 Feb 2022 20:14:29 +0300 Subject: [PATCH] =?UTF-8?q?=D0=92=D0=BE=D0=B7=D0=B2=D1=80=D0=B0=D1=89?= =?UTF-8?q?=D0=B0=D0=B5=D0=BC=20=D0=BD=D0=B0=D1=81=D1=82=D1=80=D0=BE=D0=B9?= =?UTF-8?q?=D0=BA=D1=83=20=D1=81=D1=86=D0=B5=D0=BD=D0=B0=D1=80=D0=B8=D1=8F?= =?UTF-8?q?=20=D0=BD=D0=B0=20=D0=B8=D1=81=D0=BF=D0=BE=D0=BB=D1=8C=D0=B7?= =?UTF-8?q?=D0=BE=D0=B2=D0=B0=D0=BD=D0=B8=D0=B5=20=D1=82=D0=BE=D0=BB=D1=8C?= =?UTF-8?q?=D0=BA=D0=BE=20Items=20=D0=B4=D0=BB=D1=8F=20=D0=BF=D0=BE=D0=B8?= =?UTF-8?q?=D1=81=D0=BA=D0=B0=20=D0=BF=D0=B5=D1=80=D0=B5=D0=BC=D0=B5=D0=BD?= =?UTF-8?q?=D0=BD=D1=8B=D1=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/classes/IoTScenario.cpp | 36 +++++++----------------------------- 1 file changed, 7 insertions(+), 29 deletions(-) diff --git a/src/classes/IoTScenario.cpp b/src/classes/IoTScenario.cpp index e05d3a88..41359632 100644 --- a/src/classes/IoTScenario.cpp +++ b/src/classes/IoTScenario.cpp @@ -56,26 +56,17 @@ public: }; /// VariableExprAST - Класс узла выражения для переменных (например, "a"). -class VariableExprAST : public ExprAST, IoTItem { +class VariableExprAST : public ExprAST { String Name; IoTItem* Item; // ссылка на объект модуля (прямой доступ к идентификатору указанному в сценарии), если получилось найти модуль по ID - //IoTValue value; // хранение данных для внешних переменных если не найдены в итемсах берем из базового класса IoTItem public: - VariableExprAST(const String &name, IoTItem* item) : Name(name), Item(item), IoTItem("") {} + VariableExprAST(const String &name, IoTItem* item) : Name(name), Item(item) {} - int setValue(IoTValue *valueIn) { + int setValue(IoTValue *val) { if (Item) { //Item->value = *val; // устанавливаем значение в связанном Item модуля напрямую - Item->setValue(*valueIn); - } else { - // Итем ноль, значит это переменная отсутсвует в Итемсах, значит пишем в глобальное хранилище - if (valueIn->isDecimal) { - jsonWriteFloat_(paramsHeapJson, Name, valueIn->valD); - } else { - jsonWriteStr_(paramsHeapJson, Name, valueIn->valS); - } - IoTItem::setValue(*valueIn); + Item->setValue(*val); } return 1; } @@ -85,19 +76,7 @@ public: Serial.printf("Call from VariableExprAST: %s = %f\n", Name.c_str(), Item->value.valD); else Serial.printf("Call from VariableExprAST: %s = %s\n", Name.c_str(), Item->value.valS.c_str()); - // если Итем не был найден по ID (Item == nulptr) значит либо опечатка, либо это ИД из другого контроллера, поэтому осуществляем поиск значения в - // глобальном сетевом хранилище переменных - if (Item) return &(Item->value); - else { - // смотрим в хранилище - String valueStr; - jsonRead(paramsHeapJson, Name, valueStr); - if (value.isDecimal = isDigitDotCommaStr(valueStr)) - value.valD = valueStr.toFloat(); - else - value.valS = valueStr; - return &value; - } + return &(Item->value); } }; @@ -443,9 +422,8 @@ public: } if (CurTok != '(') { // Обычная переменная. - //if (tmpItem) - return new VariableExprAST(IdName, tmpItem); - // else return new StringExprAST("id " + IdName + " not_found"); + if (tmpItem) return new VariableExprAST(IdName, tmpItem); + else return new StringExprAST("id " + IdName + " not_found"); } // Вызов функции.