You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
4.1 KiB
115 lines
4.1 KiB
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
CMakeForceCompiler
|
|
------------------
|
|
|
|
.. deprecated:: 3.6
|
|
|
|
Do not use.
|
|
|
|
The macros provided by this module were once intended for use by
|
|
cross-compiling toolchain files when CMake was not able to automatically
|
|
detect the compiler identification. Since the introduction of this module,
|
|
CMake's compiler identification capabilities have improved and can now be
|
|
taught to recognize any compiler. Furthermore, the suite of information
|
|
CMake detects from a compiler is now too extensive to be provided by
|
|
toolchain files using these macros.
|
|
|
|
One common use case for this module was to skip CMake's checks for a
|
|
working compiler when using a cross-compiler that cannot link binaries
|
|
without special flags or custom linker scripts. This case is now supported
|
|
by setting the :variable:`CMAKE_TRY_COMPILE_TARGET_TYPE` variable in the
|
|
toolchain file instead.
|
|
|
|
-------------------------------------------------------------------------
|
|
|
|
Macro ``CMAKE_FORCE_C_COMPILER`` has the following signature:
|
|
|
|
::
|
|
|
|
CMAKE_FORCE_C_COMPILER(<compiler> <compiler-id>)
|
|
|
|
It sets :variable:`CMAKE_C_COMPILER <CMAKE_<LANG>_COMPILER>` to
|
|
the given compiler and the cmake internal variable
|
|
:variable:`CMAKE_C_COMPILER_ID <CMAKE_<LANG>_COMPILER_ID>` to the given
|
|
compiler-id. It also bypasses the check for working compiler and basic
|
|
compiler information tests.
|
|
|
|
Macro ``CMAKE_FORCE_CXX_COMPILER`` has the following signature:
|
|
|
|
::
|
|
|
|
CMAKE_FORCE_CXX_COMPILER(<compiler> <compiler-id>)
|
|
|
|
It sets :variable:`CMAKE_CXX_COMPILER <CMAKE_<LANG>_COMPILER>` to
|
|
the given compiler and the cmake internal variable
|
|
:variable:`CMAKE_CXX_COMPILER_ID <CMAKE_<LANG>_COMPILER_ID>` to the given
|
|
compiler-id. It also bypasses the check for working compiler and basic
|
|
compiler information tests.
|
|
|
|
Macro ``CMAKE_FORCE_Fortran_COMPILER`` has the following signature:
|
|
|
|
::
|
|
|
|
CMAKE_FORCE_Fortran_COMPILER(<compiler> <compiler-id>)
|
|
|
|
It sets :variable:`CMAKE_Fortran_COMPILER <CMAKE_<LANG>_COMPILER>` to
|
|
the given compiler and the cmake internal variable
|
|
:variable:`CMAKE_Fortran_COMPILER_ID <CMAKE_<LANG>_COMPILER_ID>` to the given
|
|
compiler-id. It also bypasses the check for working compiler and basic
|
|
compiler information tests.
|
|
|
|
So a simple toolchain file could look like this:
|
|
|
|
::
|
|
|
|
include (CMakeForceCompiler)
|
|
set(CMAKE_SYSTEM_NAME Generic)
|
|
CMAKE_FORCE_C_COMPILER (chc12 MetrowerksHicross)
|
|
CMAKE_FORCE_CXX_COMPILER (chc12 MetrowerksHicross)
|
|
#]=======================================================================]
|
|
|
|
macro(CMAKE_FORCE_C_COMPILER compiler id)
|
|
message(DEPRECATION "The CMAKE_FORCE_C_COMPILER macro is deprecated. "
|
|
"Instead just set CMAKE_C_COMPILER and allow CMake to identify the compiler.")
|
|
set(CMAKE_C_COMPILER "${compiler}")
|
|
set(CMAKE_C_COMPILER_ID_RUN TRUE)
|
|
set(CMAKE_C_COMPILER_ID ${id})
|
|
set(CMAKE_C_COMPILER_FORCED TRUE)
|
|
|
|
# Set old compiler id variables.
|
|
if(CMAKE_C_COMPILER_ID MATCHES "GNU")
|
|
set(CMAKE_COMPILER_IS_GNUCC 1)
|
|
endif()
|
|
endmacro()
|
|
|
|
macro(CMAKE_FORCE_CXX_COMPILER compiler id)
|
|
message(DEPRECATION "The CMAKE_FORCE_CXX_COMPILER macro is deprecated. "
|
|
"Instead just set CMAKE_CXX_COMPILER and allow CMake to identify the compiler.")
|
|
set(CMAKE_CXX_COMPILER "${compiler}")
|
|
set(CMAKE_CXX_COMPILER_ID_RUN TRUE)
|
|
set(CMAKE_CXX_COMPILER_ID ${id})
|
|
set(CMAKE_CXX_COMPILER_FORCED TRUE)
|
|
|
|
# Set old compiler id variables.
|
|
if("${CMAKE_CXX_COMPILER_ID}" MATCHES "GNU")
|
|
set(CMAKE_COMPILER_IS_GNUCXX 1)
|
|
endif()
|
|
endmacro()
|
|
|
|
macro(CMAKE_FORCE_Fortran_COMPILER compiler id)
|
|
message(DEPRECATION "The CMAKE_FORCE_Fortran_COMPILER macro is deprecated. "
|
|
"Instead just set CMAKE_Fortran_COMPILER and allow CMake to identify the compiler.")
|
|
set(CMAKE_Fortran_COMPILER "${compiler}")
|
|
set(CMAKE_Fortran_COMPILER_ID_RUN TRUE)
|
|
set(CMAKE_Fortran_COMPILER_ID ${id})
|
|
set(CMAKE_Fortran_COMPILER_FORCED TRUE)
|
|
|
|
# Set old compiler id variables.
|
|
if(CMAKE_Fortran_COMPILER_ID MATCHES "GNU")
|
|
set(CMAKE_COMPILER_IS_GNUG77 1)
|
|
endif()
|
|
endmacro()
|