Normalize client_id when manually entered (#97)

Co-authored-by: J. Nick Koston <nick@koston.org>
This commit is contained in:
Marius Muja 2023-11-07 10:58:16 -08:00 committed by GitHub
parent 5bd2464588
commit cdc7780c72
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 12 additions and 4 deletions

View File

@ -5,6 +5,15 @@
namespace esphome { namespace esphome {
namespace ratgdo { namespace ratgdo {
float normalize_client_id(float client_id)
{
uint32_t int_value = static_cast<uint32_t>(client_id);
if ((int_value & 0xFFF) != 0x539) {
client_id = ceil((client_id - 0x539) / 0x1000) * 0x1000 + 0x539;
}
return client_id;
}
static const char* const TAG = "ratgdo.number"; static const char* const TAG = "ratgdo.number";
void RATGDONumber::dump_config() void RATGDONumber::dump_config()
@ -27,12 +36,11 @@ namespace ratgdo {
this->pref_ = global_preferences->make_preference<float>(this->get_object_id_hash()); this->pref_ = global_preferences->make_preference<float>(this->get_object_id_hash());
if (!this->pref_.load(&value)) { if (!this->pref_.load(&value)) {
if (this->number_type_ == RATGDO_CLIENT_ID) { if (this->number_type_ == RATGDO_CLIENT_ID) {
value = ((random_uint32() + 1) % 0x7FF) << 12 | 0x539; // max size limited to be precisely convertible to float value = ((random_uint32() + 1) % 0x7FF) << 12 | 0x539; // max size limited to be precisely convertible to float
} else { } else {
value = 0; value = 0;
} }
} } else {
else {
if (this->number_type_ == RATGDO_CLIENT_ID) { if (this->number_type_ == RATGDO_CLIENT_ID) {
uint32_t int_value = static_cast<uint32_t>(value); uint32_t int_value = static_cast<uint32_t>(value);
if ((int_value & 0xFFF) != 0x539) { if ((int_value & 0xFFF) != 0x539) {
@ -41,7 +49,6 @@ namespace ratgdo {
} }
} }
} }
this->publish_state(value);
this->control(value); this->control(value);
if (this->number_type_ == RATGDO_ROLLING_CODE_COUNTER) { if (this->number_type_ == RATGDO_ROLLING_CODE_COUNTER) {
@ -90,6 +97,7 @@ namespace ratgdo {
} else if (this->number_type_ == RATGDO_CLOSING_DURATION) { } else if (this->number_type_ == RATGDO_CLOSING_DURATION) {
this->parent_->set_closing_duration(value); this->parent_->set_closing_duration(value);
} else if (this->number_type_ == RATGDO_CLIENT_ID) { } else if (this->number_type_ == RATGDO_CLIENT_ID) {
value = normalize_client_id(value);
this->parent_->set_client_id(value); this->parent_->set_client_id(value);
} }
this->update_state(value); this->update_state(value);