Merge branch 'filesystem' into mergefs-201112
This commit is contained in:
		| @@ -3,16 +3,16 @@ | ||||
| /* | ||||
|    Main sketch, global variable declarations | ||||
|    @title WLED project sketch | ||||
|    @version 0.10.2 | ||||
|    @version 0.11.0p | ||||
|    @author Christian Schwinne | ||||
|  */ | ||||
|  | ||||
| // version code in format yymmddb (b = daily build) | ||||
| #define VERSION 2011120 | ||||
| #define VERSION 2011121 | ||||
|  | ||||
| // ESP8266-01 (blue) got too little storage space to work with all features of WLED. To use it, you must use ESP8266 Arduino Core v2.4.2 and the setting 512K(No SPIFFS). | ||||
| // ESP8266-01 (blue) got too little storage space to work with WLED. 0.10.2 is the last release supporting this unit. | ||||
|  | ||||
| // ESP8266-01 (black) has 1MB flash and can thus fit the whole program. Use 1M(64K SPIFFS). | ||||
| // ESP8266-01 (black) has 1MB flash and can thus fit the whole program, although OTA update is not possible. Use 1M(128K SPIFFS). | ||||
| // Uncomment some of the following lines to disable features to compile for ESP8266-01 (max flash size 434kB): | ||||
| // Alternatively, with platformio pass your chosen flags to your custom build target in platformio.ini.override | ||||
|  | ||||
| @@ -35,19 +35,23 @@ | ||||
|   #define WLED_ENABLE_WEBSOCKETS | ||||
| #endif | ||||
|  | ||||
| #define WLED_DISABLE_FILESYSTEM    // SPIFFS is not used by any WLED feature yet | ||||
| //#define WLED_ENABLE_FS_SERVING   // Enable sending html file from SPIFFS before serving progmem version | ||||
| //#define WLED_ENABLE_FS_EDITOR    // enable /edit page for editing SPIFFS content. Will also be disabled with OTA lock | ||||
| //#define WLED_DISABLE_FILESYSTEM  // FS used by new preset functionality | ||||
| #define WLED_ENABLE_FS_SERVING     // Enable sending html file from SPIFFS before serving progmem version | ||||
| #define WLED_ENABLE_FS_EDITOR      // enable /edit page for editing SPIFFS content. Will also be disabled with OTA lock | ||||
|  | ||||
| // to toggle usb serial debug (un)comment the following line | ||||
| //#define WLED_DEBUG | ||||
|  | ||||
| // filesystem specific debugging | ||||
| //#define WLED_DEBUG_FS | ||||
|  | ||||
| // Library inclusions.  | ||||
| #include <Arduino.h> | ||||
| #ifdef ESP8266 | ||||
|   #include <ESP8266WiFi.h> | ||||
|   #include <ESP8266mDNS.h> | ||||
|   #include <ESPAsyncTCP.h> | ||||
|   #include <LittleFS.h> | ||||
|   extern "C" | ||||
|   { | ||||
|   #include <user_interface.h> | ||||
| @@ -57,7 +61,9 @@ | ||||
|   #include "esp_wifi.h" | ||||
|   #include <ESPmDNS.h> | ||||
|   #include <AsyncTCP.h> | ||||
|   #include "SPIFFS.h" | ||||
|   //#include "SPIFFS.h" | ||||
|   #define CONFIG_LITTLEFS_FOR_IDF_3_2 | ||||
|   #include <LITTLEFS.h> | ||||
| #endif | ||||
|  | ||||
| #include <ESPAsyncWebServer.h> | ||||
| @@ -109,6 +115,12 @@ | ||||
|   #define CLIENT_PASS "" | ||||
| #endif | ||||
|  | ||||
| #ifndef SPIFFS_EDITOR_AIRCOOOKIE | ||||
|   #error You are not using the Aircoookie fork of the ESPAsyncWebserver library.\ | ||||
|   Using upstream puts your WiFi password at risk of being served by the filesystem.\ | ||||
|   Comment out this error message to build regardless. | ||||
| #endif | ||||
|  | ||||
| #if IR_PIN < 0 | ||||
|   #ifndef WLED_DISABLE_INFRARED | ||||
|     #define WLED_DISABLE_INFRARED | ||||
| @@ -121,25 +133,18 @@ | ||||
|   #include <IRutils.h> | ||||
| #endif | ||||
|  | ||||
| //Filesystem to use for preset and config files. SPIFFS or LittleFS on ESP8266, SPIFFS only on ESP32 (now using LITTLEFS port by lorol) | ||||
| #ifdef ESP8266 | ||||
|   #define WLED_FS LittleFS | ||||
| #else | ||||
|   #define WLED_FS LITTLEFS | ||||
| #endif | ||||
|  | ||||
| // remove flicker because PWM signal of RGB channels can become out of phase (part of core as of Arduino core v2.7.0) | ||||
| //#if defined(WLED_USE_ANALOG_LEDS) && defined(ESP8266) | ||||
| //  #include "src/dependencies/arduino/core_esp8266_waveform.h" | ||||
| //#endif | ||||
|  | ||||
| // enable additional debug output | ||||
| #ifdef WLED_DEBUG | ||||
|   #ifndef ESP8266 | ||||
|   #include <rom/rtc.h> | ||||
|   #endif | ||||
|   #define DEBUG_PRINT(x) Serial.print(x) | ||||
|   #define DEBUG_PRINTLN(x) Serial.println(x) | ||||
|   #define DEBUG_PRINTF(x) Serial.printf(x) | ||||
| #else | ||||
|   #define DEBUG_PRINT(x) | ||||
|   #define DEBUG_PRINTLN(x) | ||||
|   #define DEBUG_PRINTF(x) | ||||
| #endif | ||||
|  | ||||
| // GLOBAL VARIABLES | ||||
| // both declared and defined in header (solution from http://www.keil.com/support/docs/1868.htm) | ||||
| // | ||||
| @@ -160,8 +165,8 @@ | ||||
| #endif | ||||
|  | ||||
| // Global Variable definitions | ||||
| WLED_GLOBAL char versionString[] _INIT("0.10.2"); | ||||
| #define WLED_CODENAME "Fumikiri" | ||||
| WLED_GLOBAL char versionString[] _INIT("0.11.0p"); | ||||
| #define WLED_CODENAME "Mirai" | ||||
|  | ||||
| // AP and OTA default passwords (for maximum security change them!) | ||||
| WLED_GLOBAL char apPass[65]  _INIT(DEFAULT_AP_PASS); | ||||
| @@ -170,8 +175,12 @@ WLED_GLOBAL char otaPass[33] _INIT(DEFAULT_OTA_PASS); | ||||
| // Hardware CONFIG (only changeble HERE, not at runtime) | ||||
| // LED strip pin, button pin and IR pin changeable in NpbWrapper.h! | ||||
|  | ||||
| //WLED_GLOBAL byte presetToApply _INIT(0);  | ||||
|  | ||||
| #if AUXPIN >= 0 | ||||
| WLED_GLOBAL byte auxDefaultState _INIT(0);                         // 0: input 1: high 2: low | ||||
| WLED_GLOBAL byte auxTriggeredState _INIT(0);                       // 0: input 1: high 2: low | ||||
| #endif | ||||
| WLED_GLOBAL char ntpServerName[33] _INIT("0.wled.pool.ntp.org");   // NTP server to use | ||||
|  | ||||
| // WiFi CONFIG (all these can be changed via web UI, no need to set them here) | ||||
| @@ -291,7 +300,6 @@ WLED_GLOBAL byte countdownYear _INIT(20), countdownMonth _INIT(1);   // Countdow | ||||
| WLED_GLOBAL byte countdownDay  _INIT(1) , countdownHour  _INIT(0); | ||||
| WLED_GLOBAL byte countdownMin  _INIT(0) , countdownSec   _INIT(0); | ||||
|  | ||||
| WLED_GLOBAL byte macroBoot _INIT(0);        // macro loaded after startup | ||||
| WLED_GLOBAL byte macroNl   _INIT(0);        // after nightlight delay over | ||||
| WLED_GLOBAL byte macroCountdown _INIT(0); | ||||
| WLED_GLOBAL byte macroAlexaOn _INIT(0), macroAlexaOff _INIT(0); | ||||
| @@ -426,9 +434,10 @@ WLED_GLOBAL byte presetCycleMin _INIT(1), presetCycleMax _INIT(5); | ||||
| WLED_GLOBAL uint16_t presetCycleTime _INIT(12); | ||||
| WLED_GLOBAL unsigned long presetCycledTime _INIT(0); | ||||
| WLED_GLOBAL byte presetCycCurr _INIT(presetCycleMin); | ||||
| WLED_GLOBAL bool presetApplyBri _INIT(true); | ||||
| WLED_GLOBAL bool saveCurrPresetCycConf _INIT(false); | ||||
|  | ||||
| WLED_GLOBAL int16_t currentPlaylist _INIT(0); | ||||
|  | ||||
| // realtime | ||||
| WLED_GLOBAL byte realtimeMode _INIT(REALTIME_MODE_INACTIVE); | ||||
| WLED_GLOBAL byte realtimeOverride _INIT(REALTIME_OVERRIDE_NONE); | ||||
| @@ -473,9 +482,16 @@ WLED_GLOBAL uint16_t rolloverMillis _INIT(0); | ||||
| WLED_GLOBAL char* obuf; | ||||
| WLED_GLOBAL uint16_t olen _INIT(0); | ||||
|  | ||||
| // General filesystem | ||||
| WLED_GLOBAL size_t fsBytesUsed _INIT(0); | ||||
| WLED_GLOBAL size_t fsBytesTotal _INIT(0); | ||||
| WLED_GLOBAL unsigned long presetsModifiedTime _INIT(0L); | ||||
| WLED_GLOBAL JsonDocument* fileDoc; | ||||
| WLED_GLOBAL bool doCloseFile _INIT(false); | ||||
|  | ||||
| // presets | ||||
| WLED_GLOBAL uint16_t savedPresets _INIT(0); | ||||
| WLED_GLOBAL int8_t currentPreset _INIT(-1); | ||||
| WLED_GLOBAL int16_t currentPreset _INIT(-1); | ||||
| WLED_GLOBAL bool isPreset _INIT(false); | ||||
|  | ||||
| WLED_GLOBAL byte errorFlag _INIT(0); | ||||
| @@ -513,6 +529,30 @@ WLED_GLOBAL UsermodManager usermods _INIT(UsermodManager()); | ||||
|   WLED_GLOBAL bool ledStatusState _INIT(0); // the current LED state | ||||
| #endif | ||||
|  | ||||
| // enable additional debug output | ||||
| #ifdef WLED_DEBUG | ||||
|   #ifndef ESP8266 | ||||
|   #include <rom/rtc.h> | ||||
|   #endif | ||||
|   #define DEBUG_PRINT(x) Serial.print(x) | ||||
|   #define DEBUG_PRINTLN(x) Serial.println(x) | ||||
|   #define DEBUG_PRINTF(x...) Serial.printf(x) | ||||
| #else | ||||
|   #define DEBUG_PRINT(x) | ||||
|   #define DEBUG_PRINTLN(x) | ||||
|   #define DEBUG_PRINTF(x) | ||||
| #endif | ||||
|  | ||||
| #ifdef WLED_DEBUG_FS | ||||
|   #define DEBUGFS_PRINT(x) Serial.print(x) | ||||
|   #define DEBUGFS_PRINTLN(x) Serial.println(x) | ||||
|   #define DEBUGFS_PRINTF(x...) Serial.printf(x) | ||||
| #else | ||||
|   #define DEBUGFS_PRINT(x) | ||||
|   #define DEBUGFS_PRINTLN(x) | ||||
|   #define DEBUGFS_PRINTF(x...) | ||||
| #endif | ||||
|  | ||||
| // debug macro variable definitions | ||||
| #ifdef WLED_DEBUG | ||||
|   WLED_GLOBAL unsigned long debugTime _INIT(0); | ||||
| @@ -521,7 +561,6 @@ WLED_GLOBAL UsermodManager usermods _INIT(UsermodManager()); | ||||
|   WLED_GLOBAL int loops _INIT(0); | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #define WLED_CONNECTED (WiFi.status() == WL_CONNECTED) | ||||
| #define WLED_WIFI_CONFIGURED (strlen(clientSSID) >= 1 && strcmp(clientSSID, DEFAULT_CLIENT_SSID) != 0) | ||||
| #define WLED_MQTT_CONNECTED (mqtt != nullptr && mqtt->connected()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Aircoookie
					Aircoookie