Compare commits
	
		
			39 Commits
		
	
	
		
			trifade-fi
			...
			v0.15.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | faadb67eb0 | ||
|   | a111a2e7a1 | ||
|   | 32864d8986 | ||
|   | d7bebc2659 | ||
|   | af410ae2d0 | ||
|   | 1891cc816f | ||
|   | 9a4073e606 | ||
|   | b78229d1e2 | ||
|   | 71b242874f | ||
|   | 9328e6faca | ||
|   | bbacc2daae | ||
|   | 3e22f9cabb | ||
|   | 685ad83d4b | ||
|   | 62ddb18a1a | ||
|   | 6a12378475 | ||
|   | d26b3108da | ||
|   | c89e4576b4 | ||
|   | bc79f44a26 | ||
|   | 7ece14ff3f | ||
|   | 0b3643132b | ||
|   | a5693fbf8d | ||
|   | 5c5b70f52b | ||
|   | ae97e388a6 | ||
|   | 37cddcaacc | ||
|   | a1b332fc78 | ||
|   | 86d7c24513 | ||
|   | b28add3b8b | ||
|   | 5fd3a513a4 | ||
|   | b98a8a10b0 | ||
|   | 2bee2793ef | ||
|   | 2f6fa66f4d | ||
|   | 5d38acd787 | ||
|   | e607fcb5c5 | ||
|   | 8a18555ae4 | ||
|   | beb709dc8f | ||
|   | 7a58c69a80 | ||
|   | 1082c85789 | ||
|   | 568d2edd96 | ||
|   | d2d56ebbd2 | 
							
								
								
									
										18
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,23 @@ | |||||||
| ## WLED changelog | ## WLED changelog | ||||||
|  |  | ||||||
|  | #### Build 2412100 | ||||||
|  | -   WLED 0.15.0 release | ||||||
|  | -   Usermod BME280: Fix "Unit of Measurement" for temperature | ||||||
|  | -   WiFi reconnect bugfix (@blazoncek) | ||||||
|  |  | ||||||
|  | #### Build 2411250 | ||||||
|  | -   WLED 0.15.0-rc1 release | ||||||
|  | -   Add support for esp32S3_wroom2 (#4243 by @softhack007) | ||||||
|  | -   Fix mixed LED SK6812 and ws2812b booloop (#4301 by @willmmiles) | ||||||
|  | -   Improved FPS calculation (by DedeHai) | ||||||
|  | -   Fix crashes when using HTTP API within MQTT (#4269 by @willmmiles) | ||||||
|  | -   Fix array overflow in exploding_fireworks (#4120 by @willmmiles) | ||||||
|  | -   Fix MQTT topic buffer length (#4293 by @WouterGritter) | ||||||
|  | -   Fix SparkFunDMX fix for possible array bounds violation in DMX.write (by @softhack007) | ||||||
|  | -   Allow TV Simulator on single LED segments (by @softhack007) | ||||||
|  | -   Fix WLED_RELEASE_NAME (by @netmindz) | ||||||
|  |  | ||||||
|  |  | ||||||
| #### Build 2410270 | #### Build 2410270 | ||||||
| -   WLED 0.15.0-b7 release | -   WLED 0.15.0-b7 release | ||||||
| -   Re-license the WLED project from MIT to EUPL (#4194 by @Aircoookie) | -   Re-license the WLED project from MIT to EUPL (#4194 by @Aircoookie) | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										9
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1,18 +1,21 @@ | |||||||
| { | { | ||||||
|   "name": "wled", |   "name": "wled", | ||||||
|   "version": "0.15.0-b7", |   "version": "0.15.0", | ||||||
|   "lockfileVersion": 3, |   "lockfileVersion": 3, | ||||||
|   "requires": true, |   "requires": true, | ||||||
|   "packages": { |   "packages": { | ||||||
|     "": { |     "": { | ||||||
|       "name": "wled", |       "name": "wled", | ||||||
|       "version": "0.15.0-b7", |       "version": "0.15.0", | ||||||
|       "license": "ISC", |       "license": "ISC", | ||||||
|       "dependencies": { |       "dependencies": { | ||||||
|         "clean-css": "^5.3.3", |         "clean-css": "^5.3.3", | ||||||
|         "html-minifier-terser": "^7.2.0", |         "html-minifier-terser": "^7.2.0", | ||||||
|         "inliner": "^1.13.1", |         "inliner": "^1.13.1", | ||||||
|         "nodemon": "^3.0.2" |         "nodemon": "^3.1.7" | ||||||
|  |       }, | ||||||
|  |       "engines": { | ||||||
|  |         "node": ">=20.0.0" | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     "node_modules/@jridgewell/gen-mapping": { |     "node_modules/@jridgewell/gen-mapping": { | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "wled", |   "name": "wled", | ||||||
|   "version": "0.15.0-b7", |   "version": "0.15.0", | ||||||
|   "description": "Tools for WLED project", |   "description": "Tools for WLED project", | ||||||
|   "main": "tools/cdata.js", |   "main": "tools/cdata.js", | ||||||
|   "directories": { |   "directories": { | ||||||
|   | |||||||
| @@ -444,6 +444,7 @@ public: | |||||||
|     configComplete &= getJsonValue(top[F("PublishAlways")], PublishAlways, false); |     configComplete &= getJsonValue(top[F("PublishAlways")], PublishAlways, false); | ||||||
|     configComplete &= getJsonValue(top[F("UseCelsius")], UseCelsius, true); |     configComplete &= getJsonValue(top[F("UseCelsius")], UseCelsius, true); | ||||||
|     configComplete &= getJsonValue(top[F("HomeAssistantDiscovery")], HomeAssistantDiscovery, false); |     configComplete &= getJsonValue(top[F("HomeAssistantDiscovery")], HomeAssistantDiscovery, false); | ||||||
|  |     tempScale = UseCelsius ? "°C" : "°F"; | ||||||
|  |  | ||||||
|     DEBUG_PRINT(FPSTR(_name)); |     DEBUG_PRINT(FPSTR(_name)); | ||||||
|     if (!initDone) { |     if (!initDone) { | ||||||
|   | |||||||
| @@ -2565,11 +2565,11 @@ static CRGB twinklefox_one_twinkle(uint32_t ms, uint8_t salt, bool cat) | |||||||
| { | { | ||||||
|   // Overall twinkle speed (changed) |   // Overall twinkle speed (changed) | ||||||
|   unsigned ticks = ms / SEGENV.aux0; |   unsigned ticks = ms / SEGENV.aux0; | ||||||
|   unsigned fastcycle8 = ticks; |   unsigned fastcycle8 = uint8_t(ticks); | ||||||
|   unsigned slowcycle16 = (ticks >> 8) + salt; |   uint16_t slowcycle16 = (ticks >> 8) + salt; | ||||||
|   slowcycle16 += sin8_t(slowcycle16); |   slowcycle16 += sin8_t(slowcycle16); | ||||||
|   slowcycle16 = (slowcycle16 * 2053) + 1384; |   slowcycle16 = (slowcycle16 * 2053) + 1384; | ||||||
|   unsigned slowcycle8 = (slowcycle16 & 0xFF) + (slowcycle16 >> 8); |   uint8_t slowcycle8 = (slowcycle16 & 0xFF) + (slowcycle16 >> 8); | ||||||
|  |  | ||||||
|   // Overall twinkle density. |   // Overall twinkle density. | ||||||
|   // 0 (NONE lit) to 8 (ALL lit at once). |   // 0 (NONE lit) to 8 (ALL lit at once). | ||||||
|   | |||||||
| @@ -207,6 +207,7 @@ void WiFiEvent(WiFiEvent_t event) | |||||||
|       break; |       break; | ||||||
| #endif | #endif | ||||||
|     default: |     default: | ||||||
|  |       DEBUG_PRINTF_P(PSTR("Network event: %d\n"), (int)event); | ||||||
|       break; |       break; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -478,10 +478,7 @@ void WLED::setup() | |||||||
|   if (strcmp(multiWiFi[0].clientSSID, DEFAULT_CLIENT_SSID) == 0) |   if (strcmp(multiWiFi[0].clientSSID, DEFAULT_CLIENT_SSID) == 0) | ||||||
|     showWelcomePage = true; |     showWelcomePage = true; | ||||||
|   WiFi.persistent(false); |   WiFi.persistent(false); | ||||||
|   #ifdef WLED_USE_ETHERNET |  | ||||||
|   WiFi.onEvent(WiFiEvent); |   WiFi.onEvent(WiFiEvent); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   WiFi.mode(WIFI_STA); // enable scanning |   WiFi.mode(WIFI_STA); // enable scanning | ||||||
|   findWiFi(true);      // start scanning for available WiFi-s |   findWiFi(true);      // start scanning for available WiFi-s | ||||||
|  |  | ||||||
| @@ -781,7 +778,7 @@ int8_t WLED::findWiFi(bool doScan) { | |||||||
|  |  | ||||||
| void WLED::initConnection() | void WLED::initConnection() | ||||||
| { | { | ||||||
|   DEBUG_PRINTLN(F("initConnection() called.")); |   DEBUG_PRINTF_P(PSTR("initConnection() called @ %lus.\n"), millis()/1000); | ||||||
|  |  | ||||||
|   #ifdef WLED_ENABLE_WEBSOCKETS |   #ifdef WLED_ENABLE_WEBSOCKETS | ||||||
|   ws.onEvent(wsEvent); |   ws.onEvent(wsEvent); | ||||||
| @@ -825,9 +822,7 @@ void WLED::initConnection() | |||||||
|   if (WLED_WIFI_CONFIGURED) { |   if (WLED_WIFI_CONFIGURED) { | ||||||
|     showWelcomePage = false; |     showWelcomePage = false; | ||||||
|      |      | ||||||
|     DEBUG_PRINT(F("Connecting to ")); |     DEBUG_PRINTF_P(PSTR("Connecting to %s...\n"), multiWiFi[selectedWiFi].clientSSID); | ||||||
|     DEBUG_PRINT(multiWiFi[selectedWiFi].clientSSID); |  | ||||||
|     DEBUG_PRINTLN(F("...")); |  | ||||||
|  |  | ||||||
|     // convert the "serverDescription" into a valid DNS hostname (alphanumeric) |     // convert the "serverDescription" into a valid DNS hostname (alphanumeric) | ||||||
|     char hostname[25]; |     char hostname[25]; | ||||||
| @@ -926,7 +921,8 @@ void WLED::handleConnection() | |||||||
| { | { | ||||||
|   static bool scanDone = true; |   static bool scanDone = true; | ||||||
|   static byte stacO = 0; |   static byte stacO = 0; | ||||||
|   unsigned long now = millis(); |   const unsigned long now = millis(); | ||||||
|  |   const unsigned long nowS = now/1000; | ||||||
|   const bool wifiConfigured = WLED_WIFI_CONFIGURED; |   const bool wifiConfigured = WLED_WIFI_CONFIGURED; | ||||||
|  |  | ||||||
|   // ignore connection handling if WiFi is configured and scan still running |   // ignore connection handling if WiFi is configured and scan still running | ||||||
| @@ -935,7 +931,7 @@ void WLED::handleConnection() | |||||||
|     return; |     return; | ||||||
|  |  | ||||||
|   if (lastReconnectAttempt == 0 || forceReconnect) { |   if (lastReconnectAttempt == 0 || forceReconnect) { | ||||||
|     DEBUG_PRINTLN(F("Initial connect or forced reconnect.")); |     DEBUG_PRINTF_P(PSTR("Initial connect or forced reconnect (@ %lus).\n"), nowS); | ||||||
|     selectedWiFi = findWiFi(); // find strongest WiFi |     selectedWiFi = findWiFi(); // find strongest WiFi | ||||||
|     initConnection(); |     initConnection(); | ||||||
|     interfacesInited = false; |     interfacesInited = false; | ||||||
| @@ -955,8 +951,7 @@ void WLED::handleConnection() | |||||||
| #endif | #endif | ||||||
|     if (stac != stacO) { |     if (stac != stacO) { | ||||||
|       stacO = stac; |       stacO = stac; | ||||||
|       DEBUG_PRINT(F("Connected AP clients: ")); |       DEBUG_PRINTF_P(PSTR("Connected AP clients: %d\n"), (int)stac); | ||||||
|       DEBUG_PRINTLN(stac); |  | ||||||
|       if (!WLED_CONNECTED && wifiConfigured) {        // trying to connect, but not connected |       if (!WLED_CONNECTED && wifiConfigured) {        // trying to connect, but not connected | ||||||
|         if (stac) |         if (stac) | ||||||
|           WiFi.disconnect();        // disable search so that AP can work |           WiFi.disconnect();        // disable search so that AP can work | ||||||
| @@ -979,6 +974,7 @@ void WLED::handleConnection() | |||||||
|       initConnection(); |       initConnection(); | ||||||
|       interfacesInited = false; |       interfacesInited = false; | ||||||
|       scanDone = true; |       scanDone = true; | ||||||
|  |       return; | ||||||
|     } |     } | ||||||
|     //send improv failed 6 seconds after second init attempt (24 sec. after provisioning) |     //send improv failed 6 seconds after second init attempt (24 sec. after provisioning) | ||||||
|     if (improvActive > 2 && now - lastReconnectAttempt > 6000) { |     if (improvActive > 2 && now - lastReconnectAttempt > 6000) { | ||||||
| @@ -987,13 +983,13 @@ void WLED::handleConnection() | |||||||
|     } |     } | ||||||
|     if (now - lastReconnectAttempt > ((stac) ? 300000 : 18000) && wifiConfigured) { |     if (now - lastReconnectAttempt > ((stac) ? 300000 : 18000) && wifiConfigured) { | ||||||
|       if (improvActive == 2) improvActive = 3; |       if (improvActive == 2) improvActive = 3; | ||||||
|       DEBUG_PRINTLN(F("Last reconnect too old.")); |       DEBUG_PRINTF_P(PSTR("Last reconnect (%lus) too old (@ %lus).\n"), lastReconnectAttempt/1000, nowS); | ||||||
|       if (++selectedWiFi >= multiWiFi.size()) selectedWiFi = 0; // we couldn't connect, try with another network from the list |       if (++selectedWiFi >= multiWiFi.size()) selectedWiFi = 0; // we couldn't connect, try with another network from the list | ||||||
|       initConnection(); |       initConnection(); | ||||||
|     } |     } | ||||||
|     if (!apActive && now - lastReconnectAttempt > 12000 && (!wasConnected || apBehavior == AP_BEHAVIOR_NO_CONN)) { |     if (!apActive && now - lastReconnectAttempt > 12000 && (!wasConnected || apBehavior == AP_BEHAVIOR_NO_CONN)) { | ||||||
|       if (!(apBehavior == AP_BEHAVIOR_TEMPORARY && now > WLED_AP_TIMEOUT)) { |       if (!(apBehavior == AP_BEHAVIOR_TEMPORARY && now > WLED_AP_TIMEOUT)) { | ||||||
|         DEBUG_PRINTLN(F("Not connected AP.")); |         DEBUG_PRINTF_P(PSTR("Not connected AP (@ %lus).\n"), nowS); | ||||||
|         initAP();  // start AP only within first 5min |         initAP();  // start AP only within first 5min | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -1003,7 +999,7 @@ void WLED::handleConnection() | |||||||
|         dnsServer.stop(); |         dnsServer.stop(); | ||||||
|         WiFi.softAPdisconnect(true); |         WiFi.softAPdisconnect(true); | ||||||
|         apActive = false; |         apActive = false; | ||||||
|         DEBUG_PRINTLN(F("Temporary AP disabled.")); |         DEBUG_PRINTF_P(PSTR("Temporary AP disabled (@ %lus).\n"), nowS); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } else if (!interfacesInited) { //newly connected |   } else if (!interfacesInited) { //newly connected | ||||||
|   | |||||||
| @@ -3,12 +3,12 @@ | |||||||
| /* | /* | ||||||
|    Main sketch, global variable declarations |    Main sketch, global variable declarations | ||||||
|    @title WLED project sketch |    @title WLED project sketch | ||||||
|    @version 0.15.0-b7 |    @version 0.15.0 | ||||||
|    @author Christian Schwinne |    @author Christian Schwinne | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| // version code in format yymmddb (b = daily build) | // version code in format yymmddb (b = daily build) | ||||||
| #define VERSION 2410270 | #define VERSION 2412100 | ||||||
|  |  | ||||||
| //uncomment this if you have a "my_config.h" file you'd like to use | //uncomment this if you have a "my_config.h" file you'd like to use | ||||||
| //#define WLED_USE_MY_CONFIG | //#define WLED_USE_MY_CONFIG | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user