MCPcopy
hub / github.com/yargs/yargs

github.com/yargs/yargs @v18.0.0 sqlite

repository ↗ · DeepWiki ↗ · release v18.0.0 ↗
419 symbols 1,321 edges 101 files 0 documented · 0%
README

Yargs

Yargs be a node.js library fer hearties tryin' ter parse optstrings

ci NPM version js-standard-style Coverage Conventional Commits

Description

Yargs helps you build interactive command line tools, by parsing arguments and generating an elegant user interface.

It gives you:

  • commands and (grouped) options (my-program.js serve --port=5000).
  • a dynamically generated help menu based on your arguments:
mocha [spec..]

Run tests with Mocha

Commands
  mocha inspect [spec..]  Run tests with Mocha                         [default]
  mocha init <path>       create a client-side Mocha setup at <path>

Rules & Behavior
  --allow-uncaught           Allow uncaught errors to propagate        [boolean]
  --async-only, -A           Require all tests to use a callback (async) or
                             return a Promise                          [boolean]
  • generate completion scripts for Bash and Zsh for your command
  • and tons more.

Installation

Stable version:

npm i yargs

Bleeding edge version with the most recent features:

npm i yargs@next

Usage

Simple Example

#!/usr/bin/env node
import yargs from 'yargs';
import { hideBin } from 'yargs/helpers';
const argv = yargs(hideBin(process.argv)).parse()

if (argv.ships > 3 && argv.distance < 53.5) {
  console.log('Plunder more riffiwobbles!')
} else {
  console.log('Retreat from the xupptumblers!')
}
$ ./plunder.js --ships=4 --distance=22
Plunder more riffiwobbles!

$ ./plunder.js --ships 12 --distance 98.7
Retreat from the xupptumblers!

Note: hideBin is a shorthand for process.argv.slice(2). It has the benefit that it takes into account variations in some environments, e.g., Electron.

Complex Example

#!/usr/bin/env node
import yargs from 'yargs';
import { hideBin } from 'yargs/helpers';

yargs(hideBin(process.argv))
  .command('serve [port]', 'start the server', (yargs) => {
    return yargs
      .positional('port', {
        describe: 'port to bind on',
        default: 5000
      })
  }, (argv) => {
    if (argv.verbose) console.info(`start server on :${argv.port}`)
    serve(argv.port)
  })
  .option('verbose', {
    alias: 'v',
    type: 'boolean',
    description: 'Run with verbose logging'
  })
  .parse()

Run the example above with --help to see the help for the application.

Supported Platforms

TypeScript

yargs has type definitions at @types/yargs.

npm i @types/yargs --save-dev

See usage examples in docs.

Deno

As of v16, yargs supports Deno:

import yargs from 'https://deno.land/x/yargs@v17.7.2-deno/deno.ts'
import { Arguments } from 'https://deno.land/x/yargs@v17.7.2-deno/deno-types.ts'

yargs(Deno.args)
  .command('download <files...>', 'download a list of files', (yargs: any) => {
    return yargs.positional('files', {
      describe: 'a list of files to do something with'
    })
  }, (argv: Arguments) => {
    console.info(argv)
  })
  .strictCommands()
  .demandCommand(1)
  .parse()

Note: If you use version tags in url then you also have to add -deno flag on the end, like @17.7.2-deno

Usage in Browser

See examples of using yargs in the browser in docs.

Documentation

Table of Contents

Supported Node.js Versions

Libraries in this ecosystem make a best effort to track Node.js' release schedule. Here's a post on why we think this is important.

Extension points exported contracts — how you extend this code

CompletionInstance (Interface)
(no doc) [2 implementers]
lib/completion.ts
Arguments (Interface)
(no doc)
deno-types.ts
ParsedCommand (Interface)
(no doc)
lib/parse-command.ts
CommandHandlerDefinition (Interface)
(no doc)
lib/command.ts
MiddlewareCallback (Interface)
(no doc)
lib/middleware.ts
YargsInternalMethods (Interface)
(no doc)
lib/yargs-factory.ts
ValidationInstance (Interface)
(no doc)
lib/validation.ts
UsageInstance (Interface)
(no doc)
lib/usage.ts

Core symbols most depended-on inside this repo

parse
called by 682
lib/yargs-factory.ts
command
called by 452
lib/usage.ts
checkOutput
called by 344
test/helpers/utils.mjs
wrap
called by 204
lib/usage.ts
done
called by 178
test/helpers/utils.mjs
fail
called by 167
lib/usage.ts
option
called by 166
lib/yargs-factory.ts
help
called by 103
lib/usage.ts

Shape

Method 245
Function 115
Interface 49
Class 10

Languages

TypeScript100%

Modules by API surface

lib/yargs-factory.ts154 symbols
lib/usage.ts46 symbols
lib/command.ts38 symbols
lib/completion.ts31 symbols
lib/validation.ts21 symbols
lib/typings/common-types.ts13 symbols
lib/middleware.ts13 symbols
lib/typings/yargs-parser-types.ts12 symbols
test/yargs.mjs10 symbols
test/usage.mjs9 symbols
lib/utils/process-argv.ts6 symbols
test/command.mjs5 symbols

Dependencies from manifests, versioned

@babel/eslint-parser7.26.10 · 1×
@babel/preset-typescript7.26.0 · 1×
@types/chai4.2.11 · 1×
@types/mocha9.0.0 · 1×
@types/node20.0.0 · 1×
@typescript-eslint/eslint-plugin8.26.1 · 1×
browserslist-generator2.0.1 · 1×
c89.1.0 · 1×
chai4.2.0 · 1×
chalk4.0.0 · 1×
cliui9.0.1 · 1×
cpr3.0.1 · 1×

Datastores touched

(mongodb)Database · 1 repos

For agents

$ claude mcp add yargs \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact