2.0.0 • Published 4 years ago

yargs-unparser v2.0.0

Weekly downloads
3,319,816
License
MIT
Repository
github
Last release
4 years ago

yargs-unparser

NPM version Downloads

Converts back a yargs argv object to its original array form.

Probably the unparser word doesn't even exist, but it sounds nice and goes well with yargs-parser.

The code originally lived in MOXY's GitHub but was later moved here for discoverability.

Installation

$ npm install yargs-unparser

Usage

const parse = require('yargs-parser');
const unparse = require('yargs-unparser');

const argv = parse(['--no-boolean', '--number', '4', '--string', 'foo'], {
    boolean: ['boolean'],
    number: ['number'],
    string: ['string'],
});
// { boolean: false, number: 4, string: 'foo', _: [] }

const unparsedArgv = unparse(argv);
// ['--no-boolean', '--number', '4', '--string', 'foo'];

The second argument of unparse accepts an options object:

  • alias: The aliases so that duplicate options aren't generated
  • default: The default values so that the options with default values are omitted
  • command: The command first argument so that command names and positional arguments are handled correctly

Example with command options

const yargs = require('yargs');
const unparse = require('yargs-unparser');

const argv = yargs
    .command('my-command <positional>', 'My awesome command', (yargs) =>
        yargs
        .option('boolean', { type: 'boolean' })
        .option('number', { type: 'number' })
        .option('string', { type: 'string' })
    )
    .parse(['my-command', 'hello', '--no-boolean', '--number', '4', '--string', 'foo']);
// { positional: 'hello', boolean: false, number: 4, string: 'foo', _: ['my-command'] }

const unparsedArgv = unparse(argv, {
    command: 'my-command <positional>',
});
// ['my-command', 'hello', '--no-boolean', '--number', '4', '--string', 'foo'];

Caveats

The returned array can be parsed again by yargs-parser using the default configuration. If you used custom configuration that you want yargs-unparser to be aware, please fill an issue.

If you coerce in weird ways, things might not work correctly.

Tests

$ npm test
$ npm test -- --watch during development

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.

License

MIT License

mochaws-scripts@sonammalhotra/lotide@smishra17/lotide@cheapthrills/lotide@iobroker-community-adapters/iobroker.device-watcher@newhorizon-tech/dd-npm-package-templatelevibestliblevibestlib2levilibtest19levilibtest24levilibtest25levilibtest26levilibtest27levilibtest28levilibtest29levinodelib@nicholasjj/lotide@wumijs/clicclibyarntest@everything-registry/sub-chunk-3199@garycui222/lotidevue-router-generatorwebdatabasetest1webdatabasetest10@gemini-testing/mocha@geosolutions/mochawinx-form-winxu-scripts-utilsui4htmlyakumo-yargsyakumoyakumo-core-patchyakumo-mochayarn-toolyarn-audit-fix-ng@harinderlabana/lotide@hassanabdi/lotide@lsby/log_manage@mar10outof10/lotide@manwelj/lotide@luiscontreras/lotidescrapingbeetip4tldrawligninshadow-event-busroyman-experiment-npm-publishsparse-setthe_helper_packagethe_helper_packagesterminalmanagertest-solidity-npmtestlib17testweblibapistock-ticker-react-widgetswan-toolkittype-your-package-name-hereverit-testvitaqai-mochawebliblevi3wskongkoin@kodinghandle/bullswap-lib@kcruz95/lotide@legend02/lotide@levlevin/react-portal-tooltip@linewit/vue-router-generator@lilyhabbs/lotide@lianc/lotide@litedexdev/litedex-core-swap@litedexdev/litedexdev-default-token-listexpo-release-config@kylesferrazza/graphql-relay-updated@louismcoding/lotide@hiroyone/number-formatter@git-lazy/util-args@git-lazy/subtree@innoswap/chainlink-whitelist@innoswap/core@innoswap/default-token-list@olgatkachenko/lotide@olympfin/olymp-swap-libgoogle-remake@oneverseswap/community-token-list@oneverseswap/default-token-list@meteora277/lotide@micro-app/shared-utils@materia-dex/materia-contracts-proxy@metabitswap/default-token-list@mhassan47/lotide@lul-merina/lotidefixed_form_builder@mavfeuille/lotide@mcl2s/lotide@mclap/lotide@mv-alex/test-trendtech@mzparulina26/lotide@namraa/lotide@namtoonix/editorjs-custom-multiple-selected@munahd/lotide@mrludovic/lotide
2.0.0

4 years ago

1.6.4

4 years ago

1.6.3

4 years ago

1.6.1

4 years ago

1.6.0

5 years ago

1.5.1

5 years ago

1.5.0

5 years ago

1.4.0

6 years ago

1.3.0

6 years ago

1.2.0

7 years ago

1.1.0

7 years ago

1.0.3

7 years ago

1.0.2

7 years ago

1.0.1

7 years ago

1.0.0

7 years ago