From 770480a648ef2d747694e367996245c67e72e10d Mon Sep 17 00:00:00 2001 From: Levi Armstrong Date: Sun, 12 Jan 2025 15:31:38 -0600 Subject: [PATCH] Fix motion planner task to support error branching --- .../planning/nodes/motion_planner_task.hpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/tesseract_task_composer/planning/include/tesseract_task_composer/planning/nodes/motion_planner_task.hpp b/tesseract_task_composer/planning/include/tesseract_task_composer/planning/nodes/motion_planner_task.hpp index 296f0fa649..a1ce3d2deb 100644 --- a/tesseract_task_composer/planning/include/tesseract_task_composer/planning/nodes/motion_planner_task.hpp +++ b/tesseract_task_composer/planning/include/tesseract_task_composer/planning/nodes/motion_planner_task.hpp @@ -174,7 +174,8 @@ class MotionPlannerTask : public TaskComposerTask // Make a non-const copy of the input instructions to update the start/end auto& instructions = input_data_poly.template as(); - assert(!(input_manip_info.empty() && instructions.getManipulatorInfo().empty())); + if (input_manip_info.empty() && instructions.getManipulatorInfo().empty()) + throw std::runtime_error("Missing manipulator information"); instructions.setManipulatorInfo(instructions.getManipulatorInfo().getCombined(input_manip_info)); // -------------------- @@ -193,13 +194,14 @@ class MotionPlannerTask : public TaskComposerTask if (console_bridge::getLogLevel() == console_bridge::LogLevel::CONSOLE_BRIDGE_LOG_DEBUG) request.verbose = true; PlannerResponse response = planner_->solve(request); - setData(*context.data_storage, INOUT_PROGRAM_PORT, response.results); // -------------------- // Verify Success // -------------------- if (response) { + // Should only set on success to support error branching + setData(*context.data_storage, INOUT_PROGRAM_PORT, response.results); info->return_value = 1; info->color = "green"; info->status_code = 1;