Skip to content

Commit

Permalink
pipx list --freeze option
Browse files Browse the repository at this point in the history
If `--freeze` is supplied, print package information in a format
compatible with requirements files, like `pip freeze`.

Note that all pipx packages are listed, regardless of their associated
python version.
Like `pip freeze`, development packages and those installed from
non-pypi sources will simply have their name and version listed.
  • Loading branch information
clbarnes committed Sep 25, 2019
1 parent b3a4657 commit 981c77c
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 6 deletions.
4 changes: 3 additions & 1 deletion docs/docs.md
Original file line number Diff line number Diff line change
Expand Up @@ -347,12 +347,14 @@ optional arguments:

```
pipx list --help
usage: pipx list [-h] [--verbose]
usage: pipx list [-h] [--freeze] [--verbose]
List packages and apps installed with pipx
optional arguments:
-h, --help show this help message and exit
--freeze Print package information in `pip freeze`-like format. Unlike
`pip freeze`, dependencies are not included.
--verbose
```
Expand Down
21 changes: 21 additions & 0 deletions pipx/commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -648,6 +648,27 @@ def list_packages(venv_container: VenvContainer):
print(package_summary)


def _get_package_spec(path: Path, *, package: str = None) -> str:
venv = Venv(path)
if package is None:
package = path.name
metadata = venv.get_venv_metadata_for_package(package)
return f"{package}=={metadata.package_version}"


def freeze_packages(venv_container: VenvContainer):
dirs = list(sorted(venv_container.iter_venv_dirs()))
if not dirs:
print("")
return

venv_container.verify_shared_libs()

with multiprocessing.Pool() as p:
for package_spec in p.map(_get_package_spec, dirs):
print(package_spec)


def _get_exposed_app_paths_for_package(
venv_bin_path: Path, package_binary_names: List[str], local_bin_dir: Path
):
Expand Down
16 changes: 11 additions & 5 deletions pipx/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@
# PYTHON_ARGCOMPLETE_OK

"""The command line interface to pipx"""
from pathlib import Path

import argcomplete # type: ignore
import argparse
import functools
Expand Down Expand Up @@ -196,7 +194,10 @@ def run_pipx_command(args): # noqa: C901
force=args.force,
)
elif args.command == "list":
commands.list_packages(venv_container)
if args.freeze:
commands.freeze_packages(venv_container)
else:
commands.list_packages(venv_container)
elif args.command == "uninstall":
commands.uninstall(venv_dir, package, LOCAL_BIN_DIR, verbose)
elif args.command == "uninstall-all":
Expand Down Expand Up @@ -416,6 +417,12 @@ def _add_list(subparsers):
help="List installed packages",
description="List packages and apps installed with pipx",
)
p.add_argument(
"--freeze",
action="store_true",
help="Print package information in `pip freeze`-like format. "
"Unlike `pip freeze`, dependencies are not included.",
)
p.add_argument("--verbose", action="store_true")


Expand Down Expand Up @@ -538,8 +545,7 @@ def get_command_parser():

parser.add_argument("--version", action="store_true", help="Print version and exit")
subparsers.add_parser(
"completions",
help="Print instructions on enabling shell completions for pipx",
"completions", help="Print instructions on enabling shell completions for pipx"
)
return parser

Expand Down

0 comments on commit 981c77c

Please sign in to comment.