aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLyle Tafoya <lyle.tafoya@gmail.com>2018-11-07 01:50:54 +0000
committerRobert Schumacher <roschuma@microsoft.com>2018-11-06 17:50:54 -0800
commitab0212d6930011041683f7acc016323bd4ecf4fe (patch)
tree3f967b08ee451a8211a5e892ce20d83e1ecdcba9
parentf194e98593ac5638a15cb4b9675f52e63d2ffaf3 (diff)
downloadvcpkg-ab0212d6930011041683f7acc016323bd4ecf4fe.tar.gz
vcpkg-ab0212d6930011041683f7acc016323bd4ecf4fe.zip
Fixes #4464 GLFW3 dynamic build failure on Linux (#4467)
* Fixes #4464 GLFW3 dynamic build failure on Linux * [glfw3] Use vcpkg_from_github and remove outdated patch * [glfw3] Note dependency on xcursor
-rw-r--r--ports/glfw3/portfile.cmake74
1 files changed, 27 insertions, 47 deletions
diff --git a/ports/glfw3/portfile.cmake b/ports/glfw3/portfile.cmake
index 0df468bc3..dcc7da89d 100644
--- a/ports/glfw3/portfile.cmake
+++ b/ports/glfw3/portfile.cmake
@@ -1,30 +1,22 @@
include(vcpkg_common_functions)
-set(SOURCE_PATH ${CURRENT_BUILDTREES_DIR}/src/glfw-3.2.1)
-vcpkg_download_distfile(ARCHIVE
- URLS "https://github.com/glfw/glfw/releases/download/3.2.1/glfw-3.2.1.zip"
- FILENAME "glfw-3.2.1.zip"
- SHA512 73dd6d4a8d28a2b423f0fb25489659c1a845182b7ef09848d4f442cdc489528aea90f43ac84aeedb9d2301c4487f39782b647ee4959e67e83babb838372b980c
+
+vcpkg_from_github(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO glfw/glfw
+ REF 3.2.1
+ SHA512 c7921f993b9a99b3b9421fefadb039cd475c42d85f5b5a35d7c5401c70491349bb885a02fd31e527de06a8b40d9d49a1fdb92c964e13c04ae092c6b98eb491dc
+ HEAD_REF master
+ PATCHES move-cmake-min-req.patch
)
-vcpkg_extract_source_archive(${ARCHIVE})
-if(NOT EXISTS ${SOURCE_PATH}/patch-config.stamp)
- message(STATUS "Patching src/glfw3Config.cmake.in")
- file(READ ${SOURCE_PATH}/src/glfw3Config.cmake.in CONFIG)
- string(REPLACE "\"@GLFW_LIB_NAME@\"" "NAMES @GLFW_LIB_NAME@ @GLFW_LIB_NAME@dll"
- CONFIG ${CONFIG}
- )
- #string(REPLACE "@PACKAGE_CMAKE_INSTALL_PREFIX@" "@PACKAGE_CMAKE_INSTALL_PREFIX@/../.."
- # CONFIG ${CONFIG}
- #)
- file(WRITE ${SOURCE_PATH}/src/glfw3Config.cmake.in "${CONFIG}")
- file(APPEND ${SOURCE_PATH}/src/glfw3Config.cmake.in "set(GLFW3_LIBRARIES \${GLFW3_LIBRARY})\n")
- file(WRITE ${SOURCE_PATH}/patch-config.stamp)
-endif()
+if(VCPKG_CMAKE_SYSTEM_NAME AND NOT VCPKG_CMAKE_SYSTEM_NAME STREQUAL "WindowsStore")
+ message(
+"GLFW3 currently requires the following libraries from the system package manager:
+ xinerama
+ xcursor
-vcpkg_apply_patches(
- SOURCE_PATH ${SOURCE_PATH}
- PATCHES ${CMAKE_CURRENT_LIST_DIR}/move-cmake-min-req.patch
-)
+These can be installed on Ubuntu systems via sudo apt install libxinerama-dev libxcursor-dev")
+endif()
vcpkg_configure_cmake(
SOURCE_PATH ${SOURCE_PATH}
@@ -32,40 +24,28 @@ vcpkg_configure_cmake(
-DGLFW_BUILD_EXAMPLES=OFF
-DGLFW_BUILD_TESTS=OFF
-DGLFW_BUILD_DOCS=OFF
- -DPACKAGE_CMAKE_INSTALL_PREFIX=\${CMAKE_CURRENT_LIST_DIR}/../..
)
vcpkg_install_cmake()
-file(MAKE_DIRECTORY ${CURRENT_PACKAGES_DIR}/share)
-file(RENAME ${CURRENT_PACKAGES_DIR}/lib/cmake/glfw3 ${CURRENT_PACKAGES_DIR}/share/glfw3)
-file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/lib/cmake)
-file(READ ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets.cmake _contents)
-set(pattern "get_filename_component(_IMPORT_PREFIX \"\${_IMPORT_PREFIX}\" PATH)\n")
-string(REPLACE "${pattern}${pattern}${pattern}" "${pattern}${pattern}" _contents "${_contents}")
-file(WRITE ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets.cmake "${_contents}")
-
-file(READ ${CURRENT_PACKAGES_DIR}/debug/lib/cmake/glfw3/glfw3Targets-debug.cmake _contents)
-string(REPLACE "\${_IMPORT_PREFIX}" "\${_IMPORT_PREFIX}/debug" _contents "${_contents}")
-file(WRITE ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets-debug.cmake "${_contents}")
-file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/lib/cmake)
+vcpkg_fixup_cmake_targets(CONFIG_PATH lib/cmake/glfw3)
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
if(VCPKG_LIBRARY_LINKAGE STREQUAL dynamic)
- file(MAKE_DIRECTORY ${CURRENT_PACKAGES_DIR}/bin ${CURRENT_PACKAGES_DIR}/debug/bin)
- file(RENAME ${CURRENT_PACKAGES_DIR}/lib/glfw3.dll ${CURRENT_PACKAGES_DIR}/bin/glfw3.dll)
- file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/glfw3.dll ${CURRENT_PACKAGES_DIR}/debug/bin/glfw3.dll)
- foreach(_conf release
- debug)
- file(READ ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets-${_conf}.cmake _contents)
- string(REPLACE "lib/glfw3.dll" "bin/glfw3.dll" _contents "${_contents}")
- file(WRITE ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets-${_conf}.cmake "${_contents}")
- endforeach()
-
+ if(EXISTS ${CURRENT_PACKAGES_DIR}/lib/glfw3.dll OR EXISTS ${CURRENT_PACKAGES_DIR}/debug/lib/glfw3.dll)
+ file(MAKE_DIRECTORY ${CURRENT_PACKAGES_DIR}/bin ${CURRENT_PACKAGES_DIR}/debug/bin)
+ file(RENAME ${CURRENT_PACKAGES_DIR}/lib/glfw3.dll ${CURRENT_PACKAGES_DIR}/bin/glfw3.dll)
+ file(RENAME ${CURRENT_PACKAGES_DIR}/debug/lib/glfw3.dll ${CURRENT_PACKAGES_DIR}/debug/bin/glfw3.dll)
+ foreach(_conf release debug)
+ file(READ ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets-${_conf}.cmake _contents)
+ string(REPLACE "lib/glfw3.dll" "bin/glfw3.dll" _contents "${_contents}")
+ file(WRITE ${CURRENT_PACKAGES_DIR}/share/glfw3/glfw3Targets-${_conf}.cmake "${_contents}")
+ endforeach()
+ endif()
endif()
file(COPY ${SOURCE_PATH}/COPYING.txt DESTINATION ${CURRENT_PACKAGES_DIR}/share/glfw3)
file(RENAME ${CURRENT_PACKAGES_DIR}/share/glfw3/COPYING.txt ${CURRENT_PACKAGES_DIR}/share/glfw3/copyright)
-vcpkg_copy_pdbs()
+vcpkg_copy_pdbs()