#nushell #completion #clap

clap_complete_nushell

A generator library used with clap for Nushell completion scripts

24 releases (12 stable)

4.5.5 Jan 2, 2025
4.5.4 Oct 8, 2024
4.5.3 Jul 25, 2024
4.5.1 Feb 16, 2024
0.1.8 Nov 5, 2022

#431 in Command-line interface

Download history 31926/week @ 2024-09-21 26873/week @ 2024-09-28 33222/week @ 2024-10-05 37985/week @ 2024-10-12 31301/week @ 2024-10-19 30224/week @ 2024-10-26 30034/week @ 2024-11-02 35399/week @ 2024-11-09 35159/week @ 2024-11-16 35462/week @ 2024-11-23 37006/week @ 2024-11-30 36678/week @ 2024-12-07 34174/week @ 2024-12-14 25262/week @ 2024-12-21 28047/week @ 2024-12-28 36434/week @ 2025-01-04

129,393 downloads per month
Used in 49 crates (43 directly)

MIT/Apache and maybe CC-PDDC

270KB
3.5K SLoC

clap_complete_nushell

Generates Nushell completions for clap based CLIs

Crates.io Crates.io License License docs.rs

Examples

myapp.rs

use clap::{builder::PossibleValue, Arg, ArgAction, Command, ValueHint};
use clap_complete::generate;
use clap_complete_nushell::Nushell;
use std::io;

fn main() {
    let mut cmd = Command::new("myapp")
        .version("3.0")
        .propagate_version(true)
        .about("Tests completions")
        .arg(
            Arg::new("file")
                .value_hint(ValueHint::FilePath)
                .help("some input file"),
        )
        .arg(
            Arg::new("config")
                .action(ArgAction::Count)
                .help("some config file")
                .short('c')
                .visible_short_alias('C')
                .long("config")
                .visible_alias("conf"),
        )
        .arg(Arg::new("choice").value_parser(["first", "second"]))
        .subcommand(
            Command::new("test").about("tests things").arg(
                Arg::new("case")
                    .long("case")
                    .action(ArgAction::Set)
                    .help("the case to test"),
            ),
        )
        .subcommand(
            Command::new("some_cmd")
                .about("top level subcommand")
                .subcommand(
                    Command::new("sub_cmd").about("sub-subcommand").arg(
                        Arg::new("config")
                            .long("config")
                            .action(ArgAction::Set)
                            .value_parser([PossibleValue::new("Lest quotes aren't escaped.")])
                            .help("the other case to test"),
                    ),
                ),
        );

    generate(Nushell, &mut cmd, "myapp", &mut io::stdout());
}

myapp.nu

module completions {

  def "nu-complete myapp choice" [] {
    [ "first" "second" ]
  }

  # Tests completions
  export extern myapp [
    file?: string             # some input file
    --config(-c)              # some config file
    --conf                    # some config file
    -C                        # some config file
    choice?: string@"nu-complete myapp choice"
    --version(-V)             # Print version
  ]

  # tests things
  export extern "myapp test" [
    --case: string            # the case to test
    --version(-V)             # Print version
  ]

  # top level subcommand
  export extern "myapp some_cmd" [
    --version(-V)             # Print version
  ]

  def "nu-complete myapp some_cmd sub_cmd config" [] {
    [ "\"Lest quotes aren't escaped.\"" ]
  }

  # sub-subcommand
  export extern "myapp some_cmd sub_cmd" [
    --config: string@"nu-complete myapp some_cmd sub_cmd config" # the other case to test
    --version(-V)             # Print version
  ]

}

use completions *

Dependencies

~0.8–38MB
~602K SLoC