Metadata-Version: 2.1
Name: meta-package-manager
Version: 5.0.1
Summary: 📦 one CLI for all package managers
Home-page: https://github.com/kdeldycke/meta-package-manager
License: GPL-2.0-or-later
Keywords: CLI,apm,apt,apt-mint,atom,brew,cask,choco,chocotaley,composer,dnf,emerge,flatpak,gem,homebrew,mac app store,macos,mas,node,npm,opkg,package,pacman,php composer,pip,plugin,portage,ruby,snap,steamcmd,visual studio code,vscode,xbar,swiftbar,yarn,yum,zypper
Author: Kevin Deldycke
Author-email: kevin@deldycke.com
Requires-Python: >=3.7,<4.0
Classifier: Development Status :: 5 - Production/Stable
Classifier: Environment :: Console
Classifier: Environment :: MacOS X
Classifier: Environment :: Plugins
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Information Technology
Classifier: Intended Audience :: System Administrators
Classifier: License :: OSI Approved :: GNU General Public License v2 or later (GPLv2+)
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: System :: Archiving :: Packaging
Classifier: Topic :: System :: Installation/Setup
Classifier: Topic :: System :: Software Distribution
Classifier: Topic :: Utilities
Requires-Dist: boltons (>=21.0.0,<22.0.0)
Requires-Dist: click (>=8.1.2,<9.0.0)
Requires-Dist: click-extra (>=2.1.0,<3.0.0)
Requires-Dist: tabulate[widechars] (>=0.8.9,<0.9.0)
Requires-Dist: tomli (>=2.0.1,<3.0.0); python_version < "3.11"
Requires-Dist: tomli_w (>=1.0.0,<2.0.0)
Requires-Dist: xmltodict (>=0.12.0,<0.13.0)
Project-URL: Changelog, https://kdeldycke.github.io/meta-package-manager/changelog.html
Project-URL: Documentation, https://kdeldycke.github.io/meta-package-manager
Project-URL: Funding, https://github.com/sponsors/kdeldycke
Project-URL: Issues, https://github.com/kdeldycke/meta-package-manager/issues
Project-URL: Repository, https://github.com/kdeldycke/meta-package-manager
Description-Content-Type: text/markdown

<p align="center">
  <a href="https://github.com/kdeldycke/meta-package-manager/">
    <img src="https://raw.githubusercontent.com/kdeldycke/meta-package-manager/main/docs/images/logo-banner.svg" alt="Meta Package Manager">
  </a>
</p>

<a href="https://xkcd.com/1654/" alt="XKCD #1654: Universal Install Script">
<img align="right" width="20%" height="20%" src="http://imgs.xkcd.com/comics/universal_install_script.png"/>
</a>

[![Last release](https://img.shields.io/pypi/v/meta-package-manager.svg)](https://pypi.python.org/pypi/meta-package-manager)
[![Python versions](https://img.shields.io/pypi/pyversions/meta-package-manager.svg)](https://pypi.python.org/pypi/meta-package-manager)
[![Unittests status](https://github.com/kdeldycke/meta-package-manager/actions/workflows/tests.yaml/badge.svg?branch=main)](https://github.com/kdeldycke/meta-package-manager/actions/workflows/tests.yaml?query=branch%3Amain)
[![Documentation status](https://github.com/kdeldycke/meta-package-manager/actions/workflows/docs.yaml/badge.svg?branch=main)](https://github.com/kdeldycke/meta-package-manager/actions/workflows/docs.yaml?query=branch%3Amain)
[![Coverage status](https://codecov.io/gh/kdeldycke/meta-package-manager/branch/main/graph/badge.svg)](https://codecov.io/gh/kdeldycke/meta-package-manager/branch/main)

**What is Meta Package Manager?**

- provides the `mpm` CLI
- `mpm` is like [`yt-dlp`](https://github.com/yt-dlp/yt-dlp), but for package
  managers instead of videos
- `mpm` solves [XKCD #1654: Universal Install Script](https://xkcd.com/1654/)

______________________________________________________________________

## Features

<img align="right" width="30%" height="30%" src="https://raw.githubusercontent.com/kdeldycke/meta-package-manager/main/docs/images/mpm-outdated-cli.png"/>

<img align="right" width="30%" height="30%" src="https://raw.githubusercontent.com/kdeldycke/meta-package-manager/main/docs/images/mpm-managers-cli.png"/>

- Inventory and list all package managers available on the system.
- Supports macOS, Linux and Windows.
- List installed packages.
- Search for packages.
- Install a package.
- List outdated packages.
- Sync local package infos.
- Upgrade all outdated packages.
- Backup list of installed packages to TOML file.
- Restore/install list of packages from TOML files.
- Pin-point commands to a subset of package managers (include/exclude
  selectors).
- Export results in JSON or user-friendly tables.
- Shell auto-completion for Bash, Zsh and Fish.
- Provides a
  [Xbar/SwiftBar plugin](https://kdeldycke.github.io/meta-package-manager/bar-plugin.html) for
  friendly macOS integration.
- Because `mpm` try to wrap all other package managers, it became another
  pathological case of [XKCD #927: Standards](https://xkcd.com/927/)

## Supported package managers

| Package manager                                                           | Min. version | macOS | Linux | Windows | `installed` | `outdated` |                               `search`                                | `install` | `upgrade` | `sync` | `cleanup` |
| ------------------------------------------------------------------------- | ------------ | :---: | :---: | :-----: | :---------: | :--------: | :-------------------------------------------------------------------: | :-------: | :-------: | :----: | :-------: |
| [`apm`](https://atom.io/packages)                                         | 1.0.0        |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |           |
| [`apt`](https://wiki.debian.org/AptCLI)                                   | 1.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`apt-mint`](https://github.com/kdeldycke/meta-package-manager/issues/52) | 1.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`brew`](https://brew.sh)                                                 | 2.7.0        |   🍎   |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`cask`](https://caskroom.github.io)                                      | 2.7.0        |   🍎   |       |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`choco`](https://chocolatey.org)                                         | 0.10.4       |       |       |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |           |
| [`composer`](https://getcomposer.org)                                     | 1.4.0        |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |     ✓     |
| [`dnf`](https://github.com/rpm-software-management/dnf)                   | 4.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`emerge`](https://wiki.gentoo.org/wiki/Portage#emerge)                   | 3.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`flatpak`](https://flatpak.org)                                          | 1.2.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |     ✓     |
| [`gem`](https://rubygems.org)                                             | 2.5.0        |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |     ✓     |
| [`mas`](https://github.com/argon/mas)                                     | 1.6.1        |   🍎   |       |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |           |
| [`npm`](https://www.npmjs.com)                                            | 4.0.0        |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |           |
| [`opkg`](https://git.yoctoproject.org/cgit/cgit.cgi/opkg/)                | 0.2.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |           |
| [`pacman`](https://wiki.archlinux.org/title/pacman)                       | 5.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`pip`](https://pypi.org)                                                 | 10.0.0       |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      | [✘\*](https://github.com/pypa/pip/issues/5216#issuecomment-744605466) |     ✓     |     ✓     |        |           |
| [`snap`](https://snapcraft.io)                                            | 2.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |           |
| [`steamcmd`](https://developer.valvesoftware.com/wiki/SteamCMD)           | None         |   🍎   |   🐧   |    🪟    |             |            |                                                                       |     ✓     |     ✓     |        |           |
| [`vscode`](https://code.visualstudio.com)                                 | 1.60.0       |   🍎   |   🐧   |    🪟    |      ✓      |            |                                   ✓                                   |     ✓     |           |        |           |
| [`yarn`](https://yarnpkg.com)                                             | 1.21.0       |   🍎   |   🐧   |    🪟    |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |        |     ✓     |
| [`yum`](http://yum.baseurl.org)                                           | 4.0.0        |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |
| [`zypper`](https://en.opensuse.org/Portal:Zypper)                         | 1.14.0       |       |   🐧   |         |      ✓      |     ✓      |                                   ✓                                   |     ✓     |     ✓     |   ✓    |     ✓     |

## Quickstart

1. Install `mpm` with `pip`:

   ```shell-session
   $ pip install meta-package-manager
   ```

Other
[alternatives installation methods](https://kdeldycke.github.io/meta-package-manager/install.html)
are available in the documentation.

## List managers

List all supported package managers and their status on current system (macOS
in this case):

```shell-session
$ mpm --all-managers managers
╭────────────────────┬──────────┬────────────────┬───────────────────────────┬────────────┬──────────────╮
│ Package manager    │ ID       │ Supported      │ CLI                       │ Executable │ Version      │
├────────────────────┼──────────┼────────────────┼───────────────────────────┼────────────┼──────────────┤
│ Atom's apm         │ apm      │ ✓              │ ✓ /usr/local/bin/apm      │ ✓          │ ✓ 2.6.2      │
│ APT                │ apt      │ ✘ Linux only   │ ✓ /usr/bin/apt            │ ✓          │ ✘            │
│ Linux Mint's apt   │ apt-mint │ ✘ Linux only   │ ✓ /usr/bin/apt            │ ✓          │ ✘            │
│ Homebrew Formulae  │ brew     │ ✓              │ ✓ /usr/local/bin/brew     │ ✓          │ ✓ 3.2.16     │
│ Homebrew Cask      │ cask     │ ✓              │ ✓ /usr/local/bin/brew     │ ✓          │ ✓ 3.2.16     │
│ Chocolatey         │ choco    │ ✘ Windows only │ ✘ choco not found         │            │              │
│ PHP's Composer     │ composer │ ✓              │ ✓ /usr/local/bin/composer │ ✓          │ ✓ 2.1.8      │
│ DNF                │ dnf      │ ✘ Linux only   │ ✘ dnf not found           │            │              │
│ Emerge             │ emerge   │ ✘ Linux only   │ ✘ emerge not found        │            │              │
│ Flatpak            │ flatpak  │ ✘ Linux only   │ ✘ flatpak not found       │            │              │
│ Ruby Gems          │ gem      │ ✓              │ ✓ /usr/bin/gem            │ ✓          │ ✓ 3.0.3      │
│ Mac AppStore       │ mas      │ ✓              │ ✓ /usr/local/bin/mas      │ ✓          │ ✓ 1.8.3      │
│ Node's npm         │ npm      │ ✓              │ ✓ /usr/local/bin/npm      │ ✓          │ ✓ 7.24.0     │
│ OPKG               │ opkg     │ ✘ Linux only   │ ✘ opkg not found          │            │              │
│ Pacman             │ pacman   │ ✘ Linux only   │ ✘ pacman not found        │            │              │
│ Pip                │ pip      │ ✓              │ ✓ /usr/local/bin/python3  │ ✓          │ ✓ 21.2.4     │
│ Snap               │ snap     │ ✘ Linux only   │ ✘ snap not found          │            │              │
│ SteamCMD           │ steamcmd │ ✓              │ ✓ /opt/local/bin/steamcmd │ ✓          │ ✓ 1648077083 │
│ Visual Studio Code │ vscode   │ ✓              │ ✓ /usr/local/bin/code     │ ✓          │ ✓ 1.61.0     │
│ Node's yarn        │ yarn     │ ✓              │ ✘ yarn not found          │            │              │
│ YUM                │ yum      │ ✘ Linux only   │ ✘ yum not found           │            │              │
│ Zypper             │ zypper   │ ✘ Linux only   │ ✘ zypper not found        │            │              │
╰────────────────────┴──────────┴────────────────┴───────────────────────────┴────────────┴──────────────╯
```

## List installed packages

List all packages installed on current system:

```shell-session
$ mpm installed
╭─────────────────────────────┬─────────────────────────────┬─────────┬────────────────────╮
│ Package name                │ ID                          │ Manager │ Installed version  │
├─────────────────────────────┼─────────────────────────────┼─────────┼────────────────────┤
│ github                      │ github                      │ apm     │ 0.36.9             │
│ update-package-dependencies │ update-package-dependencies │ apm     │ 0.13.1             │
│ rust                        │ rust                        │ brew    │ 1.55.0             │
│ x264                        │ x264                        │ brew    │ r3060              │
│ atom                        │ atom                        │ cask    │ 1.58.0             │
│ visual-studio-code          │ visual-studio-code          │ cask    │ 1.52.0             │
│ nokogiri                    │ nokogiri                    │ gem     │ x86_64-darwin      │
│ rake                        │ rake                        │ gem     │ 13.0.3             │
│ iMovie                      │ 408981434                   │ mas     │ 10.2.5             │
│ Telegram                    │ 747648890                   │ mas     │ 8.1                │
│ npm                         │ npm                         │ npm     │ 7.24.0             │
│ raven                       │ raven                       │ npm     │ 2.6.4              │
│ jupyterlab                  │ jupyterlab                  │ pip     │ 3.1.14             │
│ Sphinx                      │ Sphinx                      │ pip     │ 4.2.0              │
│ ms-python.python            │ ms-python.python            │ vscode  │ 2021.10.1317843341 │
│ ms-toolsai.jupyter          │ ms-toolsai.jupyter          │ vscode  │ 2021.9.1001312534  │
╰─────────────────────────────┴─────────────────────────────┴─────────┴────────────────────╯
16 packages total (brew: 2, pip: 2, apm: 2, gem: 2, cask: 2, mas: 2, vscode: 2, npm: 2, composer: 0).
```

## List outdated packages

List all packages installed for which an upgrade is available:

```shell-session
$ mpm outdated
╭──────────────┬─────────────┬─────────┬───────────────────┬────────────────╮
│ Package name │ ID          │ Manager │ Installed version │ Latest version │
├──────────────┼─────────────┼─────────┼───────────────────┼────────────────┤
│ curl         │ curl        │ brew    │ 7.79.1            │ 7.79.1_1       │
│ git          │ git         │ brew    │ 2.33.0            │ 2.33.0_1       │
│ openssl@1.1  │ openssl@1.1 │ brew    │ 1.1.1l            │ 1.1.1l_1       │
│ rake         │ rake        │ gem     │ 13.0.3            │ 13.0.6         │
│ Telegram     │ 747648890   │ mas     │ 8.1               │ 8.1.3          │
│ npm          │ npm@8.0.0   │ npm     │ 7.24.0            │ 8.0.0          │
│ pip          │ pip         │ pip     │ 21.2.4            │ 21.3           │
│ regex        │ regex       │ pip     │ 2021.9.30         │ 2021.10.8      │
╰──────────────┴─────────────┴─────────┴───────────────────┴────────────────╯
8 packages total (brew: 3, pip: 2, gem: 1, mas: 1, npm: 1, apm: 0, cask: 0, composer: 0).
```

## Usage

More documentation is available in:

- the
  [detailed help screens](https://kdeldycke.github.io/meta-package-manager/cli-help.html)
- the
  [list of use-cases](https://kdeldycke.github.io/meta-package-manager/usecase.html)
  where you’ll find inspiration on how to leverage `mpm` power

