1
0
mirror of https://github.com/esphome/esphome.git synced 2025-10-24 04:33:49 +01:00

reduce diff

This commit is contained in:
J. Nick Koston
2025-10-18 14:11:23 -10:00
parent f2d01ecd6c
commit 764428870d
2 changed files with 17 additions and 31 deletions

View File

@@ -426,7 +426,8 @@ ColorMode LightCall::compute_color_mode_() {
// pre-colormode clients and automations, but also for the MQTT API, where HA doesn't let us know which color mode // pre-colormode clients and automations, but also for the MQTT API, where HA doesn't let us know which color mode
// was used for some reason. // was used for some reason.
// Compute intersection of suitable and supported modes using bitwise AND // Compute intersection of suitable and supported modes using bitwise AND
color_mode_bitmask_t intersection = this->get_suitable_color_modes_mask_() & supported_modes.get_mask(); ColorModeMask suitable = this->get_suitable_color_modes_();
color_mode_bitmask_t intersection = suitable.get_mask() & supported_modes.get_mask();
// Don't change if the current mode is in the intersection (suitable AND supported) // Don't change if the current mode is in the intersection (suitable AND supported)
if (ColorModeMask::mask_contains(intersection, current_mode)) { if (ColorModeMask::mask_contains(intersection, current_mode)) {
@@ -450,7 +451,7 @@ ColorMode LightCall::compute_color_mode_() {
LOG_STR_ARG(color_mode_to_human(color_mode))); LOG_STR_ARG(color_mode_to_human(color_mode)));
return color_mode; return color_mode;
} }
color_mode_bitmask_t LightCall::get_suitable_color_modes_mask_() { ColorModeMask LightCall::get_suitable_color_modes_() {
bool has_white = this->has_white() && this->white_ > 0.0f; bool has_white = this->has_white() && this->white_ > 0.0f;
bool has_ct = this->has_color_temperature(); bool has_ct = this->has_color_temperature();
bool has_cwww = bool has_cwww =
@@ -463,49 +464,34 @@ color_mode_bitmask_t LightCall::get_suitable_color_modes_mask_() {
uint8_t key = KEY(has_white, has_ct, has_cwww, has_rgb); uint8_t key = KEY(has_white, has_ct, has_cwww, has_rgb);
// Build bitmask from suitable ColorModes
ColorModeMask suitable;
switch (key) { switch (key) {
case KEY(true, false, false, false): // white only case KEY(true, false, false, false): // white only
suitable.add({ColorMode::WHITE, ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, return {ColorMode::WHITE, ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::COLD_WARM_WHITE,
ColorMode::COLD_WARM_WHITE, ColorMode::RGB_COLD_WARM_WHITE}); ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, true, false, false): // ct only case KEY(false, true, false, false): // ct only
suitable.add({ColorMode::COLOR_TEMPERATURE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::COLD_WARM_WHITE, return {ColorMode::COLOR_TEMPERATURE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::COLD_WARM_WHITE,
ColorMode::RGB_COLD_WARM_WHITE}); ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(true, true, false, false): // white + ct case KEY(true, true, false, false): // white + ct
suitable.add({ColorMode::COLD_WARM_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE}); return {ColorMode::COLD_WARM_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, false, true, false): // cwww only case KEY(false, false, true, false): // cwww only
suitable.add({ColorMode::COLD_WARM_WHITE, ColorMode::RGB_COLD_WARM_WHITE}); return {ColorMode::COLD_WARM_WHITE, ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, false, false, false): // none case KEY(false, false, false, false): // none
suitable.add({ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE, return {ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE, ColorMode::RGB,
ColorMode::RGB, ColorMode::WHITE, ColorMode::COLOR_TEMPERATURE, ColorMode::COLD_WARM_WHITE}); ColorMode::WHITE, ColorMode::COLOR_TEMPERATURE, ColorMode::COLD_WARM_WHITE};
break;
case KEY(true, false, false, true): // rgb + white case KEY(true, false, false, true): // rgb + white
suitable.add({ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE}); return {ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, true, false, true): // rgb + ct case KEY(false, true, false, true): // rgb + ct
case KEY(true, true, false, true): // rgb + white + ct case KEY(true, true, false, true): // rgb + white + ct
suitable.add({ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE}); return {ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, false, true, true): // rgb + cwww case KEY(false, false, true, true): // rgb + cwww
suitable.add(ColorMode::RGB_COLD_WARM_WHITE); return {ColorMode::RGB_COLD_WARM_WHITE};
break;
case KEY(false, false, false, true): // rgb only case KEY(false, false, false, true): // rgb only
suitable.add( return {ColorMode::RGB, ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE};
{ColorMode::RGB, ColorMode::RGB_WHITE, ColorMode::RGB_COLOR_TEMPERATURE, ColorMode::RGB_COLD_WARM_WHITE});
break;
default: default:
break; // conflicting flags - return empty mask return {}; // conflicting flags
} }
#undef KEY #undef KEY
return suitable.get_mask();
} }
LightCall &LightCall::set_effect(const std::string &effect) { LightCall &LightCall::set_effect(const std::string &effect) {

View File

@@ -186,7 +186,7 @@ class LightCall {
//// Compute the color mode that should be used for this call. //// Compute the color mode that should be used for this call.
ColorMode compute_color_mode_(); ColorMode compute_color_mode_();
/// Get potential color modes bitmask for this light call. /// Get potential color modes bitmask for this light call.
color_mode_bitmask_t get_suitable_color_modes_mask_(); ColorModeMask get_suitable_color_modes_();
/// Some color modes also can be set using non-native parameters, transform those calls. /// Some color modes also can be set using non-native parameters, transform those calls.
void transform_parameters_(); void transform_parameters_();