uv/crates
Andrew Gallant 7772e6249f
add basic "install from lock file" operation (#3340)
This PR principally adds a routine for converting a `Lock` to a
`Resolution`, where a `Resolution` is a map of package names pinned to
a specific version.

I'm not sure that a `Resolution` is ultimately what we want here (we
might need more stuff), but this was the quickest route I could find to
plug a `Lock` into our existing `uv pip install` infrastructure.

This commit also does a little refactoring of the `Lock` types. The
main thing is to permit extra state on some of the types (like a
`by_id` map on `Lock` for quick lookups of distributions) that aren't
included in the serialization format of a `Lock`. We achieve this
by defining separate `Wire` types that are automatically converted
to-and-from via `serde`.

Note that like with the lock file format types themselves, we leave a
few `todo!()` expressions around. The main idea is to get something
minimally working without spending too much effort here. (A fair bit
of refactoring will be required to generate a lock file, and it's
not clear how much this code will wind up needing to change anyway.)
In particular, we only handle the case of installing wheels from a
registry.

A demonstration of the full flow:

```
$ requirements.in
anyio
$ cargo run -p uv -- pip compile -p3.10 requirements.in --unstable-uv-lock-file
$ uv venv
$ cargo run -p uv -- pip install --unstable-uv-lock-file anyio -r requirements.in
Installed 5 packages in 7ms
 + anyio==4.3.0
 + exceptiongroup==1.2.1
 + idna==3.7
 + sniffio==1.3.1
 + typing-extensions==4.11.0
```

In order to install from a lock file, we start from the root and do a
breadth first traversal over its dependencies. We aren't yet filtering
on marker expressions (since they aren't in the lock file yet), but we
should be able to add that in the future. In so doing, the traversal
should select only the subset of distributions relevant for the current
platform.
2024-05-03 08:18:36 -04:00
..
bench Run resolve/install benchmarks in ci (#3281) 2024-04-30 13:39:42 -04:00
cache-key Avoid panic for file url (#3306) 2024-04-29 16:39:16 +02:00
distribution-filename Add missing optional rkyv feature bound (#3336) 2024-05-02 10:01:10 +00:00
distribution-types Fix typos (#3323) 2024-04-30 14:36:36 +00:00
install-wheel-rs Fix span recording with install_wheel_rs (#3293) 2024-04-28 18:33:40 +00:00
once-map once-map: avoid hard-coding Arc (#3242) 2024-04-24 11:11:46 -04:00
pep440-rs Quote version parse errors consistently (#3325) 2024-04-30 12:20:14 -05:00
pep508-rs Quote version parse errors consistently (#3325) 2024-04-30 12:20:14 -05:00
platform-tags Run resolve/install benchmarks in ci (#3281) 2024-04-30 13:39:42 -04:00
pypi-types Remove Into::into (#3337) 2024-05-02 10:26:42 +00:00
requirements-txt Move RequirementsTxtRequirement to its own module (#3235) 2024-04-24 11:16:10 +00:00
uv add basic "install from lock file" operation (#3340) 2024-05-03 08:18:36 -04:00
uv-auth Remove KeyringProvider.cache (#3243) 2024-04-24 15:39:24 +00:00
uv-build Allow --force to overwrite existing virtualenv (#2548) 2024-05-01 16:34:52 +00:00
uv-cache Accept --no-upgrade, --no-refresh, etc. on the CLI (#3328) 2024-05-01 11:13:33 -07:00
uv-client fix: remove cache generic from builder (#3322) 2024-04-30 08:27:55 -05:00
uv-configuration Accept --no-upgrade, --no-refresh, etc. on the CLI (#3328) 2024-05-01 11:13:33 -07:00
uv-dev Update toolchain discovery to avoid runtime panic (#3330) 2024-05-02 06:44:16 -05:00
uv-dispatch Use link mode for builds, in uv pip compile and for uv venv seed packages (#3016) 2024-04-15 08:49:41 +00:00
uv-distribution Fix typos (#3323) 2024-04-30 14:36:36 +00:00
uv-extract Fix single crate tokio features (#3234) 2024-04-24 08:55:15 +00:00
uv-fs Allow --force to overwrite existing virtualenv (#2548) 2024-05-01 16:34:52 +00:00
uv-git Dedicated error type for direct url parsing (#3181) 2024-04-22 11:57:36 +00:00
uv-installer Centralize installed dist satisfies requirement check (#3324) 2024-04-30 18:45:05 +02:00
uv-interpreter Split virtual environment detection into a dedicated module (#3331) 2024-05-02 06:58:48 -05:00
uv-normalize Add JSON Schema support (#3046) 2024-04-17 17:24:41 +00:00
uv-requirements An enum and backticks for lookahead error (#3216) 2024-04-23 17:28:10 +00:00
uv-resolver add basic "install from lock file" operation (#3340) 2024-05-03 08:18:36 -04:00
uv-trampoline Use c-string literals and update trampolines (#2590) 2024-03-21 15:36:00 +00:00
uv-types Remove unused dependencies (#3236) 2024-04-24 11:18:24 +00:00
uv-version Bump version to v0.1.39 (#3286) 2024-04-27 07:18:16 -04:00
uv-virtualenv Split virtual environment detection into a dedicated module (#3331) 2024-05-02 06:58:48 -05:00
uv-warnings Rename to uv (#1302) 2024-02-15 11:19:46 -06:00
uv-workspace Merge uv-toolchain and uv-interpreter (#3265) 2024-04-30 17:49:46 +00:00
README.md Rename uv-traits and split into separate modules (#2674) 2024-03-26 15:39:43 -05:00

Crates

bench

Functionality for benchmarking uv.

cache-key

Generic functionality for caching paths, URLs, and other resources across platforms.

distribution-filename

Parse built distribution (wheel) and source distribution (sdist) filenames to extract structured metadata.

distribution-types

Abstractions for representing built distributions (wheels) and source distributions (sdists), and the sources from which they can be downloaded.

install-wheel-rs

Install built distributions (wheels) into a virtual environment.]

once-map

A waitmap-like concurrent hash map for executing tasks exactly once.

pep440-rs

Utilities for interacting with Python version numbers and specifiers.

pep508-rs

Utilities for interacting with PEP 508 dependency specifiers.

platform-host

Functionality for detecting the current platform (operating system, architecture, etc.).

platform-tags

Functionality for parsing and inferring Python platform tags as per PEP 425.

uv

Command-line interface for the uv package manager.

uv-build

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-interpreter

Functionality for detecting and leveraging the current Python interpreter.

uv-normalize

Normalize package and extra names as per Python specifications.

uv-package

Types and functionality for working with Python packages, e.g., parsing wheel files.

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-types

Shared traits for uv, to avoid circular dependencies.

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.

requirements-txt

Functionality for parsing requirements.txt files.