2022-12-17 02:49:46 +00:00
|
|
|
macro(add_to_alloptions _NEWNAME)
|
2021-10-05 14:54:06 +00:00
|
|
|
list(APPEND ALLOPTIONS ${_NEWNAME})
|
|
|
|
endmacro()
|
|
|
|
|
2022-12-17 02:49:46 +00:00
|
|
|
macro(set_option _NAME _DESC)
|
2021-10-05 14:54:06 +00:00
|
|
|
add_to_alloptions(${_NAME})
|
2015-06-21 15:33:46 +00:00
|
|
|
if(${ARGC} EQUAL 3)
|
|
|
|
set(_DEFLT ${ARGV2})
|
|
|
|
else()
|
|
|
|
set(_DEFLT OFF)
|
|
|
|
endif()
|
|
|
|
option(${_NAME} ${_DESC} ${_DEFLT})
|
|
|
|
endmacro()
|
|
|
|
|
2022-12-17 02:49:46 +00:00
|
|
|
macro(dep_option _NAME _DESC _DEFLT _DEPTEST _FAILDFLT)
|
2022-06-07 02:28:55 +00:00
|
|
|
add_to_alloptions("${_NAME}")
|
|
|
|
cmake_dependent_option("${_NAME}" "${_DESC}" "${_DEFLT}" "${_DEPTEST}" "${_FAILDFLT}")
|
2015-06-21 15:33:46 +00:00
|
|
|
endmacro()
|
|
|
|
|
2022-12-17 02:49:46 +00:00
|
|
|
macro(option_string _NAME _DESC _VALUE)
|
2021-10-05 14:54:06 +00:00
|
|
|
add_to_alloptions(${_NAME})
|
2015-06-21 15:33:46 +00:00
|
|
|
set(${_NAME} ${_VALUE} CACHE STRING "${_DESC}")
|
|
|
|
set(HAVE_${_NAME} ${_VALUE})
|
|
|
|
ENDMACRO()
|
|
|
|
|
2022-12-17 02:49:46 +00:00
|
|
|
macro(message_bool_option _NAME _VALUE)
|
2022-08-22 02:11:39 +00:00
|
|
|
set(_PAD "\t")
|
|
|
|
if(${ARGC} EQUAL 3)
|
|
|
|
set(_PAD ${ARGV2})
|
|
|
|
endif()
|
2015-06-21 15:33:46 +00:00
|
|
|
if(${_VALUE})
|
2022-08-22 02:11:39 +00:00
|
|
|
message(STATUS " ${_NAME}:${_PAD}ON")
|
2015-06-21 15:33:46 +00:00
|
|
|
else()
|
2022-08-22 02:11:39 +00:00
|
|
|
message(STATUS " ${_NAME}:${_PAD}OFF")
|
2015-06-21 15:33:46 +00:00
|
|
|
endif()
|
|
|
|
endmacro()
|
|
|
|
|
2022-12-17 02:49:46 +00:00
|
|
|
macro(message_tested_option _NAME)
|
2015-06-21 15:33:46 +00:00
|
|
|
set(_REQVALUE ${${_NAME}})
|
|
|
|
set(_PAD " ")
|
|
|
|
if(${ARGC} EQUAL 2)
|
|
|
|
set(_PAD ${ARGV1})
|
|
|
|
endif()
|
2021-10-05 14:43:35 +00:00
|
|
|
string(SUBSTRING "${_NAME}" 0 4 _NAMESTART)
|
|
|
|
if(_NAMESTART STREQUAL "SDL_")
|
|
|
|
string(SUBSTRING "${_NAME}" 4 -1 _STRIPPEDNAME)
|
|
|
|
else()
|
|
|
|
set(_STRIPPEDNAME "${_NAME}")
|
|
|
|
endif()
|
|
|
|
if(NOT HAVE_${_STRIPPEDNAME})
|
|
|
|
set(HAVE_${_STRIPPEDNAME} OFF)
|
|
|
|
elseif("${HAVE_${_STRIPPEDNAME}}" MATCHES "1|TRUE|YES|Y")
|
|
|
|
set(HAVE_${_STRIPPEDNAME} ON)
|
2015-06-21 15:33:46 +00:00
|
|
|
endif()
|
2021-10-05 14:43:35 +00:00
|
|
|
message(STATUS " ${_NAME}${_PAD}(Wanted: ${_REQVALUE}): ${HAVE_${_STRIPPEDNAME}}")
|
2015-06-21 15:33:46 +00:00
|
|
|
endmacro()
|
|
|
|
|
2022-08-22 02:11:39 +00:00
|
|
|
function(find_stringlength_longest_item inList outLength)
|
|
|
|
set(maxLength 0)
|
|
|
|
foreach(item IN LISTS ${inList})
|
|
|
|
string(LENGTH "${item}" slen)
|
|
|
|
if(slen GREATER maxLength)
|
|
|
|
set(maxLength ${slen})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
set("${outLength}" ${maxLength} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
function(message_dictlist inList)
|
|
|
|
find_stringlength_longest_item(${inList} maxLength)
|
|
|
|
foreach(name IN LISTS ${inList})
|
|
|
|
# Get the padding
|
|
|
|
string(LENGTH ${name} nameLength)
|
|
|
|
math(EXPR padLength "(${maxLength} + 1) - ${nameLength}")
|
|
|
|
string(RANDOM LENGTH ${padLength} ALPHABET " " padding)
|
|
|
|
message_tested_option(${name} ${padding})
|
|
|
|
endforeach()
|
|
|
|
endfunction()
|
|
|
|
|
2023-02-28 03:20:30 +00:00
|
|
|
if(APPLE)
|
2022-02-05 15:28:24 +00:00
|
|
|
include(CheckOBJCSourceCompiles)
|
2023-02-28 03:20:30 +00:00
|
|
|
enable_language(OBJC)
|
2022-02-05 15:28:24 +00:00
|
|
|
endif()
|
2015-06-21 15:33:46 +00:00
|
|
|
|
2023-11-05 23:40:41 +00:00
|
|
|
function(SDL_detect_linker)
|
|
|
|
if(CMAKE_VERSION VERSION_LESS 3.29)
|
|
|
|
if(NOT DEFINED SDL_CMAKE_C_COMPILER_LINKER_ID)
|
|
|
|
execute_process(COMMAND ${CMAKE_LINKER} -v OUTPUT_VARIABLE LINKER_OUTPUT ERROR_VARIABLE LINKER_OUTPUT)
|
|
|
|
string(REGEX REPLACE "[\r\n]" " " LINKER_OUTPUT "${LINKER_OUTPUT}")
|
|
|
|
if(LINKER_OUTPUT MATCHES ".*Microsoft.*")
|
|
|
|
set(linker MSVC)
|
|
|
|
else()
|
|
|
|
set(linker GNUlike)
|
|
|
|
endif()
|
|
|
|
message(STATUS "Linker identification: ${linker}")
|
|
|
|
set(SDL_CMAKE_C_COMPILER_LINKER_ID "${linker}" CACHE STRING "Linker identification")
|
|
|
|
mark_as_advanced(SDL_CMAKE_C_COMPILER_LINKER_ID)
|
|
|
|
endif()
|
2023-11-06 00:58:26 +00:00
|
|
|
set(CMAKE_C_COMPILER_LINKER_ID "${SDL_CMAKE_C_COMPILER_LINKER_ID}" PARENT_SCOPE)
|
2023-11-05 23:40:41 +00:00
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
2023-09-20 02:24:08 +00:00
|
|
|
function(check_linker_supports_version_file VAR)
|
2023-11-05 23:40:41 +00:00
|
|
|
SDL_detect_linker()
|
|
|
|
if(CMAKE_C_COMPILER_LINKER_ID MATCHES "^(MSVC)$")
|
|
|
|
set(LINKER_SUPPORTS_VERSION_SCRIPT FALSE)
|
|
|
|
else()
|
|
|
|
cmake_push_check_state(RESET)
|
|
|
|
file(WRITE "${CMAKE_CURRENT_BINARY_DIR}/dummy.sym" "n_0 {\n global:\n func;\n local: *;\n};\n")
|
|
|
|
list(APPEND CMAKE_REQUIRED_LINK_OPTIONS "-Wl,--version-script=${CMAKE_CURRENT_BINARY_DIR}/dummy.sym")
|
|
|
|
check_c_source_compiles("int func(void) {return 0;} int main(int argc,char*argv[]){(void)argc;(void)argv;return func();}" LINKER_SUPPORTS_VERSION_SCRIPT FAIL_REGEX "(unsupported|syntax error|unrecognized option)")
|
|
|
|
cmake_pop_check_state()
|
|
|
|
endif()
|
2023-09-20 02:24:08 +00:00
|
|
|
set(${VAR} "${LINKER_SUPPORTS_VERSION_SCRIPT}" PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
|
build: add symbol versioning for SDL
If a program built against one version of SDL is run in an
environment where there is an earlier version of the SDL .so library
installed, the result varies depending on platform configuration; in
the best case, it won't start at all, at worst it aborts in the
middle of the user doing "something important" (systems implementing
lazy symbol resolution). verdefs on the other hand are always checked
on startup.
The dependency information present in programs and shared libraries
is not only of value to the dynamic linker, but also to a
distribution's package management. If the dynamic linker is able to
tell that a program is not runnable per the above, a package manager
is able to come to the same conclusion — and block the installation
of a nonfunctional program+library ensemble.
Because there are a lot more symbols than there are libraries (I am
going to throw in "10^4 to 1 or worse"), package managers generally
do not evaluate symbols, but only e.g. the SONAME, NEEDED and VERNEED
fields/blocks. Because the SONAME is the same between two SDL
versions like 2.0.24, and 2.0.26, everything rests on having verdefs.
This patch proposes the addition of verdefs.
2022-11-24 19:58:10 +00:00
|
|
|
if(CMAKE_VERSION VERSION_LESS 3.18)
|
|
|
|
function(check_linker_flag LANG FLAG VAR)
|
2023-11-05 23:40:41 +00:00
|
|
|
cmake_push_check_state(RESET)
|
|
|
|
list(APPEND CMAKE_REQUIRED_LINK_OPTIONS ${FLAG})
|
build: add symbol versioning for SDL
If a program built against one version of SDL is run in an
environment where there is an earlier version of the SDL .so library
installed, the result varies depending on platform configuration; in
the best case, it won't start at all, at worst it aborts in the
middle of the user doing "something important" (systems implementing
lazy symbol resolution). verdefs on the other hand are always checked
on startup.
The dependency information present in programs and shared libraries
is not only of value to the dynamic linker, but also to a
distribution's package management. If the dynamic linker is able to
tell that a program is not runnable per the above, a package manager
is able to come to the same conclusion — and block the installation
of a nonfunctional program+library ensemble.
Because there are a lot more symbols than there are libraries (I am
going to throw in "10^4 to 1 or worse"), package managers generally
do not evaluate symbols, but only e.g. the SONAME, NEEDED and VERNEED
fields/blocks. Because the SONAME is the same between two SDL
versions like 2.0.24, and 2.0.26, everything rests on having verdefs.
This patch proposes the addition of verdefs.
2022-11-24 19:58:10 +00:00
|
|
|
if(LANG STREQUAL "C")
|
|
|
|
include(CheckCSourceCompiles)
|
2023-09-20 02:24:08 +00:00
|
|
|
check_c_source_compiles("int main(int argc,char*argv[]){(void)argc;(void)argv;return 0;}" ${VAR} FAIL_REGEX "(unsupported|syntax error)")
|
build: add symbol versioning for SDL
If a program built against one version of SDL is run in an
environment where there is an earlier version of the SDL .so library
installed, the result varies depending on platform configuration; in
the best case, it won't start at all, at worst it aborts in the
middle of the user doing "something important" (systems implementing
lazy symbol resolution). verdefs on the other hand are always checked
on startup.
The dependency information present in programs and shared libraries
is not only of value to the dynamic linker, but also to a
distribution's package management. If the dynamic linker is able to
tell that a program is not runnable per the above, a package manager
is able to come to the same conclusion — and block the installation
of a nonfunctional program+library ensemble.
Because there are a lot more symbols than there are libraries (I am
going to throw in "10^4 to 1 or worse"), package managers generally
do not evaluate symbols, but only e.g. the SONAME, NEEDED and VERNEED
fields/blocks. Because the SONAME is the same between two SDL
versions like 2.0.24, and 2.0.26, everything rests on having verdefs.
This patch proposes the addition of verdefs.
2022-11-24 19:58:10 +00:00
|
|
|
elseif(LANG STREQUAL "CXX")
|
|
|
|
include(CheckCXXSourceCompiles)
|
2023-09-20 02:24:08 +00:00
|
|
|
check_cxx_source_compiles("int main(int argc,char*argv[]){(void)argc;(void)argv;return 0;}" ${VAR} FAIL_REGEX "(unsupported|syntax error)")
|
build: add symbol versioning for SDL
If a program built against one version of SDL is run in an
environment where there is an earlier version of the SDL .so library
installed, the result varies depending on platform configuration; in
the best case, it won't start at all, at worst it aborts in the
middle of the user doing "something important" (systems implementing
lazy symbol resolution). verdefs on the other hand are always checked
on startup.
The dependency information present in programs and shared libraries
is not only of value to the dynamic linker, but also to a
distribution's package management. If the dynamic linker is able to
tell that a program is not runnable per the above, a package manager
is able to come to the same conclusion — and block the installation
of a nonfunctional program+library ensemble.
Because there are a lot more symbols than there are libraries (I am
going to throw in "10^4 to 1 or worse"), package managers generally
do not evaluate symbols, but only e.g. the SONAME, NEEDED and VERNEED
fields/blocks. Because the SONAME is the same between two SDL
versions like 2.0.24, and 2.0.26, everything rests on having verdefs.
This patch proposes the addition of verdefs.
2022-11-24 19:58:10 +00:00
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Unsupported language: ${LANG}")
|
|
|
|
endif()
|
|
|
|
cmake_pop_check_state()
|
|
|
|
endfunction()
|
|
|
|
else()
|
|
|
|
cmake_policy(SET CMP0057 NEW) # Support new if() IN_LIST operator. (used inside check_linker_flag, used in CMake 3.18)
|
|
|
|
include(CheckLinkerFlag)
|
|
|
|
endif()
|
|
|
|
|
2022-10-29 01:20:30 +00:00
|
|
|
if(APPLE)
|
|
|
|
check_language(OBJC)
|
|
|
|
if(NOT CMAKE_OBJC_COMPILER)
|
|
|
|
message(WARNING "Cannot find working OBJC compiler.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2023-02-28 03:20:30 +00:00
|
|
|
function(SDL_PrintSummary)
|
|
|
|
##### Info output #####
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS "SDL3 was configured with the following options:")
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS "Platform: ${CMAKE_SYSTEM}")
|
|
|
|
message(STATUS "64-bit: ${ARCH_64}")
|
|
|
|
message(STATUS "Compiler: ${CMAKE_C_COMPILER}")
|
|
|
|
message(STATUS "Revision: ${SDL_REVISION}")
|
|
|
|
message(STATUS "Vendor: ${SDL_VENDOR_INFO}")
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS "Subsystems:")
|
|
|
|
|
|
|
|
find_stringlength_longest_item(SDL_SUBSYSTEMS maxLength)
|
|
|
|
foreach(_SUB IN LISTS SDL_SUBSYSTEMS)
|
|
|
|
string(LENGTH ${_SUB} _SUBLEN)
|
|
|
|
math(EXPR _PADLEN "(${maxLength} + 1) - ${_SUBLEN}")
|
|
|
|
string(RANDOM LENGTH ${_PADLEN} ALPHABET " " _PADDING)
|
|
|
|
string(TOUPPER ${_SUB} _OPT)
|
|
|
|
message_bool_option(${_SUB} SDL_${_OPT} ${_PADDING})
|
|
|
|
endforeach()
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS "Options:")
|
|
|
|
list(SORT ALLOPTIONS)
|
|
|
|
message_dictlist(ALLOPTIONS)
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS " Build Shared Library: ${SDL_SHARED}")
|
|
|
|
message(STATUS " Build Static Library: ${SDL_STATIC}")
|
|
|
|
if(SDL_STATIC)
|
|
|
|
message(STATUS " Build Static Library with Position Independent Code: ${SDL_STATIC_PIC}")
|
|
|
|
endif()
|
|
|
|
if(APPLE)
|
|
|
|
message(STATUS " Build libraries as Apple Framework: ${SDL_FRAMEWORK}")
|
|
|
|
endif()
|
|
|
|
message(STATUS "")
|
|
|
|
if(UNIX)
|
|
|
|
message(STATUS "If something was not detected, although the libraries")
|
|
|
|
message(STATUS "were installed, then make sure you have set the")
|
|
|
|
message(STATUS "CMAKE_C_FLAGS and CMAKE_PREFIX_PATH CMake variables correctly.")
|
|
|
|
message(STATUS "")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(WARN_ABOUT_ARM_SIMD_ASM_MIT)
|
|
|
|
message(STATUS "SDL is being built with ARM SIMD optimizations, which")
|
|
|
|
message(STATUS "uses code licensed under the MIT license. If this is a")
|
|
|
|
message(STATUS "problem, please disable that code by rerunning CMake with:")
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS " -DSDL_ARMSIMD=OFF")
|
|
|
|
message(STATUS "")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(WARN_ABOUT_ARM_NEON_ASM_MIT)
|
|
|
|
message(STATUS "SDL is being built with ARM NEON optimizations, which")
|
|
|
|
message(STATUS "uses code licensed under the MIT license. If this is a")
|
|
|
|
message(STATUS "problem, please disable that code by rerunning CMake with:")
|
|
|
|
message(STATUS "")
|
|
|
|
message(STATUS " -DSDL_ARMNEON=OFF")
|
|
|
|
message(STATUS "")
|
|
|
|
endif()
|
|
|
|
endfunction()
|
2023-11-08 23:24:10 +00:00
|
|
|
|
|
|
|
function(SDL_install_pdb TARGET DIRECTORY)
|
|
|
|
get_property(type TARGET ${TARGET} PROPERTY TYPE)
|
|
|
|
if(type MATCHES "^(SHARED_LIBRARY|EXECUTABLE)$")
|
|
|
|
install(FILES $<TARGET_PDB_FILE:${TARGET}> DESTINATION "${DIRECTORY}" OPTIONAL)
|
|
|
|
elseif(type STREQUAL "STATIC_LIBRARY")
|
|
|
|
# FIXME: Use $<TARGET_COMPILE_PDB_FILE:${TARGET} once it becomes available (https://gitlab.kitware.com/cmake/cmake/-/issues/25244)
|
|
|
|
if(CMAKE_GENERATOR MATCHES "^Visual Studio.*")
|
|
|
|
install(CODE "file(INSTALL DESTINATION \"\${CMAKE_INSTALL_PREFIX}/${DIRECTORY}\" TYPE FILE OPTIONAL FILES \"${CMAKE_CURRENT_BINARY_DIR}/\${CMAKE_INSTALL_CONFIG_NAME}/$<TARGET_FILE_BASE_NAME:${TARGET}>.pdb\")")
|
|
|
|
else()
|
|
|
|
install(CODE "file(INSTALL DESTINATION \"\${CMAKE_INSTALL_PREFIX}/${DIRECTORY}\" TYPE FILE OPTIONAL FILES \"${CMAKE_CURRENT_BINARY_DIR}/CMakeFiles/${TARGET}.dir/$<TARGET_FILE_BASE_NAME:${TARGET}>.pdb\")")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|