|  | // Copyright 2018 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.skylarkbuildapi; | 
|  |  | 
|  | import com.google.devtools.build.lib.cmdline.Label; | 
|  | import com.google.devtools.build.lib.syntax.Dict; | 
|  | import com.google.devtools.build.lib.syntax.EvalException; | 
|  | import com.google.devtools.build.lib.syntax.Sequence; | 
|  | import com.google.devtools.build.lib.syntax.StarlarkFunction; | 
|  | import com.google.devtools.build.lib.syntax.StarlarkSemantics.FlagIdentifier; | 
|  | import com.google.devtools.build.lib.syntax.StarlarkThread; | 
|  | import com.google.devtools.build.lib.syntax.StarlarkValue; | 
|  | import net.starlark.java.annot.Param; | 
|  | import net.starlark.java.annot.ParamType; | 
|  | import net.starlark.java.annot.StarlarkBuiltin; | 
|  | import net.starlark.java.annot.StarlarkDocumentationCategory; | 
|  | import net.starlark.java.annot.StarlarkMethod; | 
|  |  | 
|  | /** | 
|  | * The "attr" module of the Build API. | 
|  | * | 
|  | * <p>It exposes functions (for example, 'attr.string', 'attr.label_list', etc.) to Starlark users | 
|  | * for creating attribute definitions. | 
|  | */ | 
|  | @StarlarkBuiltin( | 
|  | name = "attr", | 
|  | namespace = true, | 
|  | category = StarlarkDocumentationCategory.TOP_LEVEL_TYPE, | 
|  | doc = | 
|  | "This is a top-level module for defining the attribute schemas of a rule or aspect. Each " | 
|  | + "function returns an object representing the schema of a single attribute. These " | 
|  | + "objects are used as the values of the <code>attrs</code> dictionary argument of " | 
|  | + "<a href=\"globals.html#rule\"><code>rule()</code></a> and " | 
|  | + "<a href=\"globals.html#aspect\"><code>aspect()</code></a>." | 
|  | + "" | 
|  | + "<p>See the Rules page for more on " | 
|  | + "<a href='../rules.$DOC_EXT#attributes'>defining</a> and " | 
|  | + "<a href='../rules.$DOC_EXT#implementation-function'>using</a> attributes.") | 
|  | public interface StarlarkAttrModuleApi extends StarlarkValue { | 
|  |  | 
|  | // dependency and output attributes | 
|  | String LABEL_PARAGRAPH = | 
|  | "<p>This attribute contains unique <a href='Label.html'><code>Label</code></a> values. If a " | 
|  | + "string is supplied in place of a <code>Label</code>, it will be converted using the " | 
|  | + "<a href='Label.html#Label'>label constructor</a>. The relative parts of the label " | 
|  | + "path, including the (possibly renamed) repository, are resolved with respect to the " | 
|  | + "instantiated target's package."; | 
|  |  | 
|  | // attr.label, attr.label_list, attr.label_keyed_string_dict | 
|  | String DEPENDENCY_ATTR_TEXT = | 
|  | LABEL_PARAGRAPH | 
|  | + "<p>At analysis time (within the rule's implementation function), when retrieving the " | 
|  | + "attribute value from <code>ctx.attr</code>, labels are replaced by the corresponding " | 
|  | + "<a href='Target.html'><code>Target</code></a>s. This allows you to access the " | 
|  | + "providers of the currrent target's dependencies."; | 
|  |  | 
|  | // attr.output, attr.output_list | 
|  | String OUTPUT_ATTR_TEXT = | 
|  | LABEL_PARAGRAPH | 
|  | + "<p>At analysis time, the corresponding <a href='File.html'><code>File</code></a> can " | 
|  | + "be retrieved using <code>ctx.outputs</code>."; | 
|  |  | 
|  | String ALLOW_FILES_ARG = "allow_files"; | 
|  | String ALLOW_FILES_DOC = | 
|  | "Whether <code>File</code> targets are allowed. Can be <code>True</code>, <code>False</code> " | 
|  | + "(default), or a list of file extensions that are allowed (for example, " | 
|  | + "<code>[\".cc\", \".cpp\"]</code>)."; | 
|  |  | 
|  | String ALLOW_RULES_ARG = "allow_rules"; | 
|  | String ALLOW_RULES_DOC = | 
|  | "Which rule targets (name of the classes) are allowed. This is deprecated (kept only for " | 
|  | + "compatibility), use providers instead."; | 
|  |  | 
|  | String ASPECTS_ARG = "aspects"; | 
|  | String ASPECTS_ARG_DOC = | 
|  | "Aspects that should be applied to the dependency or dependencies specified by this " | 
|  | + "attribute."; | 
|  |  | 
|  | String CONFIGURATION_ARG = "cfg"; | 
|  | // TODO(b/151742236): Update when new Starlark-based configuration framework is implemented. | 
|  | String CONFIGURATION_DOC = | 
|  | "<a href=\"../rules.$DOC_EXT#configurations\">Configuration</a> of the attribute. It can be " | 
|  | + "either <code>\"host\"</code> or <code>\"target\"</code>."; | 
|  |  | 
|  | String DEFAULT_ARG = "default"; | 
|  | // A trailing space is required because it's often prepended to other sentences | 
|  | String DEFAULT_DOC = | 
|  | "A default value to use if no value for this attribute is given when instantiating the rule."; | 
|  |  | 
|  | String DOC_ARG = "doc"; | 
|  | String DOC_DOC = | 
|  | "A description of the attribute that can be extracted by documentation generating tools."; | 
|  |  | 
|  | String EXECUTABLE_ARG = "executable"; | 
|  | String EXECUTABLE_DOC = | 
|  | "True if the dependency has to be executable. This means the label must refer to an " | 
|  | + "executable file, or to a rule that outputs an executable file. Access the label " | 
|  | + "with <code>ctx.executable.<attribute_name></code>."; | 
|  |  | 
|  | String FLAGS_ARG = "flags"; | 
|  | String FLAGS_DOC = "Deprecated, will be removed."; | 
|  |  | 
|  | String MANDATORY_ARG = "mandatory"; | 
|  | String MANDATORY_DOC = | 
|  | "If true, the value must be specified explicitly (even if it has a <code>default</code>)."; | 
|  |  | 
|  | String NON_EMPTY_ARG = "non_empty"; | 
|  | String NON_EMPTY_DOC = | 
|  | "True if the attribute must not be empty. Deprecated: Use <code>allow_empty</code> instead."; | 
|  |  | 
|  | String ALLOW_EMPTY_ARG = "allow_empty"; | 
|  | String ALLOW_EMPTY_DOC = "True if the attribute can be empty."; | 
|  |  | 
|  | String PROVIDERS_ARG = "providers"; | 
|  | String PROVIDERS_DOC = | 
|  | "The providers that must be given by any dependency appearing in this attribute." | 
|  | + "" | 
|  | + "<p>The format of this argument is a list of lists of providers -- <code>*Info</code> " | 
|  | + "objects returned by <a href='globals.html#provider'><code>provider()</code></a> (or " | 
|  | + "in the case of a legacy provider, its string name). The dependency must return ALL " | 
|  | + "providers mentioned in at least ONE of the inner lists. As a convenience, this " | 
|  | + "argument may also be a single-level list of providers, in which case it is wrapped in " | 
|  | + "an outer list with one element."; | 
|  |  | 
|  | String SINGLE_FILE_ARG = "single_file"; | 
|  | String ALLOW_SINGLE_FILE_ARG = "allow_single_file"; | 
|  |  | 
|  | String VALUES_ARG = "values"; | 
|  | String VALUES_DOC = | 
|  | "The list of allowed values for the attribute. An error is raised if any other " | 
|  | + "value is given."; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "int", | 
|  | doc = "Creates a schema for an integer attribute.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Integer.class, | 
|  | defaultValue = "0", | 
|  | doc = DEFAULT_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = MANDATORY_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = VALUES_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = Integer.class, | 
|  | defaultValue = "[]", | 
|  | doc = VALUES_DOC, | 
|  | named = true, | 
|  | positional = false) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor intAttribute( | 
|  | Integer defaultValue, | 
|  | String doc, | 
|  | Boolean mandatory, | 
|  | Sequence<?> values, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "string", | 
|  | doc = "Creates a schema for a string attribute.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DEFAULT_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = MANDATORY_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = VALUES_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | defaultValue = "[]", | 
|  | doc = VALUES_DOC, | 
|  | named = true, | 
|  | positional = false) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor stringAttribute( | 
|  | String defaultValue, String doc, Boolean mandatory, Sequence<?> values, StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "label", | 
|  | doc = | 
|  | "Creates a schema for a label attribute. This is a dependency attribute." | 
|  | + DEPENDENCY_ATTR_TEXT | 
|  | + "<p>In addition to ordinary source files, this kind of attribute is often used to " | 
|  | + "refer to a tool -- for example, a compiler. Such tools are considered to be " | 
|  | + "dependencies, just like source files. To avoid requiring users to specify the " | 
|  | + "tool's label every time they use the rule in their BUILD files, you can hard-code " | 
|  | + "the label of a canonical tool as the <code>default</code> value of this " | 
|  | + "attribute. If you also want to prevent users from overriding this default, you " | 
|  | + "can make the attribute private by giving it a name that starts with an " | 
|  | + "underscore. See the <a href='../rules.$DOC_EXT#private-attributes'>Rules</a> page " | 
|  | + "for more information.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | allowedTypes = { | 
|  | @ParamType(type = Label.class), | 
|  | @ParamType(type = String.class), | 
|  | @ParamType(type = LateBoundDefaultApi.class), | 
|  | // TODO(adonovan): remove StarlarkFunction. It's undocumented, | 
|  | // unused by Google's .bzl files, and likely unused in Bazel. | 
|  | // I suspect it is a vestige of a "computed defaults" feature | 
|  | // that was never fully exposed to Starlark (or was since | 
|  | // withdrawn). | 
|  | @ParamType(type = StarlarkFunction.class) | 
|  | }, | 
|  | callbackEnabled = true, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = | 
|  | DEFAULT_DOC | 
|  | + "Use a string or the <a href=\"globals.html#Label\"><code>Label</code></a> " | 
|  | + "function to specify a default value, for example, " | 
|  | + "<code>attr.label(default = \"//a:b\")</code>."), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = EXECUTABLE_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = EXECUTABLE_DOC), | 
|  | @Param( | 
|  | name = ALLOW_FILES_ARG, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | noneable = true, | 
|  | doc = ALLOW_FILES_DOC), | 
|  | @Param( | 
|  | name = ALLOW_SINGLE_FILE_ARG, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | noneable = true, | 
|  | doc = | 
|  | "This is similar to <code>allow_files</code>, with the restriction that the label " | 
|  | + "must correspond to a single <a href=\"File.html\">File</a>. " | 
|  | + "Access it through <code>ctx.file.<attribute_name></code>."), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = PROVIDERS_ARG, | 
|  | type = Sequence.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = PROVIDERS_DOC), | 
|  | @Param( | 
|  | name = ALLOW_RULES_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ALLOW_RULES_DOC), | 
|  | @Param( | 
|  | name = SINGLE_FILE_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = | 
|  | "Deprecated: Use <code>allow_single_file</code> instead. " | 
|  | + "If True, the label must correspond to a single " | 
|  | + "<a href=\"File.html\">File</a>. " | 
|  | + "Access it through <code>ctx.file.<attribute_name></code>."), | 
|  | @Param( | 
|  | name = CONFIGURATION_ARG, | 
|  | type = Object.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = | 
|  | CONFIGURATION_DOC | 
|  | + " This parameter is required if <code>executable</code> is True " | 
|  | + "to guard against accidentally building host tools in the " | 
|  | + "target configuration. <code>\"target\"</code> has no semantic " | 
|  | + "effect, so don't set it when <code>executable</code> is False " | 
|  | + "unless it really helps clarify your intentions."), | 
|  | @Param( | 
|  | name = ASPECTS_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = StarlarkAspectApi.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ASPECTS_ARG_DOC), | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor labelAttribute( | 
|  | Object defaultValue, | 
|  | String doc, | 
|  | Boolean executable, | 
|  | Object allowFiles, | 
|  | Object allowSingleFile, | 
|  | Boolean mandatory, | 
|  | Sequence<?> providers, | 
|  | Object allowRules, | 
|  | Boolean singleFile, | 
|  | Object cfg, | 
|  | Sequence<?> aspects, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "string_list", | 
|  | doc = "Creates a schema for a list-of-strings attribute.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = MANDATORY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = NON_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | defaultValue = "[]", | 
|  | doc = DEFAULT_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor stringListAttribute( | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | Boolean allowEmpty, | 
|  | Sequence<?> defaultValue, | 
|  | String doc, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "int_list", | 
|  | doc = "Creates a schema for a list-of-integers attribute.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = MANDATORY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | doc = NON_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = Integer.class, | 
|  | defaultValue = "[]", | 
|  | doc = DEFAULT_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor intListAttribute( | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | Boolean allowEmpty, | 
|  | Sequence<?> defaultValue, | 
|  | String doc, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "label_list", | 
|  | doc = | 
|  | "Creates a schema for a list-of-labels attribute. This is a dependency attribute." | 
|  | + DEPENDENCY_ATTR_TEXT, | 
|  | parameters = { | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | allowedTypes = { | 
|  | @ParamType(type = Sequence.class, generic1 = Label.class), | 
|  | @ParamType(type = StarlarkFunction.class) | 
|  | }, | 
|  | callbackEnabled = true, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = | 
|  | DEFAULT_DOC | 
|  | + "Use strings or the <a href=\"globals.html#Label\"><code>Label</code></a> " | 
|  | + "function to specify default values, for example, " | 
|  | + "<code>attr.label_list(default = [\"//a:b\", \"//a:c\"])</code>."), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = ALLOW_FILES_ARG, // bool or FileType filter | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | noneable = true, | 
|  | doc = ALLOW_FILES_DOC), | 
|  | @Param( | 
|  | name = ALLOW_RULES_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ALLOW_RULES_DOC), | 
|  | @Param( | 
|  | name = PROVIDERS_ARG, | 
|  | type = Sequence.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = PROVIDERS_DOC), | 
|  | @Param( | 
|  | name = FLAGS_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = FLAGS_DOC), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = NON_EMPTY_DOC), | 
|  | @Param( | 
|  | name = CONFIGURATION_ARG, | 
|  | type = Object.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = CONFIGURATION_DOC), | 
|  | @Param( | 
|  | name = ASPECTS_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = StarlarkAspectApi.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ASPECTS_ARG_DOC), | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor labelListAttribute( | 
|  | Boolean allowEmpty, | 
|  | Object defaultValue, | 
|  | String doc, | 
|  | Object allowFiles, | 
|  | Object allowRules, | 
|  | Sequence<?> providers, | 
|  | Sequence<?> flags, | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | Object cfg, | 
|  | Sequence<?> aspects, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "label_keyed_string_dict", | 
|  | doc = | 
|  | "Creates a schema for an attribute holding a dictionary, where the keys are labels and " | 
|  | + "the values are strings. This is a dependency attribute." | 
|  | + DEPENDENCY_ATTR_TEXT, | 
|  | parameters = { | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | allowedTypes = { | 
|  | @ParamType(type = Dict.class), | 
|  | @ParamType(type = StarlarkFunction.class) | 
|  | }, | 
|  | callbackEnabled = true, | 
|  | defaultValue = "{}", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = | 
|  | DEFAULT_DOC | 
|  | + "Use strings or the <a href=\"globals.html#Label\"><code>Label</code></a> " | 
|  | + "function to specify default values, for example, " | 
|  | + "<code>attr.label_keyed_string_dict(default = " | 
|  | + "{\"//a:b\": \"value\", \"//a:c\": \"string\"})</code>."), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = ALLOW_FILES_ARG, // bool or FileType filter | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | noneable = true, | 
|  | doc = ALLOW_FILES_DOC), | 
|  | @Param( | 
|  | name = ALLOW_RULES_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ALLOW_RULES_DOC), | 
|  | @Param( | 
|  | name = PROVIDERS_ARG, | 
|  | type = Sequence.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = PROVIDERS_DOC), | 
|  | @Param( | 
|  | name = FLAGS_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = String.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = FLAGS_DOC), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = NON_EMPTY_DOC), | 
|  | @Param( | 
|  | name = CONFIGURATION_ARG, | 
|  | type = Object.class, | 
|  | noneable = true, | 
|  | defaultValue = "None", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = CONFIGURATION_DOC), | 
|  | @Param( | 
|  | name = ASPECTS_ARG, | 
|  | type = Sequence.class, | 
|  | generic1 = StarlarkAspectApi.class, | 
|  | defaultValue = "[]", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = ASPECTS_ARG_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor labelKeyedStringDictAttribute( | 
|  | Boolean allowEmpty, | 
|  | Object defaultValue, | 
|  | String doc, | 
|  | Object allowFiles, | 
|  | Object allowRules, | 
|  | Sequence<?> providers, | 
|  | Sequence<?> flags, | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | Object cfg, | 
|  | Sequence<?> aspects, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "bool", | 
|  | doc = "Creates a schema for a boolean attribute.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = DEFAULT_DOC), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor boolAttribute( | 
|  | Boolean defaultValue, String doc, Boolean mandatory, StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "output", | 
|  | doc = "Creates a schema for an output (label) attribute." + OUTPUT_ATTR_TEXT, | 
|  | parameters = { | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor outputAttribute(String doc, Boolean mandatory, StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "output_list", | 
|  | doc = "Creates a schema for a list-of-outputs attribute." + OUTPUT_ATTR_TEXT, | 
|  | parameters = { | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = NON_EMPTY_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor outputListAttribute( | 
|  | Boolean allowEmpty, String doc, Boolean mandatory, Boolean nonEmpty, StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "string_dict", | 
|  | doc = | 
|  | "Creates a schema for an attribute holding a dictionary, where the keys and values are " | 
|  | + "strings.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Dict.class, | 
|  | named = true, | 
|  | positional = false, | 
|  | defaultValue = "{}", | 
|  | doc = DEFAULT_DOC), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | named = true, | 
|  | positional = false, | 
|  | defaultValue = "False", | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = NON_EMPTY_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor stringDictAttribute( | 
|  | Boolean allowEmpty, | 
|  | Dict<?, ?> defaultValue, | 
|  | String doc, | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "string_list_dict", | 
|  | doc = | 
|  | "Creates a schema for an attribute holding a dictionary, where the keys are strings and " | 
|  | + "the values are lists of strings.", | 
|  | parameters = { | 
|  | @Param( | 
|  | name = ALLOW_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "True", | 
|  | doc = ALLOW_EMPTY_DOC, | 
|  | named = true), | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | type = Dict.class, | 
|  | defaultValue = "{}", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = DEFAULT_DOC), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC), | 
|  | @Param( | 
|  | name = NON_EMPTY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = NON_EMPTY_DOC) | 
|  | }, | 
|  | useStarlarkThread = true) | 
|  | Descriptor stringListDictAttribute( | 
|  | Boolean allowEmpty, | 
|  | Dict<?, ?> defaultValue, | 
|  | String doc, | 
|  | Boolean mandatory, | 
|  | Boolean nonEmpty, | 
|  | StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | @StarlarkMethod( | 
|  | name = "license", | 
|  | doc = "Creates a schema for a license attribute.", | 
|  | // TODO(bazel-team): Implement proper license support for Starlark. | 
|  | parameters = { | 
|  | // TODO(bazel-team): ensure this is the correct default value | 
|  | @Param( | 
|  | name = DEFAULT_ARG, | 
|  | defaultValue = "None", | 
|  | noneable = true, | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = DEFAULT_DOC), | 
|  | @Param( | 
|  | name = DOC_ARG, | 
|  | type = String.class, | 
|  | defaultValue = "''", | 
|  | doc = DOC_DOC, | 
|  | named = true, | 
|  | positional = false), | 
|  | @Param( | 
|  | name = MANDATORY_ARG, | 
|  | type = Boolean.class, | 
|  | defaultValue = "False", | 
|  | named = true, | 
|  | positional = false, | 
|  | doc = MANDATORY_DOC) | 
|  | }, | 
|  | disableWithFlag = FlagIdentifier.INCOMPATIBLE_NO_ATTR_LICENSE, | 
|  | useStarlarkThread = true) | 
|  | Descriptor licenseAttribute( | 
|  | Object defaultValue, String doc, Boolean mandatory, StarlarkThread thread) | 
|  | throws EvalException; | 
|  |  | 
|  | /** An attribute descriptor. */ | 
|  | @StarlarkBuiltin( | 
|  | name = "Attribute", | 
|  | category = StarlarkDocumentationCategory.BUILTIN, | 
|  | doc = | 
|  | "Representation of a definition of an attribute. Use the <a href=\"attr.html\">attr</a> " | 
|  | + "module to create an Attribute. They are only for use with a " | 
|  | + "<a href=\"globals.html#rule\">rule</a> or an " | 
|  | + "<a href=\"globals.html#aspect\">aspect</a>.") | 
|  | interface Descriptor extends StarlarkValue {} | 
|  | } |