Fix bug with opening/closing duration calibration

This commit is contained in:
Marius Muja 2024-01-22 19:03:06 -08:00
parent 17fad73613
commit b26f04a626
1 changed files with 18 additions and 14 deletions

View File

@ -428,14 +428,16 @@ namespace ratgdo {
this->door_action(DoorAction::OPEN); this->door_action(DoorAction::OPEN);
if (*this->opening_duration > 0) {
// query state in case we don't get a status message // query state in case we don't get a status message
set_timeout("door_query_state", (*this->opening_duration + 1) * 1000, [=]() { set_timeout("door_query_state", (*this->opening_duration + 2) * 1000, [=]() {
if (*this->door_state != DoorState::OPEN && *this->door_state != DoorState::STOPPED) { 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->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 this->query_status(); // query in case we're wrong and it's stopped
} }
}); });
} }
}
void RATGDOComponent::door_close() void RATGDOComponent::door_close()
{ {
@ -458,14 +460,16 @@ namespace ratgdo {
this->door_action(DoorAction::CLOSE); this->door_action(DoorAction::CLOSE);
if (*this->closing_duration > 0) {
// query state in case we don't get a status message // query state in case we don't get a status message
set_timeout("door_query_state", (*this->closing_duration + 1) * 1000, [=]() { set_timeout("door_query_state", (*this->closing_duration + 2) * 1000, [=]() {
if (*this->door_state != DoorState::CLOSED && *this->door_state != DoorState::STOPPED) { 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->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 this->query_status(); // query in case we're wrong and it's stopped
} }
}); });
} }
}
void RATGDOComponent::door_stop() void RATGDOComponent::door_stop()
{ {