Skip to main content

CLI help message generator.

Project description

cli-help-maker

Command Line Interface help message generator.

ci workflow Code style: black License pyversions


This repo contains a CLI to create simulated help messages with the positions annotated of the commands, arguments and options. Its created as a separated package, but its intended use is to generate datasets to be used in helpner-core, which deals with the model that powers helpner.

What range of help messages covers?

For the moment, it indents to recreate messages like those found in the examples of docopt-ng. This should cover CLI apps created in python using for example argparse, click or typer*.

typer uses click underneath, but when rich its is installed, the message has a special (and prettier) layout, currently not in the scope.

A proper list of items covered is yet to be made.

Installation

It can be installed directly from PyPI:

pip install cli-help-maker

This creates the following CLI:

❯ cli-help-maker --help
                                                                                                
 Usage: cli-help-maker [OPTIONS] INPUT_PATH [OUTPUT_PATH]                                       
                                                                                                
 Function to generate a dataset of cli help messages from a .yaml file with the info.           
 A folder will be generated containing two jsonl files:                                         
 - arguments.jsonl:     Contains the arguments that were generated, these can be associated to  
 each     help message for further analysis.                                                    
 - dataset.jsonl:     A dataset of help messages with annotations.                              
                                                                                                
╭─ Arguments ──────────────────────────────────────────────────────────────────────────────────╮
│ *    input_path       FILE           Path pointing to the .yaml file. [default: None]        │
│                                      [required]                                              │
│      output_path      [OUTPUT_PATH]  Dirname of the output path. If not given, creates a     │
│                                      directory with the version number                       │
│                                      [default: None]                                         │
╰──────────────────────────────────────────────────────────────────────────────────────────────╯
╭─ Options ────────────────────────────────────────────────────────────────────────────────────╮
│ --install-completion        [bash|zsh|fish|powershell|pwsh]  Install completion for the      │
│                                                              specified shell.                │
│                                                              [default: None]                 │
│ --show-completion           [bash|zsh|fish|powershell|pwsh]  Show completion for the         │
│                                                              specified shell, to copy it or  │
│                                                              customize the installation.     │
│                                                              [default: None]                 │
│ --help                                                       Show this message and exit.     │
╰──────────────────────────────────────────────────────────────────────────────────────────────╯

Examples

The folder examples contains a rough recreation of some of the examples found in docopt-ng repo, to see an example, run any of them, for example:

python examples/arguments_example_like.py

This would create a random help message with a layout similar to the one found in docopt-ng (approximately).

It highlights the labels using rich.

Development

TBD

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

cli-help-maker-0.2.0.tar.gz (40.8 kB view details)

Uploaded Source

Built Distribution

cli_help_maker-0.2.0-py2.py3-none-any.whl (22.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file cli-help-maker-0.2.0.tar.gz.

File metadata

  • Download URL: cli-help-maker-0.2.0.tar.gz
  • Upload date:
  • Size: 40.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.28.1

File hashes

Hashes for cli-help-maker-0.2.0.tar.gz
Algorithm Hash digest
SHA256 3940177f7b37e9911a87cbd2728fc3d4791f8f3ab8c5225c0ce06c4225e12f87
MD5 a5fd30c578e75448fa2277c8e299ce8e
BLAKE2b-256 6e2ea7443d1eca143367bc8d9d24db246a397c86756f04d39b469bfec15d7309

See more details on using hashes here.

File details

Details for the file cli_help_maker-0.2.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for cli_help_maker-0.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b8fee0d824b6521dbb0b43c026886b390a9719748a5dece1525c57a3765af0dd
MD5 3827920f837cf63e351d6dd78957241f
BLAKE2b-256 3ed4984e17a46e5e9eecb6d8f5fb47492255c1c3b4ec180e481beceb11123b48

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