mirror of https://github.com/astral-sh/uv
56 lines
2.5 KiB
Markdown
56 lines
2.5 KiB
Markdown
# uv-virtualenv
|
|
|
|
`uv-virtualenv` is a rust library to create Python virtual environments. It also has a CLI.
|
|
|
|
## Syncing with upstream virtualenv activation scripts
|
|
|
|
This crate tries to stay in sync with pypa/virtualenv project's activation scrips. However, there
|
|
are some deviations that are specific to this crate's implementation.
|
|
|
|
### License disclaimers added
|
|
|
|
This crate includes license information at the top of each activation script. This is done in
|
|
accordance with the pypa/virtualenv project's MIT License. Do not remove the declarative license
|
|
comments from this crate's activation scripts.
|
|
|
|
### Placeholder names are slightly different
|
|
|
|
Note, these activation scripts are actually templates that are populated with certain values when a
|
|
virtual environment is created.
|
|
|
|
In upstream, the placeholder names are found in
|
|
[`virtualenv.activation.ViaTemplateActivator.replacements()`][upstream-placeholders].
|
|
|
|
In this crate, the placeholder names are found in
|
|
[`uv_virtualenv::virtualenv::create()`][crate-placeholders]
|
|
|
|
[upstream-placeholders]:
|
|
https://github.com/pypa/virtualenv/blob/dad9369e97f5aef7e33777b18dcdb51b1fdac7bd/src/virtualenv/activation/via_template.py#L43
|
|
[crate-placeholders]:
|
|
https://github.com/astral-sh/uv/blob/d8f3f03198308be53de51a3a297c85566eabb084/crates/uv-virtualenv/src/virtualenv.rs#L462
|
|
|
|
It is important that the placeholder names (as used in the activation scripts) conform to the
|
|
placeholders names used in [this crate's source][crate-placeholders].
|
|
|
|
### Relocatable virtual environments
|
|
|
|
This crate uses some additional tweaks in the activation scripts to ensure the virtual environment
|
|
is relocatable. Thus, the patch in [astral-sh/uv#5640] shall be retained.
|
|
|
|
[astral-sh/uv#5640]: https://github.com/astral-sh/uv/pull/5640
|
|
|
|
### TCL/TK library locations
|
|
|
|
The patches in upstream virtualenv ([pypa/virtualenv#2928] and [pypa/virtualenv#2940]) implement
|
|
dynamically locating the TCL/TK libraries of a base Python distribution (see [upstream
|
|
approach][upstream-tcl/tk-approach]).
|
|
|
|
[pypa/virtualenv#2928]: https://github.com/pypa/virtualenv/pull/2928
|
|
[pypa/virtualenv#2940]: https://github.com/pypa/virtualenv/pull/2940
|
|
[upstream-tcl/tk-approach]:
|
|
https://github.com/pypa/virtualenv/blob/dad9369e97f5aef7e33777b18dcdb51b1fdac7bd/src/virtualenv/discovery/py_info.py#L140
|
|
|
|
This upstream implementation is considered an undesirable complexity in this project. As such, the
|
|
upstream TCL/TK related patches shall be omitted when syncing activation scripts with upstream
|
|
sources.
|