Skip to main content

Wrapper for pipx to add some minor functionality

Project description

PIPXX - Wrapper for pipx to add some minor functionality

PyPi

Note: This project has been superceded by my pipxu project which is a new implementation of pipx that uses uv.

pipxx is a simple command line utility to wrap the usage of pipx to provide some minor improved functions. Consider pipxx a proof of concept of some ideas for pipx.

  1. Global application installation by root.
  2. Enhancement of pipx list output.
  3. Automatic determination of pyenv Python path for install.
  4. Substitution of current directory with package name for uninstall.

See the description of these enhancements below.

pipxx is merely a wrapper for pipx so takes exactly the same command line arguments and options. Just run pipxx the same as you would run pipx. Type pipx or pipx -h to view the usage summary for pipx (or type pipxx or pipxx -h to see the same usage summary).

The latest version and documentation is available at https://github.com/bulletmark/pipxx.

Enhancement 1: Global application installation by root

pipx is used normally to install applications for a single user. It can also install applications globally as root but that is awkward because you have to manually set environment variables. pipxx recognises when it is run as root (or with sudo) and automatically sets appropriate system global PIPX_BIN_DIR, PIPX_MAN_DIR, and PIPX_HOME directories for pipx.

E.g. to install application as normal user:

$ pipxx install cowsay

To install application for all users (i.e. globally):

$ sudo pipxx install cowsay

Note, to see the global directories selected by pipxx for your system:

$ sudo pipxx environment

Enhancement 2: Improved pipx list output

pipx list output lacks some useful information. pipxx adds the following to the pipx list output:

  1. The PyPi package name, or source directory, or VCS URL from where the application was installed from,
  2. Whether the application is installed as editable.

Enhancement 3: Automatic determination of pyenv Python path for install

When installing, you can tell pipx to use a specific version/path of Python using the --python option. Unfortunately, you have to specify the full path to the python interpreter you want. Very commonly, pyenv is used to install multiple versions of Python.

So to use a specific pyenv Python version with pipx you have to type:

$ pipx install --python ~/.pyenv/versions/3.12.0/bin/python cowsay

With pipxx you merely have to type:

$ pipxx install --python 3.12 cowsay

I.e. pipxx will work out from 3.12 that you want the path ~/.pyenv/versions/3.12.0/bin/python, i.e. the latest 3.12 version installed at the time of this example. You could alternately type pipxx install --python 3 cowsay, or pipxx install --python 3.12.0 cowsay.

Note the automatically selected path is dependent on your system/installation and is derived by pipxx from the output of pyenv root.

Actually, --python is a commonly used option but unfortunately pipx does not provide a short-form option for it. So pipxx also adds -P as an alias for --python allowing you to simply type:

$ pipxx install -P 3.12 cowsay

Note that pipxx also adds a description of the added pyenv version option and the added -P alias option to the install --help output.

Enhancement 4: Substitution of current directory with package name for uninstall

Developers often use pipx to install and run an application they are working on from a local source directory. E.g. for an example application myapp:

$ pwd
/home/myname/src/myapp
$ pipx install -e .
installed package myapp <...>

To uninstall this application you have to type pipx uninstall myapp. However, thinking symmetrically, you would expect pipx uninstall . would suffice. So pipxx adds the ability to do this:

$ pipxx uninstall .
uninstalled myapp!

Installation or upgrade or removal

Note pipxx is on PyPI so just ensure that pipx is installed then type the following:

To install:

$ pipx install pipxx

To upgrade:

$ pipx upgrade pipxx

To remove:

$ pipx uninstall pipxx

pipxx requires Python >= 3.7 and requires no 3rd party packages. It requires that pipx is in your $PATH.

License

Copyright (C) 2023 Mark Blakeney. This program is distributed under the terms of the GNU General Public License. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License at http://www.gnu.org/licenses/ for more details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pipxx-1.10.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

pipxx-1.10-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file pipxx-1.10.tar.gz.

File metadata

  • Download URL: pipxx-1.10.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for pipxx-1.10.tar.gz
Algorithm Hash digest
SHA256 06dc4e65a0315993fb54d1dcd493277cb012911cb1641dd3990ddd83c3adaf32
MD5 e6e6d7d3fd7fea25abca36cc583596e8
BLAKE2b-256 192316a82688edb9765ab9924cd7cc846ccf8bfb3decef49998a9f6b76308f5d

See more details on using hashes here.

File details

Details for the file pipxx-1.10-py3-none-any.whl.

File metadata

  • Download URL: pipxx-1.10-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for pipxx-1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 d556c5dcffdf86057a02824ebfda06aa8b13bc8305ab72f51f398f0a5a164ad8
MD5 84039da8e5aa70bb6a008d139d22759e
BLAKE2b-256 aee73a1e3cdda59f1ec28cd80af0728778d493b3718646921cde5a181d6330fb

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page