clap-help

MIT Latest Version Chat on Miaou

Purpose and Features

clap-help prints the --help message of clap based terminal applications.

Differences with the vanilla help renderer of the clap crate:

clap-help is especially suited to small terminals or big numbers of options.

Not (yet) supported:

Comparison

This comparison uses the broot program.

With clap-help

broot-clap-help

With the standard help rendering

broot-vanilla

(my screen isn't big enough to fit even half the help page)

Usage

Your program needs a clap Command defined.

Here's for example with clap-derive:

```rust

[derive(Parser, Debug)]

[command(name="area", author, version, about, disablehelpflag = true)]

struct Args {

/// Print help
#[arg(long)]
help: bool,

/// Height, that is the distance between bottom and top
#[arg(short, long, default_value = "9")]
height: u16,

/// Width, from there, to there
#[arg(short, long, default_value = "3")]
width: u16,

/// Whether birds should be killed
#[arg(short, long)]
kill_birds: bool,

/// Computation strategy
#[arg(long, default_value = "fast")]
strategy: Strategy,

/// Bird separator
#[arg(short, long, value_name = "SEP")]
separator: Option<String>,

/// Root Directory
pub root: Option<std::path::PathBuf>,

} ```

Notice * the disable_help_flag = true disabling the standard behaviour of clap regarding help. * the explicit help argument. Here it's with only #[arg(long)] because -h is used for something more important but you would most ofte have #[arg(short, long)].

The help introduction (the part before usage) is defined as a string which will be interpreted as Markdown. It can contain tables, lists, bold, italic, inline code, code blocks, etc.

```rust static INTRO: &str = " Compute height x width You can do it either precisely (enough) or fast (I mean not too slow).

"; ```

On program launch, you should check the value of the help flag and, if necessary, print the help:

rust let args = Args::parse(); if args.help { Printer::new(Args::command()) .with_introduction(INTRO) .show_author(false) .print_help(); return; }

Help rendered in a light terminal:

area light

Same help in a dark terminal:

area dark

Complete example is in /examples/area.