aboutsummaryrefslogtreecommitdiff
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
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
-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
-rw-r--r--ports/ignition-math4/CONTROL5
-rw-r--r--ports/ignition-math4/portfile.cmake7
-rw-r--r--ports/ignition-modularscripts/CONTROL3
-rw-r--r--ports/ignition-modularscripts/ignition_modular_library.cmake106
-rw-r--r--ports/ignition-modularscripts/portfile.cmake8
10 files changed, 194 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)
diff --git a/ports/ignition-math4/CONTROL b/ports/ignition-math4/CONTROL
new file mode 100644
index 000000000..44aa0c01a
--- /dev/null
+++ b/ports/ignition-math4/CONTROL
@@ -0,0 +1,5 @@
+Source: ignition-math4
+Version: 4.0.0
+Homepage: https://ignitionrobotics.org/libs/math
+Build-Depends: ignition-cmake0
+Description: Math API for robotic applications
diff --git a/ports/ignition-math4/portfile.cmake b/ports/ignition-math4/portfile.cmake
new file mode 100644
index 000000000..a6a00c849
--- /dev/null
+++ b/ports/ignition-math4/portfile.cmake
@@ -0,0 +1,7 @@
+include(vcpkg_common_functions)
+
+include(${CURRENT_INSTALLED_DIR}/share/ignitionmodularscripts/ignition_modular_library.cmake)
+
+ignition_modular_library(NAME math
+ VERSION "4.0.0"
+ SHA512 09023b559e7e544e628131189f3a7f57a9b73868f66f81e5ce1a353092940949973e1753f18ead8f655ad88c0e1d1bf51bbf63163760694aab7a97a4c0f6d519)
diff --git a/ports/ignition-modularscripts/CONTROL b/ports/ignition-modularscripts/CONTROL
new file mode 100644
index 000000000..fa8a222cd
--- /dev/null
+++ b/ports/ignition-modularscripts/CONTROL
@@ -0,0 +1,3 @@
+Source: ignition-modularscripts
+Version: 2019-08-20
+Description: Vcpkg helpers to package ignition libraries
diff --git a/ports/ignition-modularscripts/ignition_modular_library.cmake b/ports/ignition-modularscripts/ignition_modular_library.cmake
new file mode 100644
index 000000000..8800353d1
--- /dev/null
+++ b/ports/ignition-modularscripts/ignition_modular_library.cmake
@@ -0,0 +1,106 @@
+
+function(ignition_modular_build_library NAME MAJOR_VERSION SOURCE_PATH)
+ vcpkg_configure_cmake(
+ SOURCE_PATH ${SOURCE_PATH}
+ PREFER_NINJA
+ OPTIONS -DBUILD_TESTING=OFF
+ )
+
+ vcpkg_install_cmake()
+
+ vcpkg_fixup_cmake_targets(CONFIG_PATH "lib/cmake/ignition-${NAME}${MAJOR_VERSION}")
+
+ file(GLOB_RECURSE CMAKE_RELEASE_FILES
+ "${CURRENT_PACKAGES_DIR}/lib/cmake/ignition-${NAME}${MAJOR_VERSION}/*")
+
+ file(COPY ${CMAKE_RELEASE_FILES} DESTINATION
+ "${CURRENT_PACKAGES_DIR}/share/ignition-${NAME}${MAJOR_VERSION}/")
+
+ # Remove debug files
+ file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include
+ ${CURRENT_PACKAGES_DIR}/debug/lib/cmake
+ ${CURRENT_PACKAGES_DIR}/debug/share)
+
+ # Post-build test for cmake libraries
+ vcpkg_test_cmake(PACKAGE_NAME ignition-${NAME}${MAJOR_VERSION})
+
+ # Find the relevant license file and install it
+ if(EXISTS "${SOURCE_PATH}/LICENSE")
+ set(LICENSE_PATH "${SOURCE_PATH}/LICENSE")
+ elseif(EXISTS "${SOURCE_PATH}/README.md")
+ set(LICENSE_PATH "${SOURCE_PATH}/README.md")
+ endif()
+ file(INSTALL ${LICENSE_PATH} DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright)
+endfunction()
+
+## # ignition_modular_library
+##
+## Download and build a library from the Ignition Robotics project ( https://ignitionrobotics.org/ ).
+##
+## ## Usage:
+## ```cmake
+## ignition_modular_library(NAME <name>
+## VERSION <version>
+## SHA512 <sha512>
+## [REF <ref>]
+## [HEAD_REF <head_ref>]
+## [PATCHES <patches>])
+## ```
+##
+## ## Parameters:
+## ### NAME
+## The name of the specific ignition library, i.e. `cmake` for `ignition-cmake0`, `math` for `ignition-math4`.
+##
+## ### VERSION
+## The complete version number.
+##
+## ### SHA512
+## The SHA512 hash that should match the downloaded archive. This is forwarded to the `vcpkg_from_bitbucket` command.
+##
+## ### REF
+## Reference to the tag of the desired release. This is forwarded to the `vcpkg_from_bitbucket` command.
+## If not specified, defaults to `ignition-${NAME}${MAJOR_VERSION}_${VERSION}`.
+##
+## ### HEAD_REF
+## Reference (tag) to the desired release. This is forwarded to the `vcpkg_from_bitbucket` command.
+## If not specified, defaults to `ign-${NAME}${MAJOR_VERSION}`.
+##
+## ### PATCHES
+## A list of patches to be applied to the extracted sources.
+## This is forwarded to the `vcpkg_from_bitbucket` command.
+##
+## ## Examples:
+##
+## * [ignition-cmake0](https://github.com/Microsoft/vcpkg/blob/master/ports/ignition-cmake0/portfile.cmake)
+## * [ignition-math4](https://github.com/Microsoft/vcpkg/blob/master/ports/ignition-math4/portfile.cmake)
+function(ignition_modular_library)
+ set(oneValueArgs NAME VERSION SHA512 REF HEAD_REF)
+ set(multiValueArgs PATCHES)
+ cmake_parse_arguments(IML "" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
+
+ string(REPLACE "." ";" IML_VERSION_LIST ${IML_VERSION})
+ list(GET IML_VERSION_LIST 0 IML_MAJOR_VERSION)
+
+ # If the REF option is omitted, use the canonical one
+ if(NOT DEFINED IML_REF)
+ set(IML_REF "ignition-${IML_NAME}${IML_MAJOR_VERSION}_${IML_VERSION}")
+ endif()
+
+ # If the HEAD_REF option is omitted, use the canonical one
+ if(NOT DEFINED IML_HEAD_REF)
+ set(IML_HEAD_REF "ign-${IML_NAME}${IML_MAJOR_VERSION}")
+ endif()
+
+ # Download library from bitbucket, to support also the --head option
+ vcpkg_from_bitbucket(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO ignitionrobotics/ign-${IML_NAME}
+ REF ${IML_REF}
+ SHA512 ${IML_SHA512}
+ HEAD_REF ${IML_HEAD_REF}
+ PATCHES ${IML_PATCHES}
+ )
+
+ # Build library
+ ignition_modular_build_library(${IML_NAME} ${IML_MAJOR_VERSION} ${SOURCE_PATH})
+endfunction()
diff --git a/ports/ignition-modularscripts/portfile.cmake b/ports/ignition-modularscripts/portfile.cmake
new file mode 100644
index 000000000..509240d7d
--- /dev/null
+++ b/ports/ignition-modularscripts/portfile.cmake
@@ -0,0 +1,8 @@
+file(COPY
+ ${CMAKE_CURRENT_LIST_DIR}/ignition_modular_library.cmake
+ DESTINATION
+ ${CURRENT_PACKAGES_DIR}/share/ignitionmodularscripts
+)
+file(WRITE ${CURRENT_PACKAGES_DIR}/share/ignitionmodularscripts/copyright "")
+
+set(VCPKG_POLICY_EMPTY_PACKAGE enabled)