mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-25 21:23:53 +01:00 
			
		
		
		
	[debug] Replace std::map with struct array for ESP32 chip features (#11307)
This commit is contained in:
		| @@ -11,8 +11,6 @@ | ||||
| #include <esp_chip_info.h> | ||||
| #include <esp_partition.h> | ||||
|  | ||||
| #include <map> | ||||
|  | ||||
| #ifdef USE_ARDUINO | ||||
| #include <Esp.h> | ||||
| #endif | ||||
| @@ -125,7 +123,12 @@ void DebugComponent::log_partition_info_() { | ||||
|  | ||||
| uint32_t DebugComponent::get_free_heap_() { return heap_caps_get_free_size(MALLOC_CAP_INTERNAL); } | ||||
|  | ||||
| static const std::map<int, const char *> CHIP_FEATURES = { | ||||
| struct ChipFeature { | ||||
|   int bit; | ||||
|   const char *name; | ||||
| }; | ||||
|  | ||||
| static constexpr ChipFeature CHIP_FEATURES[] = { | ||||
|     {CHIP_FEATURE_BLE, "BLE"}, | ||||
|     {CHIP_FEATURE_BT, "BT"}, | ||||
|     {CHIP_FEATURE_EMB_FLASH, "EMB Flash"}, | ||||
| @@ -170,11 +173,13 @@ void DebugComponent::get_device_info_(std::string &device_info) { | ||||
|   esp_chip_info(&info); | ||||
|   const char *model = ESPHOME_VARIANT; | ||||
|   std::string features; | ||||
|   for (auto feature : CHIP_FEATURES) { | ||||
|     if (info.features & feature.first) { | ||||
|       features += feature.second; | ||||
|  | ||||
|   // Check each known feature bit | ||||
|   for (const auto &feature : CHIP_FEATURES) { | ||||
|     if (info.features & feature.bit) { | ||||
|       features += feature.name; | ||||
|       features += ", "; | ||||
|       info.features &= ~feature.first; | ||||
|       info.features &= ~feature.bit; | ||||
|     } | ||||
|   } | ||||
|   if (info.features != 0) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user