Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add .name and .usage, TOC, and tidy README #1010

Merged
merged 1 commit into from
Aug 11, 2019
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
78 changes: 60 additions & 18 deletions Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,39 @@

The complete solution for [node.js](http://nodejs.org) command-line interfaces, inspired by Ruby's [commander](https://github.com/commander-rb/commander).

- [Commander.js](#commanderjs)
- [Installation](#installation)
- [Declaring _program_ variable](#declaring-program-variable)
- [Options](#options)
- [Common option types, boolean and value](#common-option-types-boolean-and-value)
- [Default option value](#default-option-value)
- [Other option types, negatable boolean and flag|value](#other-option-types-negatable-boolean-and-flagvalue)
- [Custom option processing](#custom-option-processing)
- [Version option](#version-option)
- [Commands](#commands)
- [Specify the argument syntax](#specify-the-argument-syntax)
- [Action handler (sub)commands](#action-handler-subcommands)
- [Git-style executable (sub)commands](#git-style-executable-subcommands)
- [Automated --help](#automated---help)
- [Custom help](#custom-help)
- [.usage and .name](#usage-and-name)
- [.outputHelp(cb)](#outputhelpcb)
- [.helpOption(flags, description)](#helpoptionflags-description)
- [.help(cb)](#helpcb)
- [Custom event listeners](#custom-event-listeners)
- [Bits and pieces](#bits-and-pieces)
- [TypeScript](#typescript)
- [Node options such as `--harmony`](#node-options-such-as---harmony)
- [Node debugging](#node-debugging)
- [Examples](#examples)
- [License](#license)
- [Support](#support)

## Installation

$ npm install commander
```bash
npm install commander
```

## Declaring _program_ variable

Expand All @@ -29,7 +59,6 @@ For larger programs which may use commander in multiple ways, including unit tes
program.version('0.0.1');
```


## Options

Options are defined with the `.option()` method, also serving as documentation for the options. Each option can have a short flag (single character) and a long name, separated by a comma or space.
Expand Down Expand Up @@ -119,7 +148,7 @@ console.log(`You ordered a pizza with ${sauceStr} and ${cheeseStr}`);
```

```bash
$ pizza-options
$ pizza-options
You ordered a pizza with sauce and mozzarella cheese
$ pizza-options --sauce
error: unknown option '--sauce'
Expand Down Expand Up @@ -155,7 +184,7 @@ add cheese type mozzarella

### Custom option processing

You may specify a function to do custom processing of option values. The callback function receives two parameters, the user specified value and the
You may specify a function to do custom processing of option values. The callback function receives two parameters, the user specified value and the
previous value for the option. It returns the new value for the option.

This allows you to coerce the option value to the desired type, or accumulate values, or do entirely custom processing.
Expand Down Expand Up @@ -259,7 +288,6 @@ program

You use `.arguments` to specify the arguments for the top-level command, and for subcommands they are included in the `.command` call. Angled brackets (e.g. `<required>`) indicate required input. Square brackets (e.g. `[optional]`) indicate optional input.


```js
var program = require('commander');

Expand Down Expand Up @@ -357,7 +385,7 @@ If the program is designed to be installed globally, make sure the executables h

The help information is auto-generated based on the information commander already knows about your program, so the following `--help` info is for free:

```
```bash
$ ./examples/pizza --help
Usage: pizza [options]

Expand All @@ -373,7 +401,7 @@ Options:
-h, --help output usage information
```

## Custom help
### Custom help

You can display arbitrary `-h, --help` information
by listening for "--help". Commander will automatically
Expand All @@ -385,10 +413,6 @@ Options:
```js
#!/usr/bin/env node

/**
* Module dependencies.
*/

var program = require('commander');

program
Expand All @@ -414,7 +438,7 @@ console.log('stuff');

Yields the following help output when `node script-name.js -h` or `node script-name.js --help` are run:

```
```Text
Usage: custom-help [options]

Options:
Expand All @@ -429,7 +453,24 @@ Examples:
$ custom-help -h
```

## .outputHelp(cb)
### .usage and .name

These allow you to customise the usage description in the first line of the help. The name is otherwise
deduced from the (full) program arguments. Given:

```js
program
.name("my-command")
.usage("[global options] command")
```

The help will start with:

```Text
Usage: my-command [global options] command
```

### .outputHelp(cb)

Output help information without exiting.
Optional callback cb allows post-processing of help text before it is displayed.
Expand All @@ -454,7 +495,7 @@ function make_red(txt) {
}
```

## .helpOption(flags, description)
### .helpOption(flags, description)

Override the default help flags and description.

Expand All @@ -463,13 +504,13 @@ program
.helpOption('-e, --HELP', 'read more information');
```

## .help(cb)
### .help(cb)

Output help information and exit immediately.
Optional callback cb allows post-processing of help text before it is displayed.


## Custom event listeners

You can execute custom actions by listening to command and option events.

```js
Expand Down Expand Up @@ -504,8 +545,9 @@ node -r ts-node/register pm.ts
### Node options such as `--harmony`

You can enable `--harmony` option in two ways:
* Use `#! /usr/bin/env node --harmony` in the sub-commands scripts. (Note Windows does not support this pattern.)
* Use the `--harmony` option when call the command, like `node --harmony examples/pm publish`. The `--harmony` option will be preserved when spawning sub-command process.

- Use `#! /usr/bin/env node --harmony` in the sub-commands scripts. (Note Windows does not support this pattern.)
- Use the `--harmony` option when call the command, like `node --harmony examples/pm publish`. The `--harmony` option will be preserved when spawning sub-command process.

### Node debugging

Expand Down