[PATCH] D90025: add LLVM_INCLUDE_LIB CMake option

Ivan Le Lann via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Oct 23 04:29:12 PDT 2020


ilelann created this revision.
ilelann added a reviewer: ldionne.
ilelann added a project: LLVM.
Herald added subscribers: llvm-commits, mgorny.
ilelann requested review of this revision.

Including lib does not seem to be required when one want, example given, to build libcxx.
Same rationale as the others LLLM_INCLUDE options: it reduces the number of targets, and makes life inside IDE easier.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D90025

Files:
  llvm/CMakeLists.txt


Index: llvm/CMakeLists.txt
===================================================================
--- llvm/CMakeLists.txt
+++ llvm/CMakeLists.txt
@@ -563,6 +563,7 @@
 
 option (LLVM_BUILD_DOCS "Build the llvm documentation." OFF)
 option (LLVM_INCLUDE_DOCS "Generate build targets for llvm documentation." ON)
+option (LLVM_INCLUDE_LIB "Generate build targets for llvm libraries." ON)
 option (LLVM_ENABLE_DOXYGEN "Use doxygen to generate llvm API documentation." OFF)
 option (LLVM_ENABLE_SPHINX "Use Sphinx to generate llvm documentation." OFF)
 option (LLVM_ENABLE_OCAMLDOC "Build OCaml bindings documentation." ON)
@@ -987,16 +988,25 @@
   llvm_replace_compiler_option(CMAKE_CXX_FLAGS_RELEASE "-O3" "-O2")
 endif()
 
-# Put this before tblgen. Else we have a circular dependence.
-add_subdirectory(lib/Demangle)
-add_subdirectory(lib/Support)
-add_subdirectory(lib/TableGen)
+if( LLVM_INCLUDE_UTILS AND NOT LLVM_INCLUDE_LIB )
+    message(FATAL_ERROR "Including utils when not building lib will not work.
+    Either set LLVM_INCLUDE_LIB to On, or set LLVM_INCLUDE_UTILS to Off.")
+endif()
 
-add_subdirectory(utils/TableGen)
+if( LLVM_INCLUDE_LIB )
+  # Put this before tblgen. Else we have a circular dependence.
+  add_subdirectory(lib/Demangle)
+  add_subdirectory(lib/Support)
+  add_subdirectory(lib/TableGen)
 
-add_subdirectory(include/llvm)
+  if( LLVM_INCLUDE_UTILS )
+    add_subdirectory(utils/TableGen)
+  endif()
 
-add_subdirectory(lib)
+  add_subdirectory(include/llvm)
+
+  add_subdirectory(lib)
+endif()
 
 if( LLVM_INCLUDE_UTILS )
   add_subdirectory(utils/FileCheck)


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D90025.300224.patch
Type: text/x-patch
Size: 1588 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201023/e88efd6a/attachment.bin>


More information about the llvm-commits mailing list