From d2ae60e6ed25d7e5f9bd1132e542e32c7792c18c Mon Sep 17 00:00:00 2001 From: Marius Muja Date: Mon, 18 Sep 2023 11:18:13 -0700 Subject: [PATCH] Refactor sync function to be more DRY and easier to extend (#50) Co-authored-by: J. Nick Koston --- components/ratgdo/ratgdo.cpp | 40 ++++++++++++++++++++---------------- 1 file changed, 22 insertions(+), 18 deletions(-) diff --git a/components/ratgdo/ratgdo.cpp b/components/ratgdo/ratgdo.cpp index ecbe77e..55adc87 100644 --- a/components/ratgdo/ratgdo.cpp +++ b/components/ratgdo/ratgdo.cpp @@ -436,30 +436,34 @@ namespace ratgdo { void RATGDOComponent::sync() { - // increment rolling code counter by some amount in case we crashed without writing to flash the latest value - this->increment_rolling_code_counter(MAX_CODES_WITHOUT_FLASH_WRITE); + auto sync_step = [=]() { + if (*this->door_state == DoorState::UNKNOWN) { + this->send_command(Command::GET_STATUS); + return RetryResult::RETRY; + } + if (*this->openings == 0) { + this->send_command(Command::GET_OPENINGS); + return RetryResult::RETRY; + } + return RetryResult::DONE; + }; + const uint8_t MAX_ATTEMPTS = 10; set_retry( - 500, 10, [=](uint8_t r) { - if (*this->door_state != DoorState::UNKNOWN) { // have status - if (*this->openings != 0) { // have openings - return RetryResult::DONE; - } else { - if (r == 0) { // failed to sync probably rolling counter is wrong, notify - ESP_LOGD(TAG, "Triggering sync failed actions."); - this->sync_failed = true; - }; - this->send_command(Command::GET_OPENINGS); - return RetryResult::RETRY; + 500, MAX_ATTEMPTS, [=](uint8_t r) { + auto result = sync_step(); + if (result == RetryResult::RETRY) { + if (r == MAX_ATTEMPTS-2 && *this->door_state == DoorState::UNKNOWN) { // made a few attempts and no progress (door state is the first sync request) + // increment rolling code counter by some amount in case we crashed without writing to flash the latest value + this->increment_rolling_code_counter(MAX_CODES_WITHOUT_FLASH_WRITE); } - } else { - if (r == 0) { // failed to sync probably rolling counter is wrong, notify + if (r == 0) { + // this was last attempt, notify of sync failure ESP_LOGD(TAG, "Triggering sync failed actions."); this->sync_failed = true; - }; - this->send_command(Command::GET_STATUS); - return RetryResult::RETRY; + } } + return result; }, 1.5f); }