Add CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS variable
The parent commit added a warning message whenever a required file does not exist. As it turns out, the "required" files never exist when built with Visual Studio Express editions. Add a variable to suppress these warning messages because only packagers or naive includers of this file will care to see such warning messages. We want to warn about this condition by default so that people who are using InstallRequiredSystemLibraries without understanding it fully will have a chance of understanding why it's not working in the event of missing required files. But we also want to give projects the ability to suppress this warning (by "project's choice default") so that they can encourage users who are restricted to using an Express edition to build their project. Packagers should explicitly use... -DCMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS=OFF ...when building releases. That way, their release build process will warn them about any missing files, but only if their project CMakeLists files use a construct similar to CMake's: IF(NOT DEFINED CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS) SET(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS ON) ENDIF()
This commit is contained in:
parent
fc144924a0
commit
fa4a3b04d0
|
@ -16,6 +16,12 @@ IF(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake")
|
||||||
OPTION(CMAKE_INSTALL_DEBUG_LIBRARIES
|
OPTION(CMAKE_INSTALL_DEBUG_LIBRARIES
|
||||||
"Install Microsoft runtime debug libraries with CMake." FALSE)
|
"Install Microsoft runtime debug libraries with CMake." FALSE)
|
||||||
MARK_AS_ADVANCED(CMAKE_INSTALL_DEBUG_LIBRARIES)
|
MARK_AS_ADVANCED(CMAKE_INSTALL_DEBUG_LIBRARIES)
|
||||||
|
|
||||||
|
# By default, do not warn when built on machines using only VS Express:
|
||||||
|
IF(NOT DEFINED CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS)
|
||||||
|
SET(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS ON)
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
INCLUDE(${CMake_SOURCE_DIR}/Modules/InstallRequiredSystemLibraries.cmake)
|
INCLUDE(${CMake_SOURCE_DIR}/Modules/InstallRequiredSystemLibraries.cmake)
|
||||||
ENDIF(EXISTS "${CMAKE_ROOT}/Modules/InstallRequiredSystemLibraries.cmake")
|
ENDIF(EXISTS "${CMAKE_ROOT}/Modules/InstallRequiredSystemLibraries.cmake")
|
||||||
# Set the options file that needs to be included inside CMakeCPackOptions.cmake
|
# Set the options file that needs to be included inside CMakeCPackOptions.cmake
|
||||||
|
|
|
@ -16,6 +16,12 @@
|
||||||
# libraries are installed as well as the CRT run time libraries.
|
# libraries are installed as well as the CRT run time libraries.
|
||||||
# If CMAKE_INSTALL_SYSTEM_RUNTIME_DESTINATION is set then the libraries are
|
# If CMAKE_INSTALL_SYSTEM_RUNTIME_DESTINATION is set then the libraries are
|
||||||
# installed to that directory rather than the default.
|
# installed to that directory rather than the default.
|
||||||
|
# If CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS is NOT set, then this file
|
||||||
|
# warns about required files that do not exist. You can set this variable to
|
||||||
|
# ON before including this file to avoid the warning. For example, the Visual
|
||||||
|
# Studio Express editions do not include the redistributable files, so if you
|
||||||
|
# include this file on a machine with only VS Express installed, you'll get
|
||||||
|
# the warning.
|
||||||
|
|
||||||
#=============================================================================
|
#=============================================================================
|
||||||
# Copyright 2006-2009 Kitware, Inc.
|
# Copyright 2006-2009 Kitware, Inc.
|
||||||
|
@ -304,9 +310,14 @@ IF(MSVC)
|
||||||
SET(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS
|
SET(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS
|
||||||
${CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS} ${lib})
|
${CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS} ${lib})
|
||||||
ELSE(EXISTS ${lib})
|
ELSE(EXISTS ${lib})
|
||||||
|
IF(NOT CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS)
|
||||||
MESSAGE(WARNING "system runtime library file does not exist: '${lib}'")
|
MESSAGE(WARNING "system runtime library file does not exist: '${lib}'")
|
||||||
# This warning indicates an incomplete Visual Studio installation
|
# This warning indicates an incomplete Visual Studio installation
|
||||||
# or a bug somewhere above here in this file
|
# or a bug somewhere above here in this file.
|
||||||
|
# If you would like to avoid this warning, fix the real problem, or
|
||||||
|
# set CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_NO_WARNINGS before including
|
||||||
|
# this file.
|
||||||
|
ENDIF()
|
||||||
ENDIF(EXISTS ${lib})
|
ENDIF(EXISTS ${lib})
|
||||||
ENDFOREACH(lib)
|
ENDFOREACH(lib)
|
||||||
ENDIF(MSVC)
|
ENDIF(MSVC)
|
||||||
|
|
Loading…
Reference in New Issue