| // 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.packages; |
| |
| import com.google.auto.value.AutoValue; |
| import com.google.common.base.Preconditions; |
| import com.google.devtools.build.lib.cmdline.Label; |
| import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable; |
| import com.google.devtools.build.lib.concurrent.ThreadSafety.ThreadSafe; |
| import com.google.devtools.build.lib.vfs.Path; |
| import com.google.devtools.build.lib.vfs.PathFragment; |
| import javax.annotation.Nullable; |
| import net.starlark.java.syntax.Location; |
| |
| /** |
| * A file that is an input to the build system. |
| * |
| * <p>In the build system, a file is considered an <i>input</i> file iff it is not generated by the |
| * build system (e.g. it's maintained under version control, or created by the test harness). It has |
| * nothing to do with the type of the file; a generated file containing <code>Java</code> source |
| * code is an OutputFile, not an InputFile. |
| * |
| * <p>{@link InputFile} assumes the input file follows package-default visibility and no license. |
| * Use {@link PrivateVisibilityInputFile} if returned visibility is constantly {@code |
| * RuleVisibility.PRIVATE}. Use {@link VisibilityLicenseSpecifiedInputFile} if either visibility or |
| * license needs to be specified. |
| */ |
| @Immutable |
| @ThreadSafe |
| public class InputFile extends FileTarget { |
| |
| private final Package pkg; |
| private final Location location; |
| |
| /** |
| * Constructs an input file with the given label, which must be a label for |
| * the given package, and package-default visibility. |
| */ |
| InputFile(Package pkg, Label label, Location location) { |
| super(pkg, label); |
| this.pkg = pkg; |
| this.location = Preconditions.checkNotNull(location); |
| } |
| |
| @Override |
| public Package getPackage() { |
| return pkg; |
| } |
| |
| public boolean isVisibilitySpecified() { |
| return false; |
| } |
| |
| @Override |
| public RuleVisibility getVisibility() { |
| return pkg.getPackageArgs().defaultVisibility(); |
| } |
| |
| @Override |
| public boolean isConfigurable() { |
| return false; |
| } |
| |
| public boolean isLicenseSpecified() { |
| return false; |
| } |
| |
| @Override |
| public License getLicense() { |
| return License.NO_LICENSE; |
| } |
| |
| /** |
| * Returns the path to the location of the input file (which is necessarily |
| * within the source tree, not beneath <code>bin</code> or |
| * <code>genfiles</code>. |
| * |
| * <p>Prefer {@link #getExecPath} if possible. |
| */ |
| public Path getPath() { |
| return pkg.getPackageDirectory().getRelative(label.getName()); |
| } |
| |
| /** |
| * Returns the exec path of the file, i.e. the path relative to the execution root working |
| * directory. |
| */ |
| public PathFragment getExecPath(boolean siblingRepositoryLayout) { |
| return label |
| .getRepository() |
| .getExecPath(siblingRepositoryLayout) |
| .getRelative(label.getPackageName()) |
| .getRelative(label.getName()); |
| } |
| |
| @Override |
| public String getTargetKind() { |
| return targetKind(); |
| } |
| |
| @Override |
| @Nullable |
| public Rule getAssociatedRule() { |
| return null; |
| } |
| |
| @Override |
| public Location getLocation() { |
| return location; |
| } |
| |
| /** Returns the target kind for all input files. */ |
| public static String targetKind() { |
| return "source file"; |
| } |
| |
| @Override |
| public boolean isInputFile() { |
| return true; |
| } |
| |
| @Override |
| public Path getInputPath() { |
| return getPath(); |
| } |
| |
| @Override |
| public TargetData reduceForSerialization() { |
| return new AutoValue_InputFile_InputFileData(getLocation(), getLabel(), getInputPath()); |
| } |
| |
| @AutoValue |
| abstract static class InputFileData implements TargetData { |
| @Override |
| public final String getTargetKind() { |
| return targetKind(); |
| } |
| |
| @Override |
| public final boolean isFile() { |
| return true; |
| } |
| |
| @Override |
| public final boolean isInputFile() { |
| return true; |
| } |
| |
| @Override |
| public abstract Path getInputPath(); |
| } |
| } |