From 48dcf97ea697ac57073439a011c842757208f1ed Mon Sep 17 00:00:00 2001 From: Jeongseok Lee Date: Thu, 4 Apr 2024 08:26:20 -0700 Subject: [PATCH] w2 --- dart/common/Subject.hpp | 4 ++- dart/dynamics/SoftBodyNode.hpp | 2 +- dart/dynamics/detail/EntityNodeAspect.hpp | 2 +- dart/dynamics/detail/FixedFrameAspect.hpp | 5 ++-- dart/dynamics/detail/MarkerAspect.hpp | 4 ++- dart/dynamics/detail/PlanarJointAspect.hpp | 4 +-- docker/dev/v6.14/Dockerfile.gazebo | 31 +++++++++++++++++----- 7 files changed, 38 insertions(+), 14 deletions(-) diff --git a/dart/common/Subject.hpp b/dart/common/Subject.hpp index e7c05c7d13edb..c088a972fd47b 100644 --- a/dart/common/Subject.hpp +++ b/dart/common/Subject.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_SUBJECT_HPP_ #define DART_COMMON_SUBJECT_HPP_ +#include + #include namespace dart { @@ -54,7 +56,7 @@ class Observer; /// dart::sub_ptr is a templated smart pointer that will change itself into a /// nullptr when its Subject is destroyed. It offers one of the easiest ways to /// take advantage of the Subject/Observer pattern. -class Subject +class DART_API Subject { public: friend class Observer; diff --git a/dart/dynamics/SoftBodyNode.hpp b/dart/dynamics/SoftBodyNode.hpp index 5a4f23f3d41f3..dfe968a9009cc 100644 --- a/dart/dynamics/SoftBodyNode.hpp +++ b/dart/dynamics/SoftBodyNode.hpp @@ -331,7 +331,7 @@ class DART_API SoftBodyNode : public detail::SoftBodyNodeBase void updateInertiaWithPointMass(); }; -class SoftBodyNodeHelper +class DART_API SoftBodyNodeHelper { public: /// Create a Properties struct for a box-shaped SoftBodyNode with 8 diff --git a/dart/dynamics/detail/EntityNodeAspect.hpp b/dart/dynamics/detail/EntityNodeAspect.hpp index 0d2749103cd39..1701f2b781ba6 100644 --- a/dart/dynamics/detail/EntityNodeAspect.hpp +++ b/dart/dynamics/detail/EntityNodeAspect.hpp @@ -44,7 +44,7 @@ class EntityNode; namespace detail { //============================================================================== -struct EntityNodeProperties +struct DART_API EntityNodeProperties { /// Name of the Entity/Node std::string mName; diff --git a/dart/dynamics/detail/FixedFrameAspect.hpp b/dart/dynamics/detail/FixedFrameAspect.hpp index 2dcd0b99785c0..3b6da72a1301d 100644 --- a/dart/dynamics/detail/FixedFrameAspect.hpp +++ b/dart/dynamics/detail/FixedFrameAspect.hpp @@ -33,13 +33,14 @@ #ifndef DART_DYNAMICS_DETAIL_FIXEDFRAMEASPECT_HPP_ #define DART_DYNAMICS_DETAIL_FIXEDFRAMEASPECT_HPP_ -#include +#include +#include namespace dart { namespace dynamics { namespace detail { -struct FixedFrameProperties +struct DART_API FixedFrameProperties { /// The relative transform of the FixedFrame Eigen::Isometry3d mRelativeTf; diff --git a/dart/dynamics/detail/MarkerAspect.hpp b/dart/dynamics/detail/MarkerAspect.hpp index 616cf58213fbf..c3f19edcfd470 100644 --- a/dart/dynamics/detail/MarkerAspect.hpp +++ b/dart/dynamics/detail/MarkerAspect.hpp @@ -33,6 +33,8 @@ #ifndef DART_DYNAMICS_DETAIL_MARKERASPECT_HPP_ #define DART_DYNAMICS_DETAIL_MARKERASPECT_HPP_ +#include + #include #include @@ -41,7 +43,7 @@ namespace dart { namespace dynamics { namespace detail { -struct MarkerProperties +struct DART_API MarkerProperties { enum ConstraintType { diff --git a/dart/dynamics/detail/PlanarJointAspect.hpp b/dart/dynamics/detail/PlanarJointAspect.hpp index b5f6ba0732e97..fca2248113cb6 100644 --- a/dart/dynamics/detail/PlanarJointAspect.hpp +++ b/dart/dynamics/detail/PlanarJointAspect.hpp @@ -109,8 +109,8 @@ struct DART_API PlanarJointUniqueProperties }; //============================================================================== -struct PlanarJointProperties : GenericJoint::Properties, - PlanarJointUniqueProperties +struct DART_API PlanarJointProperties : GenericJoint::Properties, + PlanarJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(PlanarJointProperties) diff --git a/docker/dev/v6.14/Dockerfile.gazebo b/docker/dev/v6.14/Dockerfile.gazebo index 137fdd65a9c69..cf236064449bb 100644 --- a/docker/dev/v6.14/Dockerfile.gazebo +++ b/docker/dev/v6.14/Dockerfile.gazebo @@ -4,13 +4,32 @@ FROM jslee02/dart-dev:ubuntu-jammy-v6.14 # Avoid warnings by switching to noninteractive ENV DEBIAN_FRONTEND=noninteractive +WORKDIR /ws + # Compile and install DART and dartpy -COPY . /opt/dart -WORKDIR /opt/dart -RUN cd /opt/dart \ - && cmake \ - -B build \ +COPY . /ws/dart +RUN rm -rf /ws/dart/build +RUN cmake \ + -S dart \ + -B dart/build \ -DCMAKE_INSTALL_PREFIX=/usr/ \ -DCMAKE_BUILD_TYPE=Release .. \ -DBUILD_SHARED_LIBS=ON \ - && cmake --build build --target install -j + && cmake \ + --build dart/build \ + --target install \ + -j16 + +# Install Gazebo from source +ENV IGNITION_PHYSICS_VERSION=7 +RUN apt-add-repository -s "deb http://packages.osrfoundation.org/gazebo/ubuntu-stable $(lsb_release -c -s) main" +RUN apt-get build-dep -y ignition-physics${IGNITION_PHYSICS_VERSION}-dev +RUN clone https://github.com/ignitionrobotics/ign-physics -b ign-physics${IGNITION_PHYSICS_VERSION} +RUN cmake \ + -S ign-physics \ + -B ign-physics/build \ + -DCMAKE_BUILD_TYPE=Release .. \ + && cmake \ + --build build \ + --target install \ + -j16