aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHartmut Kaiser <hartmut.kaiser@gmail.com>2017-05-21 06:03:24 -0500
committerHartmut Kaiser <hartmut.kaiser@gmail.com>2017-05-23 07:59:32 -0500
commitc3924adea45ccf19f89708ddaa184d6ae7d716c2 (patch)
treed6950895e3383f4466b0a76bf2af3fae80160e10
parentdfaa7a831c914447cb9413bc82bd3ea2ee72594b (diff)
downloadvcpkg-c3924adea45ccf19f89708ddaa184d6ae7d716c2.tar.gz
vcpkg-c3924adea45ccf19f89708ddaa184d6ae7d716c2.zip
Adding support for HPX (https://github.com/STEllAR-GROUP/hpx)
-rw-r--r--ports/hpx/CONTROL5
-rw-r--r--ports/hpx/portfile.cmake88
2 files changed, 93 insertions, 0 deletions
diff --git a/ports/hpx/CONTROL b/ports/hpx/CONTROL
new file mode 100644
index 000000000..e6bfb7e1e
--- /dev/null
+++ b/ports/hpx/CONTROL
@@ -0,0 +1,5 @@
+Source: hpx
+Version: 1.0.0
+Build-Depends: boost, hwloc
+Description: The C++ Standards Library for Concurrency and Parallelism
+ HPX is a C++ Standards Library for Concurrency and Parallelism. It implements all of the corresponding facilities as defined by the C++ Standard. Additionally, in HPX we implement functionalities proposed as part of the ongoing C++ standardization process. We also extend the C++ Standard APIs to the distributed case.
diff --git a/ports/hpx/portfile.cmake b/ports/hpx/portfile.cmake
new file mode 100644
index 000000000..369e9ec13
--- /dev/null
+++ b/ports/hpx/portfile.cmake
@@ -0,0 +1,88 @@
+include(vcpkg_common_functions)
+
+if(NOT VCPKG_LIBRARY_LINKAGE STREQUAL dynamic)
+ message(FATAL_ERROR "HPX can be built with dynamic linking only")
+endif()
+
+set(SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/hpx_1.0.0)
+
+vcpkg_download_distfile(ARCHIVE
+ URLS "http://stellar-group.org/files/hpx_1.0.0.tar.gz"
+ FILENAME "hpx_1.0.0.tar.gz"
+ SHA512 42c155654f118bff34b48d929b1732fd56126b8fd3e7657b5bd2f84275288ddf538572ed1152883c4aed5e9683de53b9b1f1c3613e5092e7bd1a5e165bed606d
+)
+vcpkg_extract_source_archive(${ARCHIVE})
+
+# apply hotfix to enable building with vcpkg
+vcpkg_download_distfile(DIFF
+ URLS "http://stellar-group.org/files/build-system-changes-to-make-HPX-compile-when-built-with-vcpkg.diff"
+ FILENAME "build-system-changes-to-make-HPX-compile-when-built-with-vcpkg.diff"
+ SHA512 ceceb84b54bf564b7b9258063454084207538a2bd212f7f65503c6638914eb3c093076e4303369639ef9b34812a2c8ed363c08bbdf5a39cc5d49f720a376af75
+)
+vcpkg_apply_patches(SOURCE_PATH ${SOURCE_PATH} PATCHES ${DIFF})
+
+SET(BOOST_PATH "${CURRENT_INSTALLED_DIR}/share/boost")
+SET(HWLOC_PATH "${CURRENT_INSTALLED_DIR}/share/hwloc")
+
+vcpkg_configure_cmake(
+ SOURCE_PATH ${SOURCE_PATH}
+ OPTIONS
+ -DBOOST_ROOT=${BOOST_PATH}
+ -DHWLOC_ROOT=${HWLOC_ROOT}
+ -DHPX_WITH_VCPKG=ON
+ -DHPX_WITH_HWLOC=ON
+ -DHPX_WITH_TESTS=OFF
+ -DHPX_WITH_EXAMPLES=OFF
+ -DHPX_WITH_TOOLS=OFF
+ -DHPX_WITH_RUNTIME=OFF
+)
+
+vcpkg_install_cmake()
+
+file(INSTALL
+ ${SOURCE_PATH}/LICENSE_1_0.txt
+ DESTINATION ${CURRENT_PACKAGES_DIR}/share/hpx RENAME copyright)
+
+# post build cleanup
+file(GLOB __hpx_cmakes ${CURRENT_PACKAGES_DIR}/lib/cmake/HPX/*.*)
+foreach(__hpx_cmake ${__hpx_cmakes})
+ file(COPY ${__hpx_cmake} DESTINATION ${CURRENT_PACKAGES_DIR}/share/hpx/cmake)
+ file(REMOVE ${__hpx_cmake})
+endforeach()
+
+file(GLOB __hpx_dlls ${CURRENT_PACKAGES_DIR}/lib/*.dll)
+foreach(__hpx_dll ${__hpx_dlls})
+ file(COPY ${__hpx_dll} DESTINATION ${CURRENT_PACKAGES_DIR}/bin)
+ file(REMOVE ${__hpx_dll})
+endforeach()
+
+file(GLOB __hpx_dlls ${CURRENT_PACKAGES_DIR}/lib/hpx/*.dll)
+foreach(__hpx_dll ${__hpx_dlls})
+ file(COPY ${__hpx_dll} DESTINATION ${CURRENT_PACKAGES_DIR}/bin/hpx)
+ file(REMOVE ${__hpx_dll})
+endforeach()
+
+file(GLOB __hpx_dlls ${CURRENT_PACKAGES_DIR}/debug/lib/*.dll)
+foreach(__hpx_dll ${__hpx_dlls})
+ file(COPY ${__hpx_dll} DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin)
+ file(REMOVE ${__hpx_dll})
+endforeach()
+
+file(GLOB __hpx_dlls ${CURRENT_PACKAGES_DIR}/debug/lib/hpx/*.dll)
+foreach(__hpx_dll ${__hpx_dlls})
+ file(COPY ${__hpx_dll} DESTINATION ${CURRENT_PACKAGES_DIR}/debug/bin/hpx)
+ file(REMOVE ${__hpx_dll})
+endforeach()
+
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib/bazel)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib/cmake)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib/pkgconfig)
+
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/share)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/lib/bazel)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/lib/cmake)
+file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig)
+
+vcpkg_copy_pdbs()
+