uv_requirements
Generate a python_requirement
for each entry in pyproject.toml
under the [tool.uv]
section.
Backend: pants.backend.python
description
str | None
None
A human-readable description of the target.
Use pants list --documented ::
to see all targets with descriptions.
module_mapping
Dict[str, Iterable[str]]
FrozenDict({})
A mapping of requirement names to a list of the modules they provide.
For example, {"ansicolors": ["colors"]}
.
Any unspecified requirements will use a default. See the modules
field from the python_requirement
target for more information.
overrides
Dict[Union[str, Tuple[str, ...]], Dict[str, Any]] | None
None
Override the field values for generated python_requirement
targets.
Expects a dictionary of requirements to a dictionary for the overrides. You may either use a string for a single requirement, or a string tuple for multiple requirements. Each override is a dictionary of field names to the overridden value.
For example:
overrides={
"django": {"dependencies": ["#setuptools"]},
"ansicolors": {"description": "pretty colors"]},
("ansicolors, "django"): {"tags": ["overridden"]},
}
Every overridden requirement is validated to be generated by this target.
You can specify the same requirement in multiple keys, so long as you don't override the same field more than one time for the requirement.
resolve
str | None
None
The resolve from [python].resolves
that this requirement is included in.
If not defined, will default to [python].default_resolve
.
When generating a lockfile for a particular resolve via the generate-lockfiles
goal, it will include all requirements that are declared with that resolve. First-party targets like python_source
and pex_binary
then declare which resolve they use via their resolve
field; so, for your first-party code to use a particular python_requirement
target, that requirement must be included in the resolve used by that code.