uv/crates
konsti 54311c8664
Retry on python interpreter launch failures (#2278)
Sometimes, the first time we read from the stdout of the bytecode
compiler python subprocess, we get an empty string back (no newline). If
we try to write to stdin, it will often be a broken pipe (#2245). After
we got an empty string the first time, we will get the same empty string
if we read a line again.

The details of this behavior are mysterious to me, but it seems that it
can be identified by the first empty string. We check by inserting
starting with a `Ready` message on the Python side. When we encounter
the broken state, we discard the interpreter and try again.

We have to introduce a third timeout check for the interpreter launch
itself.

Minimized test script:

```bash
#!/usr/bin/env bash

set -euo pipefail

while true; do
  date --iso-8601=seconds # Progress indicator
  rm -rf testenv
  target/profiling/uv venv testenv -q --python 3.12
  VIRTUAL_ENV=$PWD/testenv target/profiling/uv pip install -q --compile wheel==0.42.0
done
```

Run as

```
cargo build --profile profiling && bash compile_bug.sh
```

Fixes #2245
2024-03-07 16:07:58 +01:00
..
bench Rename to uv (#1302) 2024-02-15 11:19:46 -06:00
cache-key Clippy pedantic (#1963) 2024-02-25 14:04:05 -05:00
distribution-filename Bump insta from 1.35.1 to 1.36.1 (#2180) 2024-03-04 23:01:49 +00:00
distribution-types tweak the order of index priority (#2083) 2024-02-29 11:57:07 -05:00
install-wheel-rs Close RECORD after reading entries during uninstall (#2259) 2024-03-07 04:35:22 +00:00
once-map Remove unused deps (#1273) 2024-02-11 18:53:58 +00:00
pep440-rs pep440: remove redundant without_local() (#2019) 2024-02-27 11:00:58 -05:00
pep508-rs Use insta in pep508_rs (#2275) 2024-03-07 08:54:05 -05:00
platform-host Clippy pedantic (#1963) 2024-02-25 14:04:05 -05:00
platform-tags Prefer more recent minor versions in wheel tags (#2263) 2024-03-07 14:04:54 +00:00
pypi-types Query interpreter to determine correct virtualenv paths (#2188) 2024-03-05 16:13:24 -05:00
requirements-txt Make Client optional in requirements-txt (#2229) 2024-03-06 05:49:09 +00:00
uv Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-auth Clippy pedantic (#1963) 2024-02-25 14:04:05 -05:00
uv-build Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-cache Centralize up-to-date checking for path installations (#2168) 2024-03-04 14:10:51 -05:00
uv-client Cache wheel metadata in no-PEP 658 fallback (#2255) 2024-03-06 19:46:24 -05:00
uv-dev Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-dispatch Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-distribution Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-extract Add fs_err to disallowed_method in clippy.toml (#1950) 2024-02-26 14:15:07 +00:00
uv-fs Fix uv tokio extra, part 2 (#2274) 2024-03-07 12:27:37 +00:00
uv-git Use Simplified instead of Normalized for path prefix stripping (#2071) 2024-02-29 01:44:50 +00:00
uv-installer Retry on python interpreter launch failures (#2278) 2024-03-07 16:07:58 +01:00
uv-interpreter Fix Conda Python detection on Windows (#2279) 2024-03-07 14:45:09 +00:00
uv-normalize Clippy pedantic (#1963) 2024-02-25 14:04:05 -05:00
uv-resolver Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-traits Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-trampoline Win Trampoline: Use Python executable path encoded in binary (#1803) 2024-02-22 16:10:02 +01:00
uv-version Bump version to v0.1.15 (#2217) 2024-03-05 14:47:10 -05:00
uv-virtualenv Add support for --no-build-isolation (#2258) 2024-03-07 14:04:02 +00:00
uv-warnings Rename to uv (#1302) 2024-02-15 11:19:46 -06:00
README.md Rename gourgeist to uv-virtualenv (#2118) 2024-03-01 14:02:40 -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-traits.

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

Functionality for resolving Python packages and their dependencies.

uv-traits

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.