| ======================= |
| LLVM Common CMake Utils |
| ======================= |
| |
| What goes here |
| -------------- |
| |
| These are CMake modules to be shared between LLVM projects strictly at build |
| time. In other words, they must not be included from an installed CMake module, |
| such as the ``Add*.cmake`` ones. Modules that are reachable from installed |
| modules should instead go in ``${project}/cmake/modules`` of the most upstream |
| project that uses them. |
| |
| The advantage of not putting these modules in an existing location like |
| ``llvm/cmake/modules`` is two-fold: |
| |
| - Since they are not installed, we don't have to worry about any out-of-tree |
| downstream usage, and thus there is no need for stability. |
| |
| - Since they are available as part of the source at build-time, we don't have |
| to do the usual stand-alone vs combined-build dances, avoiding much |
| complexity. |
| |
| How to use |
| ---------- |
| |
| For tools, please do: |
| |
| .. code-block:: cmake |
| |
| if(NOT DEFINED LLVM_COMMON_CMAKE_UTILS) |
| set(LLVM_COMMON_CMAKE_UTILS ${CMAKE_CURRENT_SOURCE_DIR}/../cmake) |
| endif() |
| |
| # Add path for custom modules. |
| list(INSERT CMAKE_MODULE_PATH 0 |
| # project-specific module dirs first |
| "${LLVM_COMMON_CMAKE_UTILS}/Modules" |
| ) |
| |
| Notes: |
| |
| - The ``if(NOT DEFINED ...)`` guard is there because in combined builds, LLVM |
| will set this variable. This is useful for legacy builds where projects are |
| found in ``llvm/tools`` instead. |
| |
| - ``INSERT ... 0`` ensures these new entries are prepended to the front of the |
| module path, so nothing might shadow them by mistake. |
| |
| For runtime libs, we skip the ``if(NOT DEFINED`` part: |
| |
| .. code-block:: cmake |
| |
| set(LLVM_COMMON_CMAKE_UTILS ${CMAKE_CURRENT_SOURCE_DIR}/../cmake) |
| |
| ... # same as before |
| |
| If ``llvm/tools`` legacy-style combined builds are deprecated, we should then |
| skip it everywhere, bringing the tools and runtimes boilerplate back in line. |