A command-line tool for command-line tools
Project description
pype
A command-line tool for command-line tools
Disclaimer: This project is an early POC and interfaces can change anytime.
In a nutshell
pype-cli is a CLI-configurable command-line tool to orchestrate sets of other command-line tools. It simplifies the creation, orchestration and access of Python scripts that you require for your development work, process automation, etc.
Installation
The core package can be installed using python3 -m pip install pype-cli
or pip3 install pype-cli
. Refer to the usage section on configuration options.
Usage
pype-cli builds upon plugins and pypes. A pype is a single Python script whereas a plugin is basically a Python module that extens pype-cli with a collection of pypes.
pype-cli ships with one built-in plugin called pype.config
that is used to configure pype-cli. All of the required information will be stored to a local JSON-configuration file that defaults to ~/.pype-config.json
. To configure a custom configuration file use the environment variable PYPE_CONFIGURATION_FILE
, e.g. in your ~/.bashrc
file set export PYPE_CONFIGURATION_FILE=/path/to/myconfig.json
.
Basic operations
- List all available pypes:
pype -l
- Open pype-cli's configuration file:
pype -o
- Refer to
pype ... -h
for further information on the command-line
Install pype autocompletion and aliases
pype-cli's main benefit is that is is extendable with custom plugins and that it will allow you to immediatelly browse and use newly created and existing plugins/pypes by using the <TAB>
key and by configuring short aliases. To enable the functionality it is required to install a source-script to your shell's rc-file that will be executed everytime you open a shell.
- Run
pype pype.config install-shell -t ~/.bashrc
for bash shells - Run
pype pype.config install-shell -t ~/.zshrc
for zsh shells
Un-/register plugins
- Register an existing plugin:
pype pype.config plugin-register -n myplugin -p ~/pype_plugins
(myplugin
is a Python module with at least an__init__.py
file and~/pype_plugins
a folder where the plugin is stored) - On-the-fly create and register a new plugin:
pype pype.config plugin-register -c -n myplugin -p ~/pype_plugins
- Unregister (but not delete) a plugin:
pype pype.config plugin-unregister -n myplugin
Create, open and delete pypes
To create a new pype you need to decide to which plugin you want to add the pype, e.g., myplugin
.
- Create a new pype from a template:
pype myplugin -c mypype
- Create a new pype from a template with less boilerplate:
pype myplugin --minimal -c mypype
orpype myplugin -mc mypype
- Create a new pype from minimal template and open immediately:
pype myplugin --minimal --edit -c mypype
orpype myplugin -mec mypype
- Open a pype in your default editor:
pype myplugin -o mypype
- Delete a pype:
pype myplugin -d mypype
Un-/register aliases
If you have selected a pype from a plugin you can set aliases for it. Afterwards you need to start a new shell session or source your rc-file to activate the aliases. New aliases are stored in the configuration file.
- Register an alias:
pype -r mm myplugin mypype
→alias mm="pype myplugin mypype"
- Register an alias with options:
pype -r mm myplugin mypype -o opt1 -v
→alias mm="pype myplugin mypype -o opt1 -v"
- Unregister an alias:
pype -u mm
Shared code for plugins
If your plugin contains shared code over all pypes you can simply put it into a subpackage of your plugin or into a file prefixed with __
, e.g., __commons__.py
. pype-cli will only scan / consider top-level Python scripts without underscores as pypes.
Development
- Run
./make shell
to open apipenv
shell with the required shell configuration - Run
pype
to operate locale development version (it will react to code changes)
To-Do's
- ✅️ Validate config.json before using it (see https://pypi.org/project/jsonschema/)
- ✅️ Fix pipenv issue on travis CI
- ✅️ Fix travis build for Python 3.5
- ✅️ Fix travis build for Python 3.7
- ✅️ Add free continuous integration
- ✅ Introduce more strict linting, e.g., on scripts using
-
instead of_
and import order - ✅ Allow immediate editing of new pypes
- ✅️ Add a template with less boilerplate for advanced users
- ✅ Add a filter to limit plugins to usernames
- ✅ Allow aliasing of pype calls
- ✅ Allow creating plugins on the fly
- ✅ Add coloring library
- ✅ Extend documentation of template pype
- ✅ Add help texts to commands
- ✅ Auto-install bash/zsh completion
- ✅ Find another name since pype is unavailable in PyPi
¯\_(ツ)_/¯
- ✅ Improve config file resolving to envvar->homefile->currdir->default
- ✅ Add option to add/delete plugins via pype
- ✅ Add option to create a new pype via pype
- ✅ Add option to open a pype in default browser
- ✅ Internalize default pypes such as 'version'
- ✅ Create a docker image to test installation on a mint system
- ✅ Auto-complete custom pypes using Click
- ✅ Allow separation of subcommand options and pype-internal options (e.g.
-h
option) - ✅ Move example pypes to dedicated folder and make path configurable
- ✅ Find a way to re-use module and script documentation for CLI documentation
- ✅ Introduce verbosity option
- ✅ Introduce a logging framework
- ✅ Add auto-listing of configured pypes
- ✅ Allow configuring custom pypes via configuration file
- ✅ Introduce configuration file
- ✅ Check how to backward-support shell scripts
- ✅ Setup with python3 best-practices boilerplate
Important resources
- https://click.palletsprojects.com/en/7.x/
- http://click.palletsprojects.com/en/7.x/commands/
- https://click.palletsprojects.com/en/7.x/bashcomplete/
- https://click.palletsprojects.com/en/7.x/api/#click.Context
License and attribution
This software is licensed under Apache License 2.0.
Icon made by Freepik from Flaticon is licensed by CC 3.0 BY.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
File details
Details for the file pype_cli-0.1.1-py2.py3-none-any.whl
.
File metadata
- Download URL: pype_cli-0.1.1-py2.py3-none-any.whl
- Upload date:
- Size: 22.0 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c8c84b5a00e3e7efa3d3d760f0fe1f819006a92cffa2bd0e87fb8402b671e885 |
|
MD5 | 2826cb65bf896f99c21ae3166fb1463c |
|
BLAKE2b-256 | f03ad26fe48057fef861b96cde3784af7fa28f74f6a0e35af587731e2d0f0f8d |