![]() ## Summary This PR enables something like the "final boss" of PyTorch setups -- explicit support for CPU vs. GPU-enabled variants via extras: ```toml [project] name = "project" version = "0.1.0" requires-python = ">=3.13.0" dependencies = [] [project.optional-dependencies] cpu = [ "torch==2.5.1+cpu", ] gpu = [ "torch==2.5.1", ] [tool.uv.sources] torch = [ { index = "torch-cpu", extra = "cpu" }, { index = "torch-gpu", extra = "gpu" }, ] [[tool.uv.index]] name = "torch-cpu" url = "https://download.pytorch.org/whl/cpu" explicit = true [[tool.uv.index]] name = "torch-gpu" url = "https://download.pytorch.org/whl/cu124" explicit = true [tool.uv] conflicts = [ [ { extra = "cpu" }, { extra = "gpu" }, ], ] ``` It builds atop the conflicting extras work to allow sources to be marked as specific to a dedicated extra being enabled or disabled. As part of this work, sources now have an `extra` field. If a source has an `extra`, it means that the source is only applied to the requirement when defined within that optional group. For example, `{ index = "torch-cpu", extra = "cpu" }` above only applies to `"torch==2.5.1+cpu"`. The `extra` field does _not_ mean that the source is "enabled" when the extra is activated. For example, this wouldn't work: ```toml [project] name = "project" version = "0.1.0" requires-python = ">=3.13.0" dependencies = ["torch"] [tool.uv.sources] torch = [ { index = "torch-cpu", extra = "cpu" }, { index = "torch-gpu", extra = "gpu" }, ] [[tool.uv.index]] name = "torch-cpu" url = "https://download.pytorch.org/whl/cpu" explicit = true [[tool.uv.index]] name = "torch-gpu" url = "https://download.pytorch.org/whl/cu124" explicit = true ``` In this case, the sources would effectively be ignored. Extras are really confusing... but I think this is correct? We don't want enabling or disabling extras to affect resolution information that's _outside_ of the relevant optional group. |
||
---|---|---|
.. | ||
uv | ||
uv-auth | ||
uv-bench | ||
uv-build-backend | ||
uv-build-frontend | ||
uv-cache | ||
uv-cache-info | ||
uv-cache-key | ||
uv-cli | ||
uv-client | ||
uv-configuration | ||
uv-console | ||
uv-dev | ||
uv-dirs | ||
uv-dispatch | ||
uv-distribution | ||
uv-distribution-filename | ||
uv-distribution-types | ||
uv-extract | ||
uv-fs | ||
uv-git | ||
uv-globfilter | ||
uv-install-wheel | ||
uv-installer | ||
uv-macros | ||
uv-metadata | ||
uv-normalize | ||
uv-once-map | ||
uv-options-metadata | ||
uv-pep440 | ||
uv-pep508 | ||
uv-performance-flate2-backend | ||
uv-performance-memory-allocator | ||
uv-platform-tags | ||
uv-publish | ||
uv-pypi-types | ||
uv-python | ||
uv-requirements | ||
uv-requirements-txt | ||
uv-resolver | ||
uv-scripts | ||
uv-settings | ||
uv-shell | ||
uv-state | ||
uv-static | ||
uv-tool | ||
uv-trampoline | ||
uv-trampoline-builder | ||
uv-types | ||
uv-version | ||
uv-virtualenv | ||
uv-warnings | ||
uv-workspace | ||
README.md |
Crates
uv-bench
Functionality for benchmarking uv.
uv-cache-key
Generic functionality for caching paths, URLs, and other resources across platforms.
uv-distribution-filename
Parse built distribution (wheel) and source distribution (sdist) filenames to extract structured metadata.
uv-distribution-types
Abstractions for representing built distributions (wheels) and source distributions (sdists), and the sources from which they can be downloaded.
uv-install-wheel-rs
Install built distributions (wheels) into a virtual environment.
uv-once-map
A waitmap
-like concurrent hash map for executing tasks
exactly once.
uv-pep440-rs
Utilities for interacting with Python version numbers and specifiers.
uv-pep508-rs
Utilities for parsing and evaluating dependency specifiers, previously known as PEP 508.
uv-platform-tags
Functionality for parsing and inferring Python platform tags as per PEP 425.
uv-cli
Command-line interface for the uv package manager.
uv-build-frontend
A PEP 517-compatible build frontend for uv.
uv-cache
Functionality for caching Python packages and associated metadata.
uv-client
Client for interacting with PyPI-compatible HTTP APIs.
uv-dev
Development utilities for uv.
uv-dispatch
A centralized struct
for resolving and building source distributions in isolated environments.
Implements the traits defined in uv-types
.
uv-distribution
Client for interacting with built distributions (wheels) and source distributions (sdists). Capable of fetching metadata, distribution contents, etc.
uv-extract
Utilities for extracting files from archives.
uv-fs
Utilities for interacting with the filesystem.
uv-git
Functionality for interacting with Git repositories.
uv-installer
Functionality for installing Python packages into a virtual environment.
uv-python
Functionality for detecting and leveraging the current Python interpreter.
uv-normalize
Normalize package and extra names as per Python specifications.
uv-requirements
Utilities for reading package requirements from pyproject.toml
and requirements.txt
files.
uv-resolver
Functionality for resolving Python packages and their dependencies.
uv-shell
Utilities for detecting and manipulating shell environments.
uv-types
Shared traits for uv, to avoid circular dependencies.
uv-pypi-types
General-purpose type definitions for types used in PyPI-compatible APIs.
uv-virtualenv
A venv
replacement to create virtual environments in Rust.
uv-warnings
User-facing warnings for uv.
uv-workspace
Workspace abstractions for uv.
uv-requirements-txt
Functionality for parsing requirements.txt
files.