123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- # Copyright (C) 2020 The Khronos Group Inc.
- #
- # All rights reserved.
- #
- # Redistribution and use in source and binary forms, with or without
- # modification, are permitted provided that the following conditions
- # are met:
- #
- # Redistributions of source code must retain the above copyright
- # notice, this list of conditions and the following disclaimer.
- #
- # Redistributions in binary form must reproduce the above
- # copyright notice, this list of conditions and the following
- # disclaimer in the documentation and/or other materials provided
- # with the distribution.
- #
- # Neither the name of The Khronos Group Inc. nor the names of its
- # contributors may be used to endorse or promote products derived
- # from this software without specific prior written permission.
- #
- # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
- # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- # COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
- # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
- # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
- # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
- # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- # POSSIBILITY OF SUCH DAMAGE.
- # The macro choose_msvc_crt() takes a list of possible
- # C runtimes to choose from, in the form of compiler flags,
- # to present to the user. (MTd for /MTd, etc)
- #
- # The macro is invoked at the end of the file.
- #
- # CMake already sets CRT flags in the CMAKE_CXX_FLAGS_* and
- # CMAKE_C_FLAGS_* variables by default. To let the user
- # override that for each build type:
- # 1. Detect which CRT is already selected, and reflect this in
- # LLVM_USE_CRT_* so the user can have a better idea of what
- # changes they're making.
- # 2. Replace the flags in both variables with the new flag via a regex.
- # 3. set() the variables back into the cache so the changes
- # are user-visible.
- ### Helper macros: ###
- macro(make_crt_regex regex crts)
- set(${regex} "")
- foreach(crt ${${crts}})
- # Trying to match the beginning or end of the string with stuff
- # like [ ^]+ didn't work, so use a bunch of parentheses instead.
- set(${regex} "${${regex}}|(^| +)/${crt}($| +)")
- endforeach(crt)
- string(REGEX REPLACE "^\\|" "" ${regex} "${${regex}}")
- endmacro(make_crt_regex)
- macro(get_current_crt crt_current regex flagsvar)
- # Find the selected-by-CMake CRT for each build type, if any.
- # Strip off the leading slash and any whitespace.
- string(REGEX MATCH "${${regex}}" ${crt_current} "${${flagsvar}}")
- string(REPLACE "/" " " ${crt_current} "${${crt_current}}")
- string(STRIP "${${crt_current}}" ${crt_current})
- endmacro(get_current_crt)
- # Replaces or adds a flag to a variable.
- # Expects 'flag' to be padded with spaces.
- macro(set_flag_in_var flagsvar regex flag)
- string(REGEX MATCH "${${regex}}" current_flag "${${flagsvar}}")
- if("${current_flag}" STREQUAL "")
- set(${flagsvar} "${${flagsvar}}${${flag}}")
- else()
- string(REGEX REPLACE "${${regex}}" "${${flag}}" ${flagsvar} "${${flagsvar}}")
- endif()
- string(STRIP "${${flagsvar}}" ${flagsvar})
- # Make sure this change gets reflected in the cache/gui.
- # CMake requires the docstring parameter whenever set() touches the cache,
- # so get the existing docstring and re-use that.
- get_property(flagsvar_docs CACHE ${flagsvar} PROPERTY HELPSTRING)
- set(${flagsvar} "${${flagsvar}}" CACHE STRING "${flagsvar_docs}" FORCE)
- endmacro(set_flag_in_var)
- macro(choose_msvc_crt MSVC_CRT)
- if(LLVM_USE_CRT)
- message(FATAL_ERROR
- "LLVM_USE_CRT is deprecated. Use the CMAKE_BUILD_TYPE-specific
- variables (LLVM_USE_CRT_DEBUG, etc) instead.")
- endif()
- make_crt_regex(MSVC_CRT_REGEX ${MSVC_CRT})
- foreach(build_type ${CMAKE_CONFIGURATION_TYPES} ${CMAKE_BUILD_TYPE})
- string(TOUPPER "${build_type}" build)
- if (NOT LLVM_USE_CRT_${build})
- get_current_crt(LLVM_USE_CRT_${build}
- MSVC_CRT_REGEX
- CMAKE_CXX_FLAGS_${build})
- set(LLVM_USE_CRT_${build}
- "${LLVM_USE_CRT_${build}}"
- CACHE STRING "Specify VC++ CRT to use for ${build_type} configurations."
- FORCE)
- set_property(CACHE LLVM_USE_CRT_${build}
- PROPERTY STRINGS ;${${MSVC_CRT}})
- endif(NOT LLVM_USE_CRT_${build})
- endforeach(build_type)
- foreach(build_type ${CMAKE_CONFIGURATION_TYPES} ${CMAKE_BUILD_TYPE})
- string(TOUPPER "${build_type}" build)
- if ("${LLVM_USE_CRT_${build}}" STREQUAL "")
- set(flag_string " ")
- else()
- set(flag_string " /${LLVM_USE_CRT_${build}} ")
- list(FIND ${MSVC_CRT} ${LLVM_USE_CRT_${build}} idx)
- if (idx LESS 0)
- message(FATAL_ERROR
- "Invalid value for LLVM_USE_CRT_${build}: ${LLVM_USE_CRT_${build}}. Valid options are one of: ${${MSVC_CRT}}")
- endif (idx LESS 0)
- message(STATUS "Using ${build_type} VC++ CRT: ${LLVM_USE_CRT_${build}}")
- endif()
- foreach(lang C CXX)
- set_flag_in_var(CMAKE_${lang}_FLAGS_${build} MSVC_CRT_REGEX flag_string)
- endforeach(lang)
- endforeach(build_type)
- endmacro(choose_msvc_crt MSVC_CRT)
- # List of valid CRTs for MSVC
- set(MSVC_CRT
- MD
- MDd
- MT
- MTd)
- choose_msvc_crt(MSVC_CRT)
|