From 4b57303c1fc5e30a7da4742440db4a8ba8540cfc Mon Sep 17 00:00:00 2001 From: Marius Muja Date: Tue, 23 Jan 2024 14:05:04 -0800 Subject: [PATCH] Fix bug with opening/closing duration calibration (#194) Co-authored-by: J. Nick Koston --- components/ratgdo/ratgdo.cpp | 32 ++++++++++++++++++-------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/components/ratgdo/ratgdo.cpp b/components/ratgdo/ratgdo.cpp index 791b803..f65ae25 100644 --- a/components/ratgdo/ratgdo.cpp +++ b/components/ratgdo/ratgdo.cpp @@ -428,13 +428,15 @@ namespace ratgdo { this->door_action(DoorAction::OPEN); - // query state in case we don't get a status message - set_timeout("door_query_state", (*this->opening_duration + 1) * 1000, [=]() { - if (*this->door_state != DoorState::OPEN && *this->door_state != DoorState::STOPPED) { - this->door_state = DoorState::OPEN; // probably missed a status mesage, assume it's open - this->query_status(); // query in case we're wrong and it's stopped - } - }); + if (*this->opening_duration > 0) { + // query state in case we don't get a status message + set_timeout("door_query_state", (*this->opening_duration + 2) * 1000, [=]() { + if (*this->door_state != DoorState::OPEN && *this->door_state != DoorState::STOPPED) { + this->received(DoorState::OPEN); // probably missed a status mesage, assume it's open + this->query_status(); // query in case we're wrong and it's stopped + } + }); + } } void RATGDOComponent::door_close() @@ -458,13 +460,15 @@ namespace ratgdo { this->door_action(DoorAction::CLOSE); - // query state in case we don't get a status message - set_timeout("door_query_state", (*this->closing_duration + 1) * 1000, [=]() { - if (*this->door_state != DoorState::CLOSED && *this->door_state != DoorState::STOPPED) { - this->door_state = DoorState::CLOSED; // probably missed a status mesage, assume it's closed - this->query_status(); // query in case we're wrong and it's stopped - } - }); + if (*this->closing_duration > 0) { + // query state in case we don't get a status message + set_timeout("door_query_state", (*this->closing_duration + 2) * 1000, [=]() { + if (*this->door_state != DoorState::CLOSED && *this->door_state != DoorState::STOPPED) { + this->received(DoorState::CLOSED); // probably missed a status mesage, assume it's closed + this->query_status(); // query in case we're wrong and it's stopped + } + }); + } } void RATGDOComponent::door_stop()