| 123456789101112131415161718192021222324252627282930313233343536 |
- CMP0119
- -------
- .. versionadded:: 3.20
- :prop_sf:`LANGUAGE` source file property explicitly compiles as specified
- language.
- The :prop_sf:`LANGUAGE` source file property is documented to mean that the
- source file is written in the specified language. In CMake 3.19 and below,
- setting this property causes CMake to compile the source file using the
- compiler for the specified language. However, it only passes an explicit
- flag to tell the compiler to treat the source as the specified language
- for MSVC-like, XL, and Embarcadero compilers for the ``CXX`` language.
- CMake 3.20 and above prefer to also explicitly tell the compiler to use
- the specified language using a flag such as ``-x c`` on all compilers
- for which such flags are known.
- This policy provides compatibility for projects that have not been updated
- to expect this behavior. For example, some projects were setting the
- ``LANGUAGE`` property to ``C`` on assembly-language ``.S`` source files
- in order to compile them using the C compiler. Such projects should be
- updated to use ``enable_language(ASM)``, for which CMake will often choose
- the C compiler as the assembler on relevant platforms anyway.
- The ``OLD`` behavior for this policy is to interpret the ``LANGUAGE <LANG>``
- property using its undocumented meaning to "use the ``<LANG>`` compiler".
- The ``NEW`` behavior for this policy is to interpret the ``LANGUAGE <LANG>``
- property using its documented meaning to "compile as a ``<LANG>`` source".
- This policy was introduced in CMake version 3.20. Use the
- :command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
- Unlike many policies, CMake version |release| does *not* warn
- when this policy is not set and simply uses ``OLD`` behavior.
- .. include:: DEPRECATED.txt
|