Skip to main content

A command-line utility toolkit for Python.

Project description

A library for developing command-line applications in Python.

License PyPI Version Python Versions Documentation Downloads

The cmdkit library implements a few common patterns needed by well-formed command-line applications in Python. It only touches a few concepts but it implements them well. The idea is to reduce the boilerplate needed to get a full featured CLI off the ground. Applications developed using cmdkit are easy to implement, easy to maintain, and easy to understand.


Features

An Application class provides the boilerplate for a good entry-point. Building your command-line application in layers with ApplicationGroup let’s you develop simple structures and modules that mirror your CLI.

An Interface class modifies the behavior of the standard argparse.ArgumentParser class to raise simple exceptions instead of exiting.

class Add(Application):
    """Application class for adding routine."""

    interface = Interface('add', USAGE_TEXT, HELP_TEXT)
    interface.add_argument('-v', '--version', action='version', '0.0.1')

    lhs: int
    rhs: int
    interface.add_argument('lhs', type=float)
    interface.add_argument('rhs', type=float)

    def run(self) -> None:
        """Business logic of the application."""
        print(self.lhs + self.rhs)

A Configuration class makes it basically a one-liner to pull in a configuration with a dictionary-like interface from a cascade of files as well as expanding environment variables into a hierarchy and merged.

The standard behavior for any good application is for a configuration to allow for system-level, user-level, and local configuration to overlap. Merging these should not clobber the same section in a lower-priority source. The Namespace class extends the behavior of a standard Python dict to have a depth-first merge for its update implementation.

config = Configuration.from_local(env=True, prefix='MYAPP', default=default, **paths)

The underlying Namespace also supports the convention of having parameters with _env and _eval automatically expanded.

[database]
password_eval = "gpg ..."

Accessing the parameter with dot-notation, i.e., config.database.password would execute "gpg ..." as a shell command and return the output.


Installation

CmdKit is tested on Python 3.7+ for Windows, macOS, and Linux, and can be installed from the Python Package Index using Pip.

$ pip install cmdkit

Getting Started

Checkout the Tutorial for examples.

You can also checkout how CmdKit is being used by other projects, e.g., REFITT and HyperShell.


Documentation

Documentation for getting started, the API, and common recipes are available at cmdkit.readthedocs.io.


Contributions

Contributions are welcome in the form of suggestions for additional features, pull requests with new features or bug fixes, etc. If you find bugs or have questions, open an Issue here. If and when the project grows, a code of conduct will be provided along side a more comprehensive set of guidelines for contributing; until then, just be nice.

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

cmdkit-2.5.0.tar.gz (26.6 kB view details)

Uploaded Source

Built Distribution

cmdkit-2.5.0-py3-none-any.whl (28.4 kB view details)

Uploaded Python 3

File details

Details for the file cmdkit-2.5.0.tar.gz.

File metadata

  • Download URL: cmdkit-2.5.0.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.5

File hashes

Hashes for cmdkit-2.5.0.tar.gz
Algorithm Hash digest
SHA256 3f84567fb8b1f528e280451549ccdc19c039f166ef62ebd446bae04c9bf602c6
MD5 2d917e2028e1f4e0fe7769c98c0224d7
BLAKE2b-256 b1e9c794b0e89a6c9d7a3a6c3e7ef49a85d24aa66a69a6df8c9022534a6ddf99

See more details on using hashes here.

File details

Details for the file cmdkit-2.5.0-py3-none-any.whl.

File metadata

  • Download URL: cmdkit-2.5.0-py3-none-any.whl
  • Upload date:
  • Size: 28.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.9.5

File hashes

Hashes for cmdkit-2.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f40e2a5752bc165fcd4ff1aa9f83d78255f2060d6bb931a416618c41e4dd78a3
MD5 25bfdd623925331e2f2738d5a4c27e77
BLAKE2b-256 84561584de77b513debff9edf4a7e51b35fe02c2ac48ae7633a8c90b2db02a25

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