summaryrefslogtreecommitdiff
path: root/CMakeLists.txt
diff options
context:
space:
mode:
authorJames Cowgill <james410@cowgill.org.uk>2015-06-19 19:36:32 +0100
committerJames Cowgill <james410@cowgill.org.uk>2015-06-19 19:36:32 +0100
commit60dd192ab7ea37d36baa02884678b306e7cae9e1 (patch)
tree060f30c816a8e498e719c7bcb5b20cc856c73018 /CMakeLists.txt
parent4d8b8114076109872733099793207b0fca7bfb87 (diff)
Imported Upstream version 3.1.1
Diffstat (limited to 'CMakeLists.txt')
-rw-r--r--CMakeLists.txt351
1 files changed, 246 insertions, 105 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 0a80900..efb559c 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -1,15 +1,23 @@
project(GLFW C)
-cmake_minimum_required(VERSION 2.8)
+cmake_minimum_required(VERSION 2.8.9)
+
+if (CMAKE_VERSION VERSION_EQUAL "3.0" OR CMAKE_VERSION VERSION_GREATER "3.0")
+ # Until all major package systems have moved to CMake 3,
+ # we stick with the older INSTALL_NAME_DIR mechanism
+ cmake_policy(SET CMP0042 OLD)
+endif()
set(GLFW_VERSION_MAJOR "3")
-set(GLFW_VERSION_MINOR "0")
-set(GLFW_VERSION_PATCH "4")
+set(GLFW_VERSION_MINOR "1")
+set(GLFW_VERSION_PATCH "1")
set(GLFW_VERSION_EXTRA "")
set(GLFW_VERSION "${GLFW_VERSION_MAJOR}.${GLFW_VERSION_MINOR}")
set(GLFW_VERSION_FULL "${GLFW_VERSION}.${GLFW_VERSION_PATCH}${GLFW_VERSION_EXTRA}")
set(LIB_SUFFIX "" CACHE STRING "Takes an empty string or 64. Directory where lib will be installed: lib or lib64")
+set_property(GLOBAL PROPERTY USE_FOLDERS ON)
+
option(BUILD_SHARED_LIBS "Build shared libraries" OFF)
option(GLFW_BUILD_EXAMPLES "Build the GLFW example programs" ON)
option(GLFW_BUILD_TESTS "Build the GLFW test programs" ON)
@@ -26,10 +34,16 @@ if (APPLE)
option(GLFW_BUILD_UNIVERSAL "Build GLFW as a Universal Binary" OFF)
option(GLFW_USE_CHDIR "Make glfwInit chdir to Contents/Resources" ON)
option(GLFW_USE_MENUBAR "Populate the menu bar on first window creation" ON)
+ option(GLFW_USE_RETINA "Use the full resolution of Retina displays" ON)
else()
option(GLFW_USE_EGL "Use EGL for context creation" OFF)
endif()
+if (UNIX AND NOT APPLE)
+ option(GLFW_USE_WAYLAND "Use Wayland for context creation (implies EGL as well)" OFF)
+ option(GLFW_USE_MIR "Use Mir for context creation (implies EGL as well)" OFF)
+endif()
+
if (MSVC)
option(USE_MSVC_RUNTIME_LIBRARY_DLL "Use MSVC runtime library DLL" ON)
endif()
@@ -38,6 +52,12 @@ if (BUILD_SHARED_LIBS)
set(_GLFW_BUILD_DLL 1)
endif()
+if (GLFW_USE_WAYLAND)
+ set(GLFW_USE_EGL ON)
+elseif (GLFW_USE_MIR)
+ set(GLFW_USE_EGL ON)
+endif()
+
if (GLFW_USE_EGL)
set(GLFW_CLIENT_LIBRARY "opengl" CACHE STRING
"The client library to use; one of opengl, glesv1 or glesv2")
@@ -52,7 +72,7 @@ if (GLFW_USE_EGL)
message(FATAL_ERROR "Unsupported client library")
endif()
- set(CMAKE_MODULE_PATH ${PROJECT_SOURCE_DIR}/CMake/modules)
+ set(CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/CMake/modules")
find_package(EGL REQUIRED)
if (NOT _GLFW_USE_OPENGL)
@@ -115,12 +135,39 @@ if (MSVC)
endif()
endif()
+if (MINGW)
+ # Enable link-time exploit mitigation features enabled by default on MSVC
+
+ include(CheckCCompilerFlag)
+
+ # Compatibility with data execution prevention (DEP)
+ set(CMAKE_REQUIRED_FLAGS "-Wl,--nxcompat")
+ check_c_compiler_flag("" _GLFW_HAS_DEP)
+ if (_GLFW_HAS_DEP)
+ set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--nxcompat ${CMAKE_SHARED_LINKER_FLAGS}")
+ endif()
+
+ # Compatibility with address space layout randomization (ASLR)
+ set(CMAKE_REQUIRED_FLAGS "-Wl,--dynamicbase")
+ check_c_compiler_flag("" _GLFW_HAS_ASLR)
+ if (_GLFW_HAS_ASLR)
+ set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--dynamicbase ${CMAKE_SHARED_LINKER_FLAGS}")
+ endif()
+
+ # Compatibility with 64-bit address space layout randomization (ASLR)
+ set(CMAKE_REQUIRED_FLAGS "-Wl,--high-entropy-va")
+ check_c_compiler_flag("" _GLFW_HAS_64ASLR)
+ if (_GLFW_HAS_64ASLR)
+ set(CMAKE_SHARED_LINKER_FLAGS "-Wl,--high-entropy-va ${CMAKE_SHARED_LINKER_FLAGS}")
+ endif()
+endif()
+
#--------------------------------------------------------------------
# Detect and select backend APIs
#--------------------------------------------------------------------
if (WIN32)
set(_GLFW_WIN32 1)
- message(STATUS "Using Win32 for window creation")
+ message(STATUS "Using Win32 for window creation")
if (GLFW_USE_EGL)
set(_GLFW_EGL 1)
@@ -135,8 +182,16 @@ elseif (APPLE)
set(_GLFW_NSGL 1)
message(STATUS "Using NSGL for context creation")
elseif (UNIX)
- set(_GLFW_X11 1)
- message(STATUS "Using X11 for window creation")
+ if (GLFW_USE_WAYLAND)
+ set(_GLFW_WAYLAND 1)
+ message(STATUS "Using Wayland for window creation")
+ elseif (GLFW_USE_MIR)
+ set(_GLFW_MIR 1)
+ message(STATUS "Using Mir for window creation")
+ else()
+ set(_GLFW_X11 1)
+ message(STATUS "Using X11 for window creation")
+ endif()
if (GLFW_USE_EGL)
set(_GLFW_EGL 1)
@@ -153,12 +208,8 @@ endif()
# Use Win32 for window creation
#--------------------------------------------------------------------
if (_GLFW_WIN32)
- # The DLL links against winmm; the static library loads it
- # That way, both code paths receive testing
- if (BUILD_SHARED_LIBS)
- set(_GLFW_NO_DLOAD_WINMM 1)
- list(APPEND glfw_LIBRARIES winmm)
- endif()
+
+ list(APPEND glfw_PKG_LIBS "-lgdi32")
if (GLFW_USE_DWM_SWAP_INTERVAL)
set(_GLFW_USE_DWM_SWAP_INTERVAL 1)
@@ -171,16 +222,20 @@ if (_GLFW_WIN32)
# the inclusion of stddef.h (by glfw3.h), which is itself included before
# win32_platform.h. We define them here until a saner solution can be found
# NOTE: MinGW-w64 and Visual C++ do /not/ need this hack.
- add_definitions(-DUNICODE)
- add_definitions(-DWINVER=0x0501)
+ if (${CMAKE_C_COMPILER_ID} STREQUAL "GNU")
+ add_definitions(-DUNICODE -DWINVER=0x0501)
+ endif()
endif()
#--------------------------------------------------------------------
# Use WGL for context creation
#--------------------------------------------------------------------
if (_GLFW_WGL)
- list(APPEND glfw_INCLUDE_DIRS ${OPENGL_INCLUDE_DIR})
- list(APPEND glfw_LIBRARIES ${OPENGL_gl_LIBRARY})
+
+ list(APPEND glfw_PKG_LIBS "-lopengl32")
+
+ list(APPEND glfw_INCLUDE_DIRS "${OPENGL_INCLUDE_DIR}")
+ list(APPEND glfw_LIBRARIES "${OPENGL_gl_LIBRARY}")
endif()
#--------------------------------------------------------------------
@@ -190,13 +245,13 @@ if (_GLFW_X11)
find_package(X11 REQUIRED)
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} x11")
+ list(APPEND glfw_PKG_DEPS "x11")
# Set up library and include paths
- list(APPEND glfw_INCLUDE_DIRS ${X11_X11_INCLUDE_PATH})
- list(APPEND glfw_LIBRARIES ${X11_X11_LIB} ${CMAKE_THREAD_LIBS_INIT})
+ list(APPEND glfw_INCLUDE_DIRS "${X11_X11_INCLUDE_PATH}")
+ list(APPEND glfw_LIBRARIES "${X11_X11_LIB}" "${CMAKE_THREAD_LIBS_INIT}")
if (UNIX AND NOT APPLE)
- list(APPEND glfw_LIBRARIES ${RT_LIBRARY})
+ list(APPEND glfw_LIBRARIES "${RT_LIBRARY}")
endif()
# Check for XRandR (modern resolution switching and gamma control)
@@ -204,61 +259,125 @@ if (_GLFW_X11)
message(FATAL_ERROR "The RandR library and headers were not found")
endif()
- list(APPEND glfw_INCLUDE_DIRS ${X11_Xrandr_INCLUDE_PATH})
- list(APPEND glfw_LIBRARIES ${X11_Xrandr_LIB})
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} xrandr")
+ list(APPEND glfw_INCLUDE_DIRS "${X11_Xrandr_INCLUDE_PATH}")
+ list(APPEND glfw_LIBRARIES "${X11_Xrandr_LIB}")
+ list(APPEND glfw_PKG_DEPS "xrandr")
- # Check for XInput (high-resolution cursor motion)
- if (NOT X11_Xinput_FOUND)
- message(FATAL_ERROR "The XInput library and headers were not found")
+ # Check for Xinerama (legacy multi-monitor support)
+ if (NOT X11_Xinerama_FOUND)
+ message(FATAL_ERROR "The Xinerama library and headers were not found")
endif()
- list(APPEND glfw_INCLUDE_DIRS ${X11_Xinput_INCLUDE_PATH})
+ list(APPEND glfw_INCLUDE_DIRS "${X11_Xinerama_INCLUDE_PATH}")
+ list(APPEND glfw_LIBRARIES "${X11_Xinerama_LIB}")
+ list(APPEND glfw_PKG_DEPS "xinerama")
- if (X11_Xinput_LIB)
- list(APPEND glfw_LIBRARIES ${X11_Xinput_LIB})
- else()
- # Backwards compatibility (bug in CMake 2.8.7)
- list(APPEND glfw_LIBRARIES Xi)
- endif()
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} xi")
+ # Check for XInput (high-resolution cursor motion)
+ if (X11_Xinput_FOUND)
+ list(APPEND glfw_INCLUDE_DIRS "${X11_Xinput_INCLUDE_PATH}")
+ list(APPEND glfw_PKG_DEPS "xi")
+
+ if (X11_Xinput_LIB)
+ list(APPEND glfw_LIBRARIES "${X11_Xinput_LIB}")
+ else()
+ # Backwards compatibility (bug in CMake 2.8.7)
+ list(APPEND glfw_LIBRARIES Xi)
+ endif()
- # Check for Xf86VidMode (fallback gamma control)
- if (NOT X11_xf86vmode_FOUND)
- message(FATAL_ERROR "The Xf86VidMode library and headers were not found")
+ set(_GLFW_HAS_XINPUT TRUE)
endif()
- list(APPEND glfw_INCLUDE_DIRS ${X11_xf86vmode_INCLUDE_PATH})
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} xxf86vm")
+ # Check for Xf86VidMode (fallback gamma control)
+ if (X11_xf86vmode_FOUND)
+ list(APPEND glfw_INCLUDE_DIRS "${X11_xf86vmode_INCLUDE_PATH}")
+ list(APPEND glfw_PKG_DEPS "xxf86vm")
+
+ if (X11_Xxf86vm_LIB)
+ list(APPEND glfw_LIBRARIES "${X11_Xxf86vm_LIB}")
+ else()
+ # Backwards compatibility (see CMake bug 0006976)
+ list(APPEND glfw_LIBRARIES Xxf86vm)
+ endif()
- if (X11_Xxf86vm_LIB)
- list(APPEND glfw_LIBRARIES ${X11_Xxf86vm_LIB})
- else()
- # Backwards compatibility (see CMake bug 0006976)
- list(APPEND glfw_LIBRARIES Xxf86vm)
+ set(_GLFW_HAS_XF86VM TRUE)
endif()
# Check for Xkb (X keyboard extension)
if (NOT X11_Xkb_FOUND)
message(FATAL_ERROR "The X keyboard extension headers were not found")
- endif()
+ endif()
- list(APPEND glfw_INCLUDE_DIR ${X11_Xkb_INCLUDE_PATH})
+ list(APPEND glfw_INCLUDE_DIR "${X11_Xkb_INCLUDE_PATH}")
find_library(RT_LIBRARY rt)
mark_as_advanced(RT_LIBRARY)
if (RT_LIBRARY)
- list(APPEND glfw_LIBRARIES ${RT_LIBRARY})
- set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} -lrt")
+ list(APPEND glfw_LIBRARIES "${RT_LIBRARY}")
+ list(APPEND glfw_PKG_LIBS "-lrt")
+ endif()
+
+ find_library(MATH_LIBRARY m)
+ mark_as_advanced(MATH_LIBRARY)
+ if (MATH_LIBRARY)
+ list(APPEND glfw_LIBRARIES "${MATH_LIBRARY}")
+ list(APPEND glfw_PKG_LIBS "-lm")
+ endif()
+
+ # Check for Xcursor
+ if (NOT X11_Xcursor_FOUND)
+ message(FATAL_ERROR "The Xcursor libraries and headers were not found")
endif()
+ list(APPEND glfw_INCLUDE_DIR "${X11_Xcursor_INCLUDE_PATH}")
+ list(APPEND glfw_LIBRARIES "${X11_Xcursor_LIB}")
+ list(APPEND glfw_PKG_DEPS "xcursor")
+
+endif()
+
+#--------------------------------------------------------------------
+# Use Wayland for window creation
+#--------------------------------------------------------------------
+if (_GLFW_WAYLAND)
+ find_package(Wayland REQUIRED)
+ list(APPEND glfw_PKG_DEPS "wayland-egl")
+
+ list(APPEND glfw_INCLUDE_DIRS "${WAYLAND_INCLUDE_DIR}")
+ list(APPEND glfw_LIBRARIES "${WAYLAND_LIBRARIES}" "${CMAKE_THREAD_LIBS_INIT}")
+
+ find_package(XKBCommon REQUIRED)
+ list(APPEND glfw_PKG_DEPS "xkbcommon")
+ list(APPEND glfw_INCLUDE_DIRS "${XKBCOMMON_INCLUDE_DIRS}")
+ list(APPEND glfw_LIBRARIES "${XKBCOMMON_LIBRARY}")
+
find_library(MATH_LIBRARY m)
mark_as_advanced(MATH_LIBRARY)
if (MATH_LIBRARY)
- list(APPEND glfw_LIBRARIES ${MATH_LIBRARY})
- set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} -lm")
+ list(APPEND glfw_LIBRARIES "${MATH_LIBRARY}")
+ list(APPEND glfw_PKG_LIBS "-lm")
endif()
+endif()
+
+#--------------------------------------------------------------------
+# Use Mir for window creation
+#--------------------------------------------------------------------
+if (_GLFW_MIR)
+ find_package(Mir REQUIRED)
+ list(APPEND glfw_PKG_DEPS "mirclient")
+
+ list(APPEND glfw_INCLUDE_DIRS "${MIR_INCLUDE_DIR}")
+ list(APPEND glfw_LIBRARIES "${MIR_LIBRARIES}" "${CMAKE_THREAD_LIBS_INIT}")
+ find_package(XKBCommon REQUIRED)
+ list(APPEND glfw_PKG_DEPS "xkbcommon")
+ list(APPEND glfw_INCLUDE_DIRS "${XKBCOMMON_INCLUDE_DIRS}")
+ list(APPEND glfw_LIBRARIES "${XKBCOMMON_LIBRARY}")
+
+ find_library(MATH_LIBRARY m)
+ mark_as_advanced(MATH_LIBRARY)
+ if (MATH_LIBRARY)
+ list(APPEND glfw_LIBRARIES "${MATH_LIBRARY}")
+ list(APPEND glfw_PKG_LIBS "-lm")
+ endif()
endif()
#--------------------------------------------------------------------
@@ -266,14 +385,14 @@ endif()
#--------------------------------------------------------------------
if (_GLFW_GLX)
- list(APPEND glfw_INCLUDE_DIRS ${OPENGL_INCLUDE_DIR})
- list(APPEND glfw_LIBRARIES ${OPENGL_gl_LIBRARY})
+ list(APPEND glfw_INCLUDE_DIRS "${OPENGL_INCLUDE_DIR}")
+ list(APPEND glfw_LIBRARIES "${OPENGL_gl_LIBRARY}")
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} gl")
+ list(APPEND glfw_PKG_DEPS "gl")
include(CheckFunctionExists)
- set(CMAKE_REQUIRED_LIBRARIES ${OPENGL_gl_LIBRARY})
+ set(CMAKE_REQUIRED_LIBRARIES "${OPENGL_gl_LIBRARY}")
check_function_exists(glXGetProcAddress _GLFW_HAS_GLXGETPROCADDRESS)
check_function_exists(glXGetProcAddressARB _GLFW_HAS_GLXGETPROCADDRESSARB)
check_function_exists(glXGetProcAddressEXT _GLFW_HAS_GLXGETPROCADDRESSEXT)
@@ -285,15 +404,15 @@ if (_GLFW_GLX)
# Check for dlopen support as a fallback
- set(CMAKE_REQUIRED_LIBRARIES ${CMAKE_DL_LIBS})
+ set(CMAKE_REQUIRED_LIBRARIES "${CMAKE_DL_LIBS}")
check_function_exists(dlopen _GLFW_HAS_DLOPEN)
if (NOT _GLFW_HAS_DLOPEN)
message(FATAL_ERROR "No entry point retrieval mechanism found")
endif()
if (CMAKE_DL_LIBS)
- list(APPEND glfw_LIBRARIES ${CMAKE_DL_LIBS})
- set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} -l${CMAKE_DL_LIBS}")
+ list(APPEND glfw_LIBRARIES "${CMAKE_DL_LIBS}")
+ list(APPEND glfw_PKG_LIBS "-l${CMAKE_DL_LIBS}")
endif()
endif()
@@ -304,25 +423,23 @@ endif()
#--------------------------------------------------------------------
if (_GLFW_EGL)
- list(APPEND glfw_INCLUDE_DIRS ${EGL_INCLUDE_DIR})
- list(APPEND glfw_LIBRARIES ${EGL_LIBRARY})
+ list(APPEND glfw_INCLUDE_DIRS "${EGL_INCLUDE_DIR}")
+ list(APPEND glfw_LIBRARIES "${EGL_LIBRARY}")
- if (UNIX)
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} egl")
- endif()
+ list(APPEND glfw_PKG_DEPS "egl")
if (_GLFW_USE_OPENGL)
- list(APPEND glfw_LIBRARIES ${OPENGL_gl_LIBRARY})
- list(APPEND glfw_INCLUDE_DIRS ${OPENGL_INCLUDE_DIR})
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} gl")
+ list(APPEND glfw_LIBRARIES "${OPENGL_gl_LIBRARY}")
+ list(APPEND glfw_INCLUDE_DIRS "${OPENGL_INCLUDE_DIR}")
+ list(APPEND glfw_PKG_DEPS "gl")
elseif (_GLFW_USE_GLESV1)
- list(APPEND glfw_LIBRARIES ${GLESv1_LIBRARY})
- list(APPEND glfw_INCLUDE_DIRS ${GLESv1_INCLUDE_DIR})
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} glesv1_cm")
+ list(APPEND glfw_LIBRARIES "${GLESv1_LIBRARY}")
+ list(APPEND glfw_INCLUDE_DIRS "${GLESv1_INCLUDE_DIR}")
+ list(APPEND glfw_PKG_DEPS "glesv1_cm")
elseif (_GLFW_USE_GLESV2)
- list(APPEND glfw_LIBRARIES ${GLESv2_LIBRARY})
- list(APPEND glfw_INCLUDE_DIRS ${GLESv2_INCLUDE_DIR})
- set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} glesv2")
+ list(APPEND glfw_LIBRARIES "${GLESv2_LIBRARY}")
+ list(APPEND glfw_INCLUDE_DIRS "${GLESv2_INCLUDE_DIR}")
+ list(APPEND glfw_PKG_DEPS "glesv2")
endif()
endif()
@@ -331,7 +448,7 @@ endif()
# Use Cocoa for window creation and NSOpenGL for context creation
#--------------------------------------------------------------------
if (_GLFW_COCOA AND _GLFW_NSGL)
-
+
if (GLFW_USE_MENUBAR)
set(_GLFW_USE_MENUBAR 1)
endif()
@@ -340,32 +457,46 @@ if (_GLFW_COCOA AND _GLFW_NSGL)
set(_GLFW_USE_CHDIR 1)
endif()
+ if (GLFW_USE_RETINA)
+ set(_GLFW_USE_RETINA 1)
+ endif()
+
if (GLFW_BUILD_UNIVERSAL)
message(STATUS "Building GLFW as Universal Binaries")
set(CMAKE_OSX_ARCHITECTURES i386;x86_64)
else()
message(STATUS "Building GLFW only for the native architecture")
endif()
-
+
# Set up library and include paths
find_library(COCOA_FRAMEWORK Cocoa)
find_library(IOKIT_FRAMEWORK IOKit)
find_library(CORE_FOUNDATION_FRAMEWORK CoreFoundation)
find_library(CORE_VIDEO_FRAMEWORK CoreVideo)
- list(APPEND glfw_LIBRARIES ${COCOA_FRAMEWORK}
- ${OPENGL_gl_LIBRARY}
- ${IOKIT_FRAMEWORK}
- ${CORE_FOUNDATION_FRAMEWORK}
- ${CORE_VIDEO_FRAMEWORK})
-
- set(GLFW_PKG_DEPS "")
- set(GLFW_PKG_LIBS "-framework Cocoa -framework OpenGL -framework IOKit -framework CoreFoundation -framework CoreVideo")
+ mark_as_advanced(COCOA_FRAMEWORK
+ IOKIT_FRAMEWORK
+ CORE_FOUNDATION_FRAMEWORK
+ CORE_VIDEO_FRAMEWORK)
+ list(APPEND glfw_LIBRARIES "${COCOA_FRAMEWORK}"
+ "${OPENGL_gl_LIBRARY}"
+ "${IOKIT_FRAMEWORK}"
+ "${CORE_FOUNDATION_FRAMEWORK}"
+ "${CORE_VIDEO_FRAMEWORK}")
+
+ set(glfw_PKG_DEPS "")
+ set(glfw_PKG_LIBS "-framework Cocoa -framework OpenGL -framework IOKit -framework CoreFoundation -framework CoreVideo")
endif()
#--------------------------------------------------------------------
# Export GLFW library dependencies
#--------------------------------------------------------------------
set(GLFW_LIBRARIES ${glfw_LIBRARIES} CACHE STRING "Dependencies of GLFW")
+foreach(arg ${glfw_PKG_DEPS})
+ set(GLFW_PKG_DEPS "${GLFW_PKG_DEPS} ${arg}")
+endforeach()
+foreach(arg ${glfw_PKG_LIBS})
+ set(GLFW_PKG_LIBS "${GLFW_PKG_LIBS} ${arg}")
+endforeach()
#--------------------------------------------------------------------
# Choose library output name
@@ -380,23 +511,35 @@ endif()
#--------------------------------------------------------------------
# Create generated files
#--------------------------------------------------------------------
-configure_file(${GLFW_SOURCE_DIR}/docs/Doxyfile.in
- ${GLFW_BINARY_DIR}/docs/Doxyfile @ONLY)
+include(CMakePackageConfigHelpers)
-configure_file(${GLFW_SOURCE_DIR}/src/glfw_config.h.in
- ${GLFW_BINARY_DIR}/src/glfw_config.h @ONLY)
+if (UNIX)
+ set(GLFW_CONFIG_PATH "${CMAKE_INSTALL_PREFIX}/lib/cmake/glfw3/")
+else()
+ set(GLFW_CONFIG_PATH "${CMAKE_INSTALL_PREFIX}/")
+endif()
-configure_file(${GLFW_SOURCE_DIR}/src/glfwConfig.cmake.in
- ${GLFW_BINARY_DIR}/src/glfwConfig.cmake @ONLY)
+configure_package_config_file("${GLFW_SOURCE_DIR}/src/glfw3Config.cmake.in"
+ "${GLFW_BINARY_DIR}/src/glfw3Config.cmake"
+ INSTALL_DESTINATION "${GLFW_CONFIG_PATH}"
+ PATH_VARS CMAKE_INSTALL_PREFIX
+ NO_CHECK_REQUIRED_COMPONENTS_MACRO)
-configure_file(${GLFW_SOURCE_DIR}/src/glfwConfigVersion.cmake.in
- ${GLFW_BINARY_DIR}/src/glfwConfigVersion.cmake @ONLY)
+write_basic_package_version_file("${GLFW_BINARY_DIR}/src/glfw3ConfigVersion.cmake"
+ VERSION ${GLFW_VERSION_FULL}
+ COMPATIBILITY SameMajorVersion)
-if (UNIX)
- configure_file(${GLFW_SOURCE_DIR}/src/glfw3.pc.in
- ${GLFW_BINARY_DIR}/src/glfw3.pc @ONLY)
+if (GLFW_BUILD_DOCS)
+ configure_file("${GLFW_SOURCE_DIR}/docs/Doxyfile.in"
+ "${GLFW_BINARY_DIR}/docs/Doxyfile" @ONLY)
endif()
+configure_file("${GLFW_SOURCE_DIR}/src/glfw_config.h.in"
+ "${GLFW_BINARY_DIR}/src/glfw_config.h" @ONLY)
+
+configure_file("${GLFW_SOURCE_DIR}/src/glfw3.pc.in"
+ "${GLFW_BINARY_DIR}/src/glfw3.pc" @ONLY)
+
#--------------------------------------------------------------------
# Add subdirectories
#--------------------------------------------------------------------
@@ -419,27 +562,25 @@ endif()
# The library is installed by src/CMakeLists.txt
#--------------------------------------------------------------------
if (GLFW_INSTALL)
- install(DIRECTORY include/GLFW DESTINATION include
+ install(DIRECTORY include/GLFW DESTINATION include
FILES_MATCHING PATTERN glfw3.h PATTERN glfw3native.h)
- install(FILES ${GLFW_BINARY_DIR}/src/glfwConfig.cmake
- ${GLFW_BINARY_DIR}/src/glfwConfigVersion.cmake
+ install(FILES "${GLFW_BINARY_DIR}/src/glfw3Config.cmake"
+ "${GLFW_BINARY_DIR}/src/glfw3ConfigVersion.cmake"
DESTINATION lib${LIB_SUFFIX}/cmake/glfw)
- if (UNIX)
- install(EXPORT glfwTargets DESTINATION lib${LIB_SUFFIX}/cmake/glfw)
- install(FILES ${GLFW_BINARY_DIR}/src/glfw3.pc
- DESTINATION lib${LIB_SUFFIX}/pkgconfig)
- endif()
+ install(EXPORT glfwTargets DESTINATION lib${LIB_SUFFIX}/cmake/glfw)
+ install(FILES "${GLFW_BINARY_DIR}/src/glfw3.pc"
+ DESTINATION lib${LIB_SUFFIX}/pkgconfig)
# Only generate this target if no higher-level project already has
if (NOT TARGET uninstall)
- configure_file(${GLFW_SOURCE_DIR}/cmake_uninstall.cmake.in
- ${GLFW_BINARY_DIR}/cmake_uninstall.cmake IMMEDIATE @ONLY)
+ configure_file("${GLFW_SOURCE_DIR}/cmake_uninstall.cmake.in"
+ "${GLFW_BINARY_DIR}/cmake_uninstall.cmake" IMMEDIATE @ONLY)
add_custom_target(uninstall
- ${CMAKE_COMMAND} -P
- ${GLFW_BINARY_DIR}/cmake_uninstall.cmake)
+ "${CMAKE_COMMAND}" -P
+ "${GLFW_BINARY_DIR}/cmake_uninstall.cmake")
endif()
endif()