aboutsummaryrefslogtreecommitdiff
path: root/ports/ignition-cmake0
diff options
context:
space:
mode:
authorSilvio Traversaro <silvio.traversaro@iit.it>2019-09-04 00:29:29 +0200
committerVictor Romero <romerosanchezv@gmail.com>2019-09-03 15:29:29 -0700
commit75a2b65447b9af04988478b4ddccad75f4e858ec (patch)
tree6c2b78028616e73f07f10821f6b329a6fce31ae2 /ports/ignition-cmake0
parentb8f0e2c8c69dc1990e175b1eecfb3a40db71a46a (diff)
downloadvcpkg-75a2b65447b9af04988478b4ddccad75f4e858ec.tar.gz
vcpkg-75a2b65447b9af04988478b4ddccad75f4e858ec.zip
Add support for writing ports of Ignition Robotics libraries and ports for ignition-cmake0 and ignition-math4 (#7781)
* Add ignition-modularscript port Modeled after the qt5-modularscript port, this port just contain ignition_modular_library, an helper CMake function to simplify the process of writing port of C++ libraries developed by the Ignition Robotics project ( https://ignitionrobotics.org ). * Add ignition-cmake0 port * Add ignition-math4 port
Diffstat (limited to 'ports/ignition-cmake0')
-rw-r--r--ports/ignition-cmake0/CONTROL7
-rw-r--r--ports/ignition-cmake0/do-not-compile-gtest.patch14
-rw-r--r--ports/ignition-cmake0/portfile.cmake24
-rw-r--r--ports/ignition-cmake0/support-arm64.patch17
-rw-r--r--ports/ignition-cmake0/usage3
5 files changed, 65 insertions, 0 deletions
diff --git a/ports/ignition-cmake0/CONTROL b/ports/ignition-cmake0/CONTROL
new file mode 100644
index 000000000..5f427ffef
--- /dev/null
+++ b/ports/ignition-cmake0/CONTROL
@@ -0,0 +1,7 @@
+Source: ignition-cmake0
+Version: 0.6.2
+Homepage: https://ignitionrobotics.org/libs/cmake
+Description: CMake helper functions for building robotic applications
+Build-Depends: ignition-modularscripts
+
+
diff --git a/ports/ignition-cmake0/do-not-compile-gtest.patch b/ports/ignition-cmake0/do-not-compile-gtest.patch
new file mode 100644
index 000000000..7c20a0dbe
--- /dev/null
+++ b/ports/ignition-cmake0/do-not-compile-gtest.patch
@@ -0,0 +1,14 @@
+diff --git a/cmake/IgnConfigureBuild.cmake b/cmake/IgnConfigureBuild.cmake
+--- a/cmake/IgnConfigureBuild.cmake
++++ b/cmake/IgnConfigureBuild.cmake
+@@ -109,7 +109,9 @@
+ # Add all the source code directories
+ add_subdirectory(src)
+ add_subdirectory(include)
+- add_subdirectory(test)
++ if(BUILD_TESTING)
++ add_subdirectory(test)
++ endif()
+
+
+ #--------------------------------------
diff --git a/ports/ignition-cmake0/portfile.cmake b/ports/ignition-cmake0/portfile.cmake
new file mode 100644
index 000000000..efb6d2f0f
--- /dev/null
+++ b/ports/ignition-cmake0/portfile.cmake
@@ -0,0 +1,24 @@
+include(vcpkg_common_functions)
+
+include(${CURRENT_INSTALLED_DIR}/share/ignitionmodularscripts/ignition_modular_library.cmake)
+
+set(PACKAGE_VERSION "0.6.1")
+
+ignition_modular_library(NAME cmake
+ VERSION ${PACKAGE_VERSION}
+ REF "ignition-cmake_${PACKAGE_VERSION}"
+ SHA512 fcd3ad6b5289697c4928c71b820e2adaa758c730f52cba3f8cc714e44ca0c9f04f432ae5b98b5f258c4851c4666740b58066a25c55ff3a6de975cd8a57991b6b
+ # Ensure that gtest is not compiled (backport of https://bitbucket.org/ignitionrobotics/ign-cmake/pull-requests/163)
+ PATCHES do-not-compile-gtest.patch
+ # Support for ARM64 (backport of https://bitbucket.org/ignitionrobotics/ign-cmake/pull-requests/168)
+ support-arm64.patch
+ )
+
+# Permit empty include folder
+set(VCPKG_POLICY_EMPTY_INCLUDE_FOLDER enabled)
+
+# Remove unneccessary directory, as ignition-cmake is a pure CMake package
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib ${CURRENT_PACKAGES_DIR}/debug)
+
+# Install custom usage
+configure_file(${CMAKE_CURRENT_LIST_DIR}/usage ${CURRENT_PACKAGES_DIR}/share/${PORT}/usage @ONLY)
diff --git a/ports/ignition-cmake0/support-arm64.patch b/ports/ignition-cmake0/support-arm64.patch
new file mode 100644
index 000000000..aba99ba35
--- /dev/null
+++ b/ports/ignition-cmake0/support-arm64.patch
@@ -0,0 +1,17 @@
+diff -r 8a976a308d77 -r 1bea7874cfec cmake/IgnSetCompilerFlags.cmake
+--- a/cmake/IgnSetCompilerFlags.cmake
++++ b/cmake/IgnSetCompilerFlags.cmake
+@@ -279,13 +279,6 @@
+ # Don't pull in the Windows min/max macros
+ add_definitions(-DNOMINMAX)
+
+- if (MSVC AND CMAKE_SIZEOF_VOID_P EQUAL 8)
+- # Not needed if a proper cmake generator (-G "...Win64") is passed
+- # to cmake. Enable as a second measure to work around bug
+- # http://www.cmake.org/Bug/print_bug_page.php?bug_id=11240
+- set(CMAKE_SHARED_LINKER_FLAGS "/machine:x64")
+- endif()
+-
+ if(USE_IGN_RECOMMENDED_FLAGS)
+
+ # Gy: Prevent errors caused by multiply-defined symbols
diff --git a/ports/ignition-cmake0/usage b/ports/ignition-cmake0/usage
new file mode 100644
index 000000000..66da98102
--- /dev/null
+++ b/ports/ignition-cmake0/usage
@@ -0,0 +1,3 @@
+The package ignition-cmake0 provides CMake integration:
+
+ find_package(ignition-cmake0 CONFIG REQUIRED)