From 4941c57ce97932371415cb74d5a75a6b0a23d65d Mon Sep 17 00:00:00 2001 From: DriftKingTW Date: Wed, 18 Dec 2024 02:32:56 +0800 Subject: [PATCH] fix: serial update config conflict --- src/main.cpp | 68 ++++++++++++++++++++++++++-------------------------- 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/src/main.cpp b/src/main.cpp index 11987d1..520d998 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -349,40 +349,7 @@ void generalTask(void *pvParameters) { while (true) { checkBattery(); - - // Accept Serial input for keyconfig.json - if (Serial.available() > 0) { - String jsonString = Serial.readString(); - Serial.println("Received JSON:"); - Serial.println(jsonString); - - // Parse JSON - DynamicJsonDocument doc(jsonDocSize); - deserializeJson(doc, jsonString); - - // Check if JSON overflowed - if (doc.overflowed() || doc.isNull()) { - Serial.println("JSON overflowed or empty"); - } else { - // Save JSON to SPIFFS as keyconfig.json - File configFile = SPIFFS.open("/keyconfig.json", "w"); - if (!configFile) { - Serial.println("Failed to open config file for writing"); - } - if (!serializeJson(doc, configFile)) { - Serial.println("Failed to write to config file"); - } - configFile.close(); - - // Reload keymaps - keymapsNeedsUpdate = true; - - // Show config updated message - configUpdated = true; - Serial.println("Config updated!"); - } - } - + // if (isDetectingLastConnectedDevice && bleKeyboard.isConnected() && // bleKeyboard.getCounnectedCount() > 1) { // isDetectingLastConnectedDevice = false; @@ -905,6 +872,39 @@ void loop() { return; } + // Accept Serial input for keyconfig.json + if (Serial.available() > 0) { + String jsonString = Serial.readString(); + Serial.println("Received JSON:"); + Serial.println(jsonString); + + // Parse JSON + DynamicJsonDocument doc(jsonDocSize); + deserializeJson(doc, jsonString); + + // Check if JSON overflowed + if (doc.overflowed() || doc.isNull()) { + Serial.println("JSON overflowed or empty"); + } else { + // Save JSON to SPIFFS as keyconfig.json + File configFile = SPIFFS.open("/keyconfig.json", "w"); + if (!configFile) { + Serial.println("Failed to open config file for writing"); + } + if (!serializeJson(doc, configFile)) { + Serial.println("Failed to write to config file"); + } + configFile.close(); + + // Reload keymaps + keymapsNeedsUpdate = true; + + // Show config updated message + configUpdated = true; + Serial.println("Config updated!"); + } + } + // Keypad scan for (int r = 0; r < ROWS; r++) { digitalWrite(outputs[r], LOW); // Setting one row low