CMP0129.rst 1.6 KB

12345678910111213141516171819202122232425262728293031323334
  1. CMP0129
  2. -------
  3. .. versionadded:: 3.23
  4. Compiler id for MCST LCC compilers is now ``LCC``, not ``GNU``.
  5. CMake 3.23 and above recognize MCST LCC compiler as a different from ``GNU``,
  6. with its own command line and set of capabilities.
  7. CMake now prefers to present this to projects by setting the
  8. :variable:`CMAKE_<LANG>_COMPILER_ID` variable to ``LCC`` instead
  9. of ``GNU``. However, existing projects may assume the compiler id for
  10. LCC is ``GNU`` as it was in CMake versions prior to 3.23.
  11. Therefore this policy determines for MCST LCC compiler which
  12. compiler id to report in the :variable:`CMAKE_<LANG>_COMPILER_ID`
  13. variable after language ``<LANG>`` is enabled by the :command:`project`
  14. or :command:`enable_language` command. The policy must be set prior
  15. to the invocation of either command.
  16. The ``OLD`` behavior for this policy is to use compiler id ``GNU`` (and set
  17. :variable:`CMAKE_<LANG>_COMPILER_VERSION` to the supported GNU compiler version.)
  18. ``NEW`` behavior for this policy is to use compiler id ``LCC``, and set
  19. :variable:`CMAKE_<LANG>_SIMULATE_ID` to ``GNU``, and
  20. :variable:`CMAKE_<LANG>_SIMULATE_VERSION` to the supported GNU compiler version.
  21. This policy was introduced in CMake version 3.23. Use the
  22. :command:`cmake_policy` command to set this policy to ``OLD`` or ``NEW`` explicitly.
  23. Unlike most policies, CMake version |release| does *not* warn
  24. by default when this policy is not set and simply uses ``OLD`` behavior.
  25. See documentation of the
  26. :variable:`CMAKE_POLICY_WARNING_CMP0129 <CMAKE_POLICY_WARNING_CMP<NNNN>>`
  27. variable to control the warning.
  28. .. include:: DEPRECATED.txt