|  | // Copyright 2017 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.actions; | 
|  |  | 
|  | import com.google.common.collect.ImmutableMap; | 
|  | import com.google.devtools.build.lib.cmdline.PackageIdentifier; | 
|  | import com.google.devtools.build.lib.vfs.Path; | 
|  | import com.google.devtools.build.lib.vfs.Root; | 
|  | import java.util.Optional; | 
|  | import javax.annotation.Nullable; | 
|  |  | 
|  | /** | 
|  | * An interface that provides information about package's source roots, that is, the paths on disk | 
|  | * that their BUILD files can be found at. Usually this information is not needed except for when | 
|  | * planting the symlink forest in the exec root, and when resolving source exec paths to artifacts | 
|  | * in an {@link ArtifactResolver}. | 
|  | */ | 
|  | public interface PackageRoots { | 
|  | /** | 
|  | * Gets a map from {@link PackageIdentifier} to {@link Path}. If present, all known packages for | 
|  | * this build are present in the map. Should only be needed for planting the symlink forest. If it | 
|  | * is absent, planting the symlink forest is not necessary. | 
|  | */ | 
|  | Optional<ImmutableMap<PackageIdentifier, Root>> getPackageRootsMap(); | 
|  |  | 
|  | PackageRootLookup getPackageRootLookup(); | 
|  |  | 
|  | /** Interface for getting the source root of a package, given its {@link PackageIdentifier}. */ | 
|  | interface PackageRootLookup { | 
|  | /** | 
|  | * Returns the {@link ArtifactRoot} of a package, given its {@link PackageIdentifier}. May be | 
|  | * null if the given {@code packageIdentifier} does not correspond to a package in this build. | 
|  | * However, if there is a unique source root for all packages, this may return that root even if | 
|  | * the {@code packageIdentifier} given does not correspond to any packages. | 
|  | */ | 
|  | @Nullable | 
|  | Root getRootForPackage(PackageIdentifier packageIdentifier); | 
|  | } | 
|  | } |