2020-01-07 10:17:23 +00:00
|
|
|
//! How to use doc comments in place of `help/long_help`.
|
|
|
|
|
2021-10-11 19:48:13 +00:00
|
|
|
use clap::{Parser, Subcommand};
|
2020-01-07 10:17:23 +00:00
|
|
|
|
|
|
|
/// A basic example for the usage of doc comments as replacement
|
|
|
|
/// of the arguments `help`, `long_help`, `about` and `long_about`.
|
2021-07-13 17:50:55 +00:00
|
|
|
#[derive(Parser, Debug)]
|
2020-01-07 10:17:23 +00:00
|
|
|
#[clap(name = "basic")]
|
|
|
|
struct Opt {
|
|
|
|
/// Just use doc comments to replace `help`, `long_help`,
|
|
|
|
/// `about` or `long_about` input.
|
|
|
|
#[clap(short, long)]
|
|
|
|
first_flag: bool,
|
|
|
|
|
|
|
|
/// Split between `help` and `long_help`.
|
|
|
|
///
|
|
|
|
/// In the previous case clap is going to present
|
|
|
|
/// the whole comment both as text for the `help` and the
|
|
|
|
/// `long_help` argument.
|
|
|
|
///
|
|
|
|
/// But if the doc comment is formatted like this example
|
|
|
|
/// -- with an empty second line splitting the heading and
|
|
|
|
/// the rest of the comment -- only the first line is used
|
|
|
|
/// as `help` argument. The `long_help` argument will still
|
|
|
|
/// contain the whole comment.
|
|
|
|
///
|
|
|
|
/// ## Attention
|
|
|
|
///
|
|
|
|
/// Any formatting next to empty lines that could be used
|
|
|
|
/// inside a doc comment is currently not preserved. If
|
|
|
|
/// lists or other well formatted content is required it is
|
|
|
|
/// necessary to use the related clap argument with a
|
|
|
|
/// raw string as shown on the `third_flag` description.
|
|
|
|
#[clap(short, long)]
|
|
|
|
second_flag: bool,
|
|
|
|
|
|
|
|
#[clap(
|
|
|
|
short,
|
|
|
|
long,
|
2021-11-18 16:17:15 +00:00
|
|
|
long_help = r"This is a raw string.
|
2020-01-07 10:17:23 +00:00
|
|
|
|
|
|
|
It can be used to pass well formatted content (e.g. lists or source
|
|
|
|
code) in the description:
|
|
|
|
|
|
|
|
- first example list entry
|
|
|
|
- second example list entry
|
|
|
|
"
|
|
|
|
)]
|
|
|
|
third_flag: bool,
|
|
|
|
|
|
|
|
#[clap(subcommand)]
|
|
|
|
sub_command: SubCommand,
|
|
|
|
}
|
|
|
|
|
2021-10-11 19:48:13 +00:00
|
|
|
#[derive(Subcommand, Debug)]
|
2020-01-07 10:17:23 +00:00
|
|
|
#[clap()]
|
|
|
|
enum SubCommand {
|
|
|
|
/// The same rules described previously for flags. Are
|
|
|
|
/// also true for in regards of sub-commands.
|
|
|
|
First,
|
|
|
|
|
|
|
|
/// Applicable for both `about` an `help`.
|
|
|
|
///
|
|
|
|
/// The formatting rules described in the comment of the
|
|
|
|
/// `second_flag` also apply to the description of
|
|
|
|
/// sub-commands which is normally given through the `about`
|
|
|
|
/// and `long_about` arguments.
|
|
|
|
Second,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let opt = Opt::parse();
|
|
|
|
println!("{:?}", opt);
|
|
|
|
}
|