blob: c7ba53fdddfdcff6940543027d068eadf1b55a7a [file] [log] [blame]
// Copyright 2014 The Bazel Authors. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.devtools.build.lib.query2.query.aspectresolvers;
import com.google.common.collect.ImmutableMultimap;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.events.ExtendedEventHandler;
import com.google.devtools.build.lib.packages.Attribute;
import com.google.devtools.build.lib.packages.DependencyFilter;
import com.google.devtools.build.lib.packages.Package;
import com.google.devtools.build.lib.packages.Target;
import com.google.devtools.build.lib.pkgcache.PackageProvider;
import java.util.Set;
/** Utility class that determines additional dependencies of a target from its aspects. */
public interface AspectResolver {
/**
* How to resolve aspect dependencies in 'blaze query'.
*/
enum Mode {
// Do not report aspect dependencies
OFF {
@Override
public AspectResolver createResolver(
PackageProvider provider, ExtendedEventHandler eventHandler) {
return new NullAspectResolver();
}
},
// Do not load dependent packages; report deps assuming all aspects defined on a rule are
// triggered
CONSERVATIVE {
@Override
public AspectResolver createResolver(
PackageProvider provider, ExtendedEventHandler eventHandler) {
return new ConservativeAspectResolver();
}
},
// Load direct dependencies and report aspects that can be triggered based on their types.
PRECISE {
@Override
public AspectResolver createResolver(
PackageProvider provider, ExtendedEventHandler eventHandler) {
return new PreciseAspectResolver(provider, eventHandler);
}
};
public abstract AspectResolver createResolver(
PackageProvider provider, ExtendedEventHandler eventHandler);
}
/**
* Compute additional dependencies of target from aspects. This method may load the direct deps
* of target to determine their types. Returns map of attributes and corresponding label values.
*/
ImmutableMultimap<Attribute, Label> computeAspectDependencies(Target target,
DependencyFilter dependencyFilter) throws InterruptedException;
/**
* Compute the labels of the BUILD Starlark files on which the results of the other two methods
* depend for a target in the given package.
*/
Set<Label> computeBuildFileDependencies(Package pkg) throws InterruptedException;
}