[llvm] r245716 - llvm-build: Factor out duplicate cmake export listing. Patch by
Dan Liew via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 21 11:10:52 PDT 2015
Author: delcypher
Date: Fri Aug 21 13:10:51 2015
New Revision: 245716
URL: http://llvm.org/viewvc/llvm-project?rev=245716&view=rev
Log:
llvm-build: Factor out duplicate cmake export listing. Patch by
Brad King.
The write_cmake_fragment and write_cmake_exports_fragment methods share
some logic for selecting libraries that CMake needs to know about.
Factor it out into a helper to avoid duplication.
Modified:
llvm/trunk/utils/llvm-build/llvmbuild/main.py
Modified: llvm/trunk/utils/llvm-build/llvmbuild/main.py
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/llvm-build/llvmbuild/main.py?rev=245716&r1=245715&r2=245716&view=diff
==============================================================================
--- llvm/trunk/utils/llvm-build/llvmbuild/main.py (original)
+++ llvm/trunk/utils/llvm-build/llvmbuild/main.py Fri Aug 21 13:10:51 2015
@@ -501,6 +501,28 @@ subdirectories = %s
if (path.startswith(self.source_root) and os.path.exists(path)):
yield path
+ def foreach_cmake_library(self, f,
+ enabled_optional_components,
+ skip_disabled):
+ for ci in self.ordered_component_infos:
+ # Skip optional components which are not enabled.
+ if ci.type_name == 'OptionalLibrary' \
+ and ci.name not in enabled_optional_components:
+ continue
+
+ # We only write the information for libraries currently.
+ if ci.type_name not in ('Library', 'OptionalLibrary'):
+ continue
+
+ # Skip disabled targets.
+ if skip_disabled:
+ tg = ci.get_parent_target_group()
+ if tg and not tg.enabled:
+ continue
+
+ f(ci)
+
+
def write_cmake_fragment(self, output_path, enabled_optional_components):
"""
write_cmake_fragment(output_path) -> None
@@ -569,21 +591,17 @@ configure_file(\"%s\"
# The following property assignments effectively create a map from component
# names to required libraries, in a way that is easily accessed from CMake.
""")
- for ci in self.ordered_component_infos:
- # Skip optional components which are not enabled.
- if ci.type_name == 'OptionalLibrary' \
- and ci.name not in enabled_optional_components:
- continue
-
- # We only write the information for certain components currently.
- if ci.type_name not in ('Library', 'OptionalLibrary'):
- continue
-
- f.write("""\
+ self.foreach_cmake_library(
+ lambda ci:
+ f.write("""\
set_property(GLOBAL PROPERTY LLVMBUILD_LIB_DEPS_%s %s)\n""" % (
ci.get_prefixed_library_name(), " ".join(sorted(
dep.get_prefixed_library_name()
for dep in self.get_required_libraries_for_component(ci)))))
+ ,
+ enabled_optional_components,
+ skip_disabled = False
+ )
f.close()
@@ -608,26 +626,17 @@ set_property(GLOBAL PROPERTY LLVMBUILD_L
# The following property assignments tell CMake about link
# dependencies of libraries imported from LLVM.
""")
- for ci in self.ordered_component_infos:
- # Skip optional components which are not enabled.
- if ci.type_name == 'OptionalLibrary' \
- and ci.name not in enabled_optional_components:
- continue
-
- # We only write the information for libraries currently.
- if ci.type_name not in ('Library', 'OptionalLibrary'):
- continue
-
- # Skip disabled targets.
- tg = ci.get_parent_target_group()
- if tg and not tg.enabled:
- continue
-
- f.write("""\
+ self.foreach_cmake_library(
+ lambda ci:
+ f.write("""\
set_property(TARGET %s PROPERTY IMPORTED_LINK_INTERFACE_LIBRARIES %s)\n""" % (
ci.get_prefixed_library_name(), " ".join(sorted(
dep.get_prefixed_library_name()
for dep in self.get_required_libraries_for_component(ci)))))
+ ,
+ enabled_optional_components,
+ skip_disabled = True
+ )
f.close()
More information about the llvm-commits
mailing list