From 40e14bcf3ec2e03204a4bae8c0984bf2bf0865df Mon Sep 17 00:00:00 2001 From: Levi Armstrong Date: Sun, 1 Dec 2024 09:41:59 -0600 Subject: [PATCH] Simplify the type erasure poly --- .../poly/cartesian_waypoint_poly.h | 13 +++++++------ .../poly/instruction_poly.h | 13 +++++++------ .../poly/joint_waypoint_poly.h | 13 +++++++------ .../poly/move_instruction_poly.h | 13 +++++++------ .../poly/state_waypoint_poly.h | 13 +++++++------ .../tesseract_command_language/poly/waypoint_poly.h | 13 +++++++------ 6 files changed, 42 insertions(+), 36 deletions(-) diff --git a/tesseract_command_language/include/tesseract_command_language/poly/cartesian_waypoint_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/cartesian_waypoint_poly.h index 1536f832744..699ebb6e1f1 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/cartesian_waypoint_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/cartesian_waypoint_poly.h @@ -48,20 +48,16 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP using C##InstanceBase = tesseract_common:: \ TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_cartesian_waypoint::CartesianWaypointInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_CARTESIAN_WAYPOINT_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -194,6 +190,11 @@ struct CartesianWaypointInstance : tesseract_common::TypeErasureInstanceget().getName(); } void print(const std::string& prefix) const final { this->get().print(prefix); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization; diff --git a/tesseract_command_language/include/tesseract_command_language/poly/instruction_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/instruction_poly.h index 0cb3cf56d6c..813ba86068b 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/instruction_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/instruction_poly.h @@ -51,20 +51,16 @@ struct uuid; using C##InstanceBase = \ tesseract_common::TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_instruction::InstructionInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_INSTRUCTION_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -158,6 +154,11 @@ struct InstructionInstance : tesseract_common::TypeErasureInstanceget().print(prefix); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); // Creates a copy of this object + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization; diff --git a/tesseract_command_language/include/tesseract_command_language/poly/joint_waypoint_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/joint_waypoint_poly.h index c9aab1f93ef..e77f4cc7023 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/joint_waypoint_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/joint_waypoint_poly.h @@ -47,20 +47,16 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP using C##InstanceBase = \ tesseract_common::TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_joint_waypoint::JointWaypointInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_JOINT_WAYPOINT_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -204,6 +200,11 @@ struct JointWaypointInstance : tesseract_common::TypeErasureInstanceget().getName(); } void print(const std::string& prefix) const final { this->get().print(prefix); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization; diff --git a/tesseract_command_language/include/tesseract_command_language/poly/move_instruction_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/move_instruction_poly.h index 8587e0550cb..0058c670db3 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/move_instruction_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/move_instruction_poly.h @@ -51,20 +51,16 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP using C##InstanceBase = \ tesseract_common::TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_move_instruction::MoveInstructionInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_MOVE_INSTRUCTION_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -283,6 +279,11 @@ struct MoveInstructionInstance : tesseract_common::TypeErasureInstanceget().createJointWaypoint(); } StateWaypointPoly createStateWaypoint() const final { return this->get().createStateWaypoint(); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization; diff --git a/tesseract_command_language/include/tesseract_command_language/poly/state_waypoint_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/state_waypoint_poly.h index 4a07cc1e505..33b915d6a44 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/state_waypoint_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/state_waypoint_poly.h @@ -46,20 +46,16 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP using C##InstanceBase = \ tesseract_common::TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_state_waypoint::StateWaypointInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_STATE_WAYPOINT_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -222,6 +218,11 @@ struct StateWaypointInstance : tesseract_common::TypeErasureInstanceget().getName(); } void print(const std::string& prefix) const final { this->get().print(prefix); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization; diff --git a/tesseract_command_language/include/tesseract_command_language/poly/waypoint_poly.h b/tesseract_command_language/include/tesseract_command_language/poly/waypoint_poly.h index 6a4a26442bf..0d232371918 100644 --- a/tesseract_command_language/include/tesseract_command_language/poly/waypoint_poly.h +++ b/tesseract_command_language/include/tesseract_command_language/poly/waypoint_poly.h @@ -46,20 +46,16 @@ TESSERACT_COMMON_IGNORE_WARNINGS_POP using C##InstanceBase = \ tesseract_common::TypeErasureInstance; \ using C##Instance = tesseract_planning::detail_waypoint::WaypointInstance; \ - using C##InstanceWrapper = tesseract_common::TypeErasureInstanceWrapper; \ } \ BOOST_CLASS_EXPORT_KEY(N::C##InstanceBase) \ BOOST_CLASS_EXPORT_KEY(N::C##Instance) \ - BOOST_CLASS_EXPORT_KEY(N::C##InstanceWrapper) \ BOOST_CLASS_TRACKING(N::C##InstanceBase, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) \ - BOOST_CLASS_TRACKING(N::C##InstanceWrapper, boost::serialization::track_never) + BOOST_CLASS_TRACKING(N::C##Instance, boost::serialization::track_never) /** @brief If shared library, this must go in the cpp after the implicit instantiation of the serialize function */ #define TESSERACT_WAYPOINT_EXPORT_IMPLEMENT(inst) \ BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceBase) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) \ - BOOST_CLASS_EXPORT_IMPLEMENT(inst##InstanceWrapper) + BOOST_CLASS_EXPORT_IMPLEMENT(inst##Instance) /** * @brief This should not be used within shared libraries use the two above. @@ -124,6 +120,11 @@ struct WaypointInstance : tesseract_common::TypeErasureInstanceget().getName(); } void print(const std::string& prefix) const final { this->get().print(prefix); } + std::unique_ptr clone() const final + { + return std::make_unique>(this->get()); + } + private: friend class boost::serialization::access; friend struct tesseract_common::Serialization;