From 880508ccf8bab7aa9d238210f8b2ee21d52600f9 Mon Sep 17 00:00:00 2001 From: tomlu Date: Fri, 3 Aug 2018 11:21:29 -0700 Subject: Add support to completion function to create a path resolver from its looked-up artifact values. RELNOTES: None PiperOrigin-RevId: 207295716 --- .../build/lib/skyframe/CompletionFunction.java | 44 ++++++++++++++++++---- 1 file changed, 36 insertions(+), 8 deletions(-) (limited to 'src/main/java/com/google/devtools/build/lib/skyframe/CompletionFunction.java') diff --git a/src/main/java/com/google/devtools/build/lib/skyframe/CompletionFunction.java b/src/main/java/com/google/devtools/build/lib/skyframe/CompletionFunction.java index 5d1fa1c7a9..57a9d47206 100644 --- a/src/main/java/com/google/devtools/build/lib/skyframe/CompletionFunction.java +++ b/src/main/java/com/google/devtools/build/lib/skyframe/CompletionFunction.java @@ -14,6 +14,7 @@ package com.google.devtools.build.lib.skyframe; import com.google.devtools.build.lib.actions.ActionExecutionException; +import com.google.devtools.build.lib.actions.ActionInputMap; import com.google.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.actions.ArtifactPathResolver; import com.google.devtools.build.lib.actions.ArtifactSkyKey; @@ -39,6 +40,8 @@ import com.google.devtools.build.skyframe.SkyFunctionException; import com.google.devtools.build.skyframe.SkyKey; import com.google.devtools.build.skyframe.SkyValue; import com.google.devtools.build.skyframe.ValueOrException2; +import java.util.Collection; +import java.util.HashMap; import java.util.Map; import javax.annotation.Nullable; @@ -48,6 +51,12 @@ import javax.annotation.Nullable; public final class CompletionFunction implements SkyFunction { + interface PathResolverFactory { + ArtifactPathResolver createPathResolverForArtifactValues(ActionInputMap actionInputMap); + + boolean shouldCreatePathResolverForArtifactValues(); + } + /** A strategy for completing the build. */ interface Completor { @@ -281,17 +290,20 @@ public final class CompletionFunction(new TargetCompletor()); + public static SkyFunction targetCompletionFunction(PathResolverFactory pathResolverFactory) { + return new CompletionFunction<>(pathResolverFactory, new TargetCompletor()); } - public static SkyFunction aspectCompletionFunction() { - return new CompletionFunction<>(new AspectCompletor()); + public static SkyFunction aspectCompletionFunction(PathResolverFactory pathResolverFactory) { + return new CompletionFunction<>(pathResolverFactory, new AspectCompletor()); } + private final PathResolverFactory pathResolverFactory; private final Completor completor; - private CompletionFunction(Completor completor) { + private CompletionFunction( + PathResolverFactory pathResolverFactory, Completor completor) { + this.pathResolverFactory = pathResolverFactory; this.completor = completor; } @@ -311,6 +323,14 @@ public final class CompletionFunction> expandedArtifacts = null; + if (createPathResolver) { + inputMap = new ActionInputMap(inputDeps.size()); + expandedArtifacts = new HashMap<>(); + } + int missingCount = 0; ActionExecutionException firstActionExecutionException = null; MissingInputFileException missingInputException = null; @@ -319,7 +339,10 @@ public final class CompletionFunction