7static const char *
const TAG =
"mitsubishi_cn105.climate";
9static constexpr std::array MODE_MAP{
17static constexpr std::array FAN_MODE_MAP{
26template<
typename A,
typename B, std::
size_t N>
27static bool map_lookup(
const std::array<std::pair<A, B>, N> &map, A key, B &out) {
28 for (
const auto &[from, to] : map) {
37template<
typename Left,
typename Right, std::
size_t N>
38static constexpr std::optional<Left> reverse_map_lookup(
const std::array<std::pair<Left, Right>, N> &map, Right key) {
39 for (
const auto &entry : map) {
40 if (entry.second == key) {
47template<
typename Left,
typename Right, std::
size_t N>
48static constexpr std::optional<Left> reverse_map_lookup(
const std::array<std::pair<Left, Right>, N> &map,
49 const std::optional<Right> &key) {
50 return key.has_value() ? reverse_map_lookup(map, *key) : std::nullopt;
54 LOG_CLIMATE(
"",
"Mitsubishi CN105 Climate",
this);
56 ESP_LOGCONFIG(TAG,
" Current temperature min interval: %" PRIu32
" ms",
59 ESP_LOGCONFIG(TAG,
" Current temperature: disabled");
62 " Update interval: %" PRIu32
" ms\n"
63 " UART: baud_rate=%" PRIu32
" data_bits=%u parity=%s stop_bits=%u",
65 LOG_STR_ARG(parity_to_str(this->
parent_->
get_parity())), this->parent_->get_stop_bits());
117 }
else if (
const auto mapped = reverse_map_lookup(MODE_MAP, *
mode)) {
123 if (
const auto fan_mode = reverse_map_lookup(FAN_MODE_MAP,
call.get_fan_mode())) {
142 if (!map_lookup(MODE_MAP,
status.mode, this->mode)) {
143 ESP_LOGD(TAG,
"Unable to map mode");
153 ESP_LOGD(TAG,
"Unable to map fan mode");
This class is used to encode all control actions on a climate device.
const optional< ClimateMode > & get_mode() const
ClimateMode mode
The active mode of the climate device.
optional< ClimateFanMode > fan_mode
The active fan mode of the climate device.
float target_temperature
The target temperature of the climate device.
float current_temperature
The current temperature of the climate device, as reported from the integration.
void publish_state()
Publish the state of the climate device, to be called from integrations.
void set_visual_max_temperature(float visual_max_temperature)
void add_feature_flags(uint32_t feature_flags)
void set_visual_temperature_step(float temperature_step)
void set_visual_min_temperature(float visual_min_temperature)
void set_visual_current_temperature_step(float temperature_step)
void set_supported_modes(ClimateModeMask modes)
void set_supported_fan_modes(ClimateFanModeMask modes)
void control(const climate::ClimateCall &call) override
void dump_config() override
climate::ClimateTraits traits() override
uint32_t get_update_interval() const
bool is_status_initialized() const
void set_power(bool power_on)
uint32_t get_room_temperature_min_interval() const
void set_target_temperature(float target_temperature)
const Status & status() const
void set_fan_mode(FanMode fan_mode)
bool is_room_temperature_enabled() const
UARTParityOptions get_parity() const
@ CLIMATE_SUPPORTS_CURRENT_TEMPERATURE
@ CLIMATE_MODE_DRY
The climate device is set to dry/humidity mode.
@ CLIMATE_MODE_FAN_ONLY
The climate device only has the fan enabled, no heating or cooling is taking place.
@ CLIMATE_MODE_HEAT
The climate device is set to heat to reach the target temperature.
@ CLIMATE_MODE_COOL
The climate device is set to cool to reach the target temperature.
@ CLIMATE_MODE_OFF
The climate device is off.
@ CLIMATE_MODE_AUTO
The climate device is adjusting the temperature dynamically.
ClimateFanMode
NOTE: If adding values, update ClimateFanModeMask in climate_traits.h to use the new last value.
@ CLIMATE_FAN_MEDIUM
The fan mode is set to Medium.
@ CLIMATE_FAN_AUTO
The fan mode is set to Auto.
@ CLIMATE_FAN_LOW
The fan mode is set to Low.
@ CLIMATE_FAN_MIDDLE
The fan mode is set to Middle.
@ CLIMATE_FAN_QUIET
The fan mode is set to Quiet.
@ CLIMATE_FAN_HIGH
The fan mode is set to High.