cli-argv-util
<img src=https://centerkey.com/graphics/center-key-logo.svg align=right width=200 alt=logo>
Simple utility to parse command line parameters and flags (arguments vector)
cli-argv-util is called from your bin/cli.js
file in order to read user
supplied information on the command line and return the flags and parameters
in an easy-to-use structure.
A) Setup
Install package for node:
$ npm install cli-argv-util
B) Usage
Place the following code in your bin/cli.js file
import { cliArgvUtil } from 'cli-argv-util';
const validFlags = ['cd', 'find', 'no-summary'];
const cli = cliArgvUtil.parse(validFlags);
if (cliArgvUtil.invalidFlag)
throw Error(cliArgvUtil.invalidFlagMsg);
For a real world example, see: cli.js
If your CLI tool is named my-program
and a user runs it like:
$ my-program file.html --cd=src --no-summary file.png
the resulting cli
object will be:
{
flagMap: {
cd: 'src',
noSummary: undefined,
},
flagOn: {
cd: true,
find: false,
noSummary: true,
},
invalidFlag: null,
invalidFlagMsg: null,
params: ['file.html', 'file.png'],
}
C) Results
The cliArgvUtil.parse()
returns an object of type Result
:
export type StringFlagMap = { [flag: string]: string | undefined };
export type BooleanFlagMap = { [flag: string]: boolean };
export type Result = {
flagMap: StringFlagMap,
flagOn: BooleanFlagMap,
invalidFlag: string | null,
invalidFlagMsg: string | null,
params: string[],
};
See the TypeScript Declarations at the top of cli-argv-util.ts for documentation.
CLI Build Tools
- 🎋 add-dist-header: Prepend a one-line banner comment (with license notice) to distribution files
- 📄 cli-argv-util: Copy or rename a file with optional package version number
- 📂 copy-folder-util: Recursively copy files from one folder to another folder
- 🔍 replacer-util: Find and replace strings or template outputs in text files
- 🔢 rev-web-assets: Revision web asset filenames with cache busting content hash fingerprints
- 🚆 run-scripts-util: Organize npm scripts into named groups of easy to manage commands
- 🚦 w3c-html-validator: Check the markup validity of HTML files using the W3C validator
Feel free to submit questions at:
github.com/center-key/cli-argv-util/issues
MIT License