diff options
author | Googler <noreply@google.com> | 2017-04-29 03:34:50 +0200 |
---|---|---|
committer | Vladimir Moskva <vladmos@google.com> | 2017-04-30 23:14:08 +0200 |
commit | 5f31944b8942818aaf53571c76f5c6a9a9dafc72 (patch) | |
tree | 76fea4ef01225ebb3ce7cd8d2d623aa57e79c025 /src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java | |
parent | 5790def75cc81c36b43a213e26f64c7b1b0855f8 (diff) |
Custom module map for j2objc_library
PiperOrigin-RevId: 154606005
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java')
-rw-r--r-- | src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java b/src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java index 3154b16a34..35b39eedea 100644 --- a/src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java +++ b/src/main/java/com/google/devtools/build/lib/rules/cpp/CcLibraryHelper.java @@ -16,6 +16,7 @@ package com.google.devtools.build.lib.rules.cpp; import com.google.common.base.Function; import com.google.common.base.Joiner; +import com.google.common.base.Optional; import com.google.common.base.Predicates; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; @@ -1384,6 +1385,11 @@ public final class CcLibraryHelper { featureConfiguration.isEnabled(CppRuleClasses.HEADER_MODULES) || featureConfiguration.isEnabled(CppRuleClasses.COMPILE_ALL_MODULES); Iterable<CppModuleMap> dependentModuleMaps = collectModuleMaps(); + Optional<Artifact> umbrellaHeader = cppModuleMap.getUmbrellaHeader(); + if (umbrellaHeader.isPresent()) { + ruleContext.registerAction( + createUmbrellaHeaderAction(umbrellaHeader.get(), publicHeaders)); + } ruleContext.registerAction( createModuleMapAction(cppModuleMap, publicHeaders, dependentModuleMaps, compiled)); if (model.getGeneratesPicHeaderModule()) { @@ -1412,6 +1418,17 @@ public final class CcLibraryHelper { return contextBuilder.build(); } + private UmbrellaHeaderAction createUmbrellaHeaderAction(Artifact umbrellaHeader, + PublicHeaders publicHeaders) { + return new UmbrellaHeaderAction( + ruleContext.getActionOwner(), + umbrellaHeader, + featureConfiguration.isEnabled(CppRuleClasses.ONLY_DOTH_HEADERS_IN_MODULE_MAPS) + ? Iterables.filter(publicHeaders.getModuleMapHeaders(), CppFileTypes.MODULE_MAP_HEADER) + : publicHeaders.getModuleMapHeaders(), + additionalExportedHeaders); + } + private CppModuleMapAction createModuleMapAction( CppModuleMap moduleMap, PublicHeaders publicHeaders, |