From 8747feef0e6a6a7f3bed37bdd766ce18fa366b2f Mon Sep 17 00:00:00 2001 From: Jeremy Salwen Date: Sat, 14 Sep 2024 17:28:53 +0000 Subject: [PATCH] Add aborted checks when paused mowing Previously the mower would have to become unpaused before it would recognize that mowing had been aborted. --- src/mower_logic/src/mower_logic/behaviors/MowingBehavior.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/mower_logic/src/mower_logic/behaviors/MowingBehavior.cpp b/src/mower_logic/src/mower_logic/behaviors/MowingBehavior.cpp index e5685fe8..78794863 100644 --- a/src/mower_logic/src/mower_logic/behaviors/MowingBehavior.cpp +++ b/src/mower_logic/src/mower_logic/behaviors/MowingBehavior.cpp @@ -268,7 +268,7 @@ bool MowingBehavior::execute_mowing_plan() { paused = true; mowerEnabled = false; u_int8_t last_requested_pause_flags = 0; - while (requested_pause_flag) // while emergency and/or manual pause not asked to continue, we wait + while (requested_pause_flag && !aborted) // while emergency and/or manual pause not asked to continue, we wait { if (last_requested_pause_flags != requested_pause_flag) { update_actions(); @@ -293,7 +293,7 @@ bool MowingBehavior::execute_mowing_plan() { } if (paused) { paused_time = ros::Time::now(); - while (!this->hasGoodGPS()) // while no good GPS we wait + while (!this->hasGoodGPS() && !aborted) // while no good GPS we wait { ROS_INFO_STREAM("MowingBehavior: PAUSED (" << (ros::Time::now() - paused_time).toSec() << "s) (waiting for GPS)");