Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yargs/yargs
yargs the modern, pirate-themed successor to optimist.
https://github.com/yargs/yargs
Last synced: 6 days ago
JSON representation
yargs the modern, pirate-themed successor to optimist.
- Host: GitHub
- URL: https://github.com/yargs/yargs
- Owner: yargs
- License: mit
- Created: 2013-11-07T17:25:51.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2024-10-01T18:35:59.000Z (3 months ago)
- Last Synced: 2024-12-30T12:39:35.507Z (13 days ago)
- Language: JavaScript
- Homepage: https://yargs.js.org/
- Size: 4.85 MB
- Stars: 11,133
- Watchers: 82
- Forks: 994
- Open Issues: 319
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: contributing.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome - yargs/yargs - yargs the modern, pirate-themed successor to optimist. (JavaScript)
- awesome - yargs - yargs the modern, pirate-themed successor to optimist. (JavaScript)
- my-awesome-list - yargs - themed successor to optimist. | yargs | 11137 | (JavaScript)
- Starred-Repo - Yargs
- awesome-nodejs - yargs - Collection of common interactive command line user interfaces. ![](https://img.shields.io/github/stars/yargs/yargs.svg?style=social&label=Star) (Repository / Command-line Utilities)
- awesome-cli-frameworks - Yargs
- awesome-libraries - yargs
- awesome-github-star - yargs - themed successor to optimist. | yargs | 10678 | (JavaScript)
- awesome-node-esm - yargs - Command-line parser that automatically generates an elegant user-interface. (Packages / CLI)
- awesome-nodejs - yargs - Command-line parser that automatically generates an elegant user-interface. (Packages / Command-line utilities)
- awesome-npm - yargs - 海盗主题的命令行用户界面的处理方案 (3. 命令行程序 / 3.1 开发库)
- awesome-fluents - yargs - themed, successor to optimist. -- *Maintainer*: `Benjamin E. Coe`[![Github](https://rawgit.com/d3viant0ne/awesome-webpack/master/media/github-square.svg)](https://github.com/bcoe)[![Twitter](https://rawgit.com/d3viant0ne/awesome-webpack/master/media/twitter-square.svg)](https://twitter.com/benjamincoe) (NodeJS)
- awesome-nodejs - yargs - yargs the modern, pirate-themed successor to optimist. - ★ 5397 (Command-line utilities)
- awesome-node - yargs - Command-line parser that automatically generates an elegant user-interface. (Packages / Command-line utilities)
- awesome-f2e-libs - **yargs** - 命令行入口套件。 (命令行 / redux 扩展)
- awesome-nodejs-cn - yargs - 自动生成优雅用户界面的命令行解析器. (目录 / 命令行工具)
- awesome-nodejs - yargs - 命令行参数解析工具 (Uncategorized / Uncategorized)
- awesome-deno - yargs - The modern, pirate-themed successor to optimist. (Modules / CLI utils)
- awesome-fe - **yargs** - 命令行入口套件。 (命令行 / macros)
- awesome-starred - yargs/yargs - yargs the modern, pirate-themed successor to optimist. (others)
- awesome-nodejs-cn - yargs - 自动生成优雅用户界面的命令行分析程序 (包 / 命令行工具)
- awesome - yargs/yargs - yargs the modern, pirate-themed successor to optimist. (JavaScript)
- awesome - yargs/yargs - yargs the modern, pirate-themed successor to optimist. (JavaScript)
- awesome-nodejs-cn - yargs - **star:11134** 自动生成优雅用户界面的命令行解析器 ![star > 2000][Awesome] (包 / 命令行实用工具)
- stars - yargs - themed successor to optimist. | yargs | 11138 | (JavaScript)
- stars - yargs - themed successor to optimist. | yargs | 11132 | (JavaScript)
README
Yargs
Yargs be a node.js library fer hearties tryin' ter parse optstrings
![ci](https://github.com/yargs/yargs/workflows/ci/badge.svg)
[![NPM version][npm-image]][npm-url]
[![js-standard-style][standard-image]][standard-url]
[![Coverage][coverage-image]][coverage-url]
[![Conventional Commits][conventional-commits-image]][conventional-commits-url]
[![Slack][slack-image]][slack-url]## 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 create a client-side Mocha setup atRules & 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]
```* bash-completion shortcuts for commands and options.
* and [tons more](/docs/api.md).## Installation
Stable version:
```bash
npm i yargs
```Bleeding edge version with the most recent features:
```bash
npm i yargs@next
```## Usage
### Simple Example
```javascript
#!/usr/bin/env node
const yargs = require('yargs/yargs')
const { hideBin } = require('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!')
}
``````bash
$ ./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)`](https://nodejs.org/en/knowledge/command-line/how-to-parse-command-line-arguments/). It has the benefit that it takes into account variations in some environments, e.g., [Electron](https://github.com/electron/electron/issues/4690).
### Complex Example
```javascript
#!/usr/bin/env node
const yargs = require('yargs/yargs')
const { hideBin } = require('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][type-definitions].
```
npm i @types/yargs --save-dev
```See usage examples in [docs](/docs/typescript.md).
### Deno
As of `v16`, `yargs` supports [Deno](https://github.com/denoland/deno):
```typescript
import yargs from 'https://deno.land/x/[email protected]/deno.ts'
import { Arguments } from 'https://deno.land/x/[email protected]/deno-types.ts'yargs(Deno.args)
.command('download ', '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`
### ESM
As of `v16`,`yargs` supports ESM imports:
```js
import yargs from 'yargs'
import { hideBin } from 'yargs/helpers'yargs(hideBin(process.argv))
.command('curl ', 'fetch the contents of the URL', () => {}, (argv) => {
console.info(argv)
})
.demandCommand(1)
.parse()
```### Usage in Browser
See examples of using yargs in the browser in [docs](/docs/browser.md).
## Community
Having problems? want to contribute? join our [community slack](http://devtoolscommunity.herokuapp.com).
## Documentation
### Table of Contents
* [Yargs' API](/docs/api.md)
* [Examples](/docs/examples.md)
* [Parsing Tricks](/docs/tricks.md)
* [Stop the Parser](/docs/tricks.md#stop)
* [Negating Boolean Arguments](/docs/tricks.md#negate)
* [Numbers](/docs/tricks.md#numbers)
* [Arrays](/docs/tricks.md#arrays)
* [Objects](/docs/tricks.md#objects)
* [Quotes](/docs/tricks.md#quotes)
* [Advanced Topics](/docs/advanced.md)
* [Composing Your App Using Commands](/docs/advanced.md#commands)
* [Building Configurable CLI Apps](/docs/advanced.md#configuration)
* [Customizing Yargs' Parser](/docs/advanced.md#customizing)
* [Bundling yargs](/docs/bundling.md)
* [Contributing](/contributing.md)## Supported Node.js Versions
Libraries in this ecosystem make a best effort to track
[Node.js' release schedule](https://nodejs.org/en/about/releases/). Here's [a
post on why we think this is important](https://medium.com/the-node-js-collection/maintainers-should-consider-following-node-js-release-schedule-ab08ed4de71a).[npm-url]: https://www.npmjs.com/package/yargs
[npm-image]: https://img.shields.io/npm/v/yargs.svg
[standard-image]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg
[standard-url]: http://standardjs.com/
[conventional-commits-image]: https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg
[conventional-commits-url]: https://conventionalcommits.org/
[slack-image]: http://devtoolscommunity.herokuapp.com/badge.svg
[slack-url]: http://devtoolscommunity.herokuapp.com
[type-definitions]: https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/yargs
[coverage-image]: https://img.shields.io/nycrc/yargs/yargs
[coverage-url]: https://github.com/yargs/yargs/blob/main/.nycrc