Switched waterlevel to queue
All checks were successful
Test project compilation / test (push) Successful in 3m51s
All checks were successful
Test project compilation / test (push) Successful in 3m51s
This commit is contained in:
2
.vscode/extensions.json
vendored
2
.vscode/extensions.json
vendored
@@ -1,4 +1,6 @@
|
||||
{
|
||||
// See http://go.microsoft.com/fwlink/?LinkId=827846
|
||||
// for the documentation about the extensions.json format
|
||||
"recommendations": [
|
||||
"pioarduino.pioarduino-ide",
|
||||
"platformio.platformio-ide"
|
||||
|
||||
@@ -3,9 +3,9 @@
|
||||
#include <Elog.h>
|
||||
#include "../tools/tools.h"
|
||||
#include <tools/log.h>
|
||||
#include "../global_data/water_data_queue.h"
|
||||
|
||||
extern ActiveErrors active_errors;
|
||||
extern WaterData water_data;
|
||||
|
||||
void display_task(void* parameter)
|
||||
{
|
||||
|
||||
@@ -5,7 +5,6 @@ NetworkData ethernet_data;
|
||||
DeviceTelemetry telemetry;
|
||||
|
||||
SensorData shunt_data;
|
||||
WaterData water_data;
|
||||
|
||||
OTAStatus ota_status;
|
||||
|
||||
|
||||
30
src/global_data/water_data_queue.cpp
Normal file
30
src/global_data/water_data_queue.cpp
Normal file
@@ -0,0 +1,30 @@
|
||||
#include "water_data_queue.h"
|
||||
#include <Arduino.h>
|
||||
|
||||
QueueHandle_t waterDataQueue = nullptr;
|
||||
|
||||
void initWaterDataQueue() {
|
||||
// Create queue that can hold 5 WaterData structures
|
||||
waterDataQueue = xQueueCreate(5, sizeof(WaterData));
|
||||
|
||||
if (waterDataQueue == nullptr) {
|
||||
Serial.println("Failed to create water data queue");
|
||||
}
|
||||
}
|
||||
|
||||
WaterData getLatestWaterData() {
|
||||
WaterData latestData;
|
||||
|
||||
// Try to receive the latest data without blocking
|
||||
if (xQueueReceive(waterDataQueue, &latestData, 0) == pdPASS) {
|
||||
// Put the data back in the queue so other consumers can get it too
|
||||
xQueueSendToBack(waterDataQueue, &latestData, 0);
|
||||
return latestData;
|
||||
}
|
||||
|
||||
// Return default values if queue is empty
|
||||
latestData.level = 0.0f;
|
||||
latestData.liters = 0.0f;
|
||||
latestData.percentage = 0.0f;
|
||||
return latestData;
|
||||
}
|
||||
12
src/global_data/water_data_queue.h
Normal file
12
src/global_data/water_data_queue.h
Normal file
@@ -0,0 +1,12 @@
|
||||
#pragma once
|
||||
#include "global_data.h"
|
||||
#include "freertos/queue.h"
|
||||
|
||||
// Create a queue handle for WaterData
|
||||
extern QueueHandle_t waterDataQueue;
|
||||
|
||||
// Initialize the water data queue
|
||||
void initWaterDataQueue();
|
||||
|
||||
// Helper function to get latest water data
|
||||
WaterData getLatestWaterData();
|
||||
@@ -13,6 +13,7 @@
|
||||
#include <ArduinoOTA.h>
|
||||
|
||||
#include "global_data/defines.h"
|
||||
#include "global_data/water_data_queue.h"
|
||||
|
||||
#include "networking/networking.h"
|
||||
|
||||
@@ -32,7 +33,6 @@
|
||||
|
||||
Preferences prefs;
|
||||
|
||||
extern WaterData water_data;
|
||||
extern DeviceTelemetry telemetry;
|
||||
extern NetworkData wifi_data;
|
||||
extern NetworkData ethernet_data;
|
||||
@@ -60,6 +60,9 @@ void setup()
|
||||
LOG(ELOG_LEVEL_DEBUG, "Init Sensor");
|
||||
init_sensor();
|
||||
|
||||
LOG(ELOG_LEVEL_DEBUG, "Init Water Data Queue");
|
||||
initWaterDataQueue();
|
||||
|
||||
LOG(ELOG_LEVEL_DEBUG, "Beginning LittleFS");
|
||||
LittleFS.begin(FORMAT_LITTLEFS_IF_FAILED);
|
||||
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
#include "json_builder.h"
|
||||
#include <Elog.h>
|
||||
#include "../global_data/water_data_queue.h"
|
||||
|
||||
extern WaterData water_data;
|
||||
extern DeviceTelemetry telemetry;
|
||||
extern NetworkData wifi_data;
|
||||
extern NetworkData ethernet_data;
|
||||
|
||||
@@ -8,8 +8,8 @@
|
||||
#include "json_builder.h"
|
||||
#include "../tools/tools.h"
|
||||
#include <SPIFFS.h>
|
||||
#include "../global_data/water_data_queue.h"
|
||||
|
||||
extern WaterData water_data;
|
||||
extern DeviceTelemetry telemetry;
|
||||
extern NetworkData wifi_data;
|
||||
extern NetworkData ethernet_data;
|
||||
@@ -25,18 +25,21 @@ void setup_api_endpoints(){
|
||||
request->send(200, "application/json", output); });
|
||||
|
||||
server.on("/water_data", HTTP_GET, [](AsyncWebServerRequest* request) {
|
||||
WaterData current_water_data = getLatestWaterData();
|
||||
String output;
|
||||
serializeJson(build_water_data_json(water_data), output);
|
||||
serializeJson(build_water_data_json(current_water_data), output);
|
||||
request->send(200, "application/json", output); });
|
||||
|
||||
server.on("/raw_percent", HTTP_GET, [](AsyncWebServerRequest* request) {
|
||||
WaterData current_water_data = getLatestWaterData();
|
||||
String output;
|
||||
output = water_data.percentage;
|
||||
output = String(current_water_data.percentage);
|
||||
request->send(200, "text/raw", output); });
|
||||
|
||||
server.on("/raw_level", HTTP_GET, [](AsyncWebServerRequest* request) {
|
||||
WaterData current_water_data = getLatestWaterData();
|
||||
String output;
|
||||
output = water_data.level;
|
||||
output = String(current_water_data.level);
|
||||
request->send(200, "text/raw", output); });
|
||||
|
||||
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
#include <Elog.h>
|
||||
#include "Wire.h"
|
||||
#include "../global_data/global_data.h"
|
||||
#include "../global_data/water_data_queue.h"
|
||||
|
||||
|
||||
#ifdef USE_INA226
|
||||
@@ -18,7 +19,6 @@ INA233 ina_sensor(0x40);
|
||||
#include "freertos/task.h"
|
||||
|
||||
extern Preferences prefs;
|
||||
extern WaterData water_data;
|
||||
extern ActiveErrors active_errors;
|
||||
extern SensorData shunt_data;
|
||||
|
||||
@@ -106,9 +106,16 @@ void read_sensor_task(void* parameter)
|
||||
shunt_data.shunt_voltage = shunt_voltage;
|
||||
shunt_data.shunt_current = shunt_current;
|
||||
|
||||
water_data.level = cm_over_zero;
|
||||
water_data.liters = liters;
|
||||
water_data.percentage = percentage_rounded;
|
||||
// Create water data structure and send to queue
|
||||
WaterData current_water_data;
|
||||
current_water_data.level = cm_over_zero;
|
||||
current_water_data.liters = liters;
|
||||
current_water_data.percentage = percentage_rounded;
|
||||
|
||||
// Send to queue, don't block if queue is full
|
||||
if (waterDataQueue != nullptr) {
|
||||
xQueueSendToBack(waterDataQueue, ¤t_water_data, 0);
|
||||
}
|
||||
|
||||
delay(20000);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user