![]() <!-- Thank you for contributing to uv! To help us out with reviewing, please consider the following: - Does this pull request include a summary of the change? (See below.) - Does this pull request include a descriptive title? - Does this pull request include references to any relevant issues? --> ## Summary This modifies `gourgeist` to allow passing additional k,v pairs to add to the `pyvenv.cfg` file as proposed in #1697. I made it allow an arbitrary set of pairs (to decouple from `uv` since this is mainly a change to `gourgeist`) , but I can slim it down to just allow just a name and version strings if that's desired. The `pyvenv.cfg` will also have a `uv = <uv-crate-version>` when a venv is created via `uv venv` ~~and `uv-build = <uv-build-crate-version>` when it's created via `SourceBuild::setup`~~. Example below via `uv venv`: ```ini home = ... implementation = CPython version_info = 3.12 include-system-site-packages = false base-prefix = ... base-exec-prefix = ... base-executable = ... uv = 0.1.6 prompt = uv ``` Open to any suggestions, thanks! Closes #1697 ## Test Plan Added new test in `tests/venv.rs` called `verify_pyvenv_cfg` to verify that it contains the right uv version string. I didn't see tests configured in `gourgeist` itself, so I didn't add any there. |
||
---|---|---|
.. | ||
bench | ||
cache-key | ||
distribution-filename | ||
distribution-types | ||
gourgeist | ||
install-wheel-rs | ||
once-map | ||
pep440-rs | ||
pep508-rs | ||
platform-host | ||
platform-tags | ||
pypi-types | ||
requirements-txt | ||
uv | ||
uv-build | ||
uv-cache | ||
uv-client | ||
uv-dev | ||
uv-dispatch | ||
uv-distribution | ||
uv-extract | ||
uv-fs | ||
uv-git | ||
uv-installer | ||
uv-interpreter | ||
uv-normalize | ||
uv-resolver | ||
uv-traits | ||
uv-trampoline | ||
uv-warnings | ||
README.md |
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.
gourgeist
A venv
replacement to create virtual environments in Rust.
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-warnings
User-facing warnings for uv.
requirements-txt
Functionality for parsing requirements.txt
files.