Przeglądaj źródła

Implement sensors save to SD-card, improved sensors loading

Victor 3 lat temu
rodzic
commit
6c5a4bc59e
4 zmienionych plików z 87 dodań i 1 usunięć
  1. 5 0
      interfaces/OneWire.c
  2. 8 0
      interfaces/OneWire.h
  3. 59 1
      interfaces/Sensors.c
  4. 15 0
      interfaces/Sensors.h

+ 5 - 0
interfaces/OneWire.c

@@ -38,6 +38,11 @@ bool unitemp_oneWire_sensorSetGPIO(Sensor* sensor, const GPIO* gpio) {
     instance->gpio = gpio;
     return true;
 }
+const GPIO* unitemp_oneWire_sensorGetGPIO(Sensor* sensor) {
+    if(sensor == NULL) return NULL;
+    OneWireSensor* instance = sensor->instance;
+    return instance->gpio;
+}
 
 UnitempStatus unitemp_oneWire_getData(Sensor* sensor) {
     OneWireSensor* instance = sensor->instance;

+ 8 - 0
interfaces/OneWire.h

@@ -46,4 +46,12 @@ UnitempStatus unitemp_oneWire_getData(Sensor* sensor);
  */
 bool unitemp_oneWire_sensorSetGPIO(Sensor* sensor, const GPIO* gpio);
 
+/**
+ * @brief Получить порт датчика
+ * 
+ * @param sensor Указатель на датчик
+ * @return Указатель на GPIO
+ */
+const GPIO* unitemp_oneWire_sensorGetGPIO(Sensor* sensor);
+
 #endif

+ 59 - 1
interfaces/Sensors.c

@@ -60,6 +60,16 @@ const GPIO* unitemp_GPIO_getFromInt(uint8_t name) {
     return NULL;
 }
 
+uint8_t unitemp_GPIO_toInt(const GpioPin* gpio) {
+    if(gpio == NULL) return 255;
+    for(uint8_t i = 0; i < GPIO_ITEMS; i++) {
+        if(GPIOList[i].pin->pin == gpio->pin && GPIOList[i].pin->port == gpio->port) {
+            return GPIOList[i].num;
+        }
+    }
+    return 255;
+}
+
 bool unitemp_sensors_load() {
     FURI_LOG_D(APP_NAME, "Loading sensors...");
     app->sensors_count = 0;
@@ -127,6 +137,8 @@ bool unitemp_sensors_load() {
         char name[11] = {0};
         int type = 255, otherValue = 255;
         sscanf(line, "%s %d %d", name, &type, &otherValue);
+        //Ограничение длины имени
+        name[10] = '\0';
         FURI_LOG_D(APP_NAME, "%s %d %d", name, type, otherValue);
         //Проверка типа датчика
         if(type < SENSOR_TYPES_COUNT && sizeof(name) <= 11) {
@@ -160,13 +172,59 @@ bool unitemp_sensors_load() {
     return true;
 }
 
+bool unitemp_sensors_save(void) {
+    FURI_LOG_D(APP_NAME, "Saving sensors...");
+
+    //Выделение памяти для потока
+    app->file_stream = file_stream_alloc(app->storage);
+
+    //Переменная пути к файлу
+    char filepath[sizeof(APP_PATH_FOLDER) + sizeof(APP_FILENAME_SENSORS)] = {0};
+    //Составление пути к файлу
+    strcpy(filepath, APP_PATH_FOLDER);
+    strcat(filepath, "/");
+    strcat(filepath, APP_FILENAME_SENSORS);
+    //Создание папки плагина
+    storage_common_mkdir(app->storage, APP_PATH_FOLDER);
+    //Открытие потока
+    if(!file_stream_open(app->file_stream, filepath, FSAM_READ_WRITE, FSOM_CREATE_ALWAYS)) {
+        FURI_LOG_E(
+            APP_NAME,
+            "An error occurred while saving the sensors file: %d",
+            file_stream_get_error(app->file_stream));
+        //Закрытие потока и освобождение памяти
+        file_stream_close(app->file_stream);
+        stream_free(app->file_stream);
+        return false;
+    }
+
+    //Сохранение датчиков
+    for(size_t i = 0; i < app->sensors_count; i++) {
+        if(app->sensors[i]->interface == ONE_WIRE) {
+            stream_write_format(
+                app->file_stream,
+                "%s %d %d\n",
+                app->sensors[i]->name,
+                app->sensors[i]->type,
+                unitemp_GPIO_toInt(unitemp_oneWire_sensorGetGPIO(app->sensors[i])->pin));
+        }
+    }
+
+    //Закрытие потока и освобождение памяти
+    file_stream_close(app->file_stream);
+    stream_free(app->file_stream);
+
+    FURI_LOG_I(APP_NAME, "Sensors have been successfully saved");
+    return true;
+}
+
 Sensor* unitemp_sensor_alloc(char* name, SensorType st) {
     //Выделение памяти под датчик
     Sensor* sensor = malloc(sizeof(Sensor));
     if(sensor == NULL) return false;
     sensor->name = malloc(11);
     strcpy(sensor->name, name);
-    //Выделение памяти под инстанс DHT11, DHT12 (1W), DHT21, DHT22, AM2320 (1W)
+    //Выделение памяти под инстанс датчиков One Wire
     if(st == DHT11 || st == DHT12_1W || st == DHT21 || st == DHT22 || st == AM2320_1W) {
         OneWireSensor* instance = malloc(sizeof(OneWireSensor));
         instance->interface = ONE_WIRE;

+ 15 - 0
interfaces/Sensors.h

@@ -82,6 +82,14 @@ const char* unitemp_getSensorTypeName(SensorType st);
  */
 const GPIO* unitemp_GPIO_getFromInt(uint8_t name);
 
+/**
+ * @brief Конвертация GPIO в номер на корпусе FZ
+ * 
+ * @param gpio Указатель на порт
+ * @return Номер порта на корпусе FZ
+ */
+uint8_t unitemp_GPIO_toInt(const GpioPin* gpio);
+
 /**
  * @brief Выделение памяти под датчик
  * 
@@ -120,4 +128,11 @@ UnitempStatus unitemp_sensor_getValues(Sensor* sensor);
  */
 bool unitemp_sensors_load();
 
+/**
+ * @brief Сохранение настроек на SD-карту
+ * 
+ * @return Истина если сохранение прошло успешно
+ */
+bool unitemp_sensors_save(void);
+
 #endif