esphome 2025.6.2__py3-none-any.whl → 2025.7.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- esphome/__main__.py +1 -3
- esphome/codegen.py +2 -0
- esphome/components/ac_dimmer/ac_dimmer.cpp +6 -6
- esphome/components/adc/__init__.py +25 -1
- esphome/components/adc/adc_sensor.h +11 -11
- esphome/components/adc/adc_sensor_common.cpp +1 -1
- esphome/components/adc/adc_sensor_esp32.cpp +16 -8
- esphome/components/ade7880/ade7880.h +0 -2
- esphome/components/ads1115/ads1115.h +0 -1
- esphome/components/ads1118/ads1118.h +0 -1
- esphome/components/ags10/ags10.h +0 -2
- esphome/components/aic3204/aic3204.h +0 -1
- esphome/components/alarm_control_panel/__init__.py +5 -2
- esphome/components/alpha3/alpha3.h +0 -1
- esphome/components/am43/cover/am43_cover.h +0 -1
- esphome/components/am43/sensor/am43_sensor.h +0 -1
- esphome/components/analog_threshold/analog_threshold_binary_sensor.h +0 -2
- esphome/components/anova/anova.cpp +5 -1
- esphome/components/anova/anova.h +0 -1
- esphome/components/apds9960/apds9960.cpp +1 -1
- esphome/components/api/__init__.py +57 -21
- esphome/components/api/api_connection.cpp +344 -539
- esphome/components/api/api_connection.h +224 -141
- esphome/components/api/api_frame_helper.cpp +91 -127
- esphome/components/api/api_frame_helper.h +64 -54
- esphome/components/api/api_pb2.cpp +1837 -9044
- esphome/components/api/api_pb2.h +532 -685
- esphome/components/api/api_pb2_dump.cpp +4432 -0
- esphome/components/api/api_pb2_service.cpp +184 -425
- esphome/components/api/api_pb2_service.h +13 -6
- esphome/components/api/api_server.cpp +131 -167
- esphome/components/api/api_server.h +38 -10
- esphome/components/api/client.py +10 -4
- esphome/components/api/custom_api_device.h +8 -0
- esphome/components/api/list_entities.cpp +37 -104
- esphome/components/api/list_entities.h +33 -23
- esphome/components/api/proto.h +532 -26
- esphome/components/api/subscribe_state.cpp +23 -29
- esphome/components/api/subscribe_state.h +26 -19
- esphome/components/api/user_services.h +2 -0
- esphome/components/as3935_spi/as3935_spi.h +0 -2
- esphome/components/as5600/as5600.h +0 -1
- esphome/components/async_tcp/__init__.py +14 -5
- esphome/components/atc_mithermometer/atc_mithermometer.h +0 -1
- esphome/components/atm90e32/atm90e32.cpp +2 -1
- esphome/components/audio/audio_decoder.cpp +1 -1
- esphome/components/audio/audio_transfer_buffer.cpp +2 -2
- esphome/components/b_parasite/b_parasite.h +0 -1
- esphome/components/bedjet/bedjet_hub.cpp +5 -1
- esphome/components/bedjet/climate/bedjet_climate.cpp +5 -1
- esphome/components/beken_spi_led_strip/led_strip.cpp +4 -2
- esphome/components/bh1750/bh1750.cpp +5 -5
- esphome/components/binary_sensor/__init__.py +82 -5
- esphome/components/binary_sensor/automation.h +19 -1
- esphome/components/binary_sensor/binary_sensor.cpp +12 -30
- esphome/components/binary_sensor/binary_sensor.h +11 -25
- esphome/components/binary_sensor/filter.cpp +29 -24
- esphome/components/binary_sensor/filter.h +20 -10
- esphome/components/ble_client/output/ble_binary_output.h +0 -1
- esphome/components/ble_client/sensor/ble_rssi_sensor.cpp +5 -1
- esphome/components/ble_client/sensor/ble_rssi_sensor.h +0 -1
- esphome/components/ble_client/sensor/ble_sensor.cpp +5 -1
- esphome/components/ble_client/sensor/ble_sensor.h +0 -1
- esphome/components/ble_client/switch/ble_switch.h +0 -1
- esphome/components/ble_client/text_sensor/ble_text_sensor.cpp +5 -1
- esphome/components/ble_client/text_sensor/ble_text_sensor.h +0 -1
- esphome/components/ble_presence/ble_presence_device.h +0 -1
- esphome/components/ble_rssi/ble_rssi_sensor.h +0 -1
- esphome/components/ble_scanner/ble_scanner.h +0 -1
- esphome/components/bluetooth_proxy/bluetooth_connection.h +9 -2
- esphome/components/bluetooth_proxy/bluetooth_proxy.cpp +16 -6
- esphome/components/bluetooth_proxy/bluetooth_proxy.h +8 -2
- esphome/components/bme680/sensor.py +1 -1
- esphome/components/bmp581/bmp581.h +0 -2
- esphome/components/button/__init__.py +5 -2
- esphome/components/camera/__init__.py +1 -0
- esphome/components/camera/camera.cpp +22 -0
- esphome/components/camera/camera.h +80 -0
- esphome/components/canbus/__init__.py +1 -0
- esphome/components/cap1188/cap1188.h +0 -1
- esphome/components/captive_portal/__init__.py +12 -2
- esphome/components/captive_portal/captive_portal.cpp +12 -2
- esphome/components/captive_portal/captive_portal.h +5 -2
- esphome/components/ccs811/ccs811.h +0 -2
- esphome/components/climate/__init__.py +5 -2
- esphome/components/cm1106/sensor.py +2 -2
- esphome/components/const/__init__.py +2 -0
- esphome/components/copy/binary_sensor/copy_binary_sensor.h +0 -1
- esphome/components/copy/button/copy_button.h +0 -1
- esphome/components/copy/cover/copy_cover.h +0 -1
- esphome/components/copy/fan/copy_fan.h +0 -1
- esphome/components/copy/lock/copy_lock.h +0 -1
- esphome/components/copy/number/copy_number.h +0 -1
- esphome/components/copy/select/copy_select.h +0 -1
- esphome/components/copy/sensor/copy_sensor.h +0 -1
- esphome/components/copy/switch/copy_switch.h +0 -1
- esphome/components/copy/text/copy_text.h +0 -1
- esphome/components/copy/text_sensor/copy_text_sensor.h +0 -1
- esphome/components/cover/__init__.py +5 -2
- esphome/components/cs5460a/cs5460a.h +0 -1
- esphome/components/datetime/__init__.py +4 -2
- esphome/components/debug/__init__.py +20 -0
- esphome/components/debug/debug_esp32.cpp +2 -0
- esphome/components/deep_sleep/__init__.py +43 -9
- esphome/components/demo/__init__.py +2 -2
- esphome/components/display/display.cpp +4 -3
- esphome/components/display/display.h +0 -2
- esphome/components/display/display_buffer.cpp +1 -1
- esphome/components/ds2484/__init__.py +1 -0
- esphome/components/ds2484/ds2484.cpp +209 -0
- esphome/components/ds2484/ds2484.h +43 -0
- esphome/components/ds2484/one_wire.py +37 -0
- esphome/components/duty_time/duty_time_sensor.h +0 -1
- esphome/components/ens160_base/ens160_base.h +0 -1
- esphome/components/es7210/es7210.h +0 -1
- esphome/components/es7243e/es7243e.h +0 -1
- esphome/components/es8156/es8156.h +0 -1
- esphome/components/es8311/es8311.h +0 -1
- esphome/components/es8388/es8388.h +0 -1
- esphome/components/esp32/__init__.py +103 -135
- esphome/components/esp32/core.cpp +0 -4
- esphome/components/esp32/gpio.h +1 -1
- esphome/components/esp32/helpers.cpp +69 -0
- esphome/components/esp32_ble/ble.cpp +5 -6
- esphome/components/esp32_ble/ble.h +29 -14
- esphome/components/esp32_ble/ble_event.h +6 -6
- esphome/components/esp32_ble_client/ble_client_base.cpp +21 -6
- esphome/components/esp32_ble_client/ble_client_base.h +24 -9
- esphome/components/esp32_ble_tracker/__init__.py +2 -8
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.cpp +5 -5
- esphome/components/esp32_ble_tracker/esp32_ble_tracker.h +11 -7
- esphome/components/esp32_camera/__init__.py +112 -98
- esphome/components/esp32_camera/esp32_camera.cpp +41 -31
- esphome/components/esp32_camera/esp32_camera.h +35 -30
- esphome/components/esp32_camera_web_server/__init__.py +2 -1
- esphome/components/esp32_camera_web_server/camera_web_server.cpp +8 -8
- esphome/components/esp32_camera_web_server/camera_web_server.h +3 -3
- esphome/components/esp32_hall/sensor.py +2 -21
- esphome/components/esp32_hosted/__init__.py +101 -0
- esphome/components/esp32_hosted/esp32_hosted.py.script +12 -0
- esphome/components/esp32_improv/esp32_improv_component.cpp +3 -0
- esphome/components/esp32_rmt/__init__.py +0 -58
- esphome/components/esp32_rmt_led_strip/led_strip.cpp +77 -63
- esphome/components/esp32_rmt_led_strip/led_strip.h +11 -17
- esphome/components/esp32_rmt_led_strip/light.py +14 -76
- esphome/components/esp32_touch/esp32_touch.h +174 -28
- esphome/components/esp32_touch/esp32_touch_common.cpp +162 -0
- esphome/components/esp32_touch/esp32_touch_v1.cpp +240 -0
- esphome/components/esp32_touch/esp32_touch_v2.cpp +397 -0
- esphome/components/esp8266/__init__.py +2 -0
- esphome/components/esp8266/gpio.cpp +10 -10
- esphome/components/esp8266/helpers.cpp +31 -0
- esphome/components/esp_ldo/__init__.py +10 -8
- esphome/components/esp_ldo/esp_ldo.h +3 -0
- esphome/components/esphome/ota/__init__.py +1 -0
- esphome/components/esphome/ota/ota_esphome.cpp +24 -19
- esphome/components/ethernet/__init__.py +42 -23
- esphome/components/ethernet/esp_eth_phy_jl1101.c +0 -16
- esphome/components/ethernet/ethernet_component.cpp +69 -29
- esphome/components/ethernet/ethernet_component.h +18 -10
- esphome/components/event/__init__.py +5 -2
- esphome/components/ezo/ezo.h +0 -1
- esphome/components/ezo_pmp/ezo_pmp.h +0 -1
- esphome/components/fan/__init__.py +5 -2
- esphome/components/fan/fan.cpp +4 -0
- esphome/components/feedback/feedback_cover.h +0 -1
- esphome/components/font/__init__.py +92 -82
- esphome/components/font/font.cpp +9 -2
- esphome/components/font/font.h +20 -5
- esphome/components/fs3000/fs3000.h +0 -1
- esphome/components/gcja5/gcja5.h +0 -1
- esphome/components/gl_r01_i2c/__init__.py +0 -0
- esphome/components/gl_r01_i2c/gl_r01_i2c.cpp +68 -0
- esphome/components/gl_r01_i2c/gl_r01_i2c.h +22 -0
- esphome/components/gl_r01_i2c/sensor.py +36 -0
- esphome/components/gp8403/gp8403.h +0 -1
- esphome/components/gpio/binary_sensor/__init__.py +39 -1
- esphome/components/gpio/binary_sensor/gpio_binary_sensor.cpp +77 -3
- esphome/components/gpio/binary_sensor/gpio_binary_sensor.h +40 -0
- esphome/components/grove_gas_mc_v2/grove_gas_mc_v2.h +0 -2
- esphome/components/he60r/he60r.h +0 -1
- esphome/components/heatpumpir/climate.py +2 -1
- esphome/components/heatpumpir/heatpumpir.cpp +1 -0
- esphome/components/heatpumpir/heatpumpir.h +1 -0
- esphome/components/honeywellabp2_i2c/honeywellabp2.h +0 -1
- esphome/components/host/__init__.py +3 -1
- esphome/components/host/helpers.cpp +57 -0
- esphome/components/http_request/__init__.py +19 -1
- esphome/components/http_request/http_request.h +1 -1
- esphome/components/http_request/http_request_arduino.cpp +0 -1
- esphome/components/http_request/http_request_arduino.h +1 -0
- esphome/components/http_request/http_request_idf.cpp +0 -1
- esphome/components/http_request/ota/ota_http_request.cpp +1 -1
- esphome/components/http_request/update/http_request_update.cpp +35 -16
- esphome/components/hydreon_rgxx/hydreon_rgxx.cpp +3 -9
- esphome/components/hydreon_rgxx/sensor.py +1 -1
- esphome/components/i2c/__init__.py +23 -11
- esphome/components/i2c/i2c_bus.h +8 -1
- esphome/components/i2c/i2c_bus_arduino.cpp +4 -3
- esphome/components/i2c/i2c_bus_arduino.h +6 -3
- esphome/components/i2c/i2c_bus_esp_idf.h +5 -3
- esphome/components/i2c_device/i2c_device.h +0 -1
- esphome/components/i2s_audio/__init__.py +2 -10
- esphome/components/i2s_audio/i2s_audio.cpp +1 -5
- esphome/components/i2s_audio/media_player/__init__.py +2 -2
- esphome/components/i2s_audio/speaker/__init__.py +1 -1
- esphome/components/i2s_audio/speaker/i2s_audio_speaker.cpp +2 -2
- esphome/components/iaqcore/iaqcore.h +0 -2
- esphome/components/image/__init__.py +123 -24
- esphome/components/improv_serial/improv_serial_component.cpp +0 -4
- esphome/components/ina219/ina219.cpp +7 -0
- esphome/components/ina219/ina219.h +1 -0
- esphome/components/ina260/ina260.h +0 -2
- esphome/components/inkbird_ibsth1_mini/inkbird_ibsth1_mini.h +0 -1
- esphome/components/inkplate6/display.py +15 -0
- esphome/components/inkplate6/inkplate.cpp +2 -2
- esphome/components/integration/integration_sensor.h +0 -1
- esphome/components/internal_temperature/internal_temperature.cpp +8 -27
- esphome/components/internal_temperature/sensor.py +0 -26
- esphome/components/interval/interval.h +0 -2
- esphome/components/json/__init__.py +1 -1
- esphome/components/json/json_util.cpp +56 -63
- esphome/components/ld2410/button/__init__.py +3 -3
- esphome/components/ld2410/button/factory_reset_button.cpp +9 -0
- esphome/components/ld2410/button/{reset_button.h → factory_reset_button.h} +2 -2
- esphome/components/ld2410/ld2410.cpp +421 -268
- esphome/components/ld2410/ld2410.h +44 -146
- esphome/components/ld2410/number/__init__.py +2 -2
- esphome/components/ld2410/sensor.py +1 -1
- esphome/components/ld2410/switch/__init__.py +1 -1
- esphome/components/ld2420/binary_sensor/ld2420_binary_sensor.cpp +2 -2
- esphome/components/ld2420/button/reconfig_buttons.cpp +1 -1
- esphome/components/ld2420/ld2420.cpp +252 -147
- esphome/components/ld2420/ld2420.h +52 -126
- esphome/components/ld2420/number/__init__.py +2 -2
- esphome/components/ld2420/number/gate_config_number.cpp +1 -1
- esphome/components/ld2420/select/operating_mode_select.cpp +1 -1
- esphome/components/ld2420/sensor/__init__.py +6 -2
- esphome/components/ld2420/sensor/ld2420_sensor.cpp +2 -2
- esphome/components/ld2420/sensor/ld2420_sensor.h +1 -1
- esphome/components/ld2420/text_sensor/text_sensor.cpp +2 -2
- esphome/components/ld2450/button/__init__.py +3 -3
- esphome/components/ld2450/button/factory_reset_button.cpp +9 -0
- esphome/components/ld2450/button/{reset_button.h → factory_reset_button.h} +2 -2
- esphome/components/ld2450/ld2450.cpp +384 -232
- esphome/components/ld2450/ld2450.h +60 -69
- esphome/components/ld2450/switch/__init__.py +1 -1
- esphome/components/ledc/ledc_output.cpp +1 -63
- esphome/components/libretiny/__init__.py +5 -3
- esphome/components/libretiny/const.py +5 -0
- esphome/components/libretiny/generate_components.py +1 -0
- esphome/components/libretiny/helpers.cpp +35 -0
- esphome/components/libretiny/lt_component.cpp +5 -3
- esphome/components/light/__init__.py +4 -2
- esphome/components/light/addressable_light.h +3 -3
- esphome/components/light/light_call.cpp +180 -243
- esphome/components/light/light_call.h +72 -20
- esphome/components/light/light_color_values.h +14 -14
- esphome/components/light/light_json_schema.cpp +17 -16
- esphome/components/light/light_state.h +15 -13
- esphome/components/light/transformers.h +2 -2
- esphome/components/ln882x/__init__.py +52 -0
- esphome/components/ln882x/boards.py +285 -0
- esphome/components/lock/__init__.py +5 -2
- esphome/components/logger/__init__.py +40 -3
- esphome/components/logger/logger.cpp +47 -12
- esphome/components/logger/logger.h +80 -49
- esphome/components/logger/logger_esp32.cpp +3 -3
- esphome/components/lps22/__init__.py +0 -0
- esphome/components/lps22/lps22.cpp +75 -0
- esphome/components/lps22/lps22.h +27 -0
- esphome/components/lps22/sensor.py +58 -0
- esphome/components/ltr390/ltr390.h +0 -1
- esphome/components/ltr501/ltr501.h +0 -1
- esphome/components/ltr_als_ps/ltr_als_ps.h +0 -1
- esphome/components/lvgl/__init__.py +1 -1
- esphome/components/lvgl/schemas.py +66 -6
- esphome/components/lvgl/styles.py +24 -16
- esphome/components/lvgl/widgets/__init__.py +12 -2
- esphome/components/lvgl/widgets/lv_bar.py +40 -19
- esphome/components/lvgl/widgets/meter.py +20 -13
- esphome/components/m5stack_8angle/light/m5stack_8angle_light.cpp +1 -1
- esphome/components/max9611/max9611.h +0 -1
- esphome/components/mcp23016/__init__.py +1 -1
- esphome/components/mcp23xxx_base/__init__.py +1 -1
- esphome/components/mcp4461/__init__.py +1 -1
- esphome/components/mcp4461/output/__init__.py +3 -2
- esphome/components/mcp9600/mcp9600.h +0 -2
- esphome/components/md5/md5.cpp +3 -3
- esphome/components/md5/md5.h +1 -6
- esphome/components/mdns/__init__.py +22 -11
- esphome/components/media_player/__init__.py +4 -3
- esphome/components/micro_wake_word/__init__.py +1 -5
- esphome/components/micro_wake_word/streaming_model.cpp +2 -2
- esphome/components/microphone/microphone.cpp +7 -9
- esphome/components/microphone/microphone.h +0 -2
- esphome/components/mipi_spi/display.py +1 -0
- esphome/components/mmc5603/mmc5603.cpp +1 -1
- esphome/components/modbus/modbus.cpp +33 -15
- esphome/components/modbus/modbus.h +9 -0
- esphome/components/modbus_controller/__init__.py +42 -10
- esphome/components/modbus_controller/modbus_controller.cpp +92 -11
- esphome/components/modbus_controller/modbus_controller.h +61 -7
- esphome/components/mopeka_pro_check/mopeka_pro_check.h +0 -1
- esphome/components/mopeka_std_check/mopeka_std_check.h +0 -1
- esphome/components/mpl3115a2/mpl3115a2.h +0 -2
- esphome/components/mqtt/__init__.py +16 -0
- esphome/components/mqtt/mqtt_alarm_control_panel.cpp +2 -1
- esphome/components/mqtt/mqtt_backend.h +2 -1
- esphome/components/mqtt/mqtt_backend_esp32.cpp +132 -47
- esphome/components/mqtt/mqtt_backend_esp32.h +106 -4
- esphome/components/mqtt/mqtt_binary_sensor.cpp +1 -0
- esphome/components/mqtt/mqtt_button.cpp +4 -1
- esphome/components/mqtt/mqtt_client.cpp +17 -9
- esphome/components/mqtt/mqtt_client.h +8 -3
- esphome/components/mqtt/mqtt_climate.cpp +6 -4
- esphome/components/mqtt/mqtt_component.cpp +3 -1
- esphome/components/mqtt/mqtt_cover.cpp +1 -0
- esphome/components/mqtt/mqtt_date.cpp +4 -3
- esphome/components/mqtt/mqtt_datetime.cpp +7 -6
- esphome/components/mqtt/mqtt_event.cpp +6 -3
- esphome/components/mqtt/mqtt_fan.cpp +1 -0
- esphome/components/mqtt/mqtt_light.cpp +8 -4
- esphome/components/mqtt/mqtt_lock.cpp +3 -1
- esphome/components/mqtt/mqtt_number.cpp +1 -0
- esphome/components/mqtt/mqtt_select.cpp +2 -1
- esphome/components/mqtt/mqtt_sensor.cpp +3 -1
- esphome/components/mqtt/mqtt_switch.cpp +3 -1
- esphome/components/mqtt/mqtt_text.cpp +1 -0
- esphome/components/mqtt/mqtt_text_sensor.cpp +3 -1
- esphome/components/mqtt/mqtt_time.cpp +4 -3
- esphome/components/mqtt/mqtt_update.cpp +1 -0
- esphome/components/mqtt/mqtt_valve.cpp +3 -1
- esphome/components/ms8607/ms8607.cpp +1 -1
- esphome/components/ms8607/ms8607.h +0 -1
- esphome/components/neopixelbus/light.py +4 -1
- esphome/components/neopixelbus/neopixelbus_light.h +1 -1
- esphome/components/network/__init__.py +4 -1
- esphome/components/network/ip_address.h +1 -0
- esphome/components/nextion/__init__.py +16 -0
- esphome/components/nextion/base_component.py +1 -0
- esphome/components/nextion/binary_sensor/nextion_binarysensor.cpp +1 -1
- esphome/components/nextion/display.py +14 -4
- esphome/components/nextion/nextion.cpp +166 -101
- esphome/components/nextion/nextion.h +84 -53
- esphome/components/nextion/nextion_commands.cpp +11 -10
- esphome/components/nextion/nextion_component.cpp +28 -28
- esphome/components/nextion/nextion_component.h +53 -18
- esphome/components/nextion/nextion_component_base.h +3 -0
- esphome/components/nextion/nextion_upload.cpp +36 -0
- esphome/components/nextion/nextion_upload_arduino.cpp +10 -35
- esphome/components/nextion/nextion_upload_idf.cpp +9 -33
- esphome/components/nextion/sensor/nextion_sensor.cpp +1 -1
- esphome/components/nextion/switch/nextion_switch.cpp +1 -1
- esphome/components/nextion/text_sensor/nextion_textsensor.cpp +1 -1
- esphome/components/nfc/nfc.cpp +3 -22
- esphome/components/nfc/nfc.h +3 -3
- esphome/components/number/__init__.py +5 -2
- esphome/components/online_image/__init__.py +9 -1
- esphome/components/online_image/online_image.cpp +17 -7
- esphome/components/online_image/online_image.h +10 -2
- esphome/components/opentherm/opentherm.cpp +7 -12
- esphome/components/opentherm/output/output.cpp +1 -1
- esphome/components/openthread/__init__.py +47 -40
- esphome/components/openthread/const.py +1 -0
- esphome/components/openthread/openthread_esp.cpp +27 -5
- esphome/components/opt3001/__init__.py +0 -0
- esphome/components/opt3001/opt3001.cpp +122 -0
- esphome/components/opt3001/opt3001.h +27 -0
- esphome/components/opt3001/sensor.py +35 -0
- esphome/components/ota/__init__.py +17 -0
- esphome/components/ota/ota_backend.h +27 -1
- esphome/components/ota/ota_backend_arduino_esp32.cpp +12 -2
- esphome/components/ota/ota_backend_arduino_esp32.h +3 -0
- esphome/components/ota/ota_backend_arduino_esp8266.cpp +18 -4
- esphome/components/ota/ota_backend_arduino_esp8266.h +3 -0
- esphome/components/ota/ota_backend_arduino_libretiny.cpp +12 -2
- esphome/components/ota/ota_backend_arduino_libretiny.h +3 -0
- esphome/components/ota/ota_backend_arduino_rp2040.cpp +9 -2
- esphome/components/ota/ota_backend_arduino_rp2040.h +3 -0
- esphome/components/ota/ota_backend_esp_idf.cpp +10 -16
- esphome/components/ota/ota_backend_esp_idf.h +1 -0
- esphome/components/packages/__init__.py +5 -2
- esphome/components/packet_transport/binary_sensor.py +61 -4
- esphome/components/packet_transport/packet_transport.cpp +34 -1
- esphome/components/packet_transport/packet_transport.h +11 -5
- esphome/components/pcf8574/__init__.py +1 -1
- esphome/components/pi4ioe5v6408/__init__.py +84 -0
- esphome/components/pi4ioe5v6408/pi4ioe5v6408.cpp +171 -0
- esphome/components/pi4ioe5v6408/pi4ioe5v6408.h +70 -0
- esphome/components/pmsa003i/pmsa003i.h +0 -1
- esphome/components/pmsx003/pmsx003.h +0 -1
- esphome/components/pn7150/pn7150.cpp +7 -7
- esphome/components/pn7150/pn7150.h +0 -1
- esphome/components/pn7160/pn7160.cpp +7 -7
- esphome/components/pn7160/pn7160.h +0 -1
- esphome/components/preferences/syncer.h +2 -0
- esphome/components/prometheus/prometheus_handler.h +1 -1
- esphome/components/psram/psram.cpp +0 -20
- esphome/components/pulse_counter/pulse_counter_sensor.h +0 -1
- esphome/components/pulse_meter/pulse_meter_sensor.cpp +8 -4
- esphome/components/pulse_width/pulse_width.h +0 -1
- esphome/components/pvvx_mithermometer/display/pvvx_display.cpp +0 -4
- esphome/components/pvvx_mithermometer/display/pvvx_display.h +0 -2
- esphome/components/pvvx_mithermometer/pvvx_mithermometer.h +0 -1
- esphome/components/qr_code/__init__.py +13 -10
- esphome/components/qwiic_pir/qwiic_pir.h +0 -1
- esphome/components/radon_eye_ble/radon_eye_listener.cpp +1 -1
- esphome/components/rc522/rc522.h +0 -1
- esphome/components/rdm6300/rdm6300.h +0 -2
- esphome/components/remote_base/__init__.py +7 -5
- esphome/components/remote_base/remote_base.cpp +24 -21
- esphome/components/remote_base/remote_base.h +3 -26
- esphome/components/remote_receiver/__init__.py +40 -46
- esphome/components/remote_receiver/remote_receiver.h +4 -18
- esphome/components/remote_receiver/remote_receiver_esp32.cpp +0 -87
- esphome/components/remote_receiver/remote_receiver_esp8266.cpp +1 -1
- esphome/components/remote_transmitter/__init__.py +42 -43
- esphome/components/remote_transmitter/remote_transmitter.h +2 -14
- esphome/components/remote_transmitter/remote_transmitter_esp32.cpp +0 -77
- esphome/components/resistance/resistance_sensor.h +0 -1
- esphome/components/rp2040/__init__.py +2 -0
- esphome/components/rp2040/helpers.cpp +55 -0
- esphome/components/rp2040_pio_led_strip/led_strip.cpp +2 -2
- esphome/components/rpi_dpi_rgb/rpi_dpi_rgb.cpp +0 -4
- esphome/components/rtttl/__init__.py +4 -4
- esphome/components/rtttl/rtttl.cpp +10 -1
- esphome/components/ruuvitag/ruuvitag.h +0 -1
- esphome/components/safe_mode/safe_mode.cpp +2 -0
- esphome/components/safe_mode/safe_mode.h +4 -1
- esphome/components/scd30/scd30.h +0 -1
- esphome/components/scd30/sensor.py +2 -2
- esphome/components/scd4x/scd4x.cpp +61 -54
- esphome/components/scd4x/scd4x.h +17 -15
- esphome/components/scd4x/sensor.py +4 -4
- esphome/components/script/script.h +0 -2
- esphome/components/sdp3x/sensor.py +1 -1
- esphome/components/select/__init__.py +5 -2
- esphome/components/sen5x/sen5x.h +0 -1
- esphome/components/senseair/senseair.h +0 -1
- esphome/components/sensor/__init__.py +4 -2
- esphome/components/sensor/filter.cpp +1 -1
- esphome/components/sensor/sensor.cpp +12 -6
- esphome/components/sensor/sensor.h +13 -5
- esphome/components/servo/servo.cpp +2 -2
- esphome/components/servo/servo.h +0 -1
- esphome/components/sfa30/sfa30.h +0 -1
- esphome/components/sgp30/sgp30.h +0 -1
- esphome/components/sgp4x/sgp4x.h +0 -1
- esphome/components/shelly_dimmer/stm32flash.cpp +1 -2
- esphome/components/sht4x/sht4x.h +0 -1
- esphome/components/sm300d2/sm300d2.h +0 -2
- esphome/components/smt100/sensor.py +8 -4
- esphome/components/smt100/smt100.cpp +5 -5
- esphome/components/smt100/smt100.h +3 -3
- esphome/components/sn74hc595/__init__.py +1 -1
- esphome/components/sn74hc595/sn74hc595.cpp +5 -4
- esphome/components/sntp/sntp_component.cpp +9 -3
- esphome/components/sntp/time.py +2 -0
- esphome/components/socket/__init__.py +17 -0
- esphome/components/spi/__init__.py +27 -6
- esphome/components/spi/spi.cpp +3 -2
- esphome/components/spi/spi.h +9 -3
- esphome/components/spi/spi_arduino.cpp +3 -5
- esphome/components/spi/spi_esp_idf.cpp +40 -21
- esphome/components/spi_led_strip/spi_led_strip.cpp +1 -1
- esphome/components/sps30/sps30.h +0 -1
- esphome/components/ssd1306_base/ssd1306_base.cpp +1 -1
- esphome/components/st7701s/st7701s.cpp +0 -4
- esphome/components/status/status_binary_sensor.h +0 -2
- esphome/components/substitutions/__init__.py +81 -21
- esphome/components/substitutions/jinja.py +99 -0
- esphome/components/sun/sun.cpp +3 -4
- esphome/components/switch/__init__.py +5 -2
- esphome/components/switch/binary_sensor/switch_binary_sensor.h +0 -1
- esphome/components/sx126x/__init__.py +317 -0
- esphome/components/sx126x/automation.h +62 -0
- esphome/components/sx126x/packet_transport/__init__.py +26 -0
- esphome/components/sx126x/packet_transport/sx126x_transport.cpp +26 -0
- esphome/components/sx126x/packet_transport/sx126x_transport.h +25 -0
- esphome/components/sx126x/sx126x.cpp +523 -0
- esphome/components/sx126x/sx126x.h +140 -0
- esphome/components/sx126x/sx126x_reg.h +163 -0
- esphome/components/sx127x/__init__.py +325 -0
- esphome/components/sx127x/automation.h +62 -0
- esphome/components/sx127x/packet_transport/__init__.py +26 -0
- esphome/components/sx127x/packet_transport/sx127x_transport.cpp +26 -0
- esphome/components/sx127x/packet_transport/sx127x_transport.h +25 -0
- esphome/components/sx127x/sx127x.cpp +498 -0
- esphome/components/sx127x/sx127x.h +128 -0
- esphome/components/sx127x/sx127x_reg.h +295 -0
- esphome/components/syslog/esphome_syslog.cpp +5 -3
- esphome/components/syslog/esphome_syslog.h +1 -1
- esphome/components/tca9555/__init__.py +1 -1
- esphome/components/template/binary_sensor/template_binary_sensor.cpp +1 -9
- esphome/components/text/__init__.py +5 -2
- esphome/components/text_sensor/__init__.py +5 -2
- esphome/components/thermostat/thermostat_climate.cpp +34 -31
- esphome/components/thermostat/thermostat_climate.h +43 -39
- esphome/components/time/__init__.py +16 -2
- esphome/components/time/real_time_clock.cpp +4 -0
- esphome/components/time/real_time_clock.h +5 -1
- esphome/components/tlc5971/tlc5971.cpp +4 -1
- esphome/components/tmp1075/tmp1075.h +0 -2
- esphome/components/tof10120/tof10120_sensor.h +0 -1
- esphome/components/tormatic/tormatic_cover.h +0 -1
- esphome/components/total_daily_energy/total_daily_energy.h +0 -1
- esphome/components/tsl2591/tsl2591.cpp +1 -1
- esphome/components/ttp229_bsf/ttp229_bsf.h +0 -1
- esphome/components/ttp229_lsf/ttp229_lsf.h +0 -1
- esphome/components/tx20/tx20.cpp +2 -2
- esphome/components/uart/__init__.py +18 -0
- esphome/components/uart/uart_component_esp_idf.cpp +1 -5
- esphome/components/update/__init__.py +5 -2
- esphome/components/update/update_entity.h +8 -0
- esphome/components/usb_host/__init__.py +5 -2
- esphome/components/usb_host/usb_host_client.cpp +10 -10
- esphome/components/usb_uart/cp210x.cpp +1 -1
- esphome/components/usb_uart/usb_uart.cpp +41 -44
- esphome/components/usb_uart/usb_uart.h +4 -3
- esphome/components/valve/__init__.py +5 -2
- esphome/components/vbus/vbus.h +0 -1
- esphome/components/veml3235/veml3235.h +0 -1
- esphome/components/veml7700/veml7700.h +0 -1
- esphome/components/vl53l0x/vl53l0x_sensor.h +0 -1
- esphome/components/voice_assistant/voice_assistant.cpp +4 -4
- esphome/components/watchdog/watchdog.cpp +0 -4
- esphome/components/waveshare_epaper/waveshare_epaper.cpp +6 -6
- esphome/components/web_server/__init__.py +34 -19
- esphome/components/web_server/ota/__init__.py +32 -0
- esphome/components/web_server/ota/ota_web_server.cpp +210 -0
- esphome/components/web_server/ota/ota_web_server.h +26 -0
- esphome/components/web_server/web_server.cpp +324 -439
- esphome/components/web_server/web_server.h +33 -23
- esphome/components/web_server/web_server_v1.cpp +4 -5
- esphome/components/web_server_base/__init__.py +5 -2
- esphome/components/web_server_base/web_server_base.cpp +2 -94
- esphome/components/web_server_base/web_server_base.h +5 -25
- esphome/components/web_server_idf/multipart.cpp +254 -0
- esphome/components/web_server_idf/multipart.h +86 -0
- esphome/components/web_server_idf/utils.cpp +32 -0
- esphome/components/web_server_idf/utils.h +10 -0
- esphome/components/web_server_idf/web_server_idf.cpp +164 -16
- esphome/components/web_server_idf/web_server_idf.h +11 -10
- esphome/components/wiegand/wiegand.cpp +2 -2
- esphome/components/wifi/__init__.py +18 -0
- esphome/components/wifi/wifi_component.cpp +17 -22
- esphome/components/wifi/wifi_component.h +27 -23
- esphome/components/wifi/wifi_component_esp32_arduino.cpp +52 -59
- esphome/components/wifi/wifi_component_esp8266.cpp +46 -46
- esphome/components/wifi/wifi_component_esp_idf.cpp +35 -36
- esphome/components/wifi/wifi_component_libretiny.cpp +26 -27
- esphome/components/wifi/wifi_component_pico_w.cpp +3 -3
- esphome/components/wifi_info/wifi_info_text_sensor.cpp +6 -6
- esphome/components/wireguard/__init__.py +2 -11
- esphome/components/xiaomi_ble/xiaomi_ble.cpp +13 -1
- esphome/components/xiaomi_ble/xiaomi_ble.h +1 -0
- esphome/components/xiaomi_cgd1/xiaomi_cgd1.h +0 -1
- esphome/components/xiaomi_cgdk2/xiaomi_cgdk2.h +0 -1
- esphome/components/xiaomi_cgg1/xiaomi_cgg1.h +0 -1
- esphome/components/xiaomi_cgpr1/xiaomi_cgpr1.h +0 -1
- esphome/components/xiaomi_gcls002/xiaomi_gcls002.h +0 -1
- esphome/components/xiaomi_hhccjcy01/xiaomi_hhccjcy01.h +0 -1
- esphome/components/xiaomi_hhccjcy10/xiaomi_hhccjcy10.h +0 -1
- esphome/components/xiaomi_hhccpot002/xiaomi_hhccpot002.h +0 -1
- esphome/components/xiaomi_jqjcy01ym/xiaomi_jqjcy01ym.h +0 -1
- esphome/components/xiaomi_lywsd02/xiaomi_lywsd02.h +0 -1
- esphome/components/xiaomi_lywsd02mmc/xiaomi_lywsd02mmc.h +0 -1
- esphome/components/xiaomi_lywsd03mmc/xiaomi_lywsd03mmc.h +0 -1
- esphome/components/xiaomi_lywsdcgq/xiaomi_lywsdcgq.h +0 -1
- esphome/components/xiaomi_mhoc303/xiaomi_mhoc303.h +0 -1
- esphome/components/xiaomi_mhoc401/xiaomi_mhoc401.h +0 -1
- esphome/components/xiaomi_miscale/xiaomi_miscale.h +0 -1
- esphome/components/xiaomi_mjyd02yla/xiaomi_mjyd02yla.h +0 -1
- esphome/components/xiaomi_mue4094rt/xiaomi_mue4094rt.h +0 -1
- esphome/components/xiaomi_rtcgq02lm/xiaomi_rtcgq02lm.h +0 -1
- esphome/components/xiaomi_wx08zm/xiaomi_wx08zm.h +0 -1
- esphome/components/xiaomi_xmwsdj04mmc/__init__.py +0 -0
- esphome/components/xiaomi_xmwsdj04mmc/sensor.py +77 -0
- esphome/components/xiaomi_xmwsdj04mmc/xiaomi_xmwsdj04mmc.cpp +77 -0
- esphome/components/xiaomi_xmwsdj04mmc/xiaomi_xmwsdj04mmc.h +36 -0
- esphome/components/zio_ultrasonic/zio_ultrasonic.h +0 -2
- esphome/components/zyaura/zyaura.h +0 -1
- esphome/config.py +88 -22
- esphome/config_helpers.py +74 -1
- esphome/config_validation.py +12 -1
- esphome/const.py +65 -10
- esphome/core/__init__.py +18 -2
- esphome/core/application.cpp +169 -10
- esphome/core/application.h +145 -165
- esphome/core/area.h +19 -0
- esphome/core/automation.h +58 -9
- esphome/core/color.cpp +3 -5
- esphome/core/color.h +16 -16
- esphome/core/component.cpp +156 -22
- esphome/core/component.h +98 -4
- esphome/core/component_iterator.cpp +11 -9
- esphome/core/component_iterator.h +12 -10
- esphome/core/config.py +155 -6
- esphome/core/controller.cpp +4 -2
- esphome/core/controller.h +1 -1
- esphome/core/datatypes.h +2 -2
- esphome/core/defines.h +17 -2
- esphome/core/device.h +20 -0
- esphome/core/entity_base.cpp +20 -15
- esphome/core/entity_base.h +76 -0
- esphome/core/entity_helpers.py +168 -1
- esphome/core/event_pool.h +81 -0
- esphome/core/helpers.cpp +75 -230
- esphome/core/helpers.h +165 -105
- esphome/core/lock_free_queue.h +151 -0
- esphome/core/log.cpp +2 -2
- esphome/core/log.h +2 -0
- esphome/core/optional.h +5 -0
- esphome/core/ring_buffer.cpp +2 -2
- esphome/core/scheduler.cpp +275 -103
- esphome/core/scheduler.h +154 -17
- esphome/core/time.cpp +5 -5
- esphome/core/time.h +5 -5
- esphome/cpp_generator.py +17 -0
- esphome/cpp_helpers.py +0 -22
- esphome/cpp_types.py +3 -1
- esphome/dashboard/entries.py +1 -1
- esphome/dashboard/util/text.py +5 -21
- esphome/dashboard/web_server.py +9 -1
- esphome/helpers.py +47 -0
- esphome/loader.py +15 -1
- esphome/pins.py +14 -8
- esphome/platformio_api.py +2 -0
- esphome/wizard.py +17 -4
- esphome/writer.py +44 -3
- esphome/yaml_util.py +0 -2
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/METADATA +10 -9
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/RECORD +639 -580
- esphome/components/api/api_pb2_size.h +0 -361
- esphome/components/esp32_ble/ble_event_pool.h +0 -72
- esphome/components/esp32_ble/queue.h +0 -85
- esphome/components/esp32_hall/esp32_hall.cpp +0 -25
- esphome/components/esp32_hall/esp32_hall.h +0 -23
- esphome/components/esp32_touch/esp32_touch.cpp +0 -355
- esphome/components/ld2410/button/reset_button.cpp +0 -9
- esphome/components/ld2450/button/reset_button.cpp +0 -9
- esphome/components/openthread/tlv.py +0 -65
- /esphome/{dashboard/enum.py → enum.py} +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/WHEEL +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/entry_points.txt +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/licenses/LICENSE +0 -0
- {esphome-2025.6.2.dist-info → esphome-2025.7.0.dist-info}/top_level.txt +0 -0
|
@@ -1,361 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "proto.h"
|
|
4
|
-
#include <cstdint>
|
|
5
|
-
#include <string>
|
|
6
|
-
|
|
7
|
-
namespace esphome {
|
|
8
|
-
namespace api {
|
|
9
|
-
|
|
10
|
-
class ProtoSize {
|
|
11
|
-
public:
|
|
12
|
-
/**
|
|
13
|
-
* @brief ProtoSize class for Protocol Buffer serialization size calculation
|
|
14
|
-
*
|
|
15
|
-
* This class provides static methods to calculate the exact byte counts needed
|
|
16
|
-
* for encoding various Protocol Buffer field types. All methods are designed to be
|
|
17
|
-
* efficient for the common case where many fields have default values.
|
|
18
|
-
*
|
|
19
|
-
* Implements Protocol Buffer encoding size calculation according to:
|
|
20
|
-
* https://protobuf.dev/programming-guides/encoding/
|
|
21
|
-
*
|
|
22
|
-
* Key features:
|
|
23
|
-
* - Early-return optimization for zero/default values
|
|
24
|
-
* - Direct total_size updates to avoid unnecessary additions
|
|
25
|
-
* - Specialized handling for different field types according to protobuf spec
|
|
26
|
-
* - Templated helpers for repeated fields and messages
|
|
27
|
-
*/
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* @brief Calculates the size in bytes needed to encode a uint32_t value as a varint
|
|
31
|
-
*
|
|
32
|
-
* @param value The uint32_t value to calculate size for
|
|
33
|
-
* @return The number of bytes needed to encode the value
|
|
34
|
-
*/
|
|
35
|
-
static inline uint32_t varint(uint32_t value) {
|
|
36
|
-
// Optimized varint size calculation using leading zeros
|
|
37
|
-
// Each 7 bits requires one byte in the varint encoding
|
|
38
|
-
if (value < 128)
|
|
39
|
-
return 1; // 7 bits, common case for small values
|
|
40
|
-
|
|
41
|
-
// For larger values, count bytes needed based on the position of the highest bit set
|
|
42
|
-
if (value < 16384) {
|
|
43
|
-
return 2; // 14 bits
|
|
44
|
-
} else if (value < 2097152) {
|
|
45
|
-
return 3; // 21 bits
|
|
46
|
-
} else if (value < 268435456) {
|
|
47
|
-
return 4; // 28 bits
|
|
48
|
-
} else {
|
|
49
|
-
return 5; // 32 bits (maximum for uint32_t)
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* @brief Calculates the size in bytes needed to encode a uint64_t value as a varint
|
|
55
|
-
*
|
|
56
|
-
* @param value The uint64_t value to calculate size for
|
|
57
|
-
* @return The number of bytes needed to encode the value
|
|
58
|
-
*/
|
|
59
|
-
static inline uint32_t varint(uint64_t value) {
|
|
60
|
-
// Handle common case of values fitting in uint32_t (vast majority of use cases)
|
|
61
|
-
if (value <= UINT32_MAX) {
|
|
62
|
-
return varint(static_cast<uint32_t>(value));
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// For larger values, determine size based on highest bit position
|
|
66
|
-
if (value < (1ULL << 35)) {
|
|
67
|
-
return 5; // 35 bits
|
|
68
|
-
} else if (value < (1ULL << 42)) {
|
|
69
|
-
return 6; // 42 bits
|
|
70
|
-
} else if (value < (1ULL << 49)) {
|
|
71
|
-
return 7; // 49 bits
|
|
72
|
-
} else if (value < (1ULL << 56)) {
|
|
73
|
-
return 8; // 56 bits
|
|
74
|
-
} else if (value < (1ULL << 63)) {
|
|
75
|
-
return 9; // 63 bits
|
|
76
|
-
} else {
|
|
77
|
-
return 10; // 64 bits (maximum for uint64_t)
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* @brief Calculates the size in bytes needed to encode an int32_t value as a varint
|
|
83
|
-
*
|
|
84
|
-
* Special handling is needed for negative values, which are sign-extended to 64 bits
|
|
85
|
-
* in Protocol Buffers, resulting in a 10-byte varint.
|
|
86
|
-
*
|
|
87
|
-
* @param value The int32_t value to calculate size for
|
|
88
|
-
* @return The number of bytes needed to encode the value
|
|
89
|
-
*/
|
|
90
|
-
static inline uint32_t varint(int32_t value) {
|
|
91
|
-
// Negative values are sign-extended to 64 bits in protocol buffers,
|
|
92
|
-
// which always results in a 10-byte varint for negative int32
|
|
93
|
-
if (value < 0) {
|
|
94
|
-
return 10; // Negative int32 is always 10 bytes long
|
|
95
|
-
}
|
|
96
|
-
// For non-negative values, use the uint32_t implementation
|
|
97
|
-
return varint(static_cast<uint32_t>(value));
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* @brief Calculates the size in bytes needed to encode an int64_t value as a varint
|
|
102
|
-
*
|
|
103
|
-
* @param value The int64_t value to calculate size for
|
|
104
|
-
* @return The number of bytes needed to encode the value
|
|
105
|
-
*/
|
|
106
|
-
static inline uint32_t varint(int64_t value) {
|
|
107
|
-
// For int64_t, we convert to uint64_t and calculate the size
|
|
108
|
-
// This works because the bit pattern determines the encoding size,
|
|
109
|
-
// and we've handled negative int32 values as a special case above
|
|
110
|
-
return varint(static_cast<uint64_t>(value));
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* @brief Calculates the size in bytes needed to encode a field ID and wire type
|
|
115
|
-
*
|
|
116
|
-
* @param field_id The field identifier
|
|
117
|
-
* @param type The wire type value (from the WireType enum in the protobuf spec)
|
|
118
|
-
* @return The number of bytes needed to encode the field ID and wire type
|
|
119
|
-
*/
|
|
120
|
-
static inline uint32_t field(uint32_t field_id, uint32_t type) {
|
|
121
|
-
uint32_t tag = (field_id << 3) | (type & 0b111);
|
|
122
|
-
return varint(tag);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* @brief Common parameters for all add_*_field methods
|
|
127
|
-
*
|
|
128
|
-
* All add_*_field methods follow these common patterns:
|
|
129
|
-
*
|
|
130
|
-
* @param total_size Reference to the total message size to update
|
|
131
|
-
* @param field_id_size Pre-calculated size of the field ID in bytes
|
|
132
|
-
* @param value The value to calculate size for (type varies)
|
|
133
|
-
* @param force Whether to calculate size even if the value is default/zero/empty
|
|
134
|
-
*
|
|
135
|
-
* Each method follows this implementation pattern:
|
|
136
|
-
* 1. Skip calculation if value is default (0, false, empty) and not forced
|
|
137
|
-
* 2. Calculate the size based on the field's encoding rules
|
|
138
|
-
* 3. Add the field_id_size + calculated value size to total_size
|
|
139
|
-
*/
|
|
140
|
-
|
|
141
|
-
/**
|
|
142
|
-
* @brief Calculates and adds the size of an int32 field to the total message size
|
|
143
|
-
*/
|
|
144
|
-
static inline void add_int32_field(uint32_t &total_size, uint32_t field_id_size, int32_t value, bool force = false) {
|
|
145
|
-
// Skip calculation if value is zero and not forced
|
|
146
|
-
if (value == 0 && !force) {
|
|
147
|
-
return; // No need to update total_size
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
// Calculate and directly add to total_size
|
|
151
|
-
if (value < 0) {
|
|
152
|
-
// Negative values are encoded as 10-byte varints in protobuf
|
|
153
|
-
total_size += field_id_size + 10;
|
|
154
|
-
} else {
|
|
155
|
-
// For non-negative values, use the standard varint size
|
|
156
|
-
total_size += field_id_size + varint(static_cast<uint32_t>(value));
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
/**
|
|
161
|
-
* @brief Calculates and adds the size of a uint32 field to the total message size
|
|
162
|
-
*/
|
|
163
|
-
static inline void add_uint32_field(uint32_t &total_size, uint32_t field_id_size, uint32_t value,
|
|
164
|
-
bool force = false) {
|
|
165
|
-
// Skip calculation if value is zero and not forced
|
|
166
|
-
if (value == 0 && !force) {
|
|
167
|
-
return; // No need to update total_size
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
// Calculate and directly add to total_size
|
|
171
|
-
total_size += field_id_size + varint(value);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
/**
|
|
175
|
-
* @brief Calculates and adds the size of a boolean field to the total message size
|
|
176
|
-
*/
|
|
177
|
-
static inline void add_bool_field(uint32_t &total_size, uint32_t field_id_size, bool value, bool force = false) {
|
|
178
|
-
// Skip calculation if value is false and not forced
|
|
179
|
-
if (!value && !force) {
|
|
180
|
-
return; // No need to update total_size
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
// Boolean fields always use 1 byte when true
|
|
184
|
-
total_size += field_id_size + 1;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
/**
|
|
188
|
-
* @brief Calculates and adds the size of a fixed field to the total message size
|
|
189
|
-
*
|
|
190
|
-
* Fixed fields always take exactly N bytes (4 for fixed32/float, 8 for fixed64/double).
|
|
191
|
-
*
|
|
192
|
-
* @tparam NumBytes The number of bytes for this fixed field (4 or 8)
|
|
193
|
-
* @param is_nonzero Whether the value is non-zero
|
|
194
|
-
*/
|
|
195
|
-
template<uint32_t NumBytes>
|
|
196
|
-
static inline void add_fixed_field(uint32_t &total_size, uint32_t field_id_size, bool is_nonzero,
|
|
197
|
-
bool force = false) {
|
|
198
|
-
// Skip calculation if value is zero and not forced
|
|
199
|
-
if (!is_nonzero && !force) {
|
|
200
|
-
return; // No need to update total_size
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// Fixed fields always take exactly NumBytes
|
|
204
|
-
total_size += field_id_size + NumBytes;
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
/**
|
|
208
|
-
* @brief Calculates and adds the size of an enum field to the total message size
|
|
209
|
-
*
|
|
210
|
-
* Enum fields are encoded as uint32 varints.
|
|
211
|
-
*/
|
|
212
|
-
static inline void add_enum_field(uint32_t &total_size, uint32_t field_id_size, uint32_t value, bool force = false) {
|
|
213
|
-
// Skip calculation if value is zero and not forced
|
|
214
|
-
if (value == 0 && !force) {
|
|
215
|
-
return; // No need to update total_size
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
// Enums are encoded as uint32
|
|
219
|
-
total_size += field_id_size + varint(value);
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
/**
|
|
223
|
-
* @brief Calculates and adds the size of a sint32 field to the total message size
|
|
224
|
-
*
|
|
225
|
-
* Sint32 fields use ZigZag encoding, which is more efficient for negative values.
|
|
226
|
-
*/
|
|
227
|
-
static inline void add_sint32_field(uint32_t &total_size, uint32_t field_id_size, int32_t value, bool force = false) {
|
|
228
|
-
// Skip calculation if value is zero and not forced
|
|
229
|
-
if (value == 0 && !force) {
|
|
230
|
-
return; // No need to update total_size
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
// ZigZag encoding for sint32: (n << 1) ^ (n >> 31)
|
|
234
|
-
uint32_t zigzag = (static_cast<uint32_t>(value) << 1) ^ (static_cast<uint32_t>(value >> 31));
|
|
235
|
-
total_size += field_id_size + varint(zigzag);
|
|
236
|
-
}
|
|
237
|
-
|
|
238
|
-
/**
|
|
239
|
-
* @brief Calculates and adds the size of an int64 field to the total message size
|
|
240
|
-
*/
|
|
241
|
-
static inline void add_int64_field(uint32_t &total_size, uint32_t field_id_size, int64_t value, bool force = false) {
|
|
242
|
-
// Skip calculation if value is zero and not forced
|
|
243
|
-
if (value == 0 && !force) {
|
|
244
|
-
return; // No need to update total_size
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
// Calculate and directly add to total_size
|
|
248
|
-
total_size += field_id_size + varint(value);
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
/**
|
|
252
|
-
* @brief Calculates and adds the size of a uint64 field to the total message size
|
|
253
|
-
*/
|
|
254
|
-
static inline void add_uint64_field(uint32_t &total_size, uint32_t field_id_size, uint64_t value,
|
|
255
|
-
bool force = false) {
|
|
256
|
-
// Skip calculation if value is zero and not forced
|
|
257
|
-
if (value == 0 && !force) {
|
|
258
|
-
return; // No need to update total_size
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
// Calculate and directly add to total_size
|
|
262
|
-
total_size += field_id_size + varint(value);
|
|
263
|
-
}
|
|
264
|
-
|
|
265
|
-
/**
|
|
266
|
-
* @brief Calculates and adds the size of a sint64 field to the total message size
|
|
267
|
-
*
|
|
268
|
-
* Sint64 fields use ZigZag encoding, which is more efficient for negative values.
|
|
269
|
-
*/
|
|
270
|
-
static inline void add_sint64_field(uint32_t &total_size, uint32_t field_id_size, int64_t value, bool force = false) {
|
|
271
|
-
// Skip calculation if value is zero and not forced
|
|
272
|
-
if (value == 0 && !force) {
|
|
273
|
-
return; // No need to update total_size
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
// ZigZag encoding for sint64: (n << 1) ^ (n >> 63)
|
|
277
|
-
uint64_t zigzag = (static_cast<uint64_t>(value) << 1) ^ (static_cast<uint64_t>(value >> 63));
|
|
278
|
-
total_size += field_id_size + varint(zigzag);
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
/**
|
|
282
|
-
* @brief Calculates and adds the size of a string/bytes field to the total message size
|
|
283
|
-
*/
|
|
284
|
-
static inline void add_string_field(uint32_t &total_size, uint32_t field_id_size, const std::string &str,
|
|
285
|
-
bool force = false) {
|
|
286
|
-
// Skip calculation if string is empty and not forced
|
|
287
|
-
if (str.empty() && !force) {
|
|
288
|
-
return; // No need to update total_size
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
// Calculate and directly add to total_size
|
|
292
|
-
const uint32_t str_size = static_cast<uint32_t>(str.size());
|
|
293
|
-
total_size += field_id_size + varint(str_size) + str_size;
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
/**
|
|
297
|
-
* @brief Calculates and adds the size of a nested message field to the total message size
|
|
298
|
-
*
|
|
299
|
-
* This helper function directly updates the total_size reference if the nested size
|
|
300
|
-
* is greater than zero or force is true.
|
|
301
|
-
*
|
|
302
|
-
* @param nested_size The pre-calculated size of the nested message
|
|
303
|
-
*/
|
|
304
|
-
static inline void add_message_field(uint32_t &total_size, uint32_t field_id_size, uint32_t nested_size,
|
|
305
|
-
bool force = false) {
|
|
306
|
-
// Skip calculation if nested message is empty and not forced
|
|
307
|
-
if (nested_size == 0 && !force) {
|
|
308
|
-
return; // No need to update total_size
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
// Calculate and directly add to total_size
|
|
312
|
-
// Field ID + length varint + nested message content
|
|
313
|
-
total_size += field_id_size + varint(nested_size) + nested_size;
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
/**
|
|
317
|
-
* @brief Calculates and adds the size of a nested message field to the total message size
|
|
318
|
-
*
|
|
319
|
-
* This templated version directly takes a message object, calculates its size internally,
|
|
320
|
-
* and updates the total_size reference. This eliminates the need for a temporary variable
|
|
321
|
-
* at the call site.
|
|
322
|
-
*
|
|
323
|
-
* @tparam MessageType The type of the nested message (inferred from parameter)
|
|
324
|
-
* @param message The nested message object
|
|
325
|
-
*/
|
|
326
|
-
template<typename MessageType>
|
|
327
|
-
static inline void add_message_object(uint32_t &total_size, uint32_t field_id_size, const MessageType &message,
|
|
328
|
-
bool force = false) {
|
|
329
|
-
uint32_t nested_size = 0;
|
|
330
|
-
message.calculate_size(nested_size);
|
|
331
|
-
|
|
332
|
-
// Use the base implementation with the calculated nested_size
|
|
333
|
-
add_message_field(total_size, field_id_size, nested_size, force);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
/**
|
|
337
|
-
* @brief Calculates and adds the sizes of all messages in a repeated field to the total message size
|
|
338
|
-
*
|
|
339
|
-
* This helper processes a vector of message objects, calculating the size for each message
|
|
340
|
-
* and adding it to the total size.
|
|
341
|
-
*
|
|
342
|
-
* @tparam MessageType The type of the nested messages in the vector
|
|
343
|
-
* @param messages Vector of message objects
|
|
344
|
-
*/
|
|
345
|
-
template<typename MessageType>
|
|
346
|
-
static inline void add_repeated_message(uint32_t &total_size, uint32_t field_id_size,
|
|
347
|
-
const std::vector<MessageType> &messages) {
|
|
348
|
-
// Skip if the vector is empty
|
|
349
|
-
if (messages.empty()) {
|
|
350
|
-
return;
|
|
351
|
-
}
|
|
352
|
-
|
|
353
|
-
// For repeated fields, always use force=true
|
|
354
|
-
for (const auto &message : messages) {
|
|
355
|
-
add_message_object(total_size, field_id_size, message, true);
|
|
356
|
-
}
|
|
357
|
-
}
|
|
358
|
-
};
|
|
359
|
-
|
|
360
|
-
} // namespace api
|
|
361
|
-
} // namespace esphome
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#ifdef USE_ESP32
|
|
4
|
-
|
|
5
|
-
#include <atomic>
|
|
6
|
-
#include <cstddef>
|
|
7
|
-
#include "ble_event.h"
|
|
8
|
-
#include "queue.h"
|
|
9
|
-
#include "esphome/core/helpers.h"
|
|
10
|
-
|
|
11
|
-
namespace esphome {
|
|
12
|
-
namespace esp32_ble {
|
|
13
|
-
|
|
14
|
-
// BLE Event Pool - On-demand pool of BLEEvent objects to avoid heap fragmentation
|
|
15
|
-
// Events are allocated on first use and reused thereafter, growing to peak usage
|
|
16
|
-
template<uint8_t SIZE> class BLEEventPool {
|
|
17
|
-
public:
|
|
18
|
-
BLEEventPool() : total_created_(0) {}
|
|
19
|
-
|
|
20
|
-
~BLEEventPool() {
|
|
21
|
-
// Clean up any remaining events in the free list
|
|
22
|
-
BLEEvent *event;
|
|
23
|
-
while ((event = this->free_list_.pop()) != nullptr) {
|
|
24
|
-
delete event;
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
// Allocate an event from the pool
|
|
29
|
-
// Returns nullptr if pool is full
|
|
30
|
-
BLEEvent *allocate() {
|
|
31
|
-
// Try to get from free list first
|
|
32
|
-
BLEEvent *event = this->free_list_.pop();
|
|
33
|
-
if (event != nullptr)
|
|
34
|
-
return event;
|
|
35
|
-
|
|
36
|
-
// Need to create a new event
|
|
37
|
-
if (this->total_created_ >= SIZE) {
|
|
38
|
-
// Pool is at capacity
|
|
39
|
-
return nullptr;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
// Use internal RAM for better performance
|
|
43
|
-
RAMAllocator<BLEEvent> allocator(RAMAllocator<BLEEvent>::ALLOC_INTERNAL);
|
|
44
|
-
event = allocator.allocate(1);
|
|
45
|
-
|
|
46
|
-
if (event == nullptr) {
|
|
47
|
-
// Memory allocation failed
|
|
48
|
-
return nullptr;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
// Placement new to construct the object
|
|
52
|
-
new (event) BLEEvent();
|
|
53
|
-
this->total_created_++;
|
|
54
|
-
return event;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// Return an event to the pool for reuse
|
|
58
|
-
void release(BLEEvent *event) {
|
|
59
|
-
if (event != nullptr) {
|
|
60
|
-
this->free_list_.push(event);
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
private:
|
|
65
|
-
LockFreeQueue<BLEEvent, SIZE> free_list_; // Free events ready for reuse
|
|
66
|
-
uint8_t total_created_; // Total events created (high water mark)
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
} // namespace esp32_ble
|
|
70
|
-
} // namespace esphome
|
|
71
|
-
|
|
72
|
-
#endif
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#ifdef USE_ESP32
|
|
4
|
-
|
|
5
|
-
#include <atomic>
|
|
6
|
-
#include <cstddef>
|
|
7
|
-
|
|
8
|
-
/*
|
|
9
|
-
* BLE events come in from a separate Task (thread) in the ESP32 stack. Rather
|
|
10
|
-
* than using mutex-based locking, this lock-free queue allows the BLE
|
|
11
|
-
* task to enqueue events without blocking. The main loop() then processes
|
|
12
|
-
* these events at a safer time.
|
|
13
|
-
*
|
|
14
|
-
* This is a Single-Producer Single-Consumer (SPSC) lock-free ring buffer.
|
|
15
|
-
* The BLE task is the only producer, and the main loop() is the only consumer.
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
namespace esphome {
|
|
19
|
-
namespace esp32_ble {
|
|
20
|
-
|
|
21
|
-
template<class T, uint8_t SIZE> class LockFreeQueue {
|
|
22
|
-
public:
|
|
23
|
-
LockFreeQueue() : head_(0), tail_(0), dropped_count_(0) {}
|
|
24
|
-
|
|
25
|
-
bool push(T *element) {
|
|
26
|
-
if (element == nullptr)
|
|
27
|
-
return false;
|
|
28
|
-
|
|
29
|
-
uint8_t current_tail = tail_.load(std::memory_order_relaxed);
|
|
30
|
-
uint8_t next_tail = (current_tail + 1) % SIZE;
|
|
31
|
-
|
|
32
|
-
if (next_tail == head_.load(std::memory_order_acquire)) {
|
|
33
|
-
// Buffer full
|
|
34
|
-
dropped_count_.fetch_add(1, std::memory_order_relaxed);
|
|
35
|
-
return false;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
buffer_[current_tail] = element;
|
|
39
|
-
tail_.store(next_tail, std::memory_order_release);
|
|
40
|
-
return true;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
T *pop() {
|
|
44
|
-
uint8_t current_head = head_.load(std::memory_order_relaxed);
|
|
45
|
-
|
|
46
|
-
if (current_head == tail_.load(std::memory_order_acquire)) {
|
|
47
|
-
return nullptr; // Empty
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
T *element = buffer_[current_head];
|
|
51
|
-
head_.store((current_head + 1) % SIZE, std::memory_order_release);
|
|
52
|
-
return element;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
size_t size() const {
|
|
56
|
-
uint8_t tail = tail_.load(std::memory_order_acquire);
|
|
57
|
-
uint8_t head = head_.load(std::memory_order_acquire);
|
|
58
|
-
return (tail - head + SIZE) % SIZE;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
uint16_t get_and_reset_dropped_count() { return dropped_count_.exchange(0, std::memory_order_relaxed); }
|
|
62
|
-
|
|
63
|
-
void increment_dropped_count() { dropped_count_.fetch_add(1, std::memory_order_relaxed); }
|
|
64
|
-
|
|
65
|
-
bool empty() const { return head_.load(std::memory_order_acquire) == tail_.load(std::memory_order_acquire); }
|
|
66
|
-
|
|
67
|
-
bool full() const {
|
|
68
|
-
uint8_t next_tail = (tail_.load(std::memory_order_relaxed) + 1) % SIZE;
|
|
69
|
-
return next_tail == head_.load(std::memory_order_acquire);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
protected:
|
|
73
|
-
T *buffer_[SIZE];
|
|
74
|
-
// Atomic: written by producer (push/increment), read+reset by consumer (get_and_reset)
|
|
75
|
-
std::atomic<uint16_t> dropped_count_; // 65535 max - more than enough for drop tracking
|
|
76
|
-
// Atomic: written by consumer (pop), read by producer (push) to check if full
|
|
77
|
-
std::atomic<uint8_t> head_;
|
|
78
|
-
// Atomic: written by producer (push), read by consumer (pop) to check if empty
|
|
79
|
-
std::atomic<uint8_t> tail_;
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
} // namespace esp32_ble
|
|
83
|
-
} // namespace esphome
|
|
84
|
-
|
|
85
|
-
#endif
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
#ifdef USE_ESP32
|
|
2
|
-
#include "esp32_hall.h"
|
|
3
|
-
#include "esphome/core/log.h"
|
|
4
|
-
#include "esphome/core/hal.h"
|
|
5
|
-
#include <driver/adc.h>
|
|
6
|
-
|
|
7
|
-
namespace esphome {
|
|
8
|
-
namespace esp32_hall {
|
|
9
|
-
|
|
10
|
-
static const char *const TAG = "esp32_hall";
|
|
11
|
-
|
|
12
|
-
void ESP32HallSensor::update() {
|
|
13
|
-
adc1_config_width(ADC_WIDTH_BIT_12);
|
|
14
|
-
int value_int = hall_sensor_read();
|
|
15
|
-
float value = (value_int / 4095.0f) * 10000.0f;
|
|
16
|
-
ESP_LOGD(TAG, "'%s': Got reading %.0f µT", this->name_.c_str(), value);
|
|
17
|
-
this->publish_state(value);
|
|
18
|
-
}
|
|
19
|
-
std::string ESP32HallSensor::unique_id() { return get_mac_address() + "-hall"; }
|
|
20
|
-
void ESP32HallSensor::dump_config() { LOG_SENSOR("", "ESP32 Hall Sensor", this); }
|
|
21
|
-
|
|
22
|
-
} // namespace esp32_hall
|
|
23
|
-
} // namespace esphome
|
|
24
|
-
|
|
25
|
-
#endif
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "esphome/core/component.h"
|
|
4
|
-
#include "esphome/components/sensor/sensor.h"
|
|
5
|
-
|
|
6
|
-
#ifdef USE_ESP32
|
|
7
|
-
|
|
8
|
-
namespace esphome {
|
|
9
|
-
namespace esp32_hall {
|
|
10
|
-
|
|
11
|
-
class ESP32HallSensor : public sensor::Sensor, public PollingComponent {
|
|
12
|
-
public:
|
|
13
|
-
void dump_config() override;
|
|
14
|
-
|
|
15
|
-
void update() override;
|
|
16
|
-
|
|
17
|
-
std::string unique_id() override;
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
} // namespace esp32_hall
|
|
21
|
-
} // namespace esphome
|
|
22
|
-
|
|
23
|
-
#endif
|