uv/crates
Charlie Marsh bf8934e3e4
Use intersection rather than union for requires-python (#5644)
## Summary

As-is, if you have a workspace with mixed `requires-python`
requirements, resolution will _never_ succeed, since we'll use the union
as the `requires-python` bound (i.e., take the lowest value), and fail
when we see the package that only supports some more narrow range.

This PR modifies the behavior to take the intersection (i.e., the
highest value), so if you have one package that supports Python 3.12 and
later, and another that supports Python 3.8 and later, we lock for
Python 3.12. If you try to sync or run with Python 3.8, we raise an
error, since the lockfile will be incompatible with that request.

Konsti has a write-up in https://github.com/astral-sh/uv/issues/5594
that outlines what could be a longer-term strategy.

Closes https://github.com/astral-sh/uv/issues/5578.
2024-07-31 16:08:53 +00:00
..
bench Upgrade to Rust 1.80.0 (#5472) 2024-07-27 01:49:47 +00:00
cache-key Use hasher to compute resolution hash (#5495) 2024-07-26 23:24:09 +00:00
distribution-filename Match wheel tags against Requires-Python major-minor (#5289) 2024-07-22 14:33:53 +00:00
distribution-types Add forks to lockfile, don't read them yet (#5480) 2024-07-30 11:11:18 +00:00
install-wheel-rs Avoid setting executable permissions on files we might not own (#5582) 2024-07-30 12:32:52 +00:00
once-map Use lockfile to prefill resolver index (#4495) 2024-07-12 18:49:28 -04:00
pep440-rs Extend Ruff configuration to sort imports (#5528) 2024-07-28 21:49:28 +00:00
pep508-rs Remove some unused methods (#5512) 2024-07-28 17:20:12 +00:00
platform-tags Process completed Python installs and uninstalls as a stream (#5203) 2024-07-19 12:50:38 +00:00
pypi-types Use existing METADATA parser in wheel installer (#5508) 2024-07-27 14:38:16 -04:00
requirements-txt Rename Error::IO to Error::Io (#5174) 2024-07-18 04:13:45 +00:00
uv Use intersection rather than union for requires-python (#5644) 2024-07-31 16:08:53 +00:00
uv-auth Upgrade to Rust 1.80.0 (#5472) 2024-07-27 01:49:47 +00:00
uv-build feat(venv): add relocatable flag (#5515) 2024-07-29 00:10:11 +00:00
uv-cache uv-client: switch heuristic freshness lifetime to hard-coded value 2024-07-31 08:12:11 -07:00
uv-cli Add --package to uv sync (#5656) 2024-07-31 15:16:48 +00:00
uv-client uv-client: switch heuristic freshness lifetime to hard-coded value 2024-07-31 08:12:11 -07:00
uv-configuration Make --reinstall imply --refresh (#5425) 2024-07-25 09:45:58 -04:00
uv-dev Move workspace abstractions to uv-workspace crate (#5236) 2024-07-20 02:15:32 +00:00
uv-dispatch Ban --no-cache with --link-mode=symlink (#5519) 2024-07-28 15:01:17 -04:00
uv-distribution Generate hashes for --find-links entries (#5544) 2024-07-29 08:49:38 +00:00
uv-extract Avoid setting executable permissions on files we might not own (#5582) 2024-07-30 12:32:52 +00:00
uv-fs Capture portable path serialization in a struct (#5652) 2024-07-31 16:00:37 +00:00
uv-git Remove some unused methods (#5512) 2024-07-28 17:20:12 +00:00
uv-installer Retain editable designation for cached wheel installs (#5545) 2024-07-28 22:39:48 -04:00
uv-macros Autogenerate possible values for enums in reference documentation (#5137) 2024-07-17 12:37:33 -04:00
uv-normalize Use hasher to compute resolution hash (#5495) 2024-07-26 23:24:09 +00:00
uv-options-metadata Autogenerate possible values for enums in reference documentation (#5137) 2024-07-17 12:37:33 -04:00
uv-python Replace --python-preference installed with managed (#5637) 2024-07-31 08:40:39 -05:00
uv-requirements Use cached current directory everywhere (#5574) 2024-07-29 17:03:45 -04:00
uv-resolver Use intersection rather than union for requires-python (#5644) 2024-07-31 16:08:53 +00:00
uv-scripts Upgrade to Rust 1.80.0 (#5472) 2024-07-27 01:49:47 +00:00
uv-settings Make --reinstall imply --refresh (#5425) 2024-07-25 09:45:58 -04:00
uv-shell Add Windows path updates for uv tool (#5029) 2024-07-13 01:55:05 +00:00
uv-state Cache tool environments in uv tool run (#4784) 2024-07-03 19:25:39 -04:00
uv-tool Capture portable path serialization in a struct (#5652) 2024-07-31 16:00:37 +00:00
uv-trampoline Upgrade to Rust 1.80.0 (#5472) 2024-07-27 01:49:47 +00:00
uv-types Enforce hashes in lockfile install (#5170) 2024-07-17 23:10:37 +00:00
uv-version Bump version to v0.2.32 (#5641) 2024-07-30 18:56:39 -04:00
uv-virtualenv Use cached current directory everywhere (#5574) 2024-07-29 17:03:45 -04:00
uv-warnings Upgrade to Rust 1.80.0 (#5472) 2024-07-27 01:49:47 +00:00
uv-workspace Capture portable path serialization in a struct (#5652) 2024-07-31 16:00:37 +00:00
README.md Move workspace abstractions to uv-workspace crate (#5236) 2024-07-20 02:15:32 +00: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-python

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

Utilities for detecting and manipulating shell environments.

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.

uv-workspace

Workspace abstractions for uv.

requirements-txt

Functionality for parsing requirements.txt files.