diff --git a/.clang-format b/.clang-format index 68766810a2d55..d0a71b0ab518c 100644 --- a/.clang-format +++ b/.clang-format @@ -66,23 +66,23 @@ IncludeCategories: Priority: 22 - Regex: '^$' Priority: 23 - - Regex: '^$' + - Regex: '^$' Priority: 24 - - Regex: '^$' + - Regex: '^$' Priority: 25 - - Regex: '^$' + - Regex: '^$' Priority: 26 - - Regex: '^$' + - Regex: '^$' Priority: 27 - - Regex: '^$' + - Regex: '^$' Priority: 28 - - Regex: '^$' + - Regex: '^$' Priority: 29 - - Regex: '^$' + - Regex: '^$' Priority: 30 - - Regex: '^$' + - Regex: '^$' Priority: 31 - - Regex: '^$' + - Regex: '^$' Priority: 32 - Regex: '^$' Priority: 33 diff --git a/.github/workflows/ci_windows.yml b/.github/workflows/ci_windows.yml index 5d7240798d5c1..3e493577f9aed 100644 --- a/.github/workflows/ci_windows.yml +++ b/.github/workflows/ci_windows.yml @@ -22,14 +22,14 @@ on: jobs: build: - name: win-${{ matrix.build_type }} + name: win-${{ matrix.build_type }}-shared_libs=${{ matrix.build_shared_libs }} runs-on: windows-latest strategy: fail-fast: false matrix: toolset: [""] build_type: [Release] - build_shared_libs: [OFF] # TODO(JS): Add ON once shared lib build is resolved + build_shared_libs: [ON, OFF] steps: - name: Checkout @@ -73,7 +73,6 @@ jobs: -G "Visual Studio 17 2022" ^ -A x64 ^ -Wno-dev ${{ matrix.toolset }} ^ - -DCMAKE_BUILD_TYPE=${{ matrix.build_type }} ^ -DCMAKE_TOOLCHAIN_FILE="${{ github.workspace }}/vcpkg/scripts/buildsystems/vcpkg.cmake" ^ -DDART_MSVC_DEFAULT_OPTIONS=ON ^ -DDART_VERBOSE=ON ^ diff --git a/cmake/dart_defs.cmake b/cmake/dart_defs.cmake index ec1d05176134b..bb7935ee09cd1 100644 --- a/cmake/dart_defs.cmake +++ b/cmake/dart_defs.cmake @@ -125,6 +125,142 @@ function(dart_print_options) message(STATUS "") endfunction() +# cmake-format: off +# dart_check_compiler_visibility() +# +# Macro to check for visibility capability in compiler +# cmake-format: on +macro(dart_check_compiler_visibility variable) + include(CheckCXXCompilerFlag) + check_cxx_compiler_flag(-fvisibility=hidden ${variable}) +endmacro() + +# dart_generate_export_header( +# TARGET_NAME +# DESTINATION +# INCLUDE_DIR +# EXPORT_FILE_NAME +# [BASE_NAME ] +# [EXPORT_ALL_SYMBOLS_BY_DEFAULT] +# ) +# +# Function to create an export header for control of binary symbols visibility +# +function(dart_generate_export_header) + set(prefix _ARG) + set(options EXPORT_ALL_SYMBOLS_BY_DEFAULT) + set(oneValueArgs + TARGET_NAME + DESTINATION + EXPORT_FILE_NAME + BASE_NAME + BASE_DIR + ) + set(multiValueArgs) + cmake_parse_arguments( + "${prefix}" + "${options}" + "${oneValueArgs}" + "${multiValueArgs}" + ${ARGN} + ) + + # Check required argument + if(NOT _ARG_TARGET_NAME) + message(FATAL_ERROR "DEVELOPER ERROR: You must specify TARGET_NAME!") + return() + endif() + if(NOT _ARG_DESTINATION) + message(FATAL_ERROR "DEVELOPER ERROR: You must specify DESTINATION!") + return() + endif() + if(NOT _ARG_EXPORT_FILE_NAME) + message(FATAL_ERROR "DEVELOPER ERROR: You must specify EXPORT_FILE_NAME!") + return() + endif() + + # Check if target is valid + if(NOT TARGET ${_ARG_TARGET_NAME}) + message( + FATAL_ERROR + "DEVELOPER ERROR: Invalid target " + "\"${_ARG_TARGET_NAME}\" is passed! " + "Make sure this function is called after the target is defined by " + "add_library( ...).") + return() + endif() + + # Hide symbols by default + if(UNIX AND NOT _ARG_EXPORT_ALL_SYMBOLS_BY_DEFAULT) + dart_check_compiler_visibility(compiler_supports_visibility) + if(compiler_supports_visibility) + target_compile_options(${_ARG_TARGET_NAME} PRIVATE -fvisibility=hidden) + endif() + endif() + + # Base name + if(_ARG_BASE_NAME) + set(base_name ${_ARG_BASE_NAME}) + else() + set(base_name "${_ARG_TARGET_NAME}") + string(REPLACE "-" "_" base_name ${base_name}) + endif() + string(TOUPPER ${base_name} base_name) + + # Set up paths + set(export_file_path "${_ARG_DESTINATION}/${_ARG_EXPORT_FILE_NAME}") + set(export_detail_file_path "${_ARG_DESTINATION}/detail/${_ARG_EXPORT_FILE_NAME}") + + # Generate CMake's default export header + include(GenerateExportHeader) + generate_export_header( + ${_ARG_TARGET_NAME} + EXPORT_MACRO_NAME DETAIL_${base_name}_API + EXPORT_FILE_NAME ${export_detail_file_path} + DEPRECATED_MACRO_NAME _DART_DEPRECATED + ) + + # Generate final export header + file( + WRITE ${export_file_path} + "// This file is automatically generated by ${PROJECT_NAME}.\n" + "\n" + "#pragma once\n" + "\n" + "/**\n" + " * @brief Apply this macro to classes and functions that will need to be exposed\n" + " to the consumer libraries or programs.\n" + " */\n" + "#define ${base_name}_API \\\n" + " DETAIL_${base_name}_API\n" + "\n" + "#ifdef _MSC_VER\n" + " #define ${base_name}_TEMPL_INST_DECL_API\n" + "#else\n" + " #define ${base_name}_TEMPL_INST_DECL_API ${base_name}_API\n" + "#endif\n" + "\n" + "#ifdef _MSC_VER\n" + " #define ${base_name}_TEMPL_INST_DEF_API ${base_name}_API\n" + "#else\n" + " #define ${base_name}_TEMPL_INST_DEF_API\n" + "#endif\n" + "\n" + "#include \"detail/${_ARG_EXPORT_FILE_NAME}\"\n" + ) + + # Install generated export files + set(include_base_path ${CMAKE_INSTALL_INCLUDEDIR}/${org_name}/${project_name}${project_version_major}) + set(export_install_path "${include_base_path}/${_ARG_BASE_DIR}") + set(detail_export_install_path "${export_install_path}/detail/") + install(FILES "${export_file_path}" + DESTINATION "${export_install_path}" + ) + install(FILES "${export_detail_file_path}" + DESTINATION "${detail_export_install_path}" + ) +endfunction() + function(dart_library) set(prefix _ARG) set(options diff --git a/dart/CMakeLists.txt b/dart/CMakeLists.txt index 3c547e94389f2..e85e794802499 100644 --- a/dart/CMakeLists.txt +++ b/dart/CMakeLists.txt @@ -114,6 +114,13 @@ get_property(dart_core_sources GLOBAL PROPERTY DART_CORE_SOURCES) # Add target dart_add_library(dart ${dart_core_headers} ${dart_core_sources}) +dart_generate_export_header( + TARGET_NAME dart + DESTINATION ${CMAKE_CURRENT_BINARY_DIR} + EXPORT_FILE_NAME Export.hpp + BASE_NAME DART + BASE_DIR ${CMAKE_CURRENT_SOURCE_DIR} +) target_include_directories(dart BEFORE PUBLIC $ diff --git a/dart/collision/CollisionDetector.hpp b/dart/collision/CollisionDetector.hpp index b22120a76c180..e6ae192ac161e 100644 --- a/dart/collision/CollisionDetector.hpp +++ b/dart/collision/CollisionDetector.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONDETECTOR_HPP_ #define DART_COLLISION_COLLISIONDETECTOR_HPP_ +#include + #include #include #include @@ -56,7 +58,8 @@ namespace collision { class CollisionObject; -class CollisionDetector : public std::enable_shared_from_this +class DART_API CollisionDetector + : public std::enable_shared_from_this { public: friend class CollisionObject; diff --git a/dart/collision/CollisionFilter.hpp b/dart/collision/CollisionFilter.hpp index 5bfadcad430bc..85502a958be1a 100644 --- a/dart/collision/CollisionFilter.hpp +++ b/dart/collision/CollisionFilter.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONFILTER_HPP_ #define DART_COLLISION_COLLISIONFILTER_HPP_ +#include + #include #include @@ -47,7 +49,7 @@ namespace collision { class CollisionObject; -class CollisionFilter +class DART_API CollisionFilter { public: /// Destructor. @@ -68,7 +70,7 @@ class CollisionFilter const CollisionObject* object1, const CollisionObject* object2) const = 0; }; -class CompositeCollisionFilter : public CollisionFilter +class DART_API CompositeCollisionFilter : public CollisionFilter { public: /// Adds a collision filter to this CompositeCollisionFilter. @@ -90,7 +92,7 @@ class CompositeCollisionFilter : public CollisionFilter std::unordered_set mFilters; }; -class BodyNodeCollisionFilter : public CollisionFilter +class DART_API BodyNodeCollisionFilter : public CollisionFilter { public: /// Add a BodyNode pair to the blacklist. diff --git a/dart/collision/CollisionGroup.hpp b/dart/collision/CollisionGroup.hpp index 563c55c46b399..3e62b5e646073 100644 --- a/dart/collision/CollisionGroup.hpp +++ b/dart/collision/CollisionGroup.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONGROUP_HPP_ #define DART_COLLISION_COLLISIONGROUP_HPP_ +#include + #include #include #include @@ -52,7 +54,7 @@ namespace dart { namespace collision { -class CollisionGroup +class DART_API CollisionGroup { public: /// Constructor diff --git a/dart/collision/CollisionObject.hpp b/dart/collision/CollisionObject.hpp index 4483b1b700d54..8ed8626474e4f 100644 --- a/dart/collision/CollisionObject.hpp +++ b/dart/collision/CollisionObject.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONOBJECT_HPP_ #define DART_COLLISION_COLLISIONOBJECT_HPP_ +#include + #include #include @@ -42,7 +44,7 @@ namespace dart { namespace collision { -class CollisionObject +class DART_API CollisionObject { public: friend class CollisionGroup; diff --git a/dart/collision/CollisionOption.hpp b/dart/collision/CollisionOption.hpp index 176b195db645b..8573ba229178c 100644 --- a/dart/collision/CollisionOption.hpp +++ b/dart/collision/CollisionOption.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONOPTION_HPP_ #define DART_COLLISION_COLLISIONOPTION_HPP_ +#include + #include #include @@ -42,7 +44,7 @@ namespace collision { class CollisionFilter; -struct CollisionOption +struct DART_API CollisionOption { /// Flag whether the collision detector computes contact information (contact /// point, normal, and penetration depth). If it is set to false, only the diff --git a/dart/collision/CollisionResult.hpp b/dart/collision/CollisionResult.hpp index cc79873df7c80..4d2ed5736e892 100644 --- a/dart/collision/CollisionResult.hpp +++ b/dart/collision/CollisionResult.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_COLLISIONRESULT_HPP_ #define DART_COLLISION_COLLISIONRESULT_HPP_ +#include + #include #include @@ -49,7 +51,7 @@ class ShapeFrame; namespace collision { -class CollisionResult +class DART_API CollisionResult { public: /// Add one contact diff --git a/dart/collision/Contact.hpp b/dart/collision/Contact.hpp index 2947c83d200f0..efadd34e4ad46 100644 --- a/dart/collision/Contact.hpp +++ b/dart/collision/Contact.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_CONTACT_HPP_ #define DART_COLLISION_CONTACT_HPP_ +#include + #include #include @@ -43,7 +45,7 @@ namespace dart { namespace collision { /// Contact information -struct Contact +struct DART_API Contact { /// Default constructor Contact(); diff --git a/dart/collision/DistanceFilter.hpp b/dart/collision/DistanceFilter.hpp index f032ff57c6510..5213e56808805 100644 --- a/dart/collision/DistanceFilter.hpp +++ b/dart/collision/DistanceFilter.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_DISTANCEFILTER_HPP_ #define DART_COLLISION_DISTANCEFILTER_HPP_ +#include + namespace dart { namespace dynamics { @@ -43,13 +45,13 @@ namespace collision { class CollisionObject; -struct DistanceFilter +struct DART_API DistanceFilter { virtual bool needDistance( const CollisionObject* object1, const CollisionObject* object2) const = 0; }; -struct BodyNodeDistanceFilter : DistanceFilter +struct DART_API BodyNodeDistanceFilter : DistanceFilter { bool needDistance( const CollisionObject* object1, diff --git a/dart/collision/DistanceOption.hpp b/dart/collision/DistanceOption.hpp index 508a619126494..4868389fb3e10 100644 --- a/dart/collision/DistanceOption.hpp +++ b/dart/collision/DistanceOption.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_DISTANCE_OPTION_HPP_ #define DART_COLLISION_DISTANCE_OPTION_HPP_ +#include + #include #include @@ -42,7 +44,7 @@ namespace collision { struct DistanceFilter; -struct DistanceOption +struct DART_API DistanceOption { /// Whether to calculate the nearest points. /// diff --git a/dart/collision/DistanceResult.hpp b/dart/collision/DistanceResult.hpp index c0c8ac13787ee..35885bc1110d9 100644 --- a/dart/collision/DistanceResult.hpp +++ b/dart/collision/DistanceResult.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_DISTANCE_RESULT_HPP_ #define DART_COLLISION_DISTANCE_RESULT_HPP_ +#include + #include namespace dart { @@ -43,7 +45,7 @@ class ShapeFrame; namespace collision { -struct DistanceResult +struct DART_API DistanceResult { /// Minimum \b singed distance between the checked Shape pairs. /// diff --git a/dart/collision/RaycastOption.hpp b/dart/collision/RaycastOption.hpp index 838eca4495c21..874e96a90c2da 100644 --- a/dart/collision/RaycastOption.hpp +++ b/dart/collision/RaycastOption.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_RAYCASTOPTION_HPP_ #define DART_COLLISION_RAYCASTOPTION_HPP_ +#include + #include #include @@ -40,7 +42,7 @@ namespace dart { namespace collision { -struct RaycastOption +struct DART_API RaycastOption { /// Constructor RaycastOption(bool enableAllHits = false, bool sortByClosest = false); diff --git a/dart/collision/RaycastResult.hpp b/dart/collision/RaycastResult.hpp index 3e29712646f13..c20c2b95788e9 100644 --- a/dart/collision/RaycastResult.hpp +++ b/dart/collision/RaycastResult.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_RAYCASTRESULT_HPP_ #define DART_COLLISION_RAYCASTRESULT_HPP_ +#include + #include #include @@ -42,7 +44,7 @@ namespace collision { class CollisionObject; -struct RayHit +struct DART_API RayHit { /// The collision object the ray hit const CollisionObject* mCollisionObject; @@ -60,7 +62,7 @@ struct RayHit RayHit(); }; -struct RaycastResult +struct DART_API RaycastResult { /// Clear the result void clear(); diff --git a/dart/collision/fcl/FCLCollisionDetector.hpp b/dart/collision/fcl/FCLCollisionDetector.hpp index 0fb21a51af0e4..d801623517ea2 100644 --- a/dart/collision/fcl/FCLCollisionDetector.hpp +++ b/dart/collision/fcl/FCLCollisionDetector.hpp @@ -43,7 +43,7 @@ namespace collision { class FCLCollisionObject; -class FCLCollisionDetector : public CollisionDetector +class DART_API FCLCollisionDetector : public CollisionDetector { public: using CollisionDetector::createCollisionGroup; diff --git a/dart/collision/fcl/FCLCollisionGroup.hpp b/dart/collision/fcl/FCLCollisionGroup.hpp index ae443fc461740..b3cef1bf9cf7d 100644 --- a/dart/collision/fcl/FCLCollisionGroup.hpp +++ b/dart/collision/fcl/FCLCollisionGroup.hpp @@ -42,7 +42,7 @@ namespace collision { class CollisionObject; class FCLCollisionObjectUserData; -class FCLCollisionGroup : public CollisionGroup +class DART_API FCLCollisionGroup : public CollisionGroup { public: friend class FCLCollisionDetector; diff --git a/dart/collision/fcl/FCLCollisionObject.hpp b/dart/collision/fcl/FCLCollisionObject.hpp index f353741063f14..1e07e13fe9359 100644 --- a/dart/collision/fcl/FCLCollisionObject.hpp +++ b/dart/collision/fcl/FCLCollisionObject.hpp @@ -39,7 +39,7 @@ namespace dart { namespace collision { -class FCLCollisionObject : public CollisionObject +class DART_API FCLCollisionObject : public CollisionObject { public: friend class FCLCollisionDetector; diff --git a/dart/collision/fcl/FCLTypes.hpp b/dart/collision/fcl/FCLTypes.hpp index 0ab8b4afbadff..3ec4b011c89cf 100644 --- a/dart/collision/fcl/FCLTypes.hpp +++ b/dart/collision/fcl/FCLTypes.hpp @@ -33,6 +33,8 @@ #ifndef DART_COLLISION_FCL_FCLTTYPES_HPP_ #define DART_COLLISION_FCL_FCLTTYPES_HPP_ +#include + #include #include @@ -40,7 +42,7 @@ namespace dart { namespace collision { -class FCLTypes +class DART_API FCLTypes { public: /// Convert FCL vector3 type to Eigen vector3 type diff --git a/dart/common/Aspect.hpp b/dart/common/Aspect.hpp index 07638453f87a0..55f95d4c03f83 100644 --- a/dart/common/Aspect.hpp +++ b/dart/common/Aspect.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_ASPECT_HPP_ #define DART_COMMON_ASPECT_HPP_ +#include + #include #include #include @@ -44,7 +46,7 @@ namespace common { class Composite; -class Aspect +class DART_API Aspect { public: friend class Composite; diff --git a/dart/common/CAllocator.hpp b/dart/common/CAllocator.hpp index 602988fa8d131..971431531b62e 100644 --- a/dart/common/CAllocator.hpp +++ b/dart/common/CAllocator.hpp @@ -39,7 +39,7 @@ namespace dart::common { /// A stateless memory allocator (in release mode) that uses std::malloc and /// std::free for memory allocation and deallocation. -class CAllocator : public MemoryAllocator +class DART_API CAllocator : public MemoryAllocator { public: /// Constructor diff --git a/dart/common/Console.hpp b/dart/common/Console.hpp index 5a1751b55b4f9..683351b0c56da 100644 --- a/dart/common/Console.hpp +++ b/dart/common/Console.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_CONSOLE_HPP_ #define DART_COMMON_CONSOLE_HPP_ +#include + #include #include @@ -52,10 +54,10 @@ namespace dart { namespace common { /// \brief -std::ostream& colorMsg(const std::string& _msg, int _color); +DART_API std::ostream& colorMsg(const std::string& _msg, int _color); /// \brief -std::ostream& colorErr( +DART_API std::ostream& colorErr( const std::string& _msg, const std::string& _file, unsigned int _line, diff --git a/dart/common/LocalResource.hpp b/dart/common/LocalResource.hpp index e8a3599c189ec..40ea24dbaa081 100644 --- a/dart/common/LocalResource.hpp +++ b/dart/common/LocalResource.hpp @@ -40,7 +40,7 @@ namespace dart { namespace common { DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class LocalResource : public virtual Resource +class DART_API LocalResource : public virtual Resource { public: explicit LocalResource(const std::string& _path); diff --git a/dart/common/LocalResourceRetriever.hpp b/dart/common/LocalResourceRetriever.hpp index 1d2845780493a..143bf1fa57cb9 100644 --- a/dart/common/LocalResourceRetriever.hpp +++ b/dart/common/LocalResourceRetriever.hpp @@ -40,7 +40,7 @@ namespace common { /// LocalResourceRetriever provides access to local resources specified by /// file:// URIs by wrapping the standard C and C++ file manipulation routines. -class LocalResourceRetriever : public virtual ResourceRetriever +class DART_API LocalResourceRetriever : public virtual ResourceRetriever { public: virtual ~LocalResourceRetriever() = default; diff --git a/dart/common/MemoryAllocator.hpp b/dart/common/MemoryAllocator.hpp index 0964c760d4cf2..fff87a684fdd2 100644 --- a/dart/common/MemoryAllocator.hpp +++ b/dart/common/MemoryAllocator.hpp @@ -35,6 +35,8 @@ #include +#include + #include #include @@ -45,7 +47,7 @@ namespace dart::common { /// Base class for std::allocator compatible allocators. -class MemoryAllocator : public Castable +class DART_API MemoryAllocator : public Castable { public: /// Returns the default memory allocator diff --git a/dart/common/Observer.hpp b/dart/common/Observer.hpp index 2fabe2d322d0e..6257a85735cc5 100644 --- a/dart/common/Observer.hpp +++ b/dart/common/Observer.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_OBSERVER_HPP_ #define DART_COMMON_OBSERVER_HPP_ +#include + #include namespace dart { @@ -48,7 +50,7 @@ class Subject; /// 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 Observer +class DART_API Observer { public: friend class Subject; diff --git a/dart/common/Resource.hpp b/dart/common/Resource.hpp index 12014c7ed6ca5..2d7f91d2ff225 100644 --- a/dart/common/Resource.hpp +++ b/dart/common/Resource.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_RESOURCE_HPP_ #define DART_COMMON_RESOURCE_HPP_ +#include + #include #include @@ -46,7 +48,7 @@ namespace common { /// It is expected that each \a ResourceRetriever will provide a concrete / /// instantiation of the Resource class. This interface exposes an similar API /// to that of the the standard C file manipulation functions. -class Resource +class DART_API Resource { public: /// \brief Position to seek relative to. diff --git a/dart/common/ResourceRetriever.hpp b/dart/common/ResourceRetriever.hpp index 938229c2e081c..48da494adacd0 100644 --- a/dart/common/ResourceRetriever.hpp +++ b/dart/common/ResourceRetriever.hpp @@ -44,7 +44,7 @@ namespace common { /// ResourceRetriever provides methods for testing for the existance of and /// accessing the content of a resource specified by URI. -class ResourceRetriever +class DART_API ResourceRetriever { public: virtual ~ResourceRetriever() = default; diff --git a/dart/common/SharedLibrary.hpp b/dart/common/SharedLibrary.hpp index 99e2ebc1351c8..cd27f1a0e37ad 100644 --- a/dart/common/SharedLibrary.hpp +++ b/dart/common/SharedLibrary.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_SHAREDLIBRARY_HPP_ #define DART_COMMON_SHAREDLIBRARY_HPP_ +#include + #include #include #include @@ -84,7 +86,7 @@ class SharedLibraryManager; } // namespace detail /// SharedLibrary is a RAII object wrapping a shared library. -class SharedLibrary +class DART_API SharedLibrary { protected: enum ProtectedConstructionTag diff --git a/dart/common/Stopwatch.hpp b/dart/common/Stopwatch.hpp index 2f6971de5c047..3a5ceec4cac67 100644 --- a/dart/common/Stopwatch.hpp +++ b/dart/common/Stopwatch.hpp @@ -33,6 +33,8 @@ #ifndef DART_COMMON_STOPWATCH_HPP_ #define DART_COMMON_STOPWATCH_HPP_ +#include + #include #include @@ -114,22 +116,22 @@ class Stopwatch final /// tic(); /// auto elapsedS = toc(); // prints and returns the elapsed time /// \endcode -void tic(); +DART_API void tic(); /// Returns the elapsed time in seconds since the last tic() call. -double toc(bool print = false); +[[nodiscard]] DART_API double toc(bool print = false); /// Returns the elapsed time in seconds since the last tic() call. -double tocS(bool print = false); +[[nodiscard]] DART_API double tocS(bool print = false); /// Returns the elapsed time in milliseconds since the last tic() call. -double tocMS(bool print = false); +[[nodiscard]] DART_API double tocMS(bool print = false); /// Returns the elapsed time in microseconds since the last tic() call. -double tocUS(bool print = false); +[[nodiscard]] DART_API double tocUS(bool print = false); /// Returns the elapsed time in nanoseconds since the last tic() call. -double tocNS(bool print = false); +[[nodiscard]] DART_API double tocNS(bool print = false); using StopwatchS = Stopwatch; using StopwatchMS = Stopwatch; diff --git a/dart/common/String.hpp b/dart/common/String.hpp index 1657648be3472..9b5ccaf756560 100644 --- a/dart/common/String.hpp +++ b/dart/common/String.hpp @@ -33,37 +33,39 @@ #ifndef DART_COMMON_STRING_HPP_ #define DART_COMMON_STRING_HPP_ +#include + #include #include namespace dart::common { /// Converts string to upper cases -std::string toUpper(std::string str); +[[nodiscard]] DART_API std::string toUpper(std::string str); /// Converts string to upper cases in place -void toUpperInPlace(std::string& str); +DART_API void toUpperInPlace(std::string& str); /// Converts string to lower cases -std::string toLower(std::string str); +[[nodiscard]] DART_API std::string toLower(std::string str); /// Converts string to lower cases in place -void toLowerInPlace(std::string& str); +DART_API void toLowerInPlace(std::string& str); /// Trims both sides of string -std::string trim( +[[nodiscard]] DART_API std::string trim( const std::string& str, const std::string& whitespaces = " \n\r\t"); /// Trims left side of string -std::string trimLeft( +[[nodiscard]] DART_API std::string trimLeft( const std::string& str, const std::string& whitespaces = " \n\r\t"); /// Trims right side of string -std::string trimRight( +[[nodiscard]] DART_API std::string trimRight( const std::string& str, const std::string& whitespaces = " \n\r\t"); /// Splits string given delimiters -std::vector split( +[[nodiscard]] DART_API std::vector split( const std::string& str, const std::string& delimiters = " \n\r\t"); } // namespace dart::common diff --git a/dart/common/Timer.hpp b/dart/common/Timer.hpp index 729d5e49ce242..af92844c280f3 100644 --- a/dart/common/Timer.hpp +++ b/dart/common/Timer.hpp @@ -41,6 +41,8 @@ #include #endif +#include + #include namespace dart { @@ -52,7 +54,7 @@ namespace common { /// For measure the time, gettimeofday() api is used /// /// \deprecated Use Stopwatch instead. -class DART_DEPRECATED(6.13) Timer +class DART_API DART_DEPRECATED(6.13) Timer { public: /// \brief Default constructor diff --git a/dart/common/Uri.hpp b/dart/common/Uri.hpp index db31c0fa4695a..975d8b8831f95 100644 --- a/dart/common/Uri.hpp +++ b/dart/common/Uri.hpp @@ -33,12 +33,14 @@ #ifndef DART_COMMON_URI_HPP_ #define DART_COMMON_URI_HPP_ +#include + #include namespace dart { namespace common { -class UriComponent final +class DART_API UriComponent final { public: using value_type = std::string; @@ -83,7 +85,7 @@ class UriComponent final /// ResourceRetreiver classes rewrite URIs to other types of URIs (e.g, resolve /// 'package://' URIs to 'file://' URIs), which is easier to implement if you /// have direct access to the URI components. -struct Uri final +struct DART_API Uri final { /// Scheme, e.g. 'http', 'file', 'package' UriComponent mScheme; diff --git a/dart/constraint/BalanceConstraint.hpp b/dart/constraint/BalanceConstraint.hpp index ffe6c343500e7..774ed24f377b2 100644 --- a/dart/constraint/BalanceConstraint.hpp +++ b/dart/constraint/BalanceConstraint.hpp @@ -42,8 +42,8 @@ namespace constraint { /// into a HierarchicalIK module. Adding this constraint to the Problem of a /// HierarchicalIK will allow the IK solver to constrain the Skeleton so that it /// satisfies a support polygon style balancing constraint. -class BalanceConstraint : public optimizer::Function, - public dynamics::HierarchicalIK::Function +class DART_API BalanceConstraint : public optimizer::Function, + public dynamics::HierarchicalIK::Function { public: /// The ErrorMethod_t determines whether the error should be computed based on diff --git a/dart/constraint/BallJointConstraint.hpp b/dart/constraint/BallJointConstraint.hpp index d1eeb18d2177f..2cce6626d0735 100644 --- a/dart/constraint/BallJointConstraint.hpp +++ b/dart/constraint/BallJointConstraint.hpp @@ -44,7 +44,7 @@ namespace constraint { /// BallJointConstraint represents ball joint constraint between a body and the /// world or between two bodies -class BallJointConstraint : public DynamicJointConstraint +class DART_API BallJointConstraint : public DynamicJointConstraint { public: /// Constructor that takes one body and the joint position in the world frame diff --git a/dart/constraint/BoxedLcpConstraintSolver.hpp b/dart/constraint/BoxedLcpConstraintSolver.hpp index 3220c1876aaad..fb0b56a5a99ce 100644 --- a/dart/constraint/BoxedLcpConstraintSolver.hpp +++ b/dart/constraint/BoxedLcpConstraintSolver.hpp @@ -39,7 +39,7 @@ namespace dart { namespace constraint { -class BoxedLcpConstraintSolver : public ConstraintSolver +class DART_API BoxedLcpConstraintSolver : public ConstraintSolver { public: /// Constructor diff --git a/dart/constraint/BoxedLcpSolver.hpp b/dart/constraint/BoxedLcpSolver.hpp index 866cce291172e..d3e342133b863 100644 --- a/dart/constraint/BoxedLcpSolver.hpp +++ b/dart/constraint/BoxedLcpSolver.hpp @@ -35,6 +35,8 @@ #include +#include + #include #include @@ -44,7 +46,7 @@ namespace dart { namespace constraint { -class BoxedLcpSolver : public common::Castable +class DART_API BoxedLcpSolver : public common::Castable { public: /// Destructor diff --git a/dart/constraint/ConstrainedGroup.hpp b/dart/constraint/ConstrainedGroup.hpp index aa79ae559b28d..837b4ed3c0ee7 100644 --- a/dart/constraint/ConstrainedGroup.hpp +++ b/dart/constraint/ConstrainedGroup.hpp @@ -35,6 +35,8 @@ #include +#include + #include #include @@ -57,7 +59,7 @@ class ConstraintSolver; /// ConstrainedGroup is a group of skeletons that interact each other with /// constraints /// \sa class ConstraintSolver -class ConstrainedGroup +class DART_API ConstrainedGroup { public: //---------------------------------------------------------------------------- diff --git a/dart/constraint/ConstraintBase.hpp b/dart/constraint/ConstraintBase.hpp index 11b9ab8450224..22ba1f8acc386 100644 --- a/dart/constraint/ConstraintBase.hpp +++ b/dart/constraint/ConstraintBase.hpp @@ -33,6 +33,8 @@ #ifndef DART_CONSTRAINT_CONSTRAINTBASE_HPP_ #define DART_CONSTRAINT_CONSTRAINTBASE_HPP_ +#include + #include #include @@ -71,7 +73,7 @@ struct ConstraintInfo }; /// Constraint is a base class of concrete constraints classes -class ConstraintBase +class DART_API ConstraintBase { public: /// Returns a string representing the constraint type diff --git a/dart/constraint/ConstraintSolver.hpp b/dart/constraint/ConstraintSolver.hpp index 4935eb5ffda98..7ec027d90b913 100644 --- a/dart/constraint/ConstraintSolver.hpp +++ b/dart/constraint/ConstraintSolver.hpp @@ -55,7 +55,7 @@ class ShapeNodeCollisionObject; namespace constraint { /// ConstraintSolver manages constraints and computes constraint impulses -class ConstraintSolver +class DART_API ConstraintSolver { public: /// Constructor diff --git a/dart/constraint/ContactConstraint.hpp b/dart/constraint/ContactConstraint.hpp index f7e6d962bdf67..7c2bb5ee57038 100644 --- a/dart/constraint/ContactConstraint.hpp +++ b/dart/constraint/ContactConstraint.hpp @@ -50,7 +50,7 @@ class Skeleton; namespace constraint { /// ContactConstraint represents a contact constraint between two bodies -class ContactConstraint : public ConstraintBase +class DART_API ContactConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/DantzigBoxedLcpSolver.hpp b/dart/constraint/DantzigBoxedLcpSolver.hpp index 790759dea602a..23f7f61883a06 100644 --- a/dart/constraint/DantzigBoxedLcpSolver.hpp +++ b/dart/constraint/DantzigBoxedLcpSolver.hpp @@ -38,7 +38,7 @@ namespace dart { namespace constraint { -class DantzigBoxedLcpSolver : public BoxedLcpSolver +class DART_API DantzigBoxedLcpSolver : public BoxedLcpSolver { public: // Documentation inherited. diff --git a/dart/constraint/DantzigLCPSolver.hpp b/dart/constraint/DantzigLCPSolver.hpp index 2937657977759..19db8a02f6476 100644 --- a/dart/constraint/DantzigLCPSolver.hpp +++ b/dart/constraint/DantzigLCPSolver.hpp @@ -47,7 +47,7 @@ namespace constraint { /// /// DantzigLCPSolver is a LCP solver that uses ODE's implementation of Dantzig /// algorithm -class DantzigLCPSolver : public LCPSolver +class DART_API DantzigLCPSolver : public LCPSolver { public: /// Constructor diff --git a/dart/constraint/DynamicJointConstraint.hpp b/dart/constraint/DynamicJointConstraint.hpp index 6515250c660be..4711921930700 100644 --- a/dart/constraint/DynamicJointConstraint.hpp +++ b/dart/constraint/DynamicJointConstraint.hpp @@ -45,7 +45,7 @@ namespace constraint { /// Base class for joint constraints that are being created or destructed during /// simulation. -class DynamicJointConstraint : public ConstraintBase +class DART_API DynamicJointConstraint : public ConstraintBase { public: /// Contructor diff --git a/dart/constraint/JointConstraint.hpp b/dart/constraint/JointConstraint.hpp index 20308a2a5f0dc..fb3259e0ff420 100644 --- a/dart/constraint/JointConstraint.hpp +++ b/dart/constraint/JointConstraint.hpp @@ -50,7 +50,7 @@ namespace constraint { /// JointConstraint handles multiple constraints that are defined in the joint /// space, such as joint position/velocity limits and servo motor. -class JointConstraint : public ConstraintBase +class DART_API JointConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/JointCoulombFrictionConstraint.hpp b/dart/constraint/JointCoulombFrictionConstraint.hpp index e9be67eb9f4ac..7ed1f557d09e5 100644 --- a/dart/constraint/JointCoulombFrictionConstraint.hpp +++ b/dart/constraint/JointCoulombFrictionConstraint.hpp @@ -45,7 +45,7 @@ class Joint; namespace constraint { /// Joint Coulomb friction constraint -class JointCoulombFrictionConstraint : public ConstraintBase +class DART_API JointCoulombFrictionConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/JointLimitConstraint.hpp b/dart/constraint/JointLimitConstraint.hpp index 11597bcb26a77..103773a8dcae1 100644 --- a/dart/constraint/JointLimitConstraint.hpp +++ b/dart/constraint/JointLimitConstraint.hpp @@ -47,7 +47,7 @@ class Joint; namespace constraint { /// JointLimitConstraint handles joint position and velocity limits -class JointLimitConstraint : public ConstraintBase +class DART_API JointLimitConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/LCPSolver.hpp b/dart/constraint/LCPSolver.hpp index 572f4e527a058..1902688c24a7e 100644 --- a/dart/constraint/LCPSolver.hpp +++ b/dart/constraint/LCPSolver.hpp @@ -41,7 +41,7 @@ class ConstrainedGroup; /// \deprecated This header has been deprecated in DART 6.7. /// /// LCPSolver -class LCPSolver +class DART_API LCPSolver { public: /// Solve constriant impulses for a constrained group diff --git a/dart/constraint/MimicMotorConstraint.hpp b/dart/constraint/MimicMotorConstraint.hpp index 851f4c8177b36..96debfdc457de 100644 --- a/dart/constraint/MimicMotorConstraint.hpp +++ b/dart/constraint/MimicMotorConstraint.hpp @@ -49,7 +49,7 @@ class Joint; namespace constraint { /// Servo motor constraint -class MimicMotorConstraint : public ConstraintBase +class DART_API MimicMotorConstraint : public ConstraintBase { public: /// Constructor that creates a MimicMotorConstraint using the given diff --git a/dart/constraint/PGSLCPSolver.hpp b/dart/constraint/PGSLCPSolver.hpp index 7d72b1b22eb88..a326a16de3365 100644 --- a/dart/constraint/PGSLCPSolver.hpp +++ b/dart/constraint/PGSLCPSolver.hpp @@ -46,7 +46,7 @@ namespace constraint { /// PgsBoxedLcpSolver.hpp instead. /// /// PGSLCPSolver -class PGSLCPSolver : public LCPSolver +class DART_API PGSLCPSolver : public LCPSolver { public: /// Constructor diff --git a/dart/constraint/PgsBoxedLcpSolver.hpp b/dart/constraint/PgsBoxedLcpSolver.hpp index 2bd77936a032d..fee33083e3dcf 100644 --- a/dart/constraint/PgsBoxedLcpSolver.hpp +++ b/dart/constraint/PgsBoxedLcpSolver.hpp @@ -41,7 +41,7 @@ namespace dart { namespace constraint { /// Implementation of projected Gauss-Seidel (PGS) LCP solver. -class PgsBoxedLcpSolver : public BoxedLcpSolver +class DART_API PgsBoxedLcpSolver : public BoxedLcpSolver { public: struct Option diff --git a/dart/constraint/ServoMotorConstraint.hpp b/dart/constraint/ServoMotorConstraint.hpp index ab0e985ac746c..bedf5423f4b1b 100644 --- a/dart/constraint/ServoMotorConstraint.hpp +++ b/dart/constraint/ServoMotorConstraint.hpp @@ -45,7 +45,7 @@ class Joint; namespace constraint { /// Servo motor constraint -class ServoMotorConstraint : public ConstraintBase +class DART_API ServoMotorConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/SoftContactConstraint.hpp b/dart/constraint/SoftContactConstraint.hpp index d31e4371544fb..798c0bd7e93da 100644 --- a/dart/constraint/SoftContactConstraint.hpp +++ b/dart/constraint/SoftContactConstraint.hpp @@ -55,7 +55,7 @@ class Skeleton; namespace constraint { /// SoftContactConstraint represents a contact constraint between two bodies -class SoftContactConstraint : public ConstraintBase +class DART_API SoftContactConstraint : public ConstraintBase { public: /// Constructor diff --git a/dart/constraint/WeldJointConstraint.hpp b/dart/constraint/WeldJointConstraint.hpp index 8fcc3df707dd0..a9edffbe91f99 100644 --- a/dart/constraint/WeldJointConstraint.hpp +++ b/dart/constraint/WeldJointConstraint.hpp @@ -44,7 +44,7 @@ namespace constraint { /// WeldJointConstraint represents weld joint constraint between a body and the /// world or between two bodies -class WeldJointConstraint : public DynamicJointConstraint +class DART_API WeldJointConstraint : public DynamicJointConstraint { public: /// Constructor that takes one body diff --git a/dart/dynamics/ArrowShape.hpp b/dart/dynamics/ArrowShape.hpp index 31bdf7c948da7..59a4e1d86a930 100644 --- a/dart/dynamics/ArrowShape.hpp +++ b/dart/dynamics/ArrowShape.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class ArrowShape : public MeshShape +class DART_API ArrowShape : public MeshShape { public: struct Properties diff --git a/dart/dynamics/BallJoint.hpp b/dart/dynamics/BallJoint.hpp index 9eccb52083f23..801bc44f2e2fd 100644 --- a/dart/dynamics/BallJoint.hpp +++ b/dart/dynamics/BallJoint.hpp @@ -41,7 +41,7 @@ namespace dart { namespace dynamics { /// class BallJoint -class BallJoint : public GenericJoint +class DART_API BallJoint : public GenericJoint { public: friend class Skeleton; diff --git a/dart/dynamics/BoxShape.hpp b/dart/dynamics/BoxShape.hpp index 6c2444d9ce47a..eed8d531a44ed 100644 --- a/dart/dynamics/BoxShape.hpp +++ b/dart/dynamics/BoxShape.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class BoxShape : public Shape +class DART_API BoxShape : public Shape { public: /// \brief Constructor. diff --git a/dart/dynamics/Branch.hpp b/dart/dynamics/Branch.hpp index 1ea82d287bce4..b09611e6ecba2 100644 --- a/dart/dynamics/Branch.hpp +++ b/dart/dynamics/Branch.hpp @@ -41,7 +41,7 @@ namespace dynamics { /// Branch is a specialized type of Linkage that represents a complete subtree /// of a Skeleton. The Branch will start at a specific BodyNode and will include /// every BodyNode that descends from it, all the way to the leaves. -class Branch : public Linkage +class DART_API Branch : public Linkage { public: struct Criteria diff --git a/dart/dynamics/CapsuleShape.hpp b/dart/dynamics/CapsuleShape.hpp index 4c2810feb157a..76de2b2af62ff 100644 --- a/dart/dynamics/CapsuleShape.hpp +++ b/dart/dynamics/CapsuleShape.hpp @@ -40,7 +40,7 @@ namespace dynamics { /// CapsuleShape represents a three-dimensional geometric shape consisting of a /// cylinder with hemispherical ends. -class CapsuleShape : public Shape +class DART_API CapsuleShape : public Shape { public: /// Constructor. diff --git a/dart/dynamics/Chain.hpp b/dart/dynamics/Chain.hpp index fe614bb355d2d..c6065c59bedf1 100644 --- a/dart/dynamics/Chain.hpp +++ b/dart/dynamics/Chain.hpp @@ -43,7 +43,7 @@ namespace dynamics { /// specified BodyNode and include every BodyNode on the way to a target /// BodyNode, except it will stop if it encounters a branching (BodyNode with /// multiple child BodyNodes) or a FreeJoint. -class Chain : public Linkage +class DART_API Chain : public Linkage { public: struct Criteria diff --git a/dart/dynamics/ConeShape.hpp b/dart/dynamics/ConeShape.hpp index 8d74f07cd3abc..345cd7161bec7 100644 --- a/dart/dynamics/ConeShape.hpp +++ b/dart/dynamics/ConeShape.hpp @@ -40,7 +40,7 @@ namespace dynamics { /// ConeShape represents a three-dimensional geometric shape that tapers /// smoothly from a flat circular base to a point called the apex or vertex. -class ConeShape : public Shape +class DART_API ConeShape : public Shape { public: /// Constructor. diff --git a/dart/dynamics/CylinderShape.hpp b/dart/dynamics/CylinderShape.hpp index 3a8f6ef3f1759..daf73ee3ebd29 100644 --- a/dart/dynamics/CylinderShape.hpp +++ b/dart/dynamics/CylinderShape.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class CylinderShape : public Shape +class DART_API CylinderShape : public Shape { public: /// \brief Constructor. diff --git a/dart/dynamics/DegreeOfFreedom.hpp b/dart/dynamics/DegreeOfFreedom.hpp index 8daa0b88c94bc..5543e23f5dbf7 100644 --- a/dart/dynamics/DegreeOfFreedom.hpp +++ b/dart/dynamics/DegreeOfFreedom.hpp @@ -33,6 +33,8 @@ #ifndef DART_DYNAMICS_DEGREEOFFREEDOM_HPP_ #define DART_DYNAMICS_DEGREEOFFREEDOM_HPP_ +#include + #include #include @@ -53,7 +55,7 @@ class BodyNode; /// DegreeOfFreedom class is a proxy class for accessing single degrees of /// freedom (aka generalized coordinates) of the Skeleton. DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class DegreeOfFreedom : public virtual common::Subject +class DART_API DegreeOfFreedom : public virtual common::Subject { public: friend class Joint; diff --git a/dart/dynamics/EllipsoidShape.hpp b/dart/dynamics/EllipsoidShape.hpp index c28717c8c8f83..c294cc5f79e0c 100644 --- a/dart/dynamics/EllipsoidShape.hpp +++ b/dart/dynamics/EllipsoidShape.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class EllipsoidShape : public Shape +class DART_API EllipsoidShape : public Shape { public: /// \brief Constructor. diff --git a/dart/dynamics/EndEffector.hpp b/dart/dynamics/EndEffector.hpp index b5c1da3a9a208..8c6c4779a872c 100644 --- a/dart/dynamics/EndEffector.hpp +++ b/dart/dynamics/EndEffector.hpp @@ -49,12 +49,13 @@ class Skeleton; class EndEffector; //============================================================================== -class Support final : public common::AspectWithStateAndVersionedProperties< - Support, - detail::SupportStateData, - detail::SupportPropertiesData, - EndEffector, - &detail::SupportUpdate> +class DART_API Support final + : public common::AspectWithStateAndVersionedProperties< + Support, + detail::SupportStateData, + detail::SupportPropertiesData, + EndEffector, + &detail::SupportUpdate> { public: DART_COMMON_ASPECT_STATE_PROPERTY_CONSTRUCTORS(Support) @@ -75,10 +76,10 @@ class Support final : public common::AspectWithStateAndVersionedProperties< }; //============================================================================== -class EndEffector final : public common::EmbedPropertiesOnTopOf< - EndEffector, - detail::EndEffectorProperties, - detail::EndEffectorCompositeBase> +class DART_API EndEffector final : public common::EmbedPropertiesOnTopOf< + EndEffector, + detail::EndEffectorProperties, + detail::EndEffectorCompositeBase> { public: friend class Skeleton; diff --git a/dart/dynamics/EulerJoint.hpp b/dart/dynamics/EulerJoint.hpp index d07157e5cc99d..00d7598e809ea 100644 --- a/dart/dynamics/EulerJoint.hpp +++ b/dart/dynamics/EulerJoint.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// class EulerJoint -class EulerJoint : public detail::EulerJointBase +class DART_API EulerJoint : public detail::EulerJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/FixedFrame.hpp b/dart/dynamics/FixedFrame.hpp index d4d2c5d121562..3337750ac8a02 100644 --- a/dart/dynamics/FixedFrame.hpp +++ b/dart/dynamics/FixedFrame.hpp @@ -47,7 +47,7 @@ namespace dynamics { /// its relative transform is set. However, classes that inherit the FixedFrame /// class may alter its relative transform or change what its parent Frame is. DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class FixedFrame +class DART_API FixedFrame : public virtual Frame, public virtual common::VersionCounter, public common::EmbedProperties diff --git a/dart/dynamics/FixedJacobianNode.hpp b/dart/dynamics/FixedJacobianNode.hpp index c2c54ee57fabb..dbb5b7f07d301 100644 --- a/dart/dynamics/FixedJacobianNode.hpp +++ b/dart/dynamics/FixedJacobianNode.hpp @@ -38,8 +38,9 @@ namespace dart { namespace dynamics { -class FixedJacobianNode : public detail::FixedJacobianNodeCompositeBase, - public AccessoryNode +class DART_API FixedJacobianNode + : public detail::FixedJacobianNodeCompositeBase, + public AccessoryNode { public: /// Set the current relative transform of this Fixed Frame diff --git a/dart/dynamics/Frame.hpp b/dart/dynamics/Frame.hpp index e1f43d9df3150..8230b5a5746e3 100644 --- a/dart/dynamics/Frame.hpp +++ b/dart/dynamics/Frame.hpp @@ -55,7 +55,7 @@ namespace dynamics { /// so-called "diamond problem". Because of that, the Entity's constructor will /// be called directly by the most derived class's constructor. DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class Frame : public virtual Entity +class DART_API Frame : public virtual Entity { public: friend class Entity; diff --git a/dart/dynamics/FreeJoint.hpp b/dart/dynamics/FreeJoint.hpp index 67f684c22e306..bba06ca32ceb9 100644 --- a/dart/dynamics/FreeJoint.hpp +++ b/dart/dynamics/FreeJoint.hpp @@ -45,7 +45,7 @@ namespace dart { namespace dynamics { /// class FreeJoint -class FreeJoint : public GenericJoint +class DART_API FreeJoint : public GenericJoint { public: friend class Skeleton; diff --git a/dart/dynamics/Group.hpp b/dart/dynamics/Group.hpp index 0327adb3f3278..02d32db771eda 100644 --- a/dart/dynamics/Group.hpp +++ b/dart/dynamics/Group.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class Group : public ReferentialSkeleton +class DART_API Group : public ReferentialSkeleton { public: /// Create a Group out of a set of BodyNodes. If _includeJoints is true, the diff --git a/dart/dynamics/HierarchicalIK.hpp b/dart/dynamics/HierarchicalIK.hpp index d912ad957cad8..ec847c896a744 100644 --- a/dart/dynamics/HierarchicalIK.hpp +++ b/dart/dynamics/HierarchicalIK.hpp @@ -60,7 +60,7 @@ typedef std::vector > > /// put into the IK modules' Problems. Any additional constraints or objectives /// that you want the HierarchicalIK to solve should be put directly into the /// HierarchicalIK's Problem. -class HierarchicalIK : public common::Subject +class DART_API HierarchicalIK : public common::Subject { public: /// Virtual destructor diff --git a/dart/dynamics/IkFast.hpp b/dart/dynamics/IkFast.hpp index 0644ef9a25f45..9aa9e1e875958 100644 --- a/dart/dynamics/IkFast.hpp +++ b/dart/dynamics/IkFast.hpp @@ -47,7 +47,7 @@ namespace dynamics { /// /// The detail of IkFast can be found here: /// http://openrave.org/docs/0.8.2/openravepy/ikfast/ -class IkFast : public InverseKinematics::Analytical +class DART_API IkFast : public InverseKinematics::Analytical { public: /// Inverse kinematics types supported by IkFast diff --git a/dart/dynamics/Inertia.hpp b/dart/dynamics/Inertia.hpp index d2bbd5014b122..df9195432ee0a 100644 --- a/dart/dynamics/Inertia.hpp +++ b/dart/dynamics/Inertia.hpp @@ -33,6 +33,8 @@ #ifndef DART_DYNAMICS_INERTIA_HPP_ #define DART_DYNAMICS_INERTIA_HPP_ +#include + #include #include @@ -40,7 +42,7 @@ namespace dart { namespace dynamics { -class Inertia +class DART_API Inertia { public: /// Enumeration for minimal inertia parameters diff --git a/dart/dynamics/InverseKinematics.hpp b/dart/dynamics/InverseKinematics.hpp index 1dafe924f4564..6eeec51c63578 100644 --- a/dart/dynamics/InverseKinematics.hpp +++ b/dart/dynamics/InverseKinematics.hpp @@ -75,7 +75,7 @@ const double DefaultIKLinearWeight = 1.0; /// safely cloned over to another JacobianNode, as long as every /// optimizer::Function that depends on the JacobianNode inherits the /// InverseKinematics::Function class and correctly overloads the clone function -class InverseKinematics : public common::Subject +class DART_API InverseKinematics : public common::Subject { public: /// Create an InverseKinematics module for a specified node diff --git a/dart/dynamics/JacobianNode.hpp b/dart/dynamics/JacobianNode.hpp index 5adb0f4ce60aa..a645fbda48054 100644 --- a/dart/dynamics/JacobianNode.hpp +++ b/dart/dynamics/JacobianNode.hpp @@ -51,7 +51,7 @@ class InverseKinematics; /// EndEffectors to both be used as references for IK modules. This is a pure /// abstract class. DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class JacobianNode : public virtual Frame, public Node +class DART_API JacobianNode : public virtual Frame, public Node { public: /// Virtual destructor diff --git a/dart/dynamics/Joint.hpp b/dart/dynamics/Joint.hpp index a49a787fdaae0..79f77d3fc1a67 100644 --- a/dart/dynamics/Joint.hpp +++ b/dart/dynamics/Joint.hpp @@ -59,9 +59,10 @@ class DegreeOfFreedom; /// class Joint DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class Joint : public virtual common::Subject, - public virtual common::VersionCounter, - public common::EmbedProperties +class DART_API Joint + : public virtual common::Subject, + public virtual common::VersionCounter, + public common::EmbedProperties { public: using CompositeProperties = common::Composite::Properties; diff --git a/dart/dynamics/LineSegmentShape.hpp b/dart/dynamics/LineSegmentShape.hpp index 5d611bd8a68ac..3e6b261331a89 100644 --- a/dart/dynamics/LineSegmentShape.hpp +++ b/dart/dynamics/LineSegmentShape.hpp @@ -42,7 +42,7 @@ namespace dynamics { /// can consist of a single line segment or many interconnected line segments. /// Note: LineSegmentShape may NOT be used as a collision shape for BodyNodes, /// but it may be used for visualization purposes. -class LineSegmentShape : public Shape +class DART_API LineSegmentShape : public Shape { public: /// Default constructor diff --git a/dart/dynamics/Linkage.hpp b/dart/dynamics/Linkage.hpp index f4d7487f46dc0..3e916e9fad841 100644 --- a/dart/dynamics/Linkage.hpp +++ b/dart/dynamics/Linkage.hpp @@ -51,7 +51,7 @@ namespace dynamics { /// so that they match whatever assembly they had the last time /// Linkage::reassemble() was called (or the assembly that they had when the /// Linkage was constructed, if Linkage::reassemble has never been called). -class Linkage : public ReferentialSkeleton +class DART_API Linkage : public ReferentialSkeleton { public: /// The Criteria class is used to specify how a Linkage should be constructed diff --git a/dart/dynamics/Marker.hpp b/dart/dynamics/Marker.hpp index 7cbf7e15a75b9..c42dc430346c6 100644 --- a/dart/dynamics/Marker.hpp +++ b/dart/dynamics/Marker.hpp @@ -45,10 +45,10 @@ namespace dynamics { class BodyNode; -class Marker final : public common::EmbedPropertiesOnTopOf< - Marker, - detail::MarkerProperties, - FixedJacobianNode> +class DART_API Marker final : public common::EmbedPropertiesOnTopOf< + Marker, + detail::MarkerProperties, + FixedJacobianNode> { public: using ConstraintType = detail::MarkerProperties::ConstraintType; diff --git a/dart/dynamics/MeshShape.hpp b/dart/dynamics/MeshShape.hpp index acf4b9e39c84b..e028d124419d7 100644 --- a/dart/dynamics/MeshShape.hpp +++ b/dart/dynamics/MeshShape.hpp @@ -44,7 +44,7 @@ namespace dart { namespace dynamics { -class MeshShape : public Shape +class DART_API MeshShape : public Shape { public: enum ColorMode diff --git a/dart/dynamics/MetaSkeleton.hpp b/dart/dynamics/MetaSkeleton.hpp index a83affc750222..589668f48e647 100644 --- a/dart/dynamics/MetaSkeleton.hpp +++ b/dart/dynamics/MetaSkeleton.hpp @@ -59,7 +59,7 @@ class DegreeOfFreedom; /// MetaSkeleton is a pure abstract base class that provides a common interface /// for obtaining data (such as Jacobians and Mass Matrices) from groups of /// BodyNodes. -class MetaSkeleton : public common::Subject +class DART_API MetaSkeleton : public common::Subject { public: using NameChangedSignal = common::Signal; diff --git a/dart/dynamics/Node.hpp b/dart/dynamics/Node.hpp index 41505d7db8ffe..4feda96f36eb1 100644 --- a/dart/dynamics/Node.hpp +++ b/dart/dynamics/Node.hpp @@ -76,8 +76,8 @@ class NodeDestructor final /// In most cases, when creating your own custom Node class, you will also want /// to inherit from AccessoryNode using CRTP. DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class Node : public virtual common::Subject, - public virtual common::VersionCounter +class DART_API Node : public virtual common::Subject, + public virtual common::VersionCounter { public: friend class BodyNode; diff --git a/dart/dynamics/PlanarJoint.hpp b/dart/dynamics/PlanarJoint.hpp index a175de33e9dc6..6256e7061b8df 100644 --- a/dart/dynamics/PlanarJoint.hpp +++ b/dart/dynamics/PlanarJoint.hpp @@ -44,7 +44,7 @@ namespace dynamics { /// First and second coordiantes represent translation along first and second /// translational axes, respectively. Third coordinate represents rotation /// along rotational axis. -class PlanarJoint : public detail::PlanarJointBase +class DART_API PlanarJoint : public detail::PlanarJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/PlaneShape.hpp b/dart/dynamics/PlaneShape.hpp index e50b2e3f23947..abb720fcf6168 100644 --- a/dart/dynamics/PlaneShape.hpp +++ b/dart/dynamics/PlaneShape.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// PlaneShape represents infinite plane has normal and offset as properties. -class PlaneShape : public Shape +class DART_API PlaneShape : public Shape { public: /// Constructor diff --git a/dart/dynamics/PointCloudShape.hpp b/dart/dynamics/PointCloudShape.hpp index b55d8b1bdaa6b..0f66c6db9ac9f 100644 --- a/dart/dynamics/PointCloudShape.hpp +++ b/dart/dynamics/PointCloudShape.hpp @@ -43,7 +43,7 @@ namespace dart { namespace dynamics { /// The PointCloudShape represents point cloud data. -class PointCloudShape : public Shape +class DART_API PointCloudShape : public Shape { public: enum ColorMode diff --git a/dart/dynamics/PointMass.hpp b/dart/dynamics/PointMass.hpp index e9c1f5f411c42..7582783355478 100644 --- a/dart/dynamics/PointMass.hpp +++ b/dart/dynamics/PointMass.hpp @@ -50,7 +50,7 @@ class SoftBodyNode; class PointMassNotifier; /// -class PointMass : public common::Subject +class DART_API PointMass : public common::Subject { public: friend class SoftBodyNode; diff --git a/dart/dynamics/PrismaticJoint.hpp b/dart/dynamics/PrismaticJoint.hpp index 7cfa1feafa611..c12006f06e98c 100644 --- a/dart/dynamics/PrismaticJoint.hpp +++ b/dart/dynamics/PrismaticJoint.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// class RevoluteJoint -class PrismaticJoint : public detail::PrismaticJointBase +class DART_API PrismaticJoint : public detail::PrismaticJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/PyramidShape.hpp b/dart/dynamics/PyramidShape.hpp index a6d661f81206d..efa93ed6d152d 100644 --- a/dart/dynamics/PyramidShape.hpp +++ b/dart/dynamics/PyramidShape.hpp @@ -46,7 +46,7 @@ namespace dynamics { /// to the apex is aligned with the Z-axis while the lateral and the /// longitudinal lengths of the base are aligned with the X-axis and Y-axis, /// respectively. -class PyramidShape : public Shape +class DART_API PyramidShape : public Shape { public: /// Constructor. diff --git a/dart/dynamics/ReferentialSkeleton.hpp b/dart/dynamics/ReferentialSkeleton.hpp index d128aa31ca132..e4046bd2da6f7 100644 --- a/dart/dynamics/ReferentialSkeleton.hpp +++ b/dart/dynamics/ReferentialSkeleton.hpp @@ -44,7 +44,7 @@ namespace dynamics { /// ReferentialSkeleton is a base class used to implement Linkage, Group, and /// other classes that are used to reference subsections of Skeletons. -class ReferentialSkeleton : public MetaSkeleton +class DART_API ReferentialSkeleton : public MetaSkeleton { public: /// Remove copy operator diff --git a/dart/dynamics/RevoluteJoint.hpp b/dart/dynamics/RevoluteJoint.hpp index c4581cd523663..5999cae161130 100644 --- a/dart/dynamics/RevoluteJoint.hpp +++ b/dart/dynamics/RevoluteJoint.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// class RevoluteJoint -class RevoluteJoint : public detail::RevoluteJointBase +class DART_API RevoluteJoint : public detail::RevoluteJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/ScrewJoint.hpp b/dart/dynamics/ScrewJoint.hpp index eee12d9a1e98e..d37747092d026 100644 --- a/dart/dynamics/ScrewJoint.hpp +++ b/dart/dynamics/ScrewJoint.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// class ScrewJoint -class ScrewJoint : public detail::ScrewJointBase +class DART_API ScrewJoint : public detail::ScrewJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/Shape.hpp b/dart/dynamics/Shape.hpp index 2480eed8b2662..75fca37113ca5 100644 --- a/dart/dynamics/Shape.hpp +++ b/dart/dynamics/Shape.hpp @@ -52,9 +52,9 @@ namespace dart { namespace dynamics { DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class Shape : public virtual common::Subject, - public virtual common::VersionCounter, - public common::Castable +class DART_API Shape : public virtual common::Subject, + public virtual common::VersionCounter, + public common::Castable { public: using VersionChangedSignal diff --git a/dart/dynamics/ShapeFrame.hpp b/dart/dynamics/ShapeFrame.hpp index 9c0ee2d30aa66..7d35ab127baca 100644 --- a/dart/dynamics/ShapeFrame.hpp +++ b/dart/dynamics/ShapeFrame.hpp @@ -48,10 +48,11 @@ namespace dart { namespace dynamics { //============================================================================== -class VisualAspect final : public common::AspectWithVersionedProperties< - VisualAspect, - detail::VisualAspectProperties, - ShapeFrame> +class DART_API VisualAspect final + : public common::AspectWithVersionedProperties< + VisualAspect, + detail::VisualAspectProperties, + ShapeFrame> { public: using Base = common::AspectWithVersionedProperties< @@ -111,10 +112,11 @@ class VisualAspect final : public common::AspectWithVersionedProperties< }; //============================================================================== -class CollisionAspect final : public common::AspectWithVersionedProperties< - CollisionAspect, - detail::CollisionAspectProperties, - ShapeFrame> +class DART_API CollisionAspect final + : public common::AspectWithVersionedProperties< + CollisionAspect, + detail::CollisionAspectProperties, + ShapeFrame> { public: CollisionAspect(const CollisionAspect&) = delete; @@ -129,10 +131,11 @@ class CollisionAspect final : public common::AspectWithVersionedProperties< }; //============================================================================== -class DynamicsAspect final : public common::AspectWithVersionedProperties< - DynamicsAspect, - detail::DynamicsAspectProperties, - ShapeFrame> +class DART_API DynamicsAspect final + : public common::AspectWithVersionedProperties< + DynamicsAspect, + detail::DynamicsAspectProperties, + ShapeFrame> { public: using Base = common::AspectWithVersionedProperties< @@ -187,9 +190,9 @@ class DynamicsAspect final : public common::AspectWithVersionedProperties< //============================================================================== DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class ShapeFrame : public virtual common::VersionCounter, - public detail::ShapeFrameCompositeBase, - public virtual Frame +class DART_API ShapeFrame : public virtual common::VersionCounter, + public detail::ShapeFrameCompositeBase, + public virtual Frame { public: friend class BodyNode; diff --git a/dart/dynamics/ShapeNode.hpp b/dart/dynamics/ShapeNode.hpp index 2e66e481b373a..ac5e6f908dbcf 100644 --- a/dart/dynamics/ShapeNode.hpp +++ b/dart/dynamics/ShapeNode.hpp @@ -46,7 +46,7 @@ class VisualAspect; class CollisionAspect; class DynamicsAspect; -class ShapeNode : public detail::ShapeNodeCompositeBase +class DART_API ShapeNode : public detail::ShapeNodeCompositeBase { public: friend class BodyNode; diff --git a/dart/dynamics/SharedLibraryIkFast.hpp b/dart/dynamics/SharedLibraryIkFast.hpp index 97cd7a77af75d..875a3dfc74b1a 100644 --- a/dart/dynamics/SharedLibraryIkFast.hpp +++ b/dart/dynamics/SharedLibraryIkFast.hpp @@ -44,7 +44,7 @@ namespace dynamics { /// /// The detail of IkFast can be found here: /// http://openrave.org/docs/0.8.2/openravepy/ikfast/ -class SharedLibraryIkFast : public IkFast +class DART_API SharedLibraryIkFast : public IkFast { public: /// Constructor diff --git a/dart/dynamics/SimpleFrame.hpp b/dart/dynamics/SimpleFrame.hpp index 2d31df42c1d3b..236b6a25bde41 100644 --- a/dart/dynamics/SimpleFrame.hpp +++ b/dart/dynamics/SimpleFrame.hpp @@ -48,7 +48,7 @@ namespace dynamics { /// (such as position, velocity, and acceleration) can be modified. Conversely, /// the SimpleFrame class is nothing but a simple abstract Frame whose /// properties can be arbitrarily set and modified by the user. -class SimpleFrame : public Detachable, public ShapeFrame +class DART_API SimpleFrame : public Detachable, public ShapeFrame { public: DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(SimpleFrame) diff --git a/dart/dynamics/Skeleton.hpp b/dart/dynamics/Skeleton.hpp index 9d4259802e24e..8785447f10a6d 100644 --- a/dart/dynamics/Skeleton.hpp +++ b/dart/dynamics/Skeleton.hpp @@ -54,10 +54,11 @@ namespace dynamics { /// class Skeleton DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class Skeleton : public virtual common::VersionCounter, - public MetaSkeleton, - public SkeletonSpecializedFor, - public detail::SkeletonAspectBase +class DART_API Skeleton + : public virtual common::VersionCounter, + public MetaSkeleton, + public SkeletonSpecializedFor, + public detail::SkeletonAspectBase { public: // Some of non-virtual functions of MetaSkeleton are hidden because of the diff --git a/dart/dynamics/SoftBodyNode.hpp b/dart/dynamics/SoftBodyNode.hpp index 877776c353323..5a4f23f3d41f3 100644 --- a/dart/dynamics/SoftBodyNode.hpp +++ b/dart/dynamics/SoftBodyNode.hpp @@ -42,7 +42,7 @@ namespace dynamics { /// /// This class is implementation of Sumit Jain and C. Karen Liu's paper: /// http://www.cc.gatech.edu/graphics/projects/Sumit/homepage/projects/softcontacts/index.html -class SoftBodyNode : public detail::SoftBodyNodeBase +class DART_API SoftBodyNode : public detail::SoftBodyNodeBase { public: using UniqueProperties = detail::SoftBodyNodeUniqueProperties; diff --git a/dart/dynamics/SoftMeshShape.hpp b/dart/dynamics/SoftMeshShape.hpp index a9212f93e94dc..75bbf8c98b6c1 100644 --- a/dart/dynamics/SoftMeshShape.hpp +++ b/dart/dynamics/SoftMeshShape.hpp @@ -44,7 +44,7 @@ namespace dynamics { class SoftBodyNode; // TODO(JS): Implement -class SoftMeshShape : public Shape +class DART_API SoftMeshShape : public Shape { public: friend class SoftBodyNode; diff --git a/dart/dynamics/SphereShape.hpp b/dart/dynamics/SphereShape.hpp index 404518ea756c9..7f9657120866d 100644 --- a/dart/dynamics/SphereShape.hpp +++ b/dart/dynamics/SphereShape.hpp @@ -38,7 +38,7 @@ namespace dart { namespace dynamics { -class SphereShape : public Shape +class DART_API SphereShape : public Shape { public: /// Constructor. diff --git a/dart/dynamics/TranslationalJoint.hpp b/dart/dynamics/TranslationalJoint.hpp index c02eda2efdbb8..63d4c4e555456 100644 --- a/dart/dynamics/TranslationalJoint.hpp +++ b/dart/dynamics/TranslationalJoint.hpp @@ -41,7 +41,7 @@ namespace dart { namespace dynamics { /// class TranslationalJoint -class TranslationalJoint : public GenericJoint +class DART_API TranslationalJoint : public GenericJoint { public: friend class Skeleton; diff --git a/dart/dynamics/TranslationalJoint2D.hpp b/dart/dynamics/TranslationalJoint2D.hpp index ce00ccf54c2bd..f2058164f6f86 100644 --- a/dart/dynamics/TranslationalJoint2D.hpp +++ b/dart/dynamics/TranslationalJoint2D.hpp @@ -44,7 +44,7 @@ namespace dynamics { /// /// First and second coordiantes represent the translations along first and /// second translational axes, respectively. -class TranslationalJoint2D : public detail::TranslationalJoint2DBase +class DART_API TranslationalJoint2D : public detail::TranslationalJoint2DBase { public: friend class Skeleton; diff --git a/dart/dynamics/UniversalJoint.hpp b/dart/dynamics/UniversalJoint.hpp index 96c0b81b54043..de6ea44a1ed52 100644 --- a/dart/dynamics/UniversalJoint.hpp +++ b/dart/dynamics/UniversalJoint.hpp @@ -39,7 +39,7 @@ namespace dart { namespace dynamics { /// class UniversalJoint -class UniversalJoint : public detail::UniversalJointBase +class DART_API UniversalJoint : public detail::UniversalJointBase { public: friend class Skeleton; diff --git a/dart/dynamics/VoxelGridShape.hpp b/dart/dynamics/VoxelGridShape.hpp index f480e8f5b3e00..a93246437ffc6 100644 --- a/dart/dynamics/VoxelGridShape.hpp +++ b/dart/dynamics/VoxelGridShape.hpp @@ -48,7 +48,7 @@ namespace dart { namespace dynamics { /// VoxelGridShape represents a probabilistic 3D occupancy voxel grid. -class VoxelGridShape : public Shape +class DART_API VoxelGridShape : public Shape { public: /// Constructor. diff --git a/dart/dynamics/WeldJoint.hpp b/dart/dynamics/WeldJoint.hpp index e2a185ae91a5e..1ae7f2796a22d 100644 --- a/dart/dynamics/WeldJoint.hpp +++ b/dart/dynamics/WeldJoint.hpp @@ -43,7 +43,7 @@ namespace dart { namespace dynamics { /// class WeldJoint -class WeldJoint : public ZeroDofJoint +class DART_API WeldJoint : public ZeroDofJoint { public: friend class Skeleton; diff --git a/dart/dynamics/ZeroDofJoint.hpp b/dart/dynamics/ZeroDofJoint.hpp index 6f64a2220c706..9eb9efc4e79d2 100644 --- a/dart/dynamics/ZeroDofJoint.hpp +++ b/dart/dynamics/ZeroDofJoint.hpp @@ -44,7 +44,7 @@ class BodyNode; class Skeleton; /// class ZeroDofJoint -class ZeroDofJoint : public Joint +class DART_API ZeroDofJoint : public Joint { public: struct Properties : Joint::Properties diff --git a/dart/dynamics/detail/EulerJointAspect.hpp b/dart/dynamics/detail/EulerJointAspect.hpp index d611c70767894..8adbfdbc434c6 100644 --- a/dart/dynamics/detail/EulerJointAspect.hpp +++ b/dart/dynamics/detail/EulerJointAspect.hpp @@ -53,7 +53,7 @@ enum class AxisOrder : int }; //============================================================================== -struct EulerJointUniqueProperties +struct DART_API EulerJointUniqueProperties { /// Euler angle order AxisOrder mAxisOrder; @@ -65,8 +65,8 @@ struct EulerJointUniqueProperties }; //============================================================================== -struct EulerJointProperties : GenericJoint::Properties, - EulerJointUniqueProperties +struct DART_API EulerJointProperties : GenericJoint::Properties, + EulerJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(EulerJointProperties) diff --git a/dart/dynamics/detail/JointAspect.hpp b/dart/dynamics/detail/JointAspect.hpp index adc2844bbfab6..4f449b7f9fe1d 100644 --- a/dart/dynamics/detail/JointAspect.hpp +++ b/dart/dynamics/detail/JointAspect.hpp @@ -112,7 +112,7 @@ enum ActuatorType const ActuatorType DefaultActuatorType = FORCE; -struct JointProperties +struct DART_API JointProperties { /// Joint name std::string mName; diff --git a/dart/dynamics/detail/PlanarJointAspect.hpp b/dart/dynamics/detail/PlanarJointAspect.hpp index bf87839988b7f..b5f6ba0732e97 100644 --- a/dart/dynamics/detail/PlanarJointAspect.hpp +++ b/dart/dynamics/detail/PlanarJointAspect.hpp @@ -62,7 +62,7 @@ enum class PlaneType : int /// it use mTransAxis1 and mTransAxis2. mRotAxis has no authority; it will /// always be recomputed from mTransAxis1 and mTransAxis2 when copying it into a /// PlanarJoint -struct PlanarJointUniqueProperties +struct DART_API PlanarJointUniqueProperties { /// Plane type PlaneType mPlaneType; diff --git a/dart/dynamics/detail/PrismaticJointAspect.hpp b/dart/dynamics/detail/PrismaticJointAspect.hpp index 851fbd0b809c2..3560e7eb0a347 100644 --- a/dart/dynamics/detail/PrismaticJointAspect.hpp +++ b/dart/dynamics/detail/PrismaticJointAspect.hpp @@ -47,7 +47,7 @@ class PrismaticJoint; namespace detail { //============================================================================== -struct PrismaticJointUniqueProperties +struct DART_API PrismaticJointUniqueProperties { Eigen::Vector3d mAxis; @@ -58,8 +58,9 @@ struct PrismaticJointUniqueProperties }; //============================================================================== -struct PrismaticJointProperties : GenericJoint::Properties, - PrismaticJointUniqueProperties +struct DART_API PrismaticJointProperties + : GenericJoint::Properties, + PrismaticJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(PrismaticJointProperties) diff --git a/dart/dynamics/detail/RevoluteJointAspect.hpp b/dart/dynamics/detail/RevoluteJointAspect.hpp index 246cc42ae96bb..677f89b715187 100644 --- a/dart/dynamics/detail/RevoluteJointAspect.hpp +++ b/dart/dynamics/detail/RevoluteJointAspect.hpp @@ -47,7 +47,7 @@ class RevoluteJoint; namespace detail { //============================================================================== -struct RevoluteJointUniqueProperties +struct DART_API RevoluteJointUniqueProperties { Eigen::Vector3d mAxis; @@ -58,8 +58,9 @@ struct RevoluteJointUniqueProperties }; //============================================================================== -struct RevoluteJointProperties : GenericJoint::Properties, - RevoluteJointUniqueProperties +struct DART_API RevoluteJointProperties + : GenericJoint::Properties, + RevoluteJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(RevoluteJointProperties) diff --git a/dart/dynamics/detail/ScrewJointAspect.hpp b/dart/dynamics/detail/ScrewJointAspect.hpp index 0de55457fa184..61550c1331995 100644 --- a/dart/dynamics/detail/ScrewJointAspect.hpp +++ b/dart/dynamics/detail/ScrewJointAspect.hpp @@ -47,7 +47,7 @@ class ScrewJoint; namespace detail { //============================================================================== -struct ScrewJointUniqueProperties +struct DART_API ScrewJointUniqueProperties { /// Rotational axis Eigen::Vector3d mAxis; @@ -63,8 +63,8 @@ struct ScrewJointUniqueProperties }; //============================================================================== -struct ScrewJointProperties : GenericJoint::Properties, - ScrewJointUniqueProperties +struct DART_API ScrewJointProperties : GenericJoint::Properties, + ScrewJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(ScrewJointProperties) diff --git a/dart/dynamics/detail/ShapeFrameAspect.hpp b/dart/dynamics/detail/ShapeFrameAspect.hpp index 7068cfed8c0a4..0097de9e47273 100644 --- a/dart/dynamics/detail/ShapeFrameAspect.hpp +++ b/dart/dynamics/detail/ShapeFrameAspect.hpp @@ -49,7 +49,7 @@ class ShapeFrame; namespace detail { -struct VisualAspectProperties +struct DART_API VisualAspectProperties { /// Color for the primitive shape Eigen::Vector4d mRGBA; @@ -75,7 +75,7 @@ struct VisualAspectProperties EIGEN_MAKE_ALIGNED_OPERATOR_NEW }; -struct CollisionAspectProperties +struct DART_API CollisionAspectProperties { /// This object is collidable if true bool mCollidable; @@ -87,7 +87,7 @@ struct CollisionAspectProperties virtual ~CollisionAspectProperties() = default; }; -struct DynamicsAspectProperties +struct DART_API DynamicsAspectProperties { /// Primary coefficient of friction double mFrictionCoeff; @@ -144,7 +144,7 @@ struct DynamicsAspectProperties virtual ~DynamicsAspectProperties() = default; }; -struct ShapeFrameProperties +struct DART_API ShapeFrameProperties { /// Pointer to a shape ShapePtr mShape; diff --git a/dart/dynamics/detail/SkeletonAspect.hpp b/dart/dynamics/detail/SkeletonAspect.hpp index b0e254184b3a9..4b9e05c696813 100644 --- a/dart/dynamics/detail/SkeletonAspect.hpp +++ b/dart/dynamics/detail/SkeletonAspect.hpp @@ -51,7 +51,7 @@ namespace detail { /// The Properties of this Skeleton which are independent of the components /// within the Skeleton, such as its BodyNodes and Joints. This does not /// include any Properties of the Skeleton's Aspects. -struct SkeletonAspectProperties +struct DART_API SkeletonAspectProperties { /// Name of the Skeleton std::string mName; diff --git a/dart/dynamics/detail/SoftBodyNodeAspect.hpp b/dart/dynamics/detail/SoftBodyNodeAspect.hpp index 3d80da2f02aec..9eafadeeb7472 100644 --- a/dart/dynamics/detail/SoftBodyNodeAspect.hpp +++ b/dart/dynamics/detail/SoftBodyNodeAspect.hpp @@ -54,7 +54,7 @@ namespace detail { class SoftBodyAspect; //============================================================================== -struct SoftBodyNodeUniqueState +struct DART_API SoftBodyNodeUniqueState { /// Array of States for PointMasses std::vector mPointStates; @@ -63,7 +63,7 @@ struct SoftBodyNodeUniqueState }; //============================================================================== -struct SoftBodyNodeUniqueProperties +struct DART_API SoftBodyNodeUniqueProperties { /// Spring stiffness for vertex deformation restoring spring force of the /// point masses @@ -105,8 +105,8 @@ struct SoftBodyNodeUniqueProperties }; //============================================================================== -struct SoftBodyNodeProperties : BodyNode::Properties, - SoftBodyNodeUniqueProperties +struct DART_API SoftBodyNodeProperties : BodyNode::Properties, + SoftBodyNodeUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(SoftBodyNodeProperties) diff --git a/dart/dynamics/detail/TranslationalJoint2DAspect.hpp b/dart/dynamics/detail/TranslationalJoint2DAspect.hpp index d1c0a0647b053..2378728a039f6 100644 --- a/dart/dynamics/detail/TranslationalJoint2DAspect.hpp +++ b/dart/dynamics/detail/TranslationalJoint2DAspect.hpp @@ -48,7 +48,7 @@ class TranslationalJoint2D; namespace detail { //============================================================================== -class TranslationalJoint2DUniqueProperties +class DART_API TranslationalJoint2DUniqueProperties { public: /// Constructor for pre-defined plane types. Defaults to the XY plane if @@ -113,8 +113,9 @@ class TranslationalJoint2DUniqueProperties }; //============================================================================== -struct TranslationalJoint2DProperties : GenericJoint::Properties, - TranslationalJoint2DUniqueProperties +struct DART_API TranslationalJoint2DProperties + : GenericJoint::Properties, + TranslationalJoint2DUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(TranslationalJoint2DProperties) diff --git a/dart/dynamics/detail/UniversalJointAspect.hpp b/dart/dynamics/detail/UniversalJointAspect.hpp index f0e2b87d34e4a..61bfe63af023a 100644 --- a/dart/dynamics/detail/UniversalJointAspect.hpp +++ b/dart/dynamics/detail/UniversalJointAspect.hpp @@ -47,7 +47,7 @@ class UniversalJoint; namespace detail { //============================================================================== -struct UniversalJointUniqueProperties +struct DART_API UniversalJointUniqueProperties { std::array mAxis; @@ -59,8 +59,9 @@ struct UniversalJointUniqueProperties }; //============================================================================== -struct UniversalJointProperties : GenericJoint::Properties, - UniversalJointUniqueProperties +struct DART_API UniversalJointProperties + : GenericJoint::Properties, + UniversalJointUniqueProperties { DART_DEFINE_ALIGNED_SHARED_OBJECT_CREATOR(UniversalJointProperties) diff --git a/dart/external/odelcpsolver/CMakeLists.txt b/dart/external/odelcpsolver/CMakeLists.txt index 1223df84340a1..b471ad7b05ee1 100644 --- a/dart/external/odelcpsolver/CMakeLists.txt +++ b/dart/external/odelcpsolver/CMakeLists.txt @@ -6,7 +6,7 @@ file(GLOB srcs "*.cpp") set(target_name ${PROJECT_NAME}-external-odelcpsolver) set(component_name external-odelcpsolver) -dart_add_library(${target_name} ${hdrs} ${srcs}) +dart_add_library(${target_name} STATIC ${hdrs} ${srcs}) target_include_directories(${target_name} PUBLIC $ diff --git a/dart/math/Geometry.hpp b/dart/math/Geometry.hpp index e8982b82de530..e0f9c3cba56ef 100644 --- a/dart/math/Geometry.hpp +++ b/dart/math/Geometry.hpp @@ -33,6 +33,8 @@ #ifndef DART_MATH_GEOMETRY_HPP_ #define DART_MATH_GEOMETRY_HPP_ +#include + #include #include @@ -44,114 +46,114 @@ namespace dart { namespace math { /// \brief -Eigen::Matrix3d makeSkewSymmetric(const Eigen::Vector3d& _v); +DART_API Eigen::Matrix3d makeSkewSymmetric(const Eigen::Vector3d& _v); /// \brief -Eigen::Vector3d fromSkewSymmetric(const Eigen::Matrix3d& _m); +DART_API Eigen::Vector3d fromSkewSymmetric(const Eigen::Matrix3d& _m); //------------------------------------------------------------------------------ /// \brief -Eigen::Quaterniond expToQuat(const Eigen::Vector3d& _v); +DART_API Eigen::Quaterniond expToQuat(const Eigen::Vector3d& _v); /// \brief -Eigen::Vector3d quatToExp(const Eigen::Quaterniond& _q); +DART_API Eigen::Vector3d quatToExp(const Eigen::Quaterniond& _q); /// \brief -Eigen::Vector3d rotatePoint( +DART_API Eigen::Vector3d rotatePoint( const Eigen::Quaterniond& _q, const Eigen::Vector3d& _pt); /// \brief -Eigen::Vector3d rotatePoint( +DART_API Eigen::Vector3d rotatePoint( const Eigen::Quaterniond& _q, double _x, double _y, double _z); /// \brief -Eigen::Matrix3d quatDeriv(const Eigen::Quaterniond& _q, int _el); +DART_API Eigen::Matrix3d quatDeriv(const Eigen::Quaterniond& _q, int _el); /// \brief -Eigen::Matrix3d quatSecondDeriv( +DART_API Eigen::Matrix3d quatSecondDeriv( const Eigen::Quaterniond& _q, int _el1, int _el2); //------------------------------------------------------------------------------ /// \brief Given Euler XYX angles, return a 3x3 rotation matrix, which is /// equivalent to RotX(angle(0)) * RotY(angle(1)) * RotX(angle(2)). -Eigen::Matrix3d eulerXYXToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerXYXToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerXYZ angles, return a 3x3 rotation matrix, which is /// equivalent to RotX(angle(0)) * RotY(angle(1)) * RotZ(angle(2)). -Eigen::Matrix3d eulerXYZToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerXYZToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerXZX angles, return a 3x3 rotation matrix, which is /// equivalent to RotX(angle(0)) * RotZ(angle(1)) * RotX(angle(2)). -Eigen::Matrix3d eulerXZXToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerXZXToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerXZY angles, return a 3x3 rotation matrix, which is /// equivalent to RotX(angle(0)) * RotZ(angle(1)) * RotY(angle(2)). -Eigen::Matrix3d eulerXZYToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerXZYToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerYXY angles, return a 3x3 rotation matrix, which is /// equivalent to RotY(angle(0)) * RotX(angle(1)) * RotY(angle(2)). -Eigen::Matrix3d eulerYXYToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerYXYToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerYXZ angles, return a 3x3 rotation matrix, which is /// equivalent to RotY(angle(0)) * RotX(angle(1)) * RotZ(angle(2)). -Eigen::Matrix3d eulerYXZToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerYXZToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerYZX angles, return a 3x3 rotation matrix, which is /// equivalent to RotY(angle(0)) * RotZ(angle(1)) * RotX(angle(2)). -Eigen::Matrix3d eulerYZXToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerYZXToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerYZY angles, return a 3x3 rotation matrix, which is /// equivalent to RotY(angle(0)) * RotZ(angle(1)) * RotY(angle(2)). -Eigen::Matrix3d eulerYZYToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerYZYToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerZXY angles, return a 3x3 rotation matrix, which is /// equivalent to RotZ(angle(0)) * RotX(angle(1)) * RotY(angle(2)). -Eigen::Matrix3d eulerZXYToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerZXYToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerZYX angles, return a 3x3 rotation matrix, which is /// equivalent to RotZ(angle(0)) * RotY(angle(1)) * RotX(angle(2)). /// singularity : angle[1] = -+ 0.5*PI -Eigen::Matrix3d eulerZYXToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerZYXToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerZXZ angles, return a 3x3 rotation matrix, which is /// equivalent to RotZ(angle(0)) * RotX(angle(1)) * RotZ(angle(2)). -Eigen::Matrix3d eulerZXZToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerZXZToMatrix(const Eigen::Vector3d& _angle); /// \brief Given EulerZYZ angles, return a 3x3 rotation matrix, which is /// equivalent to RotZ(angle(0)) * RotY(angle(1)) * RotZ(angle(2)). /// singularity : angle[1] = 0, PI -Eigen::Matrix3d eulerZYZToMatrix(const Eigen::Vector3d& _angle); +DART_API Eigen::Matrix3d eulerZYZToMatrix(const Eigen::Vector3d& _angle); //------------------------------------------------------------------------------ /// \brief get the Euler XYX angle from R -Eigen::Vector3d matrixToEulerXYX(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerXYX(const Eigen::Matrix3d& _R); /// \brief get the Euler XYZ angle from R -Eigen::Vector3d matrixToEulerXYZ(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerXYZ(const Eigen::Matrix3d& _R); ///// \brief get the Euler XZX angle from R // Eigen::Vector3d matrixToEulerXZX(const Eigen::Matrix3d& R); /// \brief get the Euler XZY angle from R -Eigen::Vector3d matrixToEulerXZY(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerXZY(const Eigen::Matrix3d& _R); ///// \brief get the Euler YXY angle from R // Eigen::Vector3d matrixToEulerYXY(const Eigen::Matrix3d& R); /// \brief get the Euler YXZ angle from R -Eigen::Vector3d matrixToEulerYXZ(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerYXZ(const Eigen::Matrix3d& _R); /// \brief get the Euler YZX angle from R -Eigen::Vector3d matrixToEulerYZX(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerYZX(const Eigen::Matrix3d& _R); ///// \brief get the Euler YZY angle from R // Eigen::Vector3d matrixToEulerYZY(const Eigen::Matrix3d& R); /// \brief get the Euler ZXY angle from R -Eigen::Vector3d matrixToEulerZXY(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerZXY(const Eigen::Matrix3d& _R); /// \brief get the Euler ZYX angle from R -Eigen::Vector3d matrixToEulerZYX(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d matrixToEulerZYX(const Eigen::Matrix3d& _R); ///// \brief get the Euler ZXZ angle from R // Eigen::Vector3d matrixToEulerZXZ(const Eigen::Matrix3d& R); @@ -161,35 +163,36 @@ Eigen::Vector3d matrixToEulerZYX(const Eigen::Matrix3d& _R); //------------------------------------------------------------------------------ /// \brief Exponential mapping -Eigen::Isometry3d expMap(const Eigen::Vector6d& _S); +DART_API Eigen::Isometry3d expMap(const Eigen::Vector6d& _S); /// \brief fast version of Exp(se3(s, 0)) /// \todo This expAngular() can be replaced by Eigen::AngleAxis() but we need /// to verify that they have exactly same functionality. /// See: https://github.com/dartsim/dart/issues/88 -Eigen::Isometry3d expAngular(const Eigen::Vector3d& _s); +DART_API Eigen::Isometry3d expAngular(const Eigen::Vector3d& _s); /// \brief Computes the Rotation matrix from a given expmap vector. -Eigen::Matrix3d expMapRot(const Eigen::Vector3d& _expmap); +DART_API Eigen::Matrix3d expMapRot(const Eigen::Vector3d& _expmap); /// \brief Computes the Jacobian of the expmap -Eigen::Matrix3d expMapJac(const Eigen::Vector3d& _expmap); +DART_API Eigen::Matrix3d expMapJac(const Eigen::Vector3d& _expmap); /// \brief Computes the time derivative of the expmap Jacobian. -Eigen::Matrix3d expMapJacDot( +DART_API Eigen::Matrix3d expMapJacDot( const Eigen::Vector3d& _expmap, const Eigen::Vector3d& _qdot); /// \brief computes the derivative of the Jacobian of the expmap wrt to _qi /// indexed dof; _qi \f$ \in \f$ {0,1,2} -Eigen::Matrix3d expMapJacDeriv(const Eigen::Vector3d& _expmap, int _qi); +DART_API Eigen::Matrix3d expMapJacDeriv( + const Eigen::Vector3d& _expmap, int _qi); /// \brief Log mapping /// \note When @f$|Log(R)| = @pi@f$, Exp(LogR(R) = Exp(-Log(R)). /// The implementation returns only the positive one. -Eigen::Vector3d logMap(const Eigen::Matrix3d& _R); +DART_API Eigen::Vector3d logMap(const Eigen::Matrix3d& _R); /// \brief Log mapping -Eigen::Vector6d logMap(const Eigen::Isometry3d& _T); +DART_API Eigen::Vector6d logMap(const Eigen::Isometry3d& _T); //------------------------------------------------------------------------------ /// \brief Rectify the rotation part so as that it satifies the orthogonality @@ -207,10 +210,11 @@ Eigen::Vector6d logMap(const Eigen::Isometry3d& _T); /// \brief adjoint mapping /// \note @f$Ad_TV = ( Rw@,, ~p @times Rw + Rv)@f$, /// where @f$T=(R,p)@in SE(3), @quad V=(w,v)@in se(3) @f$. -Eigen::Vector6d AdT(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); +DART_API Eigen::Vector6d AdT( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); /// \brief Get linear transformation matrix of Adjoint mapping -Eigen::Matrix6d getAdTMatrix(const Eigen::Isometry3d& T); +DART_API Eigen::Matrix6d getAdTMatrix(const Eigen::Isometry3d& T); /// Adjoint mapping for dynamic size Jacobian template @@ -256,14 +260,15 @@ typename Derived::PlainObject AdTJacFixed( } /// \brief Fast version of Ad([R 0; 0 1], V) -Eigen::Vector6d AdR(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); +DART_API Eigen::Vector6d AdR( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); /// \brief fast version of Ad(T, se3(w, 0)) -Eigen::Vector6d AdTAngular( +DART_API Eigen::Vector6d AdTAngular( const Eigen::Isometry3d& _T, const Eigen::Vector3d& _w); /// \brief fast version of Ad(T, se3(0, v)) -Eigen::Vector6d AdTLinear( +DART_API Eigen::Vector6d AdTLinear( const Eigen::Isometry3d& _T, const Eigen::Vector3d& _v); ///// \brief fast version of Ad([I p; 0 1], V) @@ -328,7 +333,8 @@ typename Derived::PlainObject adJac( } /// \brief fast version of Ad(Inv(T), V) -Eigen::Vector6d AdInvT(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); +DART_API Eigen::Vector6d AdInvT( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _V); /// Adjoint mapping for dynamic size Jacobian template @@ -386,22 +392,25 @@ typename Derived::PlainObject AdInvTJacFixed( // se3 AdInvR(const SE3& T, const se3& V); /// \brief Fast version of Ad(Inv([R 0; 0 1]), se3(0, v)) -Eigen::Vector6d AdInvRLinear( +DART_API Eigen::Vector6d AdInvRLinear( const Eigen::Isometry3d& _T, const Eigen::Vector3d& _v); /// \brief dual adjoint mapping /// \note @f$Ad^{@,*}_TF = ( R^T (m - p@times f)@,,~ R^T f)@f$, /// where @f$T=(R,p)@in SE(3), F=(m,f)@in se(3)^*@f$. -Eigen::Vector6d dAdT(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); +DART_API Eigen::Vector6d dAdT( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); ///// \brief fast version of Ad(Inv(T), dse3(Eigen_Vec3(0), F)) // dse3 dAdTLinear(const SE3& T, const Vec3& F); /// \brief fast version of dAd(Inv(T), F) -Eigen::Vector6d dAdInvT(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); +DART_API Eigen::Vector6d dAdInvT( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); /// \brief fast version of dAd(Inv([R 0; 0 1]), F) -Eigen::Vector6d dAdInvR(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); +DART_API Eigen::Vector6d dAdInvR( + const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); ///// \brief fast version of dAd(Inv(SE3(p)), dse3(Eigen_Vec3(0), F)) // dse3 dAdInvPLinear(const Vec3& p, const Vec3& F); @@ -409,7 +418,8 @@ Eigen::Vector6d dAdInvR(const Eigen::Isometry3d& _T, const Eigen::Vector6d& _F); /// \brief adjoint mapping /// \note @f$ad_X Y = ( w_X @times w_Y@,,~w_X @times v_Y - w_Y @times v_X),@f$, /// where @f$X=(w_X,v_X)@in se(3), @quad Y=(w_Y,v_Y)@in se(3) @f$. -Eigen::Vector6d ad(const Eigen::Vector6d& _X, const Eigen::Vector6d& _Y); +DART_API Eigen::Vector6d ad( + const Eigen::Vector6d& _X, const Eigen::Vector6d& _Y); /// \brief fast version of ad(se3(Eigen_Vec3(0), v), S) // Vec3 ad_Vec3_se3(const Vec3& v, const se3& S); @@ -420,14 +430,16 @@ Eigen::Vector6d ad(const Eigen::Vector6d& _X, const Eigen::Vector6d& _Y); /// \brief dual adjoint mapping /// \note @f$ad^{@,*}_V F = (m @times w + f @times v@,,~ f @times w),@f$ /// , where @f$F=(m,f)@in se^{@,*}(3), @quad V=(w,v)@in se(3) @f$. -Eigen::Vector6d dad(const Eigen::Vector6d& _s, const Eigen::Vector6d& _t); +DART_API Eigen::Vector6d dad( + const Eigen::Vector6d& _s, const Eigen::Vector6d& _t); /// \brief -Inertia transformInertia(const Eigen::Isometry3d& _T, const Inertia& _AI); +DART_API Inertia +transformInertia(const Eigen::Isometry3d& _T, const Inertia& _AI); /// Use the Parallel Axis Theorem to compute the moment of inertia of a body /// whose center of mass has been shifted from the origin -Eigen::Matrix3d parallelAxisTheorem( +DART_API Eigen::Matrix3d parallelAxisTheorem( const Eigen::Matrix3d& _original, const Eigen::Vector3d& _comShift, double _mass); @@ -442,29 +454,29 @@ enum AxisType /// Compute a rotation matrix from a vector. One axis of the rotated coordinates /// by the rotation matrix matches the input axis where the axis is specified /// by axisType. -Eigen::Matrix3d computeRotation( +DART_API Eigen::Matrix3d computeRotation( const Eigen::Vector3d& axis, AxisType axisType = AxisType::AXIS_X); /// Compute a transform from a vector and a position. The rotation of the result /// transform is computed by computeRotationMatrix(), and the translation is /// just the input translation. -Eigen::Isometry3d computeTransform( +DART_API Eigen::Isometry3d computeTransform( const Eigen::Vector3d& axis, const Eigen::Vector3d& translation, AxisType axisType = AxisType::AXIS_X); /// Generate frame given origin and z-axis DART_DEPRECATED(6.0) -Eigen::Isometry3d getFrameOriginAxisZ( +DART_API Eigen::Isometry3d getFrameOriginAxisZ( const Eigen::Vector3d& _origin, const Eigen::Vector3d& _axisZ); /// \brief Check if determinant of _R is equat to 1 and all the elements are not /// NaN values. -bool verifyRotation(const Eigen::Matrix3d& _R); +DART_API bool verifyRotation(const Eigen::Matrix3d& _R); /// \brief Check if determinant of the rotational part of _T is equat to 1 and /// all the elements are not NaN values. -bool verifyTransform(const Eigen::Isometry3d& _T); +DART_API bool verifyTransform(const Eigen::Isometry3d& _T); /// Compute the angle (in the range of -pi to +pi) which ignores any full /// rotations @@ -509,7 +521,7 @@ typedef common::aligned_vector SupportPolygon; /// and then compute their convex hull, which will take the form of a polgyon. /// _axis1 and _axis2 must both have unit length for this function to work /// correctly. -SupportPolygon computeSupportPolgyon( +DART_API SupportPolygon computeSupportPolgyon( const SupportGeometry& _geometry, const Eigen::Vector3d& _axis1 = Eigen::Vector3d::UnitX(), const Eigen::Vector3d& _axis2 = Eigen::Vector3d::UnitY()); @@ -518,18 +530,18 @@ SupportPolygon computeSupportPolgyon( /// std::vector which will have the same size as the returned /// SupportPolygon, and each entry will contain the original index of each point /// in the SupportPolygon -SupportPolygon computeSupportPolgyon( +DART_API SupportPolygon computeSupportPolgyon( std::vector& _originalIndices, const SupportGeometry& _geometry, const Eigen::Vector3d& _axis1 = Eigen::Vector3d::UnitX(), const Eigen::Vector3d& _axis2 = Eigen::Vector3d::UnitY()); /// Computes the convex hull of a set of 2D points -SupportPolygon computeConvexHull(const SupportPolygon& _points); +DART_API SupportPolygon computeConvexHull(const SupportPolygon& _points); /// Computes the convex hull of a set of 2D points and fills in _originalIndices /// with the original index of each entry in the returned SupportPolygon -SupportPolygon computeConvexHull( +DART_API SupportPolygon computeConvexHull( std::vector& _originalIndices, const SupportPolygon& _points); /// Generates a 3D convex hull given vertices and indices. @@ -549,7 +561,8 @@ computeConvexHull3D( const std::vector>& vertices, bool optimize = true); /// Compute the centroid of a polygon, assuming the polygon is a convex hull -Eigen::Vector2d computeCentroidOfHull(const SupportPolygon& _convexHull); +DART_API Eigen::Vector2d computeCentroidOfHull( + const SupportPolygon& _convexHull); /// Intersection_t is returned by the computeIntersection() function to indicate /// whether there was a valid intersection between the two line segments @@ -565,7 +578,7 @@ enum IntersectionResult /// Compute the intersection between a line segment that goes from a1 -> a2 and /// a line segment that goes from b1 -> b2. -IntersectionResult computeIntersection( +DART_API IntersectionResult computeIntersection( Eigen::Vector2d& _intersectionPoint, const Eigen::Vector2d& a1, const Eigen::Vector2d& a2, @@ -573,36 +586,36 @@ IntersectionResult computeIntersection( const Eigen::Vector2d& b2); /// Compute a 2D cross product -double cross(const Eigen::Vector2d& _v1, const Eigen::Vector2d& _v2); +DART_API double cross(const Eigen::Vector2d& _v1, const Eigen::Vector2d& _v2); /// Returns true if the point _p is inside the support polygon -bool isInsideSupportPolygon( +DART_API bool isInsideSupportPolygon( const Eigen::Vector2d& _p, const SupportPolygon& _support, bool _includeEdge = true); /// Returns the point which is closest to _p that also lays on the line segment /// that goes from _s1 -> _s2 -Eigen::Vector2d computeClosestPointOnLineSegment( +DART_API Eigen::Vector2d computeClosestPointOnLineSegment( const Eigen::Vector2d& _p, const Eigen::Vector2d& _s1, const Eigen::Vector2d& _s2); /// Returns the point which is closest to _p that also lays on the edge of the /// support polygon -Eigen::Vector2d computeClosestPointOnSupportPolygon( +DART_API Eigen::Vector2d computeClosestPointOnSupportPolygon( const Eigen::Vector2d& _p, const SupportPolygon& _support); /// Same as closestPointOnSupportPolygon, but also fills in _index1 and _index2 /// with the indices of the line segment -Eigen::Vector2d computeClosestPointOnSupportPolygon( +DART_API Eigen::Vector2d computeClosestPointOnSupportPolygon( std::size_t& _index1, std::size_t& _index2, const Eigen::Vector2d& _p, const SupportPolygon& _support); // Represents a bounding box with minimum and maximum coordinates. -class BoundingBox +class DART_API BoundingBox { public: EIGEN_MAKE_ALIGNED_OPERATOR_NEW diff --git a/dart/optimizer/Function.hpp b/dart/optimizer/Function.hpp index 90c3788f1a4cd..7eb1c455eb08d 100644 --- a/dart/optimizer/Function.hpp +++ b/dart/optimizer/Function.hpp @@ -33,6 +33,8 @@ #ifndef DART_OPTIMIZER_FUNCTION_HPP_ #define DART_OPTIMIZER_FUNCTION_HPP_ +#include + #include #include @@ -42,7 +44,7 @@ namespace dart { namespace optimizer { -class Function +class DART_API Function { public: /// Constructor diff --git a/dart/optimizer/GenericMultiObjectiveProblem.hpp b/dart/optimizer/GenericMultiObjectiveProblem.hpp index 2ebe9c2390be4..cf4762b17ceaf 100644 --- a/dart/optimizer/GenericMultiObjectiveProblem.hpp +++ b/dart/optimizer/GenericMultiObjectiveProblem.hpp @@ -45,7 +45,7 @@ namespace dart { namespace optimizer { -class GenericMultiObjectiveProblem : public MultiObjectiveProblem +class DART_API GenericMultiObjectiveProblem : public MultiObjectiveProblem { public: /// Constructor diff --git a/dart/optimizer/GradientDescentSolver.hpp b/dart/optimizer/GradientDescentSolver.hpp index 13ab0e5683f55..5e98377a88344 100644 --- a/dart/optimizer/GradientDescentSolver.hpp +++ b/dart/optimizer/GradientDescentSolver.hpp @@ -46,7 +46,7 @@ namespace optimizer { /// objective function and assigned weights) to solve nonlinear problems. Note /// that this is not a good option for Problems with difficult constraint /// functions that need to be solved exactly. -class GradientDescentSolver : public Solver +class DART_API GradientDescentSolver : public Solver { public: static const std::string Type; diff --git a/dart/optimizer/MultiObjectiveProblem.hpp b/dart/optimizer/MultiObjectiveProblem.hpp index e61c68f6f4b16..2c508b91cc3f9 100644 --- a/dart/optimizer/MultiObjectiveProblem.hpp +++ b/dart/optimizer/MultiObjectiveProblem.hpp @@ -44,7 +44,7 @@ namespace dart { namespace optimizer { -class MultiObjectiveProblem +class DART_API MultiObjectiveProblem { public: /// Constructor diff --git a/dart/optimizer/MultiObjectiveSolver.hpp b/dart/optimizer/MultiObjectiveSolver.hpp index f948728bd045a..5db4520ff013b 100644 --- a/dart/optimizer/MultiObjectiveSolver.hpp +++ b/dart/optimizer/MultiObjectiveSolver.hpp @@ -54,7 +54,7 @@ class MultiObjectiveProblem; /// for various problem types. This base class allows the different /// MultiObjectiveSolver implementations to be swapped out with each other /// quickly and easily to help with testing, benchmarking, and experimentation. -class MultiObjectiveSolver +class DART_API MultiObjectiveSolver { public: /// The MultiObjectiveSolver::Properties class contains Solver parameters that diff --git a/dart/optimizer/Population.hpp b/dart/optimizer/Population.hpp index 1fab564add055..c0469754e4250 100644 --- a/dart/optimizer/Population.hpp +++ b/dart/optimizer/Population.hpp @@ -46,7 +46,7 @@ namespace optimizer { class MultiObjectiveProblem; -class Population +class DART_API Population { public: /// Constructor diff --git a/dart/optimizer/Problem.hpp b/dart/optimizer/Problem.hpp index fdb95062d8785..5ee028e912b71 100644 --- a/dart/optimizer/Problem.hpp +++ b/dart/optimizer/Problem.hpp @@ -33,6 +33,8 @@ #ifndef DART_OPTIMIZER_PROBLEM_HPP_ #define DART_OPTIMIZER_PROBLEM_HPP_ +#include + #include #include @@ -45,7 +47,7 @@ namespace dart { namespace optimizer { /// \brief class Problem -class Problem +class DART_API Problem { public: /// \brief Constructor diff --git a/dart/optimizer/Solver.hpp b/dart/optimizer/Solver.hpp index c1cb526ed173c..85017abae5571 100644 --- a/dart/optimizer/Solver.hpp +++ b/dart/optimizer/Solver.hpp @@ -33,6 +33,8 @@ #ifndef DART_OPTIMIZER_SOLVER_HPP_ #define DART_OPTIMIZER_SOLVER_HPP_ +#include + #include #include @@ -49,7 +51,7 @@ class Problem; /// problem types. This base class allows the different Solver implementations /// to be swapped out with each other quickly and easily to help with testing, /// benchmarking, and experimentation. -class Solver +class DART_API Solver { public: /// The Solver::Properties class contains Solver parameters that are common diff --git a/dart/simulation/Recording.hpp b/dart/simulation/Recording.hpp index b6c5351833f1b..fc58bd89845ec 100644 --- a/dart/simulation/Recording.hpp +++ b/dart/simulation/Recording.hpp @@ -54,7 +54,7 @@ class Skeleton; namespace simulation { /// \brief class Recording -class Recording +class DART_API Recording { public: /// \brief Create Recording with a list of skeletons diff --git a/dart/simulation/World.hpp b/dart/simulation/World.hpp index dc65bd0ca927b..4ea77f476e6bd 100644 --- a/dart/simulation/World.hpp +++ b/dart/simulation/World.hpp @@ -83,7 +83,7 @@ DART_COMMON_DECLARE_SHARED_WEAK(World) /// class World DART_DECLARE_CLASS_WITH_VIRTUAL_BASE_BEGIN -class World : public virtual common::Subject +class DART_API World : public virtual common::Subject { public: using NameChangedSignal = common::Signal