[PATCH] D80218: Use configure depends to trigger reconfiguration when LLVMBuild files change

Daniel Frampton via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue May 19 08:42:32 PDT 2020


danielframpton created this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.

The existing logic has a workaround where configure_file is used to write a single dummy file output many times.

CMake has a feature to more directly add the dependency and avoid the dummy file (it is available in the minimum version specified).


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D80218

Files:
  llvm/utils/llvm-build/llvmbuild/main.py


Index: llvm/utils/llvm-build/llvmbuild/main.py
===================================================================
--- llvm/utils/llvm-build/llvmbuild/main.py
+++ llvm/utils/llvm-build/llvmbuild/main.py
@@ -563,19 +563,10 @@
         f.write("""
 # LLVMBuild CMake fragment dependencies.
 #
-# CMake has no builtin way to declare that the configuration depends on
-# a particular file. However, a side effect of configure_file is to add
-# said input file to CMake's internal dependency list. So, we use that
-# and a dummy output file to communicate the dependency information to
-# CMake.
-#
-# FIXME: File a CMake RFE to get a properly supported version of this
-# feature.
 """)
         for dep in dependencies:
             f.write("""\
-configure_file(\"%s\"
-               ${CMAKE_CURRENT_BINARY_DIR}/DummyConfigureOutput)\n""" % (
+set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS \"%s\")\n""" % (
                 cmake_quote_path(dep),))
 
         # Write the properties we use to encode the required library dependency


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D80218.264929.patch
Type: text/x-patch
Size: 1047 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200519/25758ad9/attachment.bin>


More information about the llvm-commits mailing list