mirror of
https://github.com/neovim/neovim.git
synced 2024-12-19 10:45:16 -07:00
build: remove enforcement of cmake build type
Forcing the build type to be one of the default types was intended to prevent usage of custom build types which risks unpredictability. Unfortunately, many distributions patch this check out so they can use a custom type anyway, making the check moot in the first place. Instead, allow custom build types but don't try to accomodate them in the code: we're making the assumption that anyone who wants to use a custom build type will be able to set any additional necessary flags needed for their specific system.
This commit is contained in:
parent
8c532a9ea8
commit
573bcb2aaf
@ -175,8 +175,7 @@ function(add_target)
|
||||
add_custom_target(${target} DEPENDS ${touch_file})
|
||||
endfunction()
|
||||
|
||||
# Set default build type to BUILD_TYPE. Also limit the list of allowable build
|
||||
# types to the ones defined in variable allowableBuildTypes.
|
||||
# Set default build type to BUILD_TYPE.
|
||||
#
|
||||
# The correct way to specify build type (for example Release) for
|
||||
# single-configuration generators (Make and Ninja) is to run
|
||||
@ -193,28 +192,24 @@ endfunction()
|
||||
# Passing CMAKE_BUILD_TYPE for multi-config generators will not only not be
|
||||
# used, but also generate a warning for the user.
|
||||
function(set_default_buildtype BUILD_TYPE)
|
||||
set(allowableBuildTypes Debug Release MinSizeRel RelWithDebInfo)
|
||||
if(NOT BUILD_TYPE IN_LIST allowableBuildTypes)
|
||||
message(FATAL_ERROR "Invalid build type: ${BUILD_TYPE}")
|
||||
endif()
|
||||
set(defaultBuildTypes Debug Release MinSizeRel RelWithDebInfo)
|
||||
|
||||
get_property(isMultiConfig GLOBAL PROPERTY GENERATOR_IS_MULTI_CONFIG)
|
||||
if(isMultiConfig)
|
||||
# Multi-config generators use the first element in CMAKE_CONFIGURATION_TYPES as the default build type
|
||||
list(INSERT allowableBuildTypes 0 ${BUILD_TYPE})
|
||||
list(REMOVE_DUPLICATES allowableBuildTypes)
|
||||
set(CMAKE_CONFIGURATION_TYPES ${allowableBuildTypes} PARENT_SCOPE)
|
||||
# Multi-config generators use the first element in
|
||||
# CMAKE_CONFIGURATION_TYPES as the default build type
|
||||
list(INSERT defaultBuildTypes 0 ${BUILD_TYPE})
|
||||
list(REMOVE_DUPLICATES defaultBuildTypes)
|
||||
set(CMAKE_CONFIGURATION_TYPES ${defaultBuildTypes} PARENT_SCOPE)
|
||||
if(CMAKE_BUILD_TYPE)
|
||||
message(WARNING "CMAKE_BUILD_TYPE specified which is ignored on \
|
||||
multi-configuration generators. Defaulting to ${BUILD_TYPE} build type.")
|
||||
endif()
|
||||
else()
|
||||
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "${allowableBuildTypes}")
|
||||
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "${defaultBuildTypes}")
|
||||
if(NOT CMAKE_BUILD_TYPE)
|
||||
message(STATUS "CMAKE_BUILD_TYPE not specified, default is '${BUILD_TYPE}'")
|
||||
set(CMAKE_BUILD_TYPE ${BUILD_TYPE} CACHE STRING "Choose the type of build" FORCE)
|
||||
elseif(NOT CMAKE_BUILD_TYPE IN_LIST allowableBuildTypes)
|
||||
message(FATAL_ERROR "Invalid build type: ${CMAKE_BUILD_TYPE}")
|
||||
else()
|
||||
message(STATUS "CMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}")
|
||||
endif()
|
||||
|
Loading…
Reference in New Issue
Block a user