Argc

CI Crates

An elegant command-line options, arguments and sub-commands parser for bash.

demo

Install

With cargo

cargo install argc

Binaries on macOS, Linux, Windows

Download from Github Releases, unzip and add argc to your $PATH.

GitHub Actions

extractions/setup-crate can be used to install just in a GitHub Actions workflow.

yaml - uses: extractions/setup-crate@v1 with: owner: sigoden name: argc

Usage

To write a command-line program with argc, we only need to do two things:

  1. Describe options, flags, positional parameters and subcommands in comments.
  2. Insert eval "$(argc --argc-eval "$0" "$@")" into script to let argc to parse command line arguments.

Write example.sh

```sh

@flag --foo Flag value

@option --bar Option value

@arg baz* Positional values

eval "$(argc --argc-eval "$0" "$@")" echo foo: $argcfoo echo bar: $argcbar echo baz: ${argc_baz[@]} ```

Run ./example.sh --foo --bar=xyz a b c, you can see argc successfully parses arguments and generate variables with argc_ prefix.

foo: 1 bar: xyz baz: a b c

Run ./example.sh -h, argc wll print help information for you.

``` USAGE: example.sh [OPTIONS] [BAZ]...

ARGS: [BAZ]... Positional values

OPTIONS: --foo Flag value --bar Option value -h, --help Print help ```

Comment Tags

argc parses cli definition from comment tags.

@cmd

@cmd [string]

Define a subcommand

```sh

@cmd Upload a file

upload() { echo Run upload }

@cmd Download a file

download() { echo Run download } ```

``` USAGE: test.sh

COMMANDS: upload Upload a file download Download a file ```

@arg

@arg <name>[modifier|default|modifer+choices] [zero-or-one value notation] [help-string]

Define a positional argument.

```sh

@arg va

@arg vb! requird

@arg vc* multiple

@arg vd+ required + multiple

@arg vna value notation

@arg vda=a default

@arg vdb=_default_fn default from fn

@arg vca[a|b] choice

@arg vcb[=a|b] choice + default

@arg vcc*[a|b] multiple + choice

@arg vcd+[a|b] required + multiple + choice

@arg vfa[_choice_fn] choice from fn

@arg vfb[?_choice_fn] choice from fn + no validation

@arg vfc*[_choice_fn] multiple + choice from fn

```

@option

@option [short] <long>[modifier|default|modifier+choices] [value-notation]... [help-string]

Define a option.

```sh

@option --oa

@option -b --ob short

@option -c short only

@option --oc! required

@option --od* multiple

@option --oe+ required + multiple

@option --ona value notation

@option --onb multiple value notations

@option --oda=a default

@option --odb=_default_fn default from fn

@option --oca[a|b] choice

@option --ocb[=a|b] choice + default

@option --occ*[a|b] multiple + choice

@option --ocd+[a|b] required + multiple + choice

@option --ofa[_choice_fn] choice from fn

@option --ofb[?_choice_fn] choice from fn + no validation

@option --ofc*[_choice_fn] multiple + choice from fn

```

@flag

@flag [short] <long>[*] [help string]

Define a flag. A flag is an option of boolean type, and is always false by default (e.g. --verbose, --quiet, --all, --long, etc).

```sh

@flag --fa

@flag -b --fb shoft

@flag -c shoft only

@flag --fd* multiple

@flag -e --fe* short + multiple

```

@alias

@alias <name...>

Add aliases for subcommand.

```sh

@cmd Run tests

@alias t,tst

test() { echo Run test } ```

``` USAGE: test.sh

COMMANDS: test Run tests [aliases: t, tst] ```

Meta

```sh

@describe A demo cli

@version 2.17.1

@author nobody nobody@example.com

@cmd Run test

test() { echo Run test } ```

``` test.sh 2.17.1 nobody nobody@example.com A demo cli

USAGE: test.sh

COMMANDS: test Run test ```

Value Notation

Value notation is used to describe value type of options and positional parameters.

```

@option --target

@arg target

```

Here are some value notation that will affect the shell completion.

Shell Completion

Argc provides shell completion for argc command and all the bash scripts powered by argc.

```

bash (~/.bashrc)

source <(argc --argc-completions bash mycmd1 mycmd2)

elvish (~/.config/elvish/rc.elv)

eval (argc --argc-completions elvish mycmd1 mycmd2 | slurp)

fish (~/.config/fish/config.fish)

argc --argc-completions fish mycmd1 mycmd2 | source

nushell (~/.config/nushell/config.nu)

argc --argc-completions nushell mycmd1 mycmd2 # update config.nu manually according to output

powershell ($PROFILE)

Set-PSReadlineKeyHandler -Key Tab -Function MenuComplete argc --argc-completions powershell mycmd1 mycmd2 | Out-String | Invoke-Expression

xonsh (~/.config/xonsh/rc.xsh)

exec($(argc --argc-completions xonsh mycmd1 mycmd2))

zsh (~/.zshrc)

source <(argc --argc-completions zsh mycmd1 mycmd2) ```

Replace mycmd1 mycmd2 with your argc scripts.

Argc can be used as multiple shell completion engine. see argc-completions

Argcscript

Argc will automatically find and run Argcfile.sh unless --argc-* options are used to change this behaviour.

Argcfile is to argc what Makefile is to make.

what is the benefit?

You can use argc --argc-create to quickly create boilerplate Argcscripts. For example:

argc --argc-create test build run

The above command will create an Argcfile.sh in the current directory containing the commands: test, build and run.

Parallel

argc provides features for running commands/functions in parallel.

sh argc --argc-parallel "$0" cmd1 arg1 arg2 ::: cmd2

The above command will run cmd1 arg1 arg2 and cmd2 in parellel. Functions running in parallel mode can still access the argc_* variable.

Windows Only

Argc requires bash to run scripts. git's built-in bash is good enough for argc.

If you want to use another bash, please specify it via ARGC_SHELL_PATH environment variable.

If you want to run the bash script directly, you can add the following configuration to Windows Registry.

```ps1

Add .sh to PATHEXT

Associate the .sh file extension with Git Bash

New-ItemProperty -LiteralPath 'HKLM:\SOFTWARE\Classes\shautofile\shell\open\command' ` -Name '(default)' -Value '"C:\Program Files\Git\bin\bash.exe" "%1" %*' -PropertyType String -Force ```

License

argc is made available under the terms of either the MIT License or the Apache License 2.0, at your option.

See the LICENSE-APACHE and LICENSE-MIT files for license details.