Skip to content

Commit

Permalink
Require TransitionFactory subclasses to implement transitionType.
Browse files Browse the repository at this point in the history
This guarantees that it is accurate, the default of `ANY` was too broad.

Part of bazelbuild#22248.

PiperOrigin-RevId: 632513554
Change-Id: I90b66b45b640ba84b658f23cb56a9016dd853310
  • Loading branch information
katre authored and Kila2 committed May 13, 2024
1 parent 21673d9 commit 0bdccf7
Show file tree
Hide file tree
Showing 21 changed files with 124 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,11 @@ abstract static class IdentityFactory<T extends TransitionFactory.Data>
public ConfigurationTransition create(T data) {
return transition();
}

@Override
public TransitionType transitionType() {
return TransitionType.ANY;
}
}

/** A {@link TransitionFactory} implementation that wraps a split transition. */
Expand All @@ -66,6 +71,12 @@ abstract static class SplitTransitionFactory<T extends TransitionFactory.Data>
implements TransitionFactory<T> {
abstract SplitTransition splitTransition();

@Override
public TransitionType transitionType() {
// Splits can only be used on attributes.
return TransitionType.ATTRIBUTE;
}

@Override
public SplitTransition create(T data) {
return splitTransition();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,12 @@ public ConfigurationTransition create(T data) {
return new ComposingTransition(transition1, transition2);
}

@Override
public TransitionType transitionType() {
// Both types must match so this is correct.
return transitionFactory1().transitionType();
}

abstract TransitionFactory<T> transitionFactory1();

abstract TransitionFactory<T> transitionFactory2();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,11 @@ public PatchTransition create(T unused) {
return INSTANCE;
}

@Override
public TransitionType transitionType() {
return TransitionType.ANY;
}

@Override
public boolean isTool() {
return true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,5 +52,10 @@ abstract static class Factory<T extends TransitionFactory.Data> implements Trans
public ConfigurationTransition create(T unused) {
return INSTANCE;
}

@Override
public TransitionType transitionType() {
return TransitionType.ANY;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,5 +57,10 @@ abstract static class Factory<T extends TransitionFactory.Data> implements Trans
public ConfigurationTransition create(T unused) {
return INSTANCE;
}

@Override
public TransitionType transitionType() {
return TransitionType.ANY;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,9 +57,11 @@ interface Data {}
/** Returns a new {@link ConfigurationTransition}, based on the given data. */
ConfigurationTransition create(T data);

default TransitionType transitionType() {
return TransitionType.ANY;
}
/**
* Returns a {@link TransitionType} to clarify what data (if any) the factory requires to create a
* transation.
*/
TransitionType transitionType();

// TODO(https://github.com/bazelbuild/bazel/issues/7814): Once everything uses TransitionFactory,
// remove these methods.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
import com.google.devtools.build.lib.analysis.config.Fragment;
import com.google.devtools.build.lib.analysis.config.ToolchainTypeRequirement;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory.TransitionType;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.cmdline.LabelSyntaxException;
import com.google.devtools.build.lib.cmdline.RepositoryName;
Expand Down Expand Up @@ -1142,6 +1143,8 @@ public Builder cfg(TransitionFactory<RuleTransitionData> transitionFactory) {
name);
Preconditions.checkState(this.transitionFactory == null, "Property cfg has already been set");
Preconditions.checkNotNull(transitionFactory);
Preconditions.checkArgument(
transitionFactory.transitionType().isCompatibleWith(TransitionType.RULE));
Preconditions.checkArgument(!transitionFactory.isSplit());
this.transitionFactory = transitionFactory;
return this;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,11 @@ public static final class AndroidPlatformsTransitionFactory
public PatchTransition create(RuleTransitionData unused) {
return INSTANCE;
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
}

public static TransitionFactory<RuleTransitionData> create() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ java_library(
"//src/main/java/com/google/devtools/build/lib/actions:artifacts",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/patch_transition",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/starlark_exposed_rule_transition_factory",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/transition_factory",
"//src/main/java/com/google/devtools/build/lib/analysis:rule_definition_environment",
"//src/main/java/com/google/devtools/build/lib/cmdline",
"//src/main/java/com/google/devtools/build/lib/packages",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,9 @@ public void addToStarlarkRule(RuleDefinitionEnvironment ctx, RuleClass.Builder b
public PatchTransition create(RuleTransitionData ruleData) {
return null;
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,14 @@
import com.google.devtools.build.lib.analysis.config.FragmentOptions;
import com.google.devtools.build.lib.analysis.config.InvalidConfigurationException;
import com.google.devtools.build.lib.analysis.config.RequiresOptions;
import com.google.devtools.build.lib.analysis.config.transitions.ConfigurationTransition;
import com.google.devtools.build.lib.analysis.config.transitions.NoTransition;
import com.google.devtools.build.lib.analysis.config.transitions.PatchTransition;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory;
import com.google.devtools.build.lib.analysis.util.AnalysisCachingTestBase;
import com.google.devtools.build.lib.events.Event;
import com.google.devtools.build.lib.events.EventHandler;
import com.google.devtools.build.lib.packages.RuleTransitionData;
import com.google.devtools.build.lib.rules.java.JavaInfo;
import com.google.devtools.build.lib.rules.java.JavaSourceJarsProvider;
import com.google.devtools.build.lib.testutil.TestConstants;
Expand Down Expand Up @@ -1073,11 +1076,19 @@ private void setupDiffResetTesting() throws Exception {
return !optionsThatCanChange.contains(changedOption);
});
builder.overrideTrimmingTransitionFactoryForTesting(
(ruleData) -> {
if (ruleData.rule().getRuleClassObject().getName().equals("uses_irrelevant")) {
return NoTransition.INSTANCE;
new TransitionFactory<>() {
@Override
public ConfigurationTransition create(RuleTransitionData ruleData) {
if (ruleData.rule().getRuleClassObject().getName().equals("uses_irrelevant")) {
return NoTransition.INSTANCE;
}
return DiffResetOptions.CLEAR_IRRELEVANT;
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
return DiffResetOptions.CLEAR_IRRELEVANT;
});
useRuleClassProvider(builder.build());
scratch.file(
Expand Down
1 change: 1 addition & 0 deletions src/test/java/com/google/devtools/build/lib/analysis/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -441,6 +441,7 @@ java_test(
"//src/main/java/com/google/devtools/build/lib/actions",
"//src/main/java/com/google/devtools/build/lib/actions:artifacts",
"//src/main/java/com/google/devtools/build/lib/analysis:analysis_cluster",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/configuration_transition",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/transition_factory",
"//src/main/java/com/google/devtools/build/lib/analysis:configured_target",
"//src/main/java/com/google/devtools/build/lib/analysis/platform",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -306,7 +306,7 @@ def _impl(ctx):
.mandatory()
.allowedFileTypes()
.cfg(
new TransitionFactory<AttributeTransitionData>() {
new TransitionFactory<>() {
@Override
public SplitTransition create(AttributeTransitionData data) {
return new SplitTransition() {
Expand All @@ -332,6 +332,11 @@ public Map<String, BuildOptions> split(
};
}

@Override
public TransitionType transitionType() {
return TransitionType.ATTRIBUTE;
}

@Override
public boolean isSplit() {
return true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,7 @@ public class NoConfigTransitionTest extends BuildViewTestCase {
private static final MockRule NO_CONFIG_RULE =
() ->
MockRule.define(
"no_config_rule",
(builder, env) -> builder.cfg(unused -> NoConfigTransition.INSTANCE));
"no_config_rule", (builder, env) -> builder.cfg(NoConfigTransition.createFactory()));

@Override
protected ConfiguredRuleClassProvider createRuleClassProvider() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,13 +28,14 @@
import com.google.devtools.build.lib.analysis.ConfiguredTarget;
import com.google.devtools.build.lib.analysis.FilesToRunProvider;
import com.google.devtools.build.lib.analysis.actions.FileWriteAction;
import com.google.devtools.build.lib.analysis.config.transitions.ConfigurationTransition;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory.Data;
import com.google.devtools.build.lib.analysis.platform.ToolchainInfo;
import com.google.devtools.build.lib.analysis.util.BuildViewTestCase;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.cmdline.LabelSyntaxException;
import com.google.devtools.build.lib.packages.Attribute;
import com.google.devtools.build.lib.packages.AttributeTransitionData;
import com.google.devtools.build.lib.packages.AttributeValueSource;
import com.google.devtools.build.lib.packages.Provider;
import com.google.devtools.build.lib.packages.StarlarkInfo;
Expand Down Expand Up @@ -701,7 +702,19 @@ public void testSubruleAttrs_cannotHaveStarlarkTransitions() throws Exception {

@Test
public void testSubruleAttrs_cannotHaveNativeTransitions() throws Exception {
ev.update("native_transition", (TransitionFactory<Data>) data -> null);
ev.update(
"native_transition",
new TransitionFactory<AttributeTransitionData>() {
@Override
public ConfigurationTransition create(AttributeTransitionData data) {
return null;
}

@Override
public TransitionType transitionType() {
return TransitionType.ATTRIBUTE;
}
});
ev.checkEvalErrorContains(
"bad cfg for attribute '_foo': subrules may only have target/exec attributes.",
"_my_subrule = subrule(",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,11 @@ public PatchTransition create(RuleTransitionData ruleData) {
return new PathTransition(
NonconfigurableAttributeMapper.of(ruleData.rule()).get("path", STRING));
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
}

private static final class UselessOptionTransition implements PatchTransition {
Expand Down Expand Up @@ -152,6 +157,11 @@ public PatchTransition create(RuleTransitionData ruleData) {
return new UselessOptionTransition(
NonconfigurableAttributeMapper.of(ruleData.rule()).get("value", STRING));
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
}

private static final class PathTestRulesModule extends BlazeModule {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -162,6 +162,7 @@ java_test(
":configured_target_query_test",
"//src/main/java/com/google/devtools/build/lib/analysis:analysis_cluster",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transition_factories",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/configuration_transition",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/no_transition",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/transition_factory",
"//src/main/java/com/google/devtools/build/lib/events",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,9 @@ public void testTopLevelTransition() throws Exception {
MockRule.define(
"rule_class_transition",
(builder, env) ->
builder.cfg(unused -> new FooPatchTransition("SET BY PATCH")).build());
builder
.cfg(TransitionFactories.of(new FooPatchTransition("SET BY PATCH")))
.build());

helper.useRuleClassProvider(setRuleClassProviders(ruleClassTransition).build());
helper.setUniverseScope("//test:rule_class");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import com.google.common.eventbus.EventBus;
import com.google.devtools.build.lib.analysis.ConfiguredRuleClassProvider;
import com.google.devtools.build.lib.analysis.config.TransitionFactories;
import com.google.devtools.build.lib.analysis.config.transitions.ConfigurationTransition;
import com.google.devtools.build.lib.analysis.config.transitions.NoTransition;
import com.google.devtools.build.lib.analysis.config.transitions.TransitionFactory;
import com.google.devtools.build.lib.analysis.util.MockRule;
Expand Down Expand Up @@ -219,12 +220,20 @@ public void nonAttributeDependencySkipped() throws Exception {

private void setUpRules() throws Exception {
TransitionFactory<RuleTransitionData> infixTrimmingTransitionFactory =
(ruleData) -> {
if (!ruleData.rule().getName().contains("trimmed")) {
return NoTransition.INSTANCE;
new TransitionFactory<>() {
@Override
public ConfigurationTransition create(RuleTransitionData ruleData) {
if (!ruleData.rule().getName().contains("trimmed")) {
return NoTransition.INSTANCE;
}
// rename the transition so it's distinguishable from the others in tests
return new FooPatchTransition("SET BY TRIM", "FooPatchTransition(trim)");
}

@Override
public TransitionType transitionType() {
return TransitionType.RULE;
}
// rename the transition so it's distinguishable from the others in tests
return new FooPatchTransition("SET BY TRIM", "FooPatchTransition(trim)");
};
FooPatchTransition ruleClassTransition = new FooPatchTransition("SET BY RULE CLASS PATCH");
FooPatchTransition attributePatchTransition = new FooPatchTransition("SET BY PATCH");
Expand All @@ -237,7 +246,7 @@ private void setUpRules() throws Exception {
"my_rule",
(builder, env) ->
builder
.cfg(unused -> ruleClassTransition)
.cfg(TransitionFactories.of(ruleClassTransition))
.add(
attr("patched", LABEL_LIST)
.allowedFileTypes(FileTypeSet.ANY_FILE)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ java_library(
"//src/main/java/com/google/devtools/build/lib/analysis:config/build_options",
"//src/main/java/com/google/devtools/build/lib/analysis:config/fragment_options",
"//src/main/java/com/google/devtools/build/lib/analysis:config/toolchain_type_requirement",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transition_factories",
"//src/main/java/com/google/devtools/build/lib/analysis:config/transitions/patch_transition",
"//src/main/java/com/google/devtools/build/lib/analysis:server_directories",
"//src/main/java/com/google/devtools/build/lib/bazel/bzlmod:common",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import com.google.devtools.build.lib.analysis.config.BuildOptionsView;
import com.google.devtools.build.lib.analysis.config.FragmentOptions;
import com.google.devtools.build.lib.analysis.config.ToolchainTypeRequirement;
import com.google.devtools.build.lib.analysis.config.TransitionFactories;
import com.google.devtools.build.lib.analysis.config.transitions.PatchTransition;
import com.google.devtools.build.lib.analysis.util.DummyTestFragment.DummyTestOptions;
import com.google.devtools.build.lib.analysis.util.MockRule;
Expand Down Expand Up @@ -618,7 +619,9 @@ public void testMultipleTopLevelConfigurations() throws Exception {
MockRule.define(
"transitioned_rule",
(builder, env) ->
builder.cfg(unused -> new FooPatchTransition("SET BY PATCH")).build());
builder
.cfg(TransitionFactories.of(new FooPatchTransition("SET BY PATCH")))
.build());

MockRule untransitionedRule = () -> MockRule.define("untransitioned_rule");

Expand Down Expand Up @@ -653,7 +656,7 @@ public void testMultipleTopLevelConfigurations_multipleConfigsPrefersTopLevel()
"rule_with_transition_and_dep",
(builder, env) ->
builder
.cfg(unused -> new FooPatchTransition("SET BY PATCH"))
.cfg(TransitionFactories.of(new FooPatchTransition("SET BY PATCH")))
.addAttribute(
attr("dep", LABEL).allowedFileTypes(FileTypeSet.ANY_FILE).build())
.build());
Expand Down

0 comments on commit 0bdccf7

Please sign in to comment.