attrs dictionary argument of rule() and aspect().See the Rules page for more on defining and using attributes.
Members
- bool
- int
- int_list
- label
- label_keyed_string_dict
- label_list
- output
- output_list
- string
- string_dict
- string_list
- string_list_dict
bool
Attribute attr.bool(default=False, doc='', mandatory=False)
Parameters
| Parameter | Description | 
|---|---|
| default | default = False A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
int
Attribute attr.int(default=0, doc='', mandatory=False, values=[])
Parameters
| Parameter | Description | 
|---|---|
| default | default = 0 A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| values | sequence of ints;
                                     default = []The list of allowed values for the attribute. An error is raised if any other value is given. | 
int_list
Attribute attr.int_list(mandatory=False, allow_empty=True, *, default=[], doc='')
Parameters
| Parameter | Description | 
|---|---|
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| allow_empty | default = True True if the attribute can be empty. | 
| default | sequence of ints;
                                     default = []A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
label
Attribute attr.label(default=None, doc='', executable=False, allow_files=None, allow_single_file=None, mandatory=False, providers=[], allow_rules=None, cfg=None, aspects=[])
Creates a schema for a label attribute. This is a dependency attribute.
This attribute contains unique Label values. If a string is supplied in place of a Label, it will be converted using the label constructor. The relative parts of the label path, including the (possibly renamed) repository, are resolved with respect to the instantiated target's package.
At analysis time (within the rule's implementation function), when retrieving the attribute value from ctx.attr, labels are replaced by the corresponding Targets. This allows you to access the providers of the current target's dependencies.
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 default 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 Rules page for more information.
          
      
Parameters
| Parameter | Description | 
|---|---|
| default | Label; or string; or LateBoundDefault; or NativeComputedDefault; or function; or None;
                                     default = NoneA default value to use if no value for this attribute is given when instantiating the rule.Use a string or the Labelfunction to specify a default value, for example,attr.label(default = "//a:b"). | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| executable | default = False 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 ctx.executable.<attribute_name>. | 
| allow_files | bool; or sequence of strings; or None;
                                     default = NoneWhether Filetargets are allowed. Can beTrue,False(default), or a list of file extensions that are allowed (for example,[".cc", ".cpp"]). | 
| allow_single_file | default = None This is similar to allow_files, with the restriction that the label must correspond to a single File. Access it throughctx.file.<attribute_name>. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| providers | default = [] The providers that must be given by any dependency appearing in this attribute. The format of this argument is a list of lists of providers --  | 
| allow_rules | sequence of strings; or None;
                                     default = NoneWhich rule targets (name of the classes) are allowed. This is deprecated (kept only for compatibility), use providers instead. | 
| cfg | default = None Configuration of the attribute. It can be either "exec", which indicates that the dependency is built for theexecution platform, or"target", which indicates that the dependency is build for thetarget platform. A typical example of the difference is when building mobile apps, where thetarget platformisAndroidoriOSwhile theexecution platformisLinux,macOS, orWindows. This parameter is required ifexecutableis True to guard against accidentally building host tools in the target configuration."target"has no semantic effect, so don't set it whenexecutableis False unless it really helps clarify your intentions. | 
| aspects | sequence of Aspects;
                                     default = []Aspects that should be applied to the dependency or dependencies specified by this attribute. | 
label_keyed_string_dict
Attribute attr.label_keyed_string_dict(allow_empty=True, *, default={}, doc='', allow_files=None, allow_rules=None, providers=[], flags=[], mandatory=False, cfg=None, aspects=[])
Creates a schema for an attribute holding a dictionary, where the keys are labels and the values are strings. This is a dependency attribute.
This attribute contains unique Label values. If a string is supplied in place of a Label, it will be converted using the label constructor. The relative parts of the label path, including the (possibly renamed) repository, are resolved with respect to the instantiated target's package.
At analysis time (within the rule's implementation function), when retrieving the attribute value from ctx.attr, labels are replaced by the corresponding Targets. This allows you to access the providers of the current target's dependencies.
          
      
Parameters
| Parameter | Description | 
|---|---|
| allow_empty | default = True True if the attribute can be empty. | 
| default | dict; or function;
                                     default = {}A default value to use if no value for this attribute is given when instantiating the rule.Use strings or the Labelfunction to specify default values, for example,attr.label_keyed_string_dict(default = {"//a:b": "value", "//a:c": "string"}). | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| allow_files | bool; or sequence of strings; or None;
                                     default = NoneWhether Filetargets are allowed. Can beTrue,False(default), or a list of file extensions that are allowed (for example,[".cc", ".cpp"]). | 
| allow_rules | sequence of strings; or None;
                                     default = NoneWhich rule targets (name of the classes) are allowed. This is deprecated (kept only for compatibility), use providers instead. | 
| providers | default = [] The providers that must be given by any dependency appearing in this attribute. The format of this argument is a list of lists of providers --  | 
| flags | sequence of strings;
                                     default = []Deprecated, will be removed. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| cfg | default = None Configuration of the attribute. It can be either "exec", which indicates that the dependency is built for theexecution platform, or"target", which indicates that the dependency is build for thetarget platform. A typical example of the difference is when building mobile apps, where thetarget platformisAndroidoriOSwhile theexecution platformisLinux,macOS, orWindows. | 
| aspects | sequence of Aspects;
                                     default = []Aspects that should be applied to the dependency or dependencies specified by this attribute. | 
label_list
Attribute attr.label_list(allow_empty=True, *, default=[], doc='', allow_files=None, allow_rules=None, providers=[], flags=[], mandatory=False, cfg=None, aspects=[])
Creates a schema for a list-of-labels attribute. This is a dependency attribute.
This attribute contains unique Label values. If a string is supplied in place of a Label, it will be converted using the label constructor. The relative parts of the label path, including the (possibly renamed) repository, are resolved with respect to the instantiated target's package.
At analysis time (within the rule's implementation function), when retrieving the attribute value from ctx.attr, labels are replaced by the corresponding Targets. This allows you to access the providers of the current target's dependencies.
          
      
Parameters
| Parameter | Description | 
|---|---|
| allow_empty | default = True True if the attribute can be empty. | 
| default | sequence of Labels; or function;
                                     default = []A default value to use if no value for this attribute is given when instantiating the rule.Use strings or the Labelfunction to specify default values, for example,attr.label_list(default = ["//a:b", "//a:c"]). | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| allow_files | bool; or sequence of strings; or None;
                                     default = NoneWhether Filetargets are allowed. Can beTrue,False(default), or a list of file extensions that are allowed (for example,[".cc", ".cpp"]). | 
| allow_rules | sequence of strings; or None;
                                     default = NoneWhich rule targets (name of the classes) are allowed. This is deprecated (kept only for compatibility), use providers instead. | 
| providers | default = [] The providers that must be given by any dependency appearing in this attribute. The format of this argument is a list of lists of providers --  | 
| flags | sequence of strings;
                                     default = []Deprecated, will be removed. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| cfg | default = None Configuration of the attribute. It can be either "exec", which indicates that the dependency is built for theexecution platform, or"target", which indicates that the dependency is build for thetarget platform. A typical example of the difference is when building mobile apps, where thetarget platformisAndroidoriOSwhile theexecution platformisLinux,macOS, orWindows. | 
| aspects | sequence of Aspects;
                                     default = []Aspects that should be applied to the dependency or dependencies specified by this attribute. | 
output
Attribute attr.output(doc='', mandatory=False)
Creates a schema for an output (label) attribute.
This attribute contains unique Label values. If a string is supplied in place of a Label, it will be converted using the label constructor. The relative parts of the label path, including the (possibly renamed) repository, are resolved with respect to the instantiated target's package.
At analysis time, the corresponding File can be retrieved using ctx.outputs.
          
      
Parameters
| Parameter | Description | 
|---|---|
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
output_list
Attribute attr.output_list(allow_empty=True, *, doc='', mandatory=False)
This attribute contains unique Label values. If a string is supplied in place of a Label, it will be converted using the label constructor. The relative parts of the label path, including the (possibly renamed) repository, are resolved with respect to the instantiated target's package.
At analysis time, the corresponding File can be retrieved using ctx.outputs.
          
      
Parameters
| Parameter | Description | 
|---|---|
| allow_empty | default = True True if the attribute can be empty. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
string
Attribute attr.string(default='', doc='', mandatory=False, values=[])
Parameters
| Parameter | Description | 
|---|---|
| default | string; or NativeComputedDefault;
                                     default = ''A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| values | sequence of strings;
                                     default = []The list of allowed values for the attribute. An error is raised if any other value is given. | 
string_dict
Attribute attr.string_dict(allow_empty=True, *, default={}, doc='', mandatory=False)
Parameters
| Parameter | Description | 
|---|---|
| allow_empty | default = True True if the attribute can be empty. | 
| default | default = {} A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
string_list
Attribute attr.string_list(mandatory=False, allow_empty=True, *, default=[], doc='')
Parameters
| Parameter | Description | 
|---|---|
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). | 
| allow_empty | default = True True if the attribute can be empty. | 
| default | sequence of strings; or NativeComputedDefault;
                                     default = []A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
string_list_dict
Attribute attr.string_list_dict(allow_empty=True, *, default={}, doc='', mandatory=False)
Parameters
| Parameter | Description | 
|---|---|
| allow_empty | default = True True if the attribute can be empty. | 
| default | default = {} A default value to use if no value for this attribute is given when instantiating the rule. | 
| doc | default = '' A description of the attribute that can be extracted by documentation generating tools. | 
| mandatory | default = False If true, the value must be specified explicitly (even if it has a default). |