Preserve pinned PIP requirements in repositories you control..
Project description
pip-preserve-requirements
Preserve pinned PIP requirements in repositories you control.
It ensure pinned git references in pip requirements files are pushed to a repo you control, and have a tag associated with the commit, so they are preserved from garbage collection.
Table of Contents
Installation
pipx install pip-preserve-requirements
Usage
Usage: pip-preserve-requirements [OPTIONS] REQUIREMENTS_FILE...
Ensure pinned VCS references in pip requirements files have a git tag.
Arguments:
REQUIREMENTS_FILE... The requirements files to look for requirements tag.
[required]
Options:
--tag-prefix TEXT The prefix to use when creating git tag
names. [default: ppr-]
--match-any-tag Whether to consider that any tag on the
commit is sufficient. If not, ensure commits
are tagged with the requested prefix.
-r, --project-root DIRECTORY The project root directory. Default options
and arguments are read from pyproject.toml
in this directory. [default: .]
--install-completion [bash|zsh|fish|powershell|pwsh]
Install completion for the specified shell.
--show-completion [bash|zsh|fish|powershell|pwsh]
Show completion for the specified shell, to
copy it or customize the installation.
--help Show this message and exit.
Configuration
pip-preserve-requirements
is configured in a dedicated section of pyproject.toml
:
Example:
[tool.pip-preserve-requirements]
tag_prefix = "ppr-"
# ensure a tag with the above prefix is present, if true, consider any tag is valid
match_any_tag = false
[[tool.pip-preserve-requirements.vcs_vaults]]
# any git provider which accepts URLs of the form https://host/owner/repo
# or ssh://git@host/owner/repo
provider = "github.com"
owner = "acme"
# set to true for private repos
ssh_only = false
# the vault where to push VCS reference
default = true
Limitations
At the moment, only git+https
and git+ssh
URLs are supported.
The following improvements would be considered in scope, although there is no current plan to work on them:
- supporting other VCS (such as
hg
); - supporting non-VCS URLs, by pushing them to a user-controlled server;
- supporting regular requirements, by pushing them to a user-controlled index.
License
pip-preserve-requirements
is distributed under the terms of the
MIT license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pip_preserve_requirements-0.3.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 76de3022b1abf57fe30fdb575fdf7eb982ef3f6f7b30ff7159b673841266b2c4 |
|
MD5 | 71430ab432fcc2620895ff158b22b268 |
|
BLAKE2b-256 | 8c4d739198a8bf2d5c5294195ef572df2bb9b7574d3dbe34f99143a1fb1d0d1a |
Hashes for pip_preserve_requirements-0.3.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | fb75c1e831b6c69d2b46de458a50334f877569d6c4ed1029909e798619cfbcff |
|
MD5 | c1d24ba58d73b5bf9caf0480920c4744 |
|
BLAKE2b-256 | 71a5fbb43dfea3e5e4f5b94c6d70ebd563528de2e841c723f831de99236ad325 |