Hook up objc's parse_header feature logic to toolchain's supports_header_parsing attribute
RELNOTES: None
PiperOrigin-RevId: 316635766
diff --git a/src/main/java/com/google/devtools/build/lib/rules/objc/CompilationSupport.java b/src/main/java/com/google/devtools/build/lib/rules/objc/CompilationSupport.java
index 4b63841..818b57d 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/objc/CompilationSupport.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/objc/CompilationSupport.java
@@ -16,6 +16,7 @@
import static com.google.common.base.Preconditions.checkNotNull;
import static com.google.common.base.Preconditions.checkState;
+import static com.google.common.collect.ImmutableSet.toImmutableSet;
import static com.google.common.collect.ImmutableSortedSet.toImmutableSortedSet;
import static com.google.devtools.build.lib.packages.ImplicitOutputsFunction.fromTemplates;
import static com.google.devtools.build.lib.rules.cpp.Link.LINK_LIBRARY_FILETYPES;
@@ -584,9 +585,18 @@
activatedCrosstoolSelectables.addAll(CcCommon.getCoverageFeatures(cppConfiguration));
try {
- return ccToolchain
- .getFeatures()
- .getFeatureConfiguration(activatedCrosstoolSelectables.build());
+ ImmutableSet<String> activatedCrosstoolSelectablesSet;
+ if (!ccToolchain.supportsHeaderParsing()) {
+ // TODO(b/159096411): Remove once supports_header_parsing has been removed from the
+ // cc_toolchain rule.
+ activatedCrosstoolSelectablesSet =
+ activatedCrosstoolSelectables.build().stream()
+ .filter(feature -> !feature.equals(CppRuleClasses.PARSE_HEADERS))
+ .collect(toImmutableSet());
+ } else {
+ activatedCrosstoolSelectablesSet = activatedCrosstoolSelectables.build();
+ }
+ return ccToolchain.getFeatures().getFeatureConfiguration(activatedCrosstoolSelectablesSet);
} catch (CollidingProvidesException e) {
ruleContext.ruleError(e.getMessage());
return FeatureConfiguration.EMPTY;