uv/crates
Micha Reiser b296c04a67
Add CMD support (#1523)
## Sumamry

This PR adds the `activation.bat`, `deactivation.bat` and `pyenv.bat`
files to add support for using uv from CMD.

This PR further fixes an issue with our trampoline implementation where
calling an executable like `black` failed:

```
(venv) C:\Users\Micha\astral\test>where black
C:\Users\Micha\astral\test\.venv\Scripts\black.exe

(venv) C:\Users\Micha\astral\test>black
C:\Users\Micha\AppData\Local\Programs\Python\Python312\python.exe: can't open file 'C:\\Users\\Micha\\astral\\test\\black': [Errno 2] No such file or directory
```

The issue was that CMD doesn't extend `black` to its full path before
passing it to the trampoline and our trampoline generated the command
`<python> black` instead of `<python> .venv/Scripts/black`, and Python
can't find `black` in the project directory.

This PR fixes this by using the full executable name (that we already
parsed out to discover the Python version). This adds one complication,
we need to preserve the arguments without repeating the executable name
that is the first argument.
One option is to use
[`CommandLineToArgvW`](https://learn.microsoft.com/de-de/windows/win32/api/shellapi/nf-shellapi-commandlinetoargvw)
and then serialize the arguments 1.. to a string again. I decided
against that. Win32 API calls are easy to get wrong. That's why I
implemented the parsing rules specified in
[`CommandLineToArgvW`](https://learn.microsoft.com/de-de/windows/win32/api/shellapi/nf-shellapi-commandlinetoargvw)
to skip the first argument.

Fixes https://github.com/astral-sh/uv/issues/1471

## Test Plan


https://github.com/astral-sh/uv/assets/1203881/bdb537b6-97c8-4f7e-bb4a-3a614eb5e0f6

Powershell continues to work


https://github.com/astral-sh/uv/assets/1203881/6c806477-a7c6-4047-9ffc-5ed91c6f1c84

I haven't been able to test the aarch binaries.
2024-02-17 16:47:40 -05:00
..
bench Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
cache-key Avoid storing absolute URLs for files (#944) 2024-01-17 09:15:21 -05:00
distribution-filename Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
distribution-types Improve tracing when encountering invalid `requires-python` values (#1568) 2024-02-17 07:40:13 -05:00
gourgeist Add CMD support (#1523) 2024-02-17 16:47:40 -05:00
install-wheel-rs Avoid attempting rename in copy fallback path (#1546) 2024-02-16 17:08:49 -05:00
once-map Remove unused deps (#1273) 2024-02-11 18:53:58 +00:00
pep440-rs Fix typos & add pre-commit configuration (#1487) 2024-02-17 18:16:50 +01:00
pep508-rs Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
platform-host fix OS detection for Alpine Linux (#1545) 2024-02-16 16:37:18 -05:00
platform-tags Fix typos & add pre-commit configuration (#1487) 2024-02-17 18:16:50 +01:00
pypi-types Support MD5 hashes (#1556) 2024-02-17 00:25:16 +00:00
requirements-txt Add warning for empty requirements files (#1519) 2024-02-16 18:19:09 +00:00
uv Bump version to v0.1.4 (#1608) 2024-02-17 15:22:07 -05:00
uv-build Always run `get_requires_for_build_wheel` (#1590) 2024-02-17 09:24:58 -05:00
uv-cache Add `UV_NO_CACHE` environment variable (#1383) 2024-02-15 23:34:42 +00:00
uv-client Fix typos & add pre-commit configuration (#1487) 2024-02-17 18:16:50 +01:00
uv-dev Add support for `UV_EXTRA_INDEX_URL` (#1515) 2024-02-16 12:54:58 -06:00
uv-dispatch Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
uv-distribution Allow non-nested archives for `hexdump` and others (#1564) 2024-02-16 23:17:36 -05:00
uv-extract Allow non-nested archives for `hexdump` and others (#1564) 2024-02-16 23:17:36 -05:00
uv-fs Apply percent-decoding to file-based URLs (#1541) 2024-02-16 16:11:16 -05:00
uv-git Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
uv-installer Allow repeated dependencies when installing (#1558) 2024-02-17 01:33:40 +00:00
uv-interpreter Fix search for `python.exe` on Windows (#1381) 2024-02-15 17:25:20 -06:00
uv-normalize Ignore invalid extra named `.none` (#1428) 2024-02-16 05:01:21 +00:00
uv-resolver Allow URL requirements in editable installs (#1614) 2024-02-17 15:20:23 -05:00
uv-traits Fix diagram alignment (#1354) 2024-02-15 15:32:33 -06:00
uv-trampoline Add CMD support (#1523) 2024-02-17 16:47:40 -05:00
uv-warnings Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00
README.md Rename to `uv` (#1302) 2024-02-15 11:19:46 -06:00

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.