TagAttributeExtra
works around a limitation of TagAttribute
, which is that definitions
must be tagged in the same file that declares the definition.
This works well for definitions in lean core, but for attributes declared outside the core
this is problematic because we may want to tag declarations created before the attribute
was defined.
To resolve this, we allow a one-time exception to the rule that attributes must be applied in the same file as the declaration: During the declaration of the attribute itself, we can tag arbitrary other definitions, but once the attribute is declared we must tag things in the same file as normal.
The environment extension for the attribute.
- base : Lean.NameHashSet
A list of "base" declarations which have been pre-tagged.
Instances For
Equations
- Lean.instInhabitedTagAttributeExtra = { default := { ext := default, base := default } }
Registers a new tag attribute. The extra
field is a list of definitions from other modules
which will be "pre-tagged" and are not subject to the usual restriction on tagging in the same
file as the declaration.
Note: The extra
fields bypass the validate
function -
we assume the builtins are also pre-validated.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Does declaration decl
have the tag attr
?
Equations
- One or more equations did not get rendered due to their size.
Instances For
Get the list of declarations tagged with the tag attribute attr
.
Equations
- One or more equations did not get rendered due to their size.
Instances For
ParametricAttributeExtra
works around a limitation of ParametricAttribute
, which is that
definitions must be tagged in the same file that declares the definition.
This works well for definitions in lean core, but for attributes declared outside the core
this is problematic because we may want to tag declarations created before the attribute
was defined.
To resolve this, we allow a one-time exception to the rule that attributes must be applied in the same file as the declaration: During the declaration of the attribute itself, we can tag arbitrary other definitions, but once the attribute is declared we must tag things in the same file as normal.
- attr : Lean.ParametricAttribute α
The underlying
ParametricAttribute
. - base : Std.HashMap Lean.Name α
A list of pre-tagged declarations with their values.
Instances For
Equations
- Lean.instInhabitedParametricAttributeExtra = { default := { attr := default, base := default } }
Registers a new parametric attribute. The extra
field is a list of definitions from other modules
which will be "pre-tagged" and are not subject to the usual restriction on tagging in the same
file as the declaration.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Gets the parameter of attribute attr
associated to declaration decl
,
or none
if decl
is not tagged.
Equations
- attr.getParam? env decl = HOrElse.hOrElse (attr.attr.getParam? env decl) fun (x : Unit) => attr.base[decl]?
Instances For
Applies attribute attr
to declaration decl
, given a value for the parameter.
Equations
- attr.setParam env decl param = attr.attr.setParam env decl param