// 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> 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); } }