| // 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.pkgcache; |
| |
| import com.google.common.base.Splitter; |
| import com.google.common.base.Strings; |
| import com.google.common.collect.ImmutableList; |
| import com.google.devtools.build.lib.Constants; |
| import com.google.devtools.build.lib.cmdline.LabelSyntaxException; |
| import com.google.devtools.build.lib.cmdline.PackageIdentifier; |
| import com.google.devtools.build.lib.packages.ConstantRuleVisibility; |
| import com.google.devtools.build.lib.packages.RuleVisibility; |
| import com.google.devtools.common.options.Converter; |
| import com.google.devtools.common.options.Converters; |
| import com.google.devtools.common.options.Option; |
| import com.google.devtools.common.options.OptionsBase; |
| import com.google.devtools.common.options.OptionsParsingException; |
| |
| import java.util.List; |
| |
| /** |
| * Options for configuring the PackageCache. |
| */ |
| public class PackageCacheOptions extends OptionsBase { |
| /** |
| * A converter for package path that defaults to {@code Constants.DEFAULT_PACKAGE_PATH} if the |
| * option is not given. |
| * |
| * <p>Required because you cannot specify a non-constant value in annotation attributes. |
| */ |
| public static class PackagePathConverter implements Converter<List<String>> { |
| @Override |
| public List<String> convert(String input) throws OptionsParsingException { |
| return input.isEmpty() |
| ? Constants.DEFAULT_PACKAGE_PATH |
| : new Converters.ColonSeparatedOptionListConverter().convert(input); |
| } |
| |
| @Override |
| public String getTypeDescription() { |
| return "a string"; |
| } |
| } |
| |
| /** |
| * Converter for the {@code --default_visibility} option. |
| */ |
| public static class DefaultVisibilityConverter implements Converter<RuleVisibility> { |
| @Override |
| public RuleVisibility convert(String input) throws OptionsParsingException { |
| if (input.equals("public")) { |
| return ConstantRuleVisibility.PUBLIC; |
| } else if (input.equals("private")) { |
| return ConstantRuleVisibility.PRIVATE; |
| } else { |
| throw new OptionsParsingException("Not a valid default visibility: '" + input |
| + "' (should be 'public' or 'private'"); |
| } |
| } |
| |
| @Override |
| public String getTypeDescription() { |
| return "default visibility"; |
| } |
| } |
| |
| @Option(name = "package_path", |
| defaultValue = "", |
| category = "package loading", |
| converter = PackagePathConverter.class, |
| help = "A colon-separated list of where to look for packages. " |
| + "Elements beginning with '%workspace%' are relative to the enclosing " |
| + "workspace. If omitted or empty, the default is the output of " |
| + "'blaze info default-package-path'.") |
| public List<String> packagePath; |
| |
| @Option(name = "show_package_location", |
| defaultValue = "false", |
| category = "verbosity", |
| deprecationWarning = "This flag is no longer supported and will go away soon.", |
| help = "If enabled, causes Blaze to print the location on the --package_path " |
| + "from which each package was loaded.") |
| public boolean showPackageLocation; |
| |
| @Option(name = "show_loading_progress", |
| defaultValue = "true", |
| category = "verbosity", |
| help = "If enabled, causes Blaze to print \"Loading package:\" messages.") |
| public boolean showLoadingProgress; |
| |
| @Option(name = "deleted_packages", |
| defaultValue = "", |
| category = "package loading", |
| converter = CommaSeparatedPackageNameListConverter.class, |
| help = "A comma-separated list of names of packages which the " |
| + "build system will consider non-existent, even if they are " |
| + "visible somewhere on the package path." |
| + "\n" |
| + "Use this option when deleting a subpackage 'x/y' of an " |
| + "existing package 'x'. For example, after deleting x/y/BUILD " |
| + "in your client, the build system may complain if it " |
| + "encounters a label '//x:y/z' if that is still provided by another " |
| + "package_path entry. Specifying --deleted_packages x/y avoids this " |
| + "problem.") |
| public List<PackageIdentifier> deletedPackages; |
| |
| @Option(name = "default_visibility", |
| defaultValue = "private", |
| category = "undocumented", |
| converter = DefaultVisibilityConverter.class, |
| help = "Default visibility for packages that don't set it explicitly ('public' or " |
| + "'private').") |
| public RuleVisibility defaultVisibility; |
| |
| @Option(name = "legacy_globbing_threads", |
| defaultValue = "100", |
| category = "undocumented", |
| help = "Number of threads to use for glob evaluation.") |
| public int globbingThreads; |
| |
| @Option(name = "min_pkg_count_for_ct_node_eviction", |
| defaultValue = "3700", |
| // Why is the default value 3700? As of December 2013, a medium target loads about this many |
| // packages, uses ~310MB RAM to only load [1] or ~990MB to load and analyze [2,3]. So we |
| // can likely load and analyze this many packages without worrying about Blaze OOM'ing. |
| // |
| // If the total number of unique packages so far [4] is higher than the value of this flag, |
| // then we evict CT nodes [5] from the Skyframe graph. |
| // |
| // [1] blaze -x build --nobuild --noanalyze //medium:target |
| // [2] blaze -x build --nobuild //medium:target |
| // [3] according to "blaze info used-heap-size" |
| // [4] this means the number of unique packages loaded by builds, including the current one, |
| // since the last CT node eviction [5] |
| // [5] "CT node eviction" means clearing those nodes from the Skyframe graph that correspond |
| // to ConfiguredTargets; this is done using SkyframeExecutor.resetConfiguredTargets |
| category = "undocumented", |
| help = "Threshold for number of loaded packages before skyframe-m1 cache eviction kicks in") |
| public int minLoadedPkgCountForCtNodeEviction; |
| |
| @Option(name = "fetch", |
| defaultValue = "true", |
| category = "undocumented", |
| help = "Allows the command to fetch external dependencies") |
| public boolean fetch; |
| |
| /** |
| * A converter from strings containing comma-separated names of packages to lists of strings. |
| */ |
| public static class CommaSeparatedPackageNameListConverter |
| implements Converter<List<PackageIdentifier>> { |
| |
| private static final Splitter COMMA_SPLITTER = Splitter.on(','); |
| |
| @Override |
| public List<PackageIdentifier> convert(String input) throws OptionsParsingException { |
| if (Strings.isNullOrEmpty(input)) { |
| return ImmutableList.of(); |
| } |
| ImmutableList.Builder<PackageIdentifier> list = ImmutableList.builder(); |
| for (String s : COMMA_SPLITTER.split(input)) { |
| try { |
| list.add(PackageIdentifier.parse(s)); |
| } catch (LabelSyntaxException e) { |
| throw new OptionsParsingException(e.getMessage()); |
| } |
| } |
| return list.build(); |
| } |
| |
| @Override |
| public String getTypeDescription() { |
| return "comma-separated list of package names"; |
| } |
| |
| } |
| } |