-
-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support installing packages by pip install
#2128
Comments
$ pip --version
pip 21.1.2 from /Users/shunsuke-suzuki/.pyenv/versions/3.9.5/lib/python3.9/site-packages/pip (python 3.9)
$ pip install --help
Usage:
pip install [options] <requirement specifier> [package-index-options] ...
pip install [options] -r <requirements file> [package-index-options] ...
pip install [options] [-e] <vcs project url> ...
pip install [options] [-e] <local project path> ...
pip install [options] <archive url/path> ...
Description:
Install packages from:
- PyPI (and other indexes) using requirement specifiers.
- VCS project urls.
- Local project directories.
- Local or remote source archives.
pip also supports installing from "requirements files", which provide
an easy way to specify a whole environment to be installed.
Install Options:
-r, --requirement <file> Install from the given requirements file. This option can be used multiple times.
-c, --constraint <file> Constrain versions using the given constraints file. This option can be used multiple times.
--no-deps Don't install package dependencies.
--pre Include pre-release and development versions. By default, pip only finds stable versions.
-e, --editable <path/url> Install a project in editable mode (i.e. setuptools "develop mode") from a local project path or a VCS url.
-t, --target <dir> Install packages into <dir>. By default this will not replace existing files/folders in <dir>. Use --upgrade to replace existing packages in <dir>
with new versions.
--platform <platform> Only use wheels compatible with <platform>. Defaults to the platform of the running system. Use this option multiple times to specify multiple
platforms supported by the target interpreter.
--python-version <python_version>
The Python interpreter version to use for wheel and "Requires-Python" compatibility checks. Defaults to a version derived from the running
interpreter. The version can be specified using up to three dot-separated integers (e.g. "3" for 3.0.0, "3.7" for 3.7.0, or "3.7.3"). A major-
minor version can also be given as a string without dots (e.g. "37" for 3.7.0).
--implementation <implementation>
Only use wheels compatible with Python implementation <implementation>, e.g. 'pp', 'jy', 'cp', or 'ip'. If not specified, then the current
interpreter implementation is used. Use 'py' to force implementation-agnostic wheels.
--abi <abi> Only use wheels compatible with Python abi <abi>, e.g. 'pypy_41'. If not specified, then the current interpreter abi tag is used. Use this option
multiple times to specify multiple abis supported by the target interpreter. Generally you will need to specify --implementation, --platform, and
--python-version when using this option.
--user Install to the Python user install directory for your platform. Typically ~/.local/, or %APPDATA%\Python on Windows. (See the Python documentation
for site.USER_BASE for full details.)
--root <dir> Install everything relative to this alternate root directory.
--prefix <dir> Installation prefix where lib, bin and other top-level folders are placed
--src <dir> Directory to check out editable projects into. The default in a virtualenv is "<venv path>/src". The default for global installs is "<current
dir>/src".
-U, --upgrade Upgrade all specified packages to the newest available version. The handling of dependencies depends on the upgrade-strategy used.
--upgrade-strategy <upgrade_strategy>
Determines how dependency upgrading should be handled [default: only-if-needed]. "eager" - dependencies are upgraded regardless of whether the
currently installed version satisfies the requirements of the upgraded package(s). "only-if-needed" - are upgraded only when they do not satisfy
the requirements of the upgraded package(s).
--force-reinstall Reinstall all packages even if they are already up-to-date.
-I, --ignore-installed Ignore the installed packages, overwriting them. This can break your system if the existing package is of a different version or was installed
with a different package manager!
--ignore-requires-python Ignore the Requires-Python information.
--no-build-isolation Disable isolation when building a modern source distribution. Build dependencies specified by PEP 518 must be already installed if this option is
used.
--use-pep517 Use PEP 517 for building source distributions (use --no-use-pep517 to force legacy behaviour).
--install-option <options> Extra arguments to be supplied to the setup.py install command (use like --install-option="--install-scripts=/usr/local/bin"). Use multiple
--install-option options to pass multiple options to setup.py install. If you are using an option with a directory path, be sure to use absolute
path.
--global-option <options> Extra global options to be supplied to the setup.py call before the install or bdist_wheel command.
--compile Compile Python source files to bytecode
--no-compile Do not compile Python source files to bytecode
--no-warn-script-location Do not warn when installing scripts outside PATH
--no-warn-conflicts Do not warn about broken dependencies
--no-binary <format_control>
Do not use binary packages. Can be supplied multiple times, and each time adds to the existing value. Accepts either ":all:" to disable all binary
packages, ":none:" to empty the set (notice the colons), or one or more package names with commas between them (no colons). Note that some
packages are tricky to compile and may fail to install when this option is used on them.
--only-binary <format_control>
Do not use source packages. Can be supplied multiple times, and each time adds to the existing value. Accepts either ":all:" to disable all source
packages, ":none:" to empty the set, or one or more package names with commas between them. Packages without binary distributions will fail to
install when this option is used on them.
--prefer-binary Prefer older binary packages over newer source packages.
--require-hashes Require a hash to check each requirement against, for repeatable installs. This option is implied when any package in a requirements file has a
--hash option.
--progress-bar <progress_bar>
Specify type of progress to be displayed [off|on|ascii|pretty|emoji] (default: on)
--no-clean Don't clean up build directories.
Package Index Options:
-i, --index-url <url> Base URL of the Python Package Index (default https://pypi.org/simple). This should point to a repository compliant with PEP 503 (the simple
repository API) or a local directory laid out in the same format.
--extra-index-url <url> Extra URLs of package indexes to use in addition to --index-url. Should follow the same rules as --index-url.
--no-index Ignore package index (only looking at --find-links URLs instead).
-f, --find-links <url> If a URL or path to an html file, then parse for links to archives such as sdist (.tar.gz) or wheel (.whl) files. If a local path or file:// URL
that's a directory, then look for archives in the directory listing. Links to VCS project URLs are not supported.
General Options:
-h, --help Show help.
--isolated Run pip in an isolated mode, ignoring environment variables and user configuration.
-v, --verbose Give more output. Option is additive, and can be used up to 3 times.
-V, --version Show version and exit.
-q, --quiet Give less output. Option is additive, and can be used up to 3 times (corresponding to WARNING, ERROR, and CRITICAL logging levels).
--log <path> Path to a verbose appending log.
--no-input Disable prompting for input.
--proxy <proxy> Specify a proxy in the form [user:passwd@]proxy.server:port.
--retries <retries> Maximum number of retries each connection should attempt (default 5 times).
--timeout <sec> Set the socket timeout (default 15 seconds).
--exists-action <action> Default action when a path already exists: (s)witch, (i)gnore, (w)ipe, (b)ackup, (a)bort.
--trusted-host <hostname> Mark this host or host:port pair as trusted, even though it does not have valid or any HTTPS.
--cert <path> Path to PEM-encoded CA certificate bundle. If provided, overrides the default. See 'SSL Certificate Verification' in pip documentation for more
information.
--client-cert <path> Path to SSL client certificate, a single file containing the private key and the certificate in PEM format.
--cache-dir <dir> Store the cache data in <dir>.
--no-cache-dir Disable the cache.
--disable-pip-version-check
Don't periodically check PyPI to determine whether a new version of pip is available for download. Implied with --no-index.
--no-color Suppress colored output.
--no-python-version-warning
Silence deprecation warnings for upcoming unsupported Pythons.
--use-feature <feature> Enable new functionality, that may be backward incompatible.
--use-deprecated <feature> Enable deprecated functionality, that will be removed in the future. e.g. $ pip install --root pip-root pre-commit $ ls pip-root/Users/shunsuke-suzuki/.local/bin
identify-cli nodeenv pre-commit virtualenv |
Directory structure
|
RenovatePypi datasource |
Package namePackages in https://pypi.org/ should start with In the repository aquaproj/aqua-registry, pip packages should be located in |
$ pip install -t target pre-commit
$ ls target/bin
identify-cli nodeenv pre-commit virtualenv |
|
|
Get the list of available versionshttps://stackoverflow.com/a/27239645/6364492 curl "https://pypi.org/pypi/pre-commit/json" | jq -r '.releases | keys[]' |
Document (Draft)Support installing packages by pip installFeature OverviewSupport installing packages by Why is the feature needed?To support packages written in Python. Requirements
aqua doesn't install these requirements automatically. Please install them yourself. This feature depends on versions of Python and pip.
$ python --version
$ pip --version Getting StartedLet's install pre-commit by aqua. aqua init aqua g -i pypi.org/pre-commit You can also select the version by aqua g -i -s pypi.org/pre-commit aqua i -l
aqua which pre-commit
pre-commit --version aqua-renovate-confighttps://github.com/aquaproj/aqua-renovate-config From 1.8.0, aqua-renovate-config supports updating
e.g. How to add new
|
TODO
|
I decided to rename the package type name |
Hi @Gowiem , I published a pre-release version Document: #2128 (comment) aqua update-aqua v2.11.0-4
aqua -v
mkdir workspace
cd workspace
aqua init
vi aqua.yaml aqua.yaml ---
registries:
- type: standard
ref: cd6610dcdee69814d8f72e06e9557d42abad4298 # https://github.com/aquaproj/aqua-registry/pull/14185
packages: Install pre-commit. aqua g -i pypi.org/pre-commit
aqua i -l Please check if pre-commit installed by aqua is executed. command -v pre-commit If pre-commit installed by other than aqua is executed, you have some options.
Then please confirm that pre-commit --help |
|
I'm adding some pypi packages. |
|
@suzuki-shunsuke note that pipx is not suitable for project specific tool versions, see pypa/pipx#1031 Perhaps aqua can provide a wrapper for both pipx and npx to install pip and node packages declaratively? Aqua could run pipx under the hood and then just add the created binary to its path, for example |
So rethinking this, i'm not sure pipx is a good solution since I believe it can produce non-deterministic builds: pypa/pipx#1050 I believe that in order to make aqua work with pip packages and make them reproducible, aqua would need to do the following:
|
I see. Thank you. I misunderstood pipx. How about direnv? https://github.com/direnv/direnv/wiki/Python .envrc
requirements.txt
direnv allow
pip install -r requirements.txt $ command -V pre-commit
pre-commit is /Users/shunsukesuzuki/Documents/test/foo/.direnv/python-3.10/bin/pre-commit
$ pre-commit -V
pre-commit 3.3.3 To specify Python version, direnv + pyenv is useful. |
Yeah i've also considered direnv as an alternative, there are a few issues though:
|
Feature Overview
Support installing packages by
pip install
.Why is the feature needed?
To support packages written in Python.
Workaround
Install tools with other tools.
Example Code
registry.yaml
Reference
The text was updated successfully, but these errors were encountered: