Compare commits
	
		
			21 Commits
		
	
	
		
			v0.15.1-rc
			...
			tricolor-f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | fc35f0aab2 | ||
|   | 68a853455d | ||
|   | c24f67c479 | ||
|   | d1763024bf | ||
|   | b155f80dc7 | ||
|   | 2df536c0a4 | ||
|   | dba31cb433 | ||
|   | 7a52144e98 | ||
|   | 9c82add757 | ||
|   | 4e1ca9be49 | ||
|   | a9f52a132b | ||
|   | 0ecae7e831 | ||
|   | a24d4bc7e9 | ||
|   | 26080b23b1 | ||
|   | b6d9aad6b4 | ||
|   | 4f3992b4dc | ||
|   | 78252c6885 | ||
|   | 9dc7e81ba7 | ||
|   | ab2c975c36 | ||
|   | ec51804f33 | ||
|   | 83ae6d07a7 | 
							
								
								
									
										3
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,7 +23,8 @@ jobs: | ||||
|       uses: janheinrichmerker/action-github-changelog-generator@v2.3 | ||||
|       with: | ||||
|           token: ${{ secrets.GITHUB_TOKEN }}  | ||||
|           sinceTag: v0.15.0         | ||||
|           sinceTag: v0.15.0 | ||||
|           releaseBranch: 0_15_x  | ||||
|     - name: Create draft release | ||||
|       uses: softprops/action-gh-release@v1 | ||||
|       with: | ||||
|   | ||||
							
								
								
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1,12 +1,12 @@ | ||||
| { | ||||
|   "name": "wled", | ||||
|   "version": "0.15.1.beta1", | ||||
|   "version": "0.15.1", | ||||
|   "lockfileVersion": 3, | ||||
|   "requires": true, | ||||
|   "packages": { | ||||
|     "": { | ||||
|       "name": "wled", | ||||
|       "version": "0.15.1.beta1", | ||||
|       "version": "0.15.1", | ||||
|       "license": "ISC", | ||||
|       "dependencies": { | ||||
|         "clean-css": "^5.3.3", | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "wled", | ||||
|   "version": "0.15.1-rc1", | ||||
|   "version": "0.15.2-beta1", | ||||
|   "description": "Tools for WLED project", | ||||
|   "main": "tools/cdata.js", | ||||
|   "directories": { | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
| # ------------------------------------------------------------------------------ | ||||
|  | ||||
| # CI/release binaries | ||||
| default_envs = nodemcuv2, esp8266_2m, esp01_1m_full, nodemcuv2_160, esp8266_2m_160, esp01_1m_full_160, nodemcuv2_compat, esp8266_2m_compat, esp01_1m_full_compat, esp32dev, esp32_eth, lolin_s2_mini, esp32c3dev, esp32s3dev_16MB_opi, esp32s3dev_8MB_opi, esp32s3_4M_qspi, esp32_wrover | ||||
| default_envs = nodemcuv2, esp8266_2m, esp01_1m_full, nodemcuv2_160, esp8266_2m_160, esp01_1m_full_160, nodemcuv2_compat, esp8266_2m_compat, esp01_1m_full_compat, esp32dev, esp32dev_V4, esp32_eth, lolin_s2_mini, esp32c3dev, esp32s3dev_16MB_opi, esp32s3dev_8MB_opi, esp32s3_4M_qspi, esp32_wrover | ||||
|  | ||||
| src_dir  = ./wled00 | ||||
| data_dir = ./wled00/data | ||||
| @@ -140,7 +140,7 @@ lib_deps = | ||||
|     IRremoteESP8266 @ 2.8.2 | ||||
|     makuna/NeoPixelBus @ 2.8.3 | ||||
|     #https://github.com/makuna/NeoPixelBus.git#CoreShaderBeta | ||||
|     https://github.com/Aircoookie/ESPAsyncWebServer.git#v2.2.1 | ||||
|     https://github.com/Aircoookie/ESPAsyncWebServer.git#v2.4.2 | ||||
|   # for I2C interface | ||||
|     ;Wire | ||||
|   # ESP-NOW library | ||||
| @@ -248,6 +248,7 @@ build_flags = -g | ||||
|   -DARDUINO_ARCH_ESP32 | ||||
|   #-DCONFIG_LITTLEFS_FOR_IDF_3_2 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   #use LITTLEFS library by lorol in ESP32 core 1.x.x instead of built-in in 2.x.x | ||||
|   -D LOROL_LITTLEFS | ||||
|   ; -DARDUINO_USB_CDC_ON_BOOT=0 ;; this flag is mandatory for "classic ESP32" when building with arduino-esp32 >=2.0.3 | ||||
| @@ -259,7 +260,7 @@ large_partitions = tools/WLED_ESP32_8MB.csv | ||||
| extreme_partitions = tools/WLED_ESP32_16MB_9MB_FS.csv | ||||
| lib_deps = | ||||
|   https://github.com/lorol/LITTLEFS.git | ||||
|   https://github.com/pbolduc/AsyncTCP.git @ 1.2.0 | ||||
|   esp32async/AsyncTCP @ 3.4.7 | ||||
|   ${env.lib_deps} | ||||
| # additional build flags for audioreactive | ||||
| AR_build_flags = -D USERMOD_AUDIOREACTIVE  | ||||
| @@ -280,9 +281,12 @@ build_flags = -g | ||||
|   -Wshadow=compatible-local ;; emit warning in case a local variable "shadows" another local one | ||||
|   -DARDUINO_ARCH_ESP32 -DESP32 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   -DARDUINO_USB_CDC_ON_BOOT=0 ;; this flag is mandatory for "classic ESP32" when building with arduino-esp32 >=2.0.3 | ||||
|   -D WLED_ENABLE_DMX_INPUT | ||||
| lib_deps = | ||||
|   https://github.com/pbolduc/AsyncTCP.git @ 1.2.0 | ||||
|   esp32async/AsyncTCP @ 3.4.7 | ||||
|   https://github.com/someweisguy/esp_dmx.git#47db25d | ||||
|   ${env.lib_deps} | ||||
| board_build.partitions = ${esp32.default_partitions}   ;; default partioning for 4MB Flash - can be overridden in build envs | ||||
|  | ||||
| @@ -296,13 +300,14 @@ build_flags = -g | ||||
|   -DARDUINO_ARCH_ESP32S2 | ||||
|   -DCONFIG_IDF_TARGET_ESP32S2=1 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   -DARDUINO_USB_MSC_ON_BOOT=0 -DARDUINO_USB_DFU_ON_BOOT=0 | ||||
|   -DCO | ||||
|   -DARDUINO_USB_MODE=0 ;; this flag is mandatory for ESP32-S2 ! | ||||
|   ;; please make sure that the following flags are properly set (to 0 or 1) by your board.json, or included in your custom platformio_override.ini entry: | ||||
|   ;; ARDUINO_USB_CDC_ON_BOOT | ||||
| lib_deps = | ||||
|   https://github.com/pbolduc/AsyncTCP.git @ 1.2.0 | ||||
|   esp32async/AsyncTCP @ 3.4.7 | ||||
|   ${env.lib_deps} | ||||
| board_build.partitions = ${esp32.default_partitions}   ;; default partioning for 4MB Flash - can be overridden in build envs | ||||
|  | ||||
| @@ -316,12 +321,13 @@ build_flags = -g | ||||
|   -DARDUINO_ARCH_ESP32C3 | ||||
|   -DCONFIG_IDF_TARGET_ESP32C3=1 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   -DCO | ||||
|   -DARDUINO_USB_MODE=1 ;; this flag is mandatory for ESP32-C3 | ||||
|   ;; please make sure that the following flags are properly set (to 0 or 1) by your board.json, or included in your custom platformio_override.ini entry: | ||||
|   ;; ARDUINO_USB_CDC_ON_BOOT | ||||
| lib_deps = | ||||
|   https://github.com/pbolduc/AsyncTCP.git @ 1.2.0 | ||||
|   esp32async/AsyncTCP @ 3.4.7 | ||||
|   ${env.lib_deps} | ||||
| board_build.partitions = ${esp32.default_partitions}   ;; default partioning for 4MB Flash - can be overridden in build envs | ||||
|  | ||||
| @@ -336,12 +342,13 @@ build_flags = -g | ||||
|   -DARDUINO_ARCH_ESP32S3 | ||||
|   -DCONFIG_IDF_TARGET_ESP32S3=1 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   -DARDUINO_USB_MSC_ON_BOOT=0 -DARDUINO_DFU_ON_BOOT=0 | ||||
|   -DCO | ||||
|   ;; please make sure that the following flags are properly set (to 0 or 1) by your board.json, or included in your custom platformio_override.ini entry: | ||||
|   ;; ARDUINO_USB_MODE, ARDUINO_USB_CDC_ON_BOOT | ||||
| lib_deps = | ||||
|   https://github.com/pbolduc/AsyncTCP.git @ 1.2.0 | ||||
|   esp32async/AsyncTCP @ 3.4.7 | ||||
|   ${env.lib_deps} | ||||
| board_build.partitions = ${esp32.large_partitions}   ;; default partioning for 8MB flash - can be overridden in build envs | ||||
|  | ||||
| @@ -432,6 +439,18 @@ lib_deps = ${esp32.lib_deps} | ||||
| monitor_filters = esp32_exception_decoder | ||||
| board_build.partitions = ${esp32.default_partitions} | ||||
|  | ||||
| [env:esp32dev_V4] | ||||
| board = esp32dev | ||||
| platform = ${esp32_idf_V4.platform} | ||||
| platform_packages = ${esp32_idf_V4.platform_packages} | ||||
| build_unflags = ${common.build_unflags} | ||||
| build_flags = ${common.build_flags} ${esp32_idf_V4.build_flags} -D WLED_RELEASE_NAME=\"ESP32_V4\" #-D WLED_DISABLE_BROWNOUT_DET | ||||
|   ${esp32.AR_build_flags} | ||||
| lib_deps = ${esp32_idf_V4.lib_deps} | ||||
|   ${esp32.AR_lib_deps} | ||||
| monitor_filters = esp32_exception_decoder | ||||
| board_build.partitions = ${esp32.default_partitions} | ||||
|  | ||||
| [env:esp32dev_8M] | ||||
| board = esp32dev | ||||
| platform = ${esp32_idf_V4.platform} | ||||
| @@ -630,6 +649,7 @@ build_flags = ${common.build_flags} ${esp32s2.build_flags} -D WLED_RELEASE_NAME= | ||||
|   -DLOLIN_WIFI_FIX ; seems to work much better with this | ||||
|   -D WLED_WATCHDOG_TIMEOUT=0 | ||||
|   -D CONFIG_ASYNC_TCP_USE_WDT=0 | ||||
|   -D CONFIG_ASYNC_TCP_STACK_SIZE=8192 | ||||
|   -D DATA_PINS=16 | ||||
|   -D HW_PIN_SCL=35 | ||||
|   -D HW_PIN_SDA=33 | ||||
|   | ||||
| @@ -1646,8 +1646,8 @@ static const char _data_FX_MODE_TRICOLOR_WIPE[] PROGMEM = "Tri Wipe@!;1,2,3;!"; | ||||
|  * Modified by Aircoookie | ||||
|  */ | ||||
| uint16_t mode_tricolor_fade(void) { | ||||
|   unsigned counter = strip.now * ((SEGMENT.speed >> 3) +1); | ||||
|   uint16_t prog = (counter * 768) >> 16; | ||||
|   uint16_t counter = strip.now * ((SEGMENT.speed >> 3) +1); | ||||
|   uint32_t prog = (counter * 768) >> 16; | ||||
|  | ||||
|   uint32_t color1 = 0, color2 = 0; | ||||
|   unsigned stage = 0; | ||||
| @@ -3913,7 +3913,7 @@ uint16_t mode_percent(void) { | ||||
|  | ||||
|  	return FRAMETIME; | ||||
| } | ||||
| static const char _data_FX_MODE_PERCENT[] PROGMEM = "Percent@,% of fill,,,,One color;!,!;!"; | ||||
| static const char _data_FX_MODE_PERCENT[] PROGMEM = "Percent@!,% of fill,,,,One color;!,!;!"; | ||||
|  | ||||
|  | ||||
| /* | ||||
|   | ||||
| @@ -73,7 +73,7 @@ | ||||
| 		A huge thank you to everyone who helped me create WLED!<br><br> | ||||
| 		(c) 2016-2024 Christian Schwinne <br> | ||||
| 		<i>Licensed under the <a href="https://github.com/Aircoookie/WLED/blob/master/LICENSE" target="_blank">EUPL v1.2 license</a></i><br><br> | ||||
| 		Server message: <span class="sip"> Response error! </span><hr> | ||||
| 		Installed version: <span class="sip">WLED ##VERSION##</span><hr> | ||||
| 		<div id="toast"></div> | ||||
| 		<button type="button" onclick="B()">Back</button><button type="submit">Save</button> | ||||
| 	</form> | ||||
|   | ||||
| @@ -16,7 +16,7 @@ | ||||
| <body onload="GetV()"> | ||||
| 	<h2>WLED Software Update</h2> | ||||
| 	<form method='POST' action='./update' id='uf' enctype='multipart/form-data' onsubmit="U()"> | ||||
| 		Installed version: <span class="sip">##VERSION##</span><br> | ||||
| 		Installed version: <span class="sip">WLED ##VERSION##</span><br> | ||||
| 		Download the latest binary: <a href="https://github.com/Aircoookie/WLED/releases" target="_blank"  | ||||
| 		style="vertical-align: text-bottom; display: inline-flex;"> | ||||
| 		<img src="https://img.shields.io/github/release/Aircoookie/WLED.svg?style=flat-square"></a><br> | ||||
|   | ||||
| @@ -183,9 +183,9 @@ void WLED::loop() | ||||
|     bool aligned = strip.checkSegmentAlignment(); //see if old segments match old bus(ses) | ||||
|     BusManager::removeAll(); | ||||
|     strip.finalizeInit(); // will create buses and also load default ledmap if present | ||||
|     BusManager::setBrightness(bri); // fix re-initialised bus' brightness #4005 | ||||
|     if (aligned) strip.makeAutoSegments(); | ||||
|     else strip.fixInvalidSegments(); | ||||
|     BusManager::setBrightness(scaledBri(bri)); // fix re-initialised bus' brightness #4005 and #4824 | ||||
|     doSerializeConfig = true; | ||||
|   } | ||||
|   if (loadLedmap >= 0) { | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
|  */ | ||||
|  | ||||
| // version code in format yymmddb (b = daily build) | ||||
| #define VERSION 2507260 | ||||
| #define VERSION 2508020 | ||||
|  | ||||
| //uncomment this if you have a "my_config.h" file you'd like to use | ||||
| //#define WLED_USE_MY_CONFIG | ||||
| @@ -697,10 +697,10 @@ WLED_GLOBAL bool receiveNotificationPalette    _INIT(true);       // apply palet | ||||
| WLED_GLOBAL bool receiveSegmentOptions         _INIT(false);      // apply segment options | ||||
| WLED_GLOBAL bool receiveSegmentBounds          _INIT(false);      // apply segment bounds (start, stop, offset) | ||||
| WLED_GLOBAL bool receiveDirect _INIT(true);                       // receive UDP/Hyperion realtime | ||||
| WLED_GLOBAL bool notifyDirect _INIT(false);                       // send notification if change via UI or HTTP API | ||||
| WLED_GLOBAL bool notifyButton _INIT(false);                       // send if updated by button or infrared remote | ||||
| WLED_GLOBAL bool notifyDirect _INIT(true);                        // send notification if change via UI or HTTP API | ||||
| WLED_GLOBAL bool notifyButton _INIT(true);                        // send if updated by button or infrared remote | ||||
| WLED_GLOBAL bool notifyAlexa  _INIT(false);                       // send notification if updated via Alexa | ||||
| WLED_GLOBAL bool notifyHue    _INIT(true);                        // send notification if Hue light changes | ||||
| WLED_GLOBAL bool notifyHue    _INIT(false);                       // send notification if Hue light changes | ||||
| #endif | ||||
|  | ||||
| // effects | ||||
|   | ||||
| @@ -26,7 +26,8 @@ void XML_response(Print& dest) | ||||
|   ); | ||||
| } | ||||
|  | ||||
| static void extractPin(Print& settingsScript, JsonObject &obj, const char *key) { | ||||
| static void extractPin(Print& settingsScript, JsonObject &obj, const char *key) | ||||
| { | ||||
|   if (obj[key].is<JsonArray>()) { | ||||
|     JsonArray pins = obj[key].as<JsonArray>(); | ||||
|     for (JsonVariant pv : pins) { | ||||
| @@ -37,6 +38,22 @@ static void extractPin(Print& settingsScript, JsonObject &obj, const char *key) | ||||
|   } | ||||
| } | ||||
|  | ||||
| void fillWLEDVersion(char *buf, size_t len) | ||||
| { | ||||
|   if (!buf || len == 0) return; | ||||
|  | ||||
|   snprintf_P(buf,len,PSTR("WLED %s (%d)<br>\\\"%s\\\"<br>(Processor: %s)"), | ||||
|     versionString, | ||||
|     VERSION, | ||||
|     releaseString, | ||||
|   #if defined(ARDUINO_ARCH_ESP32) | ||||
|     ESP.getChipModel() | ||||
|   #else | ||||
|     "ESP8266" | ||||
|   #endif | ||||
|   ); | ||||
| } | ||||
|  | ||||
| // print used pins by scanning JsonObject (1 level deep) | ||||
| static void fillUMPins(Print& settingsScript, JsonObject &mods) | ||||
| { | ||||
| @@ -72,7 +89,8 @@ static void fillUMPins(Print& settingsScript, JsonObject &mods) | ||||
|   } | ||||
| } | ||||
|  | ||||
| void appendGPIOinfo(Print& settingsScript) { | ||||
| void appendGPIOinfo(Print& settingsScript) | ||||
| { | ||||
|   settingsScript.print(F("d.um_p=[-1")); // has to have 1 element | ||||
|   if (i2c_sda > -1 && i2c_scl > -1) { | ||||
|     settingsScript.printf_P(PSTR(",%d,%d"), i2c_sda, i2c_scl); | ||||
| @@ -580,7 +598,7 @@ void getSettingsJS(byte subPage, Print& settingsScript) | ||||
|     printSetFormCheckbox(settingsScript,PSTR("OW"),wifiLock); | ||||
|     printSetFormCheckbox(settingsScript,PSTR("AO"),aOtaEnabled); | ||||
|     char tmp_buf[128]; | ||||
|     snprintf_P(tmp_buf,sizeof(tmp_buf),PSTR("WLED %s (build %d)"),versionString,VERSION); | ||||
|     fillWLEDVersion(tmp_buf,sizeof(tmp_buf)); | ||||
|     printSetClassElementHTML(settingsScript,PSTR("sip"),0,tmp_buf); | ||||
|     settingsScript.printf_P(PSTR("sd=\"%s\";"), serverDescription); | ||||
|   } | ||||
| @@ -635,16 +653,7 @@ void getSettingsJS(byte subPage, Print& settingsScript) | ||||
|   if (subPage == SUBPAGE_UPDATE) // update | ||||
|   { | ||||
|     char tmp_buf[128]; | ||||
|     snprintf_P(tmp_buf,sizeof(tmp_buf),PSTR("WLED %s<br>%s<br>(%s build %d)"), | ||||
|       versionString, | ||||
|       releaseString, | ||||
|     #if defined(ARDUINO_ARCH_ESP32) | ||||
|       ESP.getChipModel(), | ||||
|     #else | ||||
|       "esp8266", | ||||
|     #endif | ||||
|       VERSION); | ||||
|  | ||||
|     fillWLEDVersion(tmp_buf,sizeof(tmp_buf)); | ||||
|     printSetClassElementHTML(settingsScript,PSTR("sip"),0,tmp_buf); | ||||
|   } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user