/flags

A Javascript arguments processor

Primary LanguageTypeScriptMIT LicenseMIT

Flags

A Javascript arguments processor.

Sample:

interface Options {
  version: boolean;
  name: string;
  help: boolean;
  run: string[];
  test: string[];
}

const args = ["--name=foo", "-v", "run", "hello", "world"];

const options = flags<Options>(args, {}, [
  rule(flag("--name"), isStringAt("name")),
  rule(flag("--version", "-v"), isBooleanAt("version")),
  rule(command("run"), restArgumentsAt("run")),
  rule(command("test"), restArgumentsAt("test")),
]);

expect(options.name).is.equal("foo");
expect(options.version).is.true;
expect(options.run).is.deep.equal(["hello", "world"]);

Documentation

Test Functions

The test functions provide a mechanism eval an argument and its determine whether if to proceed with the next handler function.

flag

The flag function provide a test function to match arguments that begin with the keyword it's described. If the argument contains a = (equal symbol) this test functions assumes that the rest of this argument content is the value.

const test = flag("--title", "-t");

command

The command function provide a test function to match a exactly argument.

const test = command("run");

Describe a flag or command

The describe function allow set a description or a category in your flag or command.

const test = describe(flag("--title", "-t"), {
  description: "Describe the title",
});

Handler

The handler function provides a machine to describe a behavior with the next arguments.

isStringAt

The isStringAt function is a handler function to receive the the value provided a test function or uses the next argument.

const handler = isStringAt("title");

isBooleanAt

The isBooleanAt function is a handler function. It's understand if it is called then the value to it options is true.

const handler = isBooleanAt(`show-help`);