Integrates the argparse and cmd modules.
Project description
argshell
Integrates the argparse and cmd modules to create custom shells with argparse functionality.
Installation
Install with:
pip install argshell
Usage
Custom shells are created by subclassing the ArgShell class and adding functions of the form do_*(), just like the cmd.Cmd class.
The ArgShell class contains a rich.console.Console object that can be used to print renderables.
In terminal:
Rather than being limited to input strings, you can use argparse style parsers for shell commands.
Create a function that instantiates an ArgShellParser instance, adds arguments, and then returns the ArgShellParser object.
Then you can can decorate do_* functions using with_parser() to pass a Namespace object instead of a string.
In terminal:
The with_parser function also accepts an optional list of functions that accept and return an argshell.Namespace object.
These functions will be executed in order after the parser function parses the arguments.
In terminal:
When using your shell, entering help command will, in addition to the command's doc string,
print the help message of the parser that decorates it, if it is decorated.
The capture command can be used to save an svg of another command's output by prepending to a command.
(NOTE: This only works for output printed with ArgShell's console member mentioned earlier.)
The font size is proportional to your terminal width when using the command and any text your terminal wraps will be truncated in the svg.
The following would create a file called add.svg in your current directory:
The saved svg:
There's also a "hidden" command for generating documentation called shell_docs.
Executing that command for MyShell:
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 Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file argshell-1.6.6.tar.gz.
File metadata
- Download URL: argshell-1.6.6.tar.gz
- Upload date:
- Size: 8.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
126bbbee654fb3b28aab9ae1327e1728d814331da814c683fcb7037f013db7fe
|
|
| MD5 |
eebe6d959e35ecfc0b08c9725499b54c
|
|
| BLAKE2b-256 |
464c8cb718c89696b92b5365334edd400a6afea83bccf4ba5f172f6ab26362e6
|
File details
Details for the file argshell-1.6.6-py3-none-any.whl.
File metadata
- Download URL: argshell-1.6.6-py3-none-any.whl
- Upload date:
- Size: 9.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0c45f2ad59aeefe56f4443c71e2bb846e4ffe5dccc92acedcf9dcdbc43a864b0
|
|
| MD5 |
889fecb2361f2c1b90aa7ed60af5681b
|
|
| BLAKE2b-256 |
becebb0483b74e929c92a399f96937275a3854b9d2ab2ab7024c71789ea35902
|