aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java
diff options
context:
space:
mode:
authorGravatar ulfjack <ulfjack@google.com>2018-08-02 05:16:00 -0700
committerGravatar Copybara-Service <copybara-piper@google.com>2018-08-02 05:17:26 -0700
commit36fbbde3a5a0e570ba55ea1e7d4dc3b26b135a20 (patch)
tree2cd4b100b7711339243d33046c4099007177e7fa /src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java
parent13ebd67cf8ea756a0e82eaa03f0f4a9581ccf9be (diff)
Add a flag to evaluate the top level transitions in Skyframe
This adds a new PrepareAnalysisPhaseFunction, which started out as a copy of some existing code from SkyframeExecutor, BuildView, AnalysisPhaseRunner, AnalysisUtils, and ConfigurationResolver, which was then modified to work inside Skyframe. Most of our tests already work with the new code, except for some of the tests related to configuration trimming in combination with dependency cycles. The reason for this is that we can only recover from dependency cycles at the end of a Skyframe invocation, but never inside a Skyframe invocation. The new code therefore cannot return partial results like the old code. This seems to make null builds a bit faster. In my testing, I saw null build times for a single test target go from ~50ms to ~40ms. This is probably due to slightly better caching - it seems that computing the configuration transitions and top-level targets is non-negligible, even if there's only a single top-level configuration for a single top-level target. This might be an even bigger win if there are a lot of top-level targets and configurations. PiperOrigin-RevId: 207083192
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java')
-rw-r--r--src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java27
1 files changed, 20 insertions, 7 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java b/src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java
index a7c9b3126d..617e320899 100644
--- a/src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java
+++ b/src/main/java/com/google/devtools/build/lib/skyframe/TransitiveTargetCycleReporter.java
@@ -14,6 +14,7 @@
package com.google.devtools.build.lib.skyframe;
import com.google.common.base.Predicate;
+import com.google.common.base.Predicates;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
@@ -31,9 +32,10 @@ import java.util.List;
* (e.g. '//a:foo' depends on '//b:bar' and '//b:bar' depends on '//a:foo').
*/
class TransitiveTargetCycleReporter extends AbstractLabelCycleReporter {
-
- private static final Predicate<SkyKey> IS_TRANSITIVE_TARGET_SKY_KEY =
- SkyFunctions.isSkyFunction(SkyFunctions.TRANSITIVE_TARGET);
+ private static final Predicate<SkyKey> IS_SUPPORTED_SKY_KEY =
+ Predicates.or(
+ SkyFunctions.isSkyFunction(SkyFunctions.TRANSITIVE_TARGET),
+ SkyFunctions.isSkyFunction(SkyFunctions.PREPARE_ANALYSIS_PHASE));
TransitiveTargetCycleReporter(PackageProvider packageProvider) {
super(packageProvider);
@@ -43,7 +45,7 @@ class TransitiveTargetCycleReporter extends AbstractLabelCycleReporter {
protected boolean canReportCycle(SkyKey topLevelKey, CycleInfo cycleInfo) {
return Iterables.all(Iterables.concat(ImmutableList.of(topLevelKey),
cycleInfo.getPathToCycle(), cycleInfo.getCycle()),
- IS_TRANSITIVE_TARGET_SKY_KEY);
+ IS_SUPPORTED_SKY_KEY);
}
@Override
@@ -57,18 +59,29 @@ class TransitiveTargetCycleReporter extends AbstractLabelCycleReporter {
}
@Override
+ protected boolean shouldSkip(SkyKey key) {
+ return SkyFunctions.PREPARE_ANALYSIS_PHASE.equals(key.functionName());
+ }
+
+ @Override
protected String getAdditionalMessageAboutCycle(
ExtendedEventHandler eventHandler, SkyKey topLevelKey, CycleInfo cycleInfo) {
- Target currentTarget = getTargetForLabel(eventHandler, getLabel(topLevelKey));
List<SkyKey> keys = Lists.newArrayList();
if (!cycleInfo.getPathToCycle().isEmpty()) {
- keys.add(topLevelKey);
- keys.addAll(cycleInfo.getPathToCycle());
+ if (!shouldSkip(topLevelKey)) {
+ keys.add(topLevelKey);
+ }
+ cycleInfo.getPathToCycle()
+ .stream()
+ .filter(key -> !shouldSkip(key))
+ .forEach(keys::add);
}
keys.addAll(cycleInfo.getCycle());
// Make sure we check the edge from the last element of the cycle to the first element of the
// cycle.
keys.add(cycleInfo.getCycle().get(0));
+
+ Target currentTarget = getTargetForLabel(eventHandler, getLabel(keys.get(0)));
for (SkyKey nextKey : keys) {
Label nextLabel = getLabel(nextKey);
Target nextTarget = getTargetForLabel(eventHandler, nextLabel);