aboutsummaryrefslogtreecommitdiff
path: root/ports/libffi
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2019-11-22 09:47:40 -0800
committerGitHub <noreply@github.com>2019-11-22 09:47:40 -0800
commit45f4b820e5743b89bca3508ba2028cdd5d8bbd17 (patch)
treef874a8c4a7392309bdbb86447288597ec0a4a281 /ports/libffi
parent62d67d3bf8eeff1afa8009041fd08b8822676b7b (diff)
parent8831e8f25f1ff6546ee4a5291b91d599421637b3 (diff)
downloadvcpkg-45f4b820e5743b89bca3508ba2028cdd5d8bbd17.tar.gz
vcpkg-45f4b820e5743b89bca3508ba2028cdd5d8bbd17.zip
Merge branch 'master' into vcpkg_nuget
Diffstat (limited to 'ports/libffi')
-rw-r--r--ports/libffi/CMakeLists.txt11
-rw-r--r--ports/libffi/CONTROL2
-rw-r--r--ports/libffi/libffiConfig.cmake.in7
-rw-r--r--ports/libffi/portfile.cmake17
4 files changed, 29 insertions, 8 deletions
diff --git a/ports/libffi/CMakeLists.txt b/ports/libffi/CMakeLists.txt
index 29e14bdac..ae57e7b1a 100644
--- a/ports/libffi/CMakeLists.txt
+++ b/ports/libffi/CMakeLists.txt
@@ -122,10 +122,21 @@ endif()
add_library(libffi ${FFI_SOURCES})
install(TARGETS libffi
+ EXPORT ${PROJECT_NAME}Targets
RUNTIME DESTINATION bin
ARCHIVE DESTINATION lib
LIBRARY DESTINATION lib)
+include(CMakePackageConfigHelpers)
+
+configure_package_config_file(${PROJECT_NAME}Config.cmake.in
+ "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake"
+ INSTALL_DESTINATION share/${PROJECT_NAME})
+install(FILES "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}Config.cmake"
+ DESTINATION share/${PROJECT_NAME})
+install(EXPORT ${PROJECT_NAME}Targets
+ DESTINATION share/${PROJECT_NAME})
+
if(NOT FFI_SKIP_HEADERS)
install(FILES
${CMAKE_BINARY_DIR}/include/ffi.h
diff --git a/ports/libffi/CONTROL b/ports/libffi/CONTROL
index b393491e1..2fb2301a9 100644
--- a/ports/libffi/CONTROL
+++ b/ports/libffi/CONTROL
@@ -1,4 +1,4 @@
Source: libffi
-Version: 3.1-5
+Version: 3.1-6
Homepage: https://github.com/libffi/libffi
Description: Portable, high level programming interface to various calling conventions
diff --git a/ports/libffi/libffiConfig.cmake.in b/ports/libffi/libffiConfig.cmake.in
new file mode 100644
index 000000000..ebdf1488a
--- /dev/null
+++ b/ports/libffi/libffiConfig.cmake.in
@@ -0,0 +1,7 @@
+@PACKAGE_INIT@
+
+include(CMakeFindDependencyMacro)
+
+if(NOT TARGET libffi)
+ include("${CMAKE_CURRENT_LIST_DIR}/libffiTargets.cmake")
+endif()
diff --git a/ports/libffi/portfile.cmake b/ports/libffi/portfile.cmake
index bbb4daf83..f023521c8 100644
--- a/ports/libffi/portfile.cmake
+++ b/ports/libffi/portfile.cmake
@@ -17,6 +17,7 @@ vcpkg_from_github(
)
file(COPY ${CMAKE_CURRENT_LIST_DIR}/CMakeLists.txt DESTINATION ${SOURCE_PATH})
+file(COPY ${CMAKE_CURRENT_LIST_DIR}/libffiConfig.cmake.in DESTINATION ${SOURCE_PATH})
vcpkg_configure_cmake(
SOURCE_PATH ${SOURCE_PATH}
@@ -29,14 +30,16 @@ vcpkg_configure_cmake(
vcpkg_install_cmake()
vcpkg_copy_pdbs()
+vcpkg_fixup_cmake_targets()
-if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
- vcpkg_apply_patches(
- SOURCE_PATH ${CURRENT_PACKAGES_DIR}/include
- PATCHES
- ${CMAKE_CURRENT_LIST_DIR}/auto-define-static-macro.patch
- )
-endif()
+file(READ ${CURRENT_PACKAGES_DIR}/include/ffi.h FFI_H)
+string(REPLACE "/* *know* they are going to link with the static library. */"
+"/* *know* they are going to link with the static library. */
+
+#define FFI_BUILDING
+
+" FFI_H "${FFI_H}")
+file(WRITE ${CURRENT_PACKAGES_DIR}/include/ffi.h "${FFI_H}")
file(COPY ${SOURCE_PATH}/LICENSE DESTINATION ${CURRENT_PACKAGES_DIR}/share/libffi)
file(RENAME ${CURRENT_PACKAGES_DIR}/share/libffi/LICENSE ${CURRENT_PACKAGES_DIR}/share/libffi/copyright)