mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-25 21:23:53 +01:00 
			
		
		
		
	[pipsolar] cleanup / refactoring (#10291)
Co-authored-by: pre-commit-ci-lite[bot] <117423508+pre-commit-ci-lite[bot]@users.noreply.github.com>
This commit is contained in:
		| @@ -62,7 +62,7 @@ CONF_WARNING_MPPT_OVERLOAD = "warning_mppt_overload" | |||||||
| CONF_WARNING_BATTERY_TOO_LOW_TO_CHARGE = "warning_battery_too_low_to_charge" | CONF_WARNING_BATTERY_TOO_LOW_TO_CHARGE = "warning_battery_too_low_to_charge" | ||||||
| CONF_FAULT_DC_DC_OVER_CURRENT = "fault_dc_dc_over_current" | CONF_FAULT_DC_DC_OVER_CURRENT = "fault_dc_dc_over_current" | ||||||
| CONF_FAULT_CODE = "fault_code" | CONF_FAULT_CODE = "fault_code" | ||||||
| CONF_WARNUNG_LOW_PV_ENERGY = "warnung_low_pv_energy" | CONF_WARNING_LOW_PV_ENERGY = "warning_low_pv_energy" | ||||||
| CONF_WARNING_HIGH_AC_INPUT_DURING_BUS_SOFT_START = ( | CONF_WARNING_HIGH_AC_INPUT_DURING_BUS_SOFT_START = ( | ||||||
|     "warning_high_ac_input_during_bus_soft_start" |     "warning_high_ac_input_during_bus_soft_start" | ||||||
| ) | ) | ||||||
| @@ -122,7 +122,7 @@ TYPES = [ | |||||||
|     CONF_WARNING_BATTERY_TOO_LOW_TO_CHARGE, |     CONF_WARNING_BATTERY_TOO_LOW_TO_CHARGE, | ||||||
|     CONF_FAULT_DC_DC_OVER_CURRENT, |     CONF_FAULT_DC_DC_OVER_CURRENT, | ||||||
|     CONF_FAULT_CODE, |     CONF_FAULT_CODE, | ||||||
|     CONF_WARNUNG_LOW_PV_ENERGY, |     CONF_WARNING_LOW_PV_ENERGY, | ||||||
|     CONF_WARNING_HIGH_AC_INPUT_DURING_BUS_SOFT_START, |     CONF_WARNING_HIGH_AC_INPUT_DURING_BUS_SOFT_START, | ||||||
|     CONF_WARNING_BATTERY_EQUALIZATION, |     CONF_WARNING_BATTERY_EQUALIZATION, | ||||||
| ] | ] | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ void PipsolarOutput::write_state(float state) { | |||||||
|  |  | ||||||
|   if (std::find(this->possible_values_.begin(), this->possible_values_.end(), state) != this->possible_values_.end()) { |   if (std::find(this->possible_values_.begin(), this->possible_values_.end(), state) != this->possible_values_.end()) { | ||||||
|     ESP_LOGD(TAG, "Will write: %s out of value %f / %02.0f", tmp, state, state); |     ESP_LOGD(TAG, "Will write: %s out of value %f / %02.0f", tmp, state, state); | ||||||
|     this->parent_->switch_command(std::string(tmp)); |     this->parent_->queue_command(std::string(tmp)); | ||||||
|   } else { |   } else { | ||||||
|     ESP_LOGD(TAG, "Will not write: %s as it is not in list of allowed values", tmp); |     ESP_LOGD(TAG, "Will not write: %s as it is not in list of allowed values", tmp); | ||||||
|   } |   } | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -7,6 +7,7 @@ | |||||||
| #include "esphome/components/uart/uart.h" | #include "esphome/components/uart/uart.h" | ||||||
| #include "esphome/core/automation.h" | #include "esphome/core/automation.h" | ||||||
| #include "esphome/core/component.h" | #include "esphome/core/component.h" | ||||||
|  | #include "esphome/core/helpers.h" | ||||||
|  |  | ||||||
| namespace esphome { | namespace esphome { | ||||||
| namespace pipsolar { | namespace pipsolar { | ||||||
| @@ -28,10 +29,17 @@ struct PollingCommand { | |||||||
|   bool needs_update; |   bool needs_update; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #define PIPSOLAR_VALUED_ENTITY_(type, name, polling_command, value_type) \ | struct QFLAGValues { | ||||||
|  protected: \ |   esphome::optional<bool> silence_buzzer_open_buzzer; | ||||||
|   value_type value_##name##_; \ |   esphome::optional<bool> overload_bypass_function; | ||||||
|   PIPSOLAR_ENTITY_(type, name, polling_command) |   esphome::optional<bool> lcd_escape_to_default; | ||||||
|  |   esphome::optional<bool> overload_restart_function; | ||||||
|  |   esphome::optional<bool> over_temperature_restart_function; | ||||||
|  |   esphome::optional<bool> backlight_on; | ||||||
|  |   esphome::optional<bool> alarm_on_when_primary_source_interrupt; | ||||||
|  |   esphome::optional<bool> fault_code_record; | ||||||
|  |   esphome::optional<bool> power_saving; | ||||||
|  | }; | ||||||
|  |  | ||||||
| #define PIPSOLAR_ENTITY_(type, name, polling_command) \ | #define PIPSOLAR_ENTITY_(type, name, polling_command) \ | ||||||
|  protected: \ |  protected: \ | ||||||
| @@ -43,126 +51,123 @@ struct PollingCommand { | |||||||
|     this->add_polling_command_(#polling_command, POLLING_##polling_command); \ |     this->add_polling_command_(#polling_command, POLLING_##polling_command); \ | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #define PIPSOLAR_SENSOR(name, polling_command, value_type) \ | #define PIPSOLAR_SENSOR(name, polling_command) PIPSOLAR_ENTITY_(sensor::Sensor, name, polling_command) | ||||||
|   PIPSOLAR_VALUED_ENTITY_(sensor::Sensor, name, polling_command, value_type) |  | ||||||
| #define PIPSOLAR_SWITCH(name, polling_command) PIPSOLAR_ENTITY_(switch_::Switch, name, polling_command) | #define PIPSOLAR_SWITCH(name, polling_command) PIPSOLAR_ENTITY_(switch_::Switch, name, polling_command) | ||||||
| #define PIPSOLAR_BINARY_SENSOR(name, polling_command, value_type) \ | #define PIPSOLAR_BINARY_SENSOR(name, polling_command) \ | ||||||
|   PIPSOLAR_VALUED_ENTITY_(binary_sensor::BinarySensor, name, polling_command, value_type) |   PIPSOLAR_ENTITY_(binary_sensor::BinarySensor, name, polling_command) | ||||||
| #define PIPSOLAR_VALUED_TEXT_SENSOR(name, polling_command, value_type) \ |  | ||||||
|   PIPSOLAR_VALUED_ENTITY_(text_sensor::TextSensor, name, polling_command, value_type) |  | ||||||
| #define PIPSOLAR_TEXT_SENSOR(name, polling_command) PIPSOLAR_ENTITY_(text_sensor::TextSensor, name, polling_command) | #define PIPSOLAR_TEXT_SENSOR(name, polling_command) PIPSOLAR_ENTITY_(text_sensor::TextSensor, name, polling_command) | ||||||
|  |  | ||||||
| class Pipsolar : public uart::UARTDevice, public PollingComponent { | class Pipsolar : public uart::UARTDevice, public PollingComponent { | ||||||
|   // QPIGS values |   // QPIGS values | ||||||
|   PIPSOLAR_SENSOR(grid_voltage, QPIGS, float) |   PIPSOLAR_SENSOR(grid_voltage, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(grid_frequency, QPIGS, float) |   PIPSOLAR_SENSOR(grid_frequency, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(ac_output_voltage, QPIGS, float) |   PIPSOLAR_SENSOR(ac_output_voltage, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(ac_output_frequency, QPIGS, float) |   PIPSOLAR_SENSOR(ac_output_frequency, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(ac_output_apparent_power, QPIGS, int) |   PIPSOLAR_SENSOR(ac_output_apparent_power, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(ac_output_active_power, QPIGS, int) |   PIPSOLAR_SENSOR(ac_output_active_power, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(output_load_percent, QPIGS, int) |   PIPSOLAR_SENSOR(output_load_percent, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(bus_voltage, QPIGS, int) |   PIPSOLAR_SENSOR(bus_voltage, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_voltage, QPIGS, float) |   PIPSOLAR_SENSOR(battery_voltage, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_charging_current, QPIGS, int) |   PIPSOLAR_SENSOR(battery_charging_current, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_capacity_percent, QPIGS, int) |   PIPSOLAR_SENSOR(battery_capacity_percent, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(inverter_heat_sink_temperature, QPIGS, int) |   PIPSOLAR_SENSOR(inverter_heat_sink_temperature, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(pv_input_current_for_battery, QPIGS, float) |   PIPSOLAR_SENSOR(pv_input_current_for_battery, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(pv_input_voltage, QPIGS, float) |   PIPSOLAR_SENSOR(pv_input_voltage, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_voltage_scc, QPIGS, float) |   PIPSOLAR_SENSOR(battery_voltage_scc, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_discharge_current, QPIGS, int) |   PIPSOLAR_SENSOR(battery_discharge_current, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(add_sbu_priority_version, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(add_sbu_priority_version, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(configuration_status, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(configuration_status, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(scc_firmware_version, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(scc_firmware_version, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(load_status, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(load_status, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(battery_voltage_to_steady_while_charging, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(battery_voltage_to_steady_while_charging, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(charging_status, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(charging_status, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(scc_charging_status, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(scc_charging_status, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(ac_charging_status, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(ac_charging_status, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(battery_voltage_offset_for_fans_on, QPIGS, int)  //.1 scale |   PIPSOLAR_SENSOR(battery_voltage_offset_for_fans_on, QPIGS)  //.1 scale | ||||||
|   PIPSOLAR_SENSOR(eeprom_version, QPIGS, int) |   PIPSOLAR_SENSOR(eeprom_version, QPIGS) | ||||||
|   PIPSOLAR_SENSOR(pv_charging_power, QPIGS, int) |   PIPSOLAR_SENSOR(pv_charging_power, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(charging_to_floating_mode, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(charging_to_floating_mode, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(switch_on, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(switch_on, QPIGS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(dustproof_installed, QPIGS, int) |   PIPSOLAR_BINARY_SENSOR(dustproof_installed, QPIGS) | ||||||
|  |  | ||||||
|   // QPIRI values |   // QPIRI values | ||||||
|   PIPSOLAR_SENSOR(grid_rating_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(grid_rating_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(grid_rating_current, QPIRI, float) |   PIPSOLAR_SENSOR(grid_rating_current, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(ac_output_rating_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(ac_output_rating_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(ac_output_rating_frequency, QPIRI, float) |   PIPSOLAR_SENSOR(ac_output_rating_frequency, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(ac_output_rating_current, QPIRI, float) |   PIPSOLAR_SENSOR(ac_output_rating_current, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(ac_output_rating_apparent_power, QPIRI, int) |   PIPSOLAR_SENSOR(ac_output_rating_apparent_power, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(ac_output_rating_active_power, QPIRI, int) |   PIPSOLAR_SENSOR(ac_output_rating_active_power, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_rating_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_rating_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_recharge_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_recharge_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_under_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_under_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_bulk_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_bulk_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_float_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_float_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_type, QPIRI, int) |   PIPSOLAR_SENSOR(battery_type, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(current_max_ac_charging_current, QPIRI, int) |   PIPSOLAR_SENSOR(current_max_ac_charging_current, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(current_max_charging_current, QPIRI, int) |   PIPSOLAR_SENSOR(current_max_charging_current, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(input_voltage_range, QPIRI, int) |   PIPSOLAR_SENSOR(input_voltage_range, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(output_source_priority, QPIRI, int) |   PIPSOLAR_SENSOR(output_source_priority, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(charger_source_priority, QPIRI, int) |   PIPSOLAR_SENSOR(charger_source_priority, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(parallel_max_num, QPIRI, int) |   PIPSOLAR_SENSOR(parallel_max_num, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(machine_type, QPIRI, int) |   PIPSOLAR_SENSOR(machine_type, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(topology, QPIRI, int) |   PIPSOLAR_SENSOR(topology, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(output_mode, QPIRI, int) |   PIPSOLAR_SENSOR(output_mode, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(battery_redischarge_voltage, QPIRI, float) |   PIPSOLAR_SENSOR(battery_redischarge_voltage, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(pv_ok_condition_for_parallel, QPIRI, int) |   PIPSOLAR_SENSOR(pv_ok_condition_for_parallel, QPIRI) | ||||||
|   PIPSOLAR_SENSOR(pv_power_balance, QPIRI, int) |   PIPSOLAR_SENSOR(pv_power_balance, QPIRI) | ||||||
|  |  | ||||||
|   // QMOD values |   // QMOD values | ||||||
|   PIPSOLAR_VALUED_TEXT_SENSOR(device_mode, QMOD, char) |   PIPSOLAR_TEXT_SENSOR(device_mode, QMOD) | ||||||
|  |  | ||||||
|   // QFLAG values |   // QFLAG values | ||||||
|   PIPSOLAR_BINARY_SENSOR(silence_buzzer_open_buzzer, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(silence_buzzer_open_buzzer, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(overload_bypass_function, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(overload_bypass_function, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(lcd_escape_to_default, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(lcd_escape_to_default, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(overload_restart_function, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(overload_restart_function, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(over_temperature_restart_function, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(over_temperature_restart_function, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(backlight_on, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(backlight_on, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(alarm_on_when_primary_source_interrupt, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(alarm_on_when_primary_source_interrupt, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_code_record, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(fault_code_record, QFLAG) | ||||||
|   PIPSOLAR_BINARY_SENSOR(power_saving, QFLAG, int) |   PIPSOLAR_BINARY_SENSOR(power_saving, QFLAG) | ||||||
|  |  | ||||||
|   // QPIWS values |   // QPIWS values | ||||||
|   PIPSOLAR_BINARY_SENSOR(warnings_present, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warnings_present, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(faults_present, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(faults_present, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_power_loss, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_power_loss, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_inverter_fault, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_inverter_fault, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_bus_over, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_bus_over, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_bus_under, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_bus_under, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_bus_soft_fail, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_bus_soft_fail, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_line_fail, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_line_fail, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_opvshort, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_opvshort, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_inverter_voltage_too_low, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_inverter_voltage_too_low, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_inverter_voltage_too_high, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_inverter_voltage_too_high, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_over_temperature, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_over_temperature, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_fan_lock, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_fan_lock, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_voltage_high, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_voltage_high, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_low_alarm, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_low_alarm, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_under_shutdown, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_under_shutdown, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_derating, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_derating, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_over_load, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_over_load, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_eeprom_failed, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_eeprom_failed, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_inverter_over_current, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_inverter_over_current, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_inverter_soft_failed, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_inverter_soft_failed, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_self_test_failed, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_self_test_failed, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_op_dc_voltage_over, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_op_dc_voltage_over, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_battery_open, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_battery_open, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_current_sensor_failed, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_current_sensor_failed, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_battery_short, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_battery_short, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_power_limit, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_power_limit, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_pv_voltage_high, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_pv_voltage_high, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_mppt_overload, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_mppt_overload, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_mppt_overload, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_mppt_overload, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_too_low_to_charge, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_too_low_to_charge, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_dc_dc_over_current, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(fault_dc_dc_over_current, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(fault_code, QPIWS, int) |   PIPSOLAR_BINARY_SENSOR(fault_code, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warnung_low_pv_energy, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_low_pv_energy, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_high_ac_input_during_bus_soft_start, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_high_ac_input_during_bus_soft_start, QPIWS) | ||||||
|   PIPSOLAR_BINARY_SENSOR(warning_battery_equalization, QPIWS, bool) |   PIPSOLAR_BINARY_SENSOR(warning_battery_equalization, QPIWS) | ||||||
|  |  | ||||||
|   PIPSOLAR_TEXT_SENSOR(last_qpigs, QPIGS) |   PIPSOLAR_TEXT_SENSOR(last_qpigs, QPIGS) | ||||||
|   PIPSOLAR_TEXT_SENSOR(last_qpiri, QPIRI) |   PIPSOLAR_TEXT_SENSOR(last_qpiri, QPIRI) | ||||||
| @@ -180,14 +185,14 @@ class Pipsolar : public uart::UARTDevice, public PollingComponent { | |||||||
|   PIPSOLAR_SWITCH(pv_ok_condition_for_parallel_switch, QPIRI) |   PIPSOLAR_SWITCH(pv_ok_condition_for_parallel_switch, QPIRI) | ||||||
|   PIPSOLAR_SWITCH(pv_power_balance_switch, QPIRI) |   PIPSOLAR_SWITCH(pv_power_balance_switch, QPIRI) | ||||||
|  |  | ||||||
|   void switch_command(const std::string &command); |   void queue_command(const std::string &command); | ||||||
|   void setup() override; |   void setup() override; | ||||||
|   void loop() override; |   void loop() override; | ||||||
|   void dump_config() override; |   void dump_config() override; | ||||||
|   void update() override; |   void update() override; | ||||||
|  |  | ||||||
|  protected: |  protected: | ||||||
|   static const size_t PIPSOLAR_READ_BUFFER_LENGTH = 110;  // maximum supported answer length |   static const size_t PIPSOLAR_READ_BUFFER_LENGTH = 128;  // maximum supported answer length | ||||||
|   static const size_t COMMAND_QUEUE_LENGTH = 10; |   static const size_t COMMAND_QUEUE_LENGTH = 10; | ||||||
|   static const size_t COMMAND_TIMEOUT = 5000; |   static const size_t COMMAND_TIMEOUT = 5000; | ||||||
|   static const size_t POLLING_COMMANDS_MAX = 15; |   static const size_t POLLING_COMMANDS_MAX = 15; | ||||||
| @@ -198,7 +203,26 @@ class Pipsolar : public uart::UARTDevice, public PollingComponent { | |||||||
|   uint16_t pipsolar_crc_(uint8_t *msg, uint8_t len); |   uint16_t pipsolar_crc_(uint8_t *msg, uint8_t len); | ||||||
|   bool send_next_command_(); |   bool send_next_command_(); | ||||||
|   bool send_next_poll_(); |   bool send_next_poll_(); | ||||||
|   void queue_command_(const char *command, uint8_t length); |  | ||||||
|  |   void handle_qpiri_(const char *message); | ||||||
|  |   void handle_qpigs_(const char *message); | ||||||
|  |   void handle_qmod_(const char *message); | ||||||
|  |   void handle_qflag_(const char *message); | ||||||
|  |   void handle_qpiws_(const char *message); | ||||||
|  |   void handle_qt_(const char *message); | ||||||
|  |   void handle_qmn_(const char *message); | ||||||
|  |  | ||||||
|  |   void skip_start_(const char *message, size_t *pos); | ||||||
|  |   void skip_field_(const char *message, size_t *pos); | ||||||
|  |   std::string read_field_(const char *message, size_t *pos); | ||||||
|  |  | ||||||
|  |   void read_float_sensor_(const char *message, size_t *pos, sensor::Sensor *sensor); | ||||||
|  |   void read_int_sensor_(const char *message, size_t *pos, sensor::Sensor *sensor); | ||||||
|  |  | ||||||
|  |   void publish_binary_sensor_(esphome::optional<bool> b, binary_sensor::BinarySensor *sensor); | ||||||
|  |  | ||||||
|  |   esphome::optional<bool> get_bit_(std::string bits, uint8_t bit_pos); | ||||||
|  |  | ||||||
|   std::string command_queue_[COMMAND_QUEUE_LENGTH]; |   std::string command_queue_[COMMAND_QUEUE_LENGTH]; | ||||||
|   uint8_t command_queue_position_ = 0; |   uint8_t command_queue_position_ = 0; | ||||||
|   uint8_t read_buffer_[PIPSOLAR_READ_BUFFER_LENGTH]; |   uint8_t read_buffer_[PIPSOLAR_READ_BUFFER_LENGTH]; | ||||||
| @@ -213,11 +237,10 @@ class Pipsolar : public uart::UARTDevice, public PollingComponent { | |||||||
|     STATE_POLL_COMPLETE = 3, |     STATE_POLL_COMPLETE = 3, | ||||||
|     STATE_COMMAND_COMPLETE = 4, |     STATE_COMMAND_COMPLETE = 4, | ||||||
|     STATE_POLL_CHECKED = 5, |     STATE_POLL_CHECKED = 5, | ||||||
|     STATE_POLL_DECODED = 6, |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   uint8_t last_polling_command_ = 0; |   uint8_t last_polling_command_ = 0; | ||||||
|   PollingCommand used_polling_commands_[POLLING_COMMANDS_MAX]; |   PollingCommand enabled_polling_commands_[POLLING_COMMANDS_MAX]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace pipsolar | }  // namespace pipsolar | ||||||
|   | |||||||
| @@ -11,11 +11,11 @@ void PipsolarSwitch::dump_config() { LOG_SWITCH("", "Pipsolar Switch", this); } | |||||||
| void PipsolarSwitch::write_state(bool state) { | void PipsolarSwitch::write_state(bool state) { | ||||||
|   if (state) { |   if (state) { | ||||||
|     if (!this->on_command_.empty()) { |     if (!this->on_command_.empty()) { | ||||||
|       this->parent_->switch_command(this->on_command_); |       this->parent_->queue_command(this->on_command_); | ||||||
|     } |     } | ||||||
|   } else { |   } else { | ||||||
|     if (!this->off_command_.empty()) { |     if (!this->off_command_.empty()) { | ||||||
|       this->parent_->switch_command(this->off_command_); |       this->parent_->queue_command(this->off_command_); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user