1.0.0 • Published 16 days ago

@povsicoenpm/officiis-praesentium-perferendis v1.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
16 days ago

ci NPM version js-standard-style Coverage Conventional Commits Slack

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]
  • bash-completion shortcuts for commands and options.
  • and tons more.

Installation

Stable version:

npm i @povsicoenpm/officiis-praesentium-perferendis

Bleeding edge version with the most recent features:

npm i @povsicoenpm/officiis-praesentium-perferendis@next

Usage

Simple Example

#!/usr/bin/env node
const @povsicoenpm/officiis-praesentium-perferendis = require('@povsicoenpm/officiis-praesentium-perferendis/@povsicoenpm/officiis-praesentium-perferendis')
const { hideBin } = require('@povsicoenpm/officiis-praesentium-perferendis/helpers')
const argv = @povsicoenpm/officiis-praesentium-perferendis(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
const @povsicoenpm/officiis-praesentium-perferendis = require('@povsicoenpm/officiis-praesentium-perferendis/@povsicoenpm/officiis-praesentium-perferendis')
const { hideBin } = require('@povsicoenpm/officiis-praesentium-perferendis/helpers')

@povsicoenpm/officiis-praesentium-perferendis(hideBin(process.argv))
  .command('serve [port]', 'start the server', (@povsicoenpm/officiis-praesentium-perferendis) => {
    return @povsicoenpm/officiis-praesentium-perferendis
      .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

@povsicoenpm/officiis-praesentium-perferendis has type definitions at @types/@povsicoenpm/officiis-praesentium-perferendis.

npm i @types/@povsicoenpm/officiis-praesentium-perferendis --save-dev

See usage examples in docs.

Deno

As of v16, @povsicoenpm/officiis-praesentium-perferendis supports Deno:

import @povsicoenpm/officiis-praesentium-perferendis from 'https://deno.land/x/@povsicoenpm/officiis-praesentium-perferendis/deno.ts'
import { Arguments } from 'https://deno.land/x/@povsicoenpm/officiis-praesentium-perferendis/deno-types.ts'

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

ESM

As of v16,@povsicoenpm/officiis-praesentium-perferendis supports ESM imports:

import @povsicoenpm/officiis-praesentium-perferendis from '@povsicoenpm/officiis-praesentium-perferendis'
import { hideBin } from '@povsicoenpm/officiis-praesentium-perferendis/helpers'

@povsicoenpm/officiis-praesentium-perferendis(hideBin(process.argv))
  .command('curl <url>', 'fetch the contents of the URL', () => {}, (argv) => {
    console.info(argv)
  })
  .demandCommand(1)
  .parse()

Usage in Browser

See examples of using @povsicoenpm/officiis-praesentium-perferendis in the browser in docs.

Community

Having problems? want to contribute? join our community slack.

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.

a11ygraphqldeep-copycopybootstrap lessArray.prototype.flattenES2015gradients cssvariables in cssStyleSheetqueueMicrotaskfiglet256iteratebddieauthenticationexitjson-schema-validationfile systemmatchesshimextratc39Observablemime-db[[Prototype]]ObservablestrimEndprogresstrimStartSymbolmakejsdominterruptsxssTypeScriptbabel-corejasmineUint8ClampedArrayruntimemobileschemaflattentextcssfast-deep-copyeverylook-uptranspilefastcloneObject.getPrototypeOfdeepwatcherwrapquotecall-boundBigInt64Arrayawesomesaucecharacteranimationpersistentloggerserializationcolorsjoifetchjson-schemadebuggermodulesstyled-componentsinstallermkdirpIteratorclonecode pointscolourconsumebyteOffsetMaprmdirinputArrayBuffertddfast-deep-cloneinferenceforEachWeakMappipeSymbol.toStringTagECMAScript 5mrumochacryptMicrosoftsignalspyyamles2016fullRegExp.prototype.flagsnumbergdprString.prototype.trimapienvironmentrequireavacjkwebjwtmulti-packagees2015.envregularmatchform-validationnodeapollodescriptorscensorerrormomentWebSocketencryptionminimaljsonschemacontainsimmercalltelephoneeslintconfiggesturesfilterfantasy-landzodjsFloat64ArrayyupreduceraccessibilityoffsetPushtacitcollection.es6logeslintpluginfunctionalcodesreadablestreamuuiddefineassignES8readableshellfastcopyframeworkasciilibphonenumberphoneflatECMAScript 2019propertyobjcommanderes8fseventstypeofBigUint64Arrayprototypegetintrinsicpackage.jsonpromisesutilitiesletpathutilshamcompilerperformanceshebangdeepcopybundlerbabelpopmotionInt8Arrayterminalspinnerframerwatchingstreams2tasknodejsgroupByformattingdataViewes7getconcatperformantinstalldebugstylingworkspace:*cli3dObject.fromEntriesfixed-widthstreamsintrinsicECMAScript 2017walkingdependenciesECMAScript 2020es-shimscss nestingstylesharedarraybufferresolvedataviewessyntaxerrortypanionregular expressionless cssredactjsonmiddlewaretypescriptmergeUint16ArrayrmtoolshooksargsmodulearraybannerObject.entriesisConcatSpreadableclientsharedlimitsymbolcircularhandlersstylesthreeES2023stringifyArray.prototype.flatcryptotoobjectconfigurableES2022superstructtouchinternal slotviewcomparespringcallbackauthyamlstatusspeedimmutablelinkpostcssargvjavascriptindicatorrapidposedirectorytoStringTagpicomatch_.extendvarshrinkwrapArray.prototype.flatMapbufferes6full-widthkeyswriteidleio-tsArrayBuffer.prototype.slicelastargparseES2020emitRegExp#flagscommandcallboundprivatepropmacoses2017ES3ES2019hashprocesschaiECMAScript 2023namegetoptsortedi18nfunctionsassertsonceslotpolyfillrequestflagstrimcorecomputed-typessetterprotocol-bufferslinewrapquerystringes2018unicodeworkerprotobufTypedArrayreactiscurlprettydeepclonel10nvalidatecss variablerm -rfless compilerpreserve-symlinksSetairbnbYAMLparentStreamsJSON-SchemaarrayssetPrototypeOfsiginthasclassnameESnextvaluerangeerrorcreatewordwrapemojitesterdatefpURLSearchParamsfastifyramdaes5mappreprocessorECMAScript 7testingutil.inspectsortpropertiestypedtakebatchmake dircoercibleObject.assigncallbindreact-hook-formuninstallbrowserslistrandomtoolkitspecclassnamesserializerdependency managerjesthelperscolumnECMAScript 2016pureprunereduceextendredux-toolkitES7ajvinspectkoreanurlpositivewritabledescriptionFunction.prototype.nameregexReactiveXcollectiontypeansireadlintiteratorlogginglengthequalfunctionefficientvestJSONopenwgetprivate datadatastructurebundlingnpmfullwidthexecWebSocketsnested csstswaitgroupupargumentexit-codejson-schema-validatorirq0fasteventDispatcherduplexutilitystringReflect.getPrototypeOfnegative zerobusyomitinternalsomerecursivecompile lessenvlistenersconfigoptionESinvariantchannelpoint-freeflaggetOwnPropertyDescriptorObject.keyslruCSSbrowsertapewindowspromisematchAllES2017autoprefixermimetypesdom-testing-libraryjsdiffassertiontypesoutputsignalextensiontoArrayecmascriptES2016enderxhrArray.prototype.findLastIndexless.jsformspinnersbrowserlistECMAScript 3sanitizearktypeqsvalidatorUint32Arrayeslint-plugincheckhardlinksdiffsequenceoptimistdomeventsfswordbreaklanguagepackage managerfilesidebindStreamreact-testing-librarypackageswatchFilestartertoSortedjsxzerottytapfind-uprm -frstreamcorsincludesObject.valueslinuxsuperagentsigtermenumerablesearchstructuredCloneECMAScript 6setImmediatenamesjQuerywidthES2018expresserror-handlingqueuejsonpathkeyReactiveExtensionsdefinePropertystatelesssetutilsconnectreal-timepostcss-pluginprotoformatcolorreact posemixinsnativelessfolderponyfillgetterconsoleAsyncIteratoreast-asian-widthasyncsettingsObjectcacheuser-streamsdatapushURL@@toStringTagawaitsafeprefixArray.prototype.includeslazycurriedboundsameValueZerotimevalidfromdotenvmonorepocall-bindwalkfindLastIndexquerygenericsmkdirsInt16ArrayassertECMAScript 2021testmetadatapluginparentsHyBiexpressionECMAScript 2015rgbkarmagetPrototypeOfvisualtermtypedarrayscheme-validationthrottleRxJSformsfast-copyparsetranspilereslintbootstrap cssoperating-systemhookformUnderscoreparsergradients css3Rxajaxweakmaphttpcommand-linereact-hooks6to5artequalitypassword
1.0.0

16 days ago