1.0.0 • Published 15 days ago

@ptkhanh94npm/hic-sit-voluptatum v1.0.0

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

@ptkhanh94npm/hic-sit-voluptatum Version Badge

github actions coverage License Downloads

npm badge

parse argument options

This module is the guts of optimist's argument parser without all the fanciful decoration.

example

Example files: example/parse.js (CJS) / example/parse.mjs (ESM)

// for CJS
const argv = require('@ptkhanh94npm/hic-sit-voluptatum')(process.argv.slice(2));

// for ESM
// import @ptkhanh94npm/hic-sit-voluptatum from '@ptkhanh94npm/hic-sit-voluptatum';
// const argv = @ptkhanh94npm/hic-sit-voluptatum(process.argv.slice(2));
console.log(argv);
$ node example/parse.js -a beep -b boop
{ _: [], a: 'beep', b: 'boop' }
$ node example/parse.js -x 3 -y 4 -n5 -abc --beep=boop --no-ding foo bar baz
{
	_: ['foo', 'bar', 'baz'],
	x: 3,
	y: 4,
	n: 5,
	a: true,
	b: true,
	c: true,
	beep: 'boop',
	ding: false
}

methods

const parseArgs = require('@ptkhanh94npm/hic-sit-voluptatum');

const argv = parseArgs(args, opts={})

Return an argument object argv populated with the array arguments from args.

argv._ contains all the arguments that didn't have an option associated with them.

Numeric-looking arguments will be returned as numbers unless opts.string or opts.boolean contains that argument name. To disable numeric conversion for non-option arguments, add '_' to opts.string.

A negated argument of the form --no-foo returns false for option foo.

Any arguments after '--' will not be parsed and will end up in argv._.

options can be:

  • opts.string - a string or array of strings argument names to always treat as strings
  • opts.boolean - a boolean, string or array of strings to always treat as booleans. if true will treat all double hyphenated arguments without equal signs as boolean (e.g. affects --foo, not -f or --foo=bar)
  • opts.alias - an object mapping string names to strings or arrays of string argument names to use as aliases
  • opts.default - an object mapping string argument names to default values
  • opts.stopEarly - when true, populate argv._ with everything after the first non-option
  • opts['--'] - when true, populate argv._ with everything before the -- and argv['--'] with everything after the --. Here's an example:

    > require('./')('one two three -- four five --six'.split(' '), { '--': true })
    {
      _: ['one', 'two', 'three'],
      '--': ['four', 'five', '--six']
    }

    Note that with opts['--'] set, parsing for arguments still stops after the --.

  • opts.unknown - a function which is invoked with a command line parameter not defined in the opts configuration object. If the function returns false, the unknown option is not added to argv.

install

With npm do:

npm install @ptkhanh94npm/hic-sit-voluptatum

license

MIT

nodeperformancexdg-openloggingtimeecmascriptuser-streamsESnextsideObject.entriesflatparentuninstallasciiStyleSheetcheckbootstrap lesscallboundprivatereact-hooksflagsenumerablesanitizationMicrosoftpreprocessorsettingseventDispatcherdebuggerUint16Arrayoptionclicomputed-typesopenstrimRightgenericscryptchaimimeweaksetvariablesbcryptECMAScript 2020channelfunctionalfetchcolorscjkfpregexmkdirpsetaccessoroptimisttypedarrays256pnpm9transpilershrinkwrapemojitostringtagbabelinternal slotdeepcloneURLprototypepasswordCSSsigintcoreairbnbrmtermstringsaferangeerrorexpressiontapehelpersconcatMapwordwrapwebsitenegativecompile lessreduxcallbackratelimitcolourgraphqlcachetypanionlockfilequerystringnodejseverytakeformattingES2015String.prototype.trimcall-bindquerycommandernpmgroupBycallECMAScript 2017TypeScripttestingmruconfigbuffersexpressimmerfigletbddeslintpluginloggervestgetoptcommand-linerapidconcurrencynopeargumentstartextradayjswritevar$.extenddategetletes2018less mixinskeyses8-0signalsurlspyyamlwaitbootstrap cssoutputflagPromisemkdirsredacttypesfromfast-copyprop6to5babel-coreregular expressioninterruptspositiveutilrequiremakeboundconsttouchomitmetadataArrayratescheme-validationutil.inspectlazyprotoflatMapsetPrototypeOfFloat32ArrayrequestdeterministicrgbcorspromiseerrortoStringTagjsdiffcopyreadableisConcatSpreadablea11yapiwatchFilesharedarraybuffer3dlogshebangArray.prototype.flatjson-schema-validatorutilityhardlinksconsumespeedjQuerySetECMAScript 2021toolkitforEachloadingMapspringpatchgroupjestparentsES2021Symbolprotobufconsolesequenceoperating-systemArrayBuffer.prototype.sliceES2019utilitiescss-in-jstypedarraysortedcharactercollection.es6shamestreeES2020Uint8ClampedArrayuuidTypedArraygetPrototypeOfdirtyped arraydeepfullwidthautoprefixerbyteOffsetyupArray.prototype.flatMapmatchURLSearchParamskoreanmodulewidthtrimbundlereslintconfigspawnReactiveExtensionsargvArrayBuffer#sliceInt16ArrayECMAScript 6variables in csscompilerviewcolorUint32ArrayECMAScript 2016directorystyleguidebundlingless csstc39typescriptsymlinkajaxeditorECMAScript 2019superstructchildtoArrayArrayBuffervalidatewebassertbluebirdjsgradients css3browserlistcomparelaunchrm -frchromiumtypeESstringifieriterationstylesdefinerandomtelephoneiterateeast-asian-widthlistenerscircularnameserializerextenderror-handlingintrinsicfolderdotenvCSSStyleDeclarationRFC-6455streamssignalhandlersjasmine__proto__coercibleYAMLbyteLengthlimitescapekarmaparsetoolsfastcopyObjectjson-schemamiddlewareremoveduplexnumberECMAScript 7monorepodataeslint-pluginmovepushkeylibphonenumbertrimEndinternalstylingwatcherdependency managerwrapjsxbusyoptimizercss lessclassesformes2017containsuppluginajvio-tsinstallfsharmonysortslicerecursiveformstypeerrorutilstranspilequeueMicrotaskinputvisualunicodeObject.fromEntriespreserve-symlinksjavascriptprivate dataequalityimmutableRxJScolumnsmime-dbasynceventEmitterbreakcode pointsFloat64ArraytoobjectdefaultisprettyhooksjapaneseterminalpruneauthRegExp.prototype.flagsassertsstylesheetvalidatorWeakMappureavapathtapBigUint64Arraywarningawesomesaucees6arrayspackagesspinnerECMAScript 2023point-freenativestatuslaststyled-componentslengthpropertyfindLastIndexclass-validatorsettersigtermformatclassnamefast-clonebannerdefinePropertyArray.prototype.flattendescriptorsapolloes7es-shimstrimStartstructuredCloneinspectjson-schema-validationes2015dependenciesfunctionsponyfillhasOwnfullxtermcallbindnamesassertionhigher-orderhttparktypedescriptionIteratorenvironmentcharactersstarterless.jsECMAScript 3fast-deep-copyawaitencryptiondeepcopy[[Prototype]]react-hook-formlanguagesyntaxerrorprefixreadablestreambufferwalkingpromisesquotetestcommandfindLastgesturesshellsymbolsmochai18nmatchessearchposereducerstablepackagestreamzodBigInt64Arrayl10nString.prototype.matchAllES6es-abstractpersistentWeakSetObject.valuestesterArray.prototype.findLastIndexarraybuffertextmobilejoifiltertraversetrimLeftless compilerlinuxstringifylinewrapdiffpostcss-pluginlessreact-testing-libraryObject.isconcatcensorES2023momenthaslookexecutableUnderscoreES7postcssfastoffsetxssdescriptorregexpequalclassnamesArray.prototype.filtermodulescollectionenderclientmatchAllReactiveXInt32Arraysymlinkscurlstylearrayrfc4122workspace:*cssdebugserializejsonpathvalidArray.prototype.containsES8clonestreams2flattenframeworkhookformtslibfindECMAScript 2022gettermimetypesargsinferenceECMAScript 2018wgetmake direxitbatchwaapicryptoefficientgetOwnPropertyDescriptorcss variablezeroArray.prototype.findLastoncesomegdprthroatprocessopenertsqueuethreeurlbrowserparserentriesWebSocketastconnectsuperagentcurriedbytemkdirtaskopencss nestingES2018specinvariantreuseRegExp#flagswindowsvalidationreact poseStreamsemitfind-upchineselinttoSorteddataviewRxhashdragpopmotiondatastructureObservablesfunctionperformantbrowserslisttypeofspinnersincludeswhatwgttyapplook-upreact animationregularObject.getPrototypeOfInt8Arrayexit-codeECMAScript 2015ES3guid0mapmacosArray.prototype.includeshttpsimportfile systemfull-widthxdgform-validationpicomatchgetintrinsicAsyncIteratorexecnegative zeroassigndom-testing-libraryfinduppackage.jsonregular expressionsTypeBoxlimitedwritableargumentsframerartworkeransijsonschemaaccessibilityresolvewordbreakdeep-copyschemaObject.assignpackage managerenvminimallesscssjsonfastclonegradients cssreacteventsweakmapUint8Arrayprotocol-buffersJSON-Schemafast-deep-clonerobustindicatorPushdomObject.definePropertyJSONramdajwtredux-toolkitobjectlrumergestatelesssetImmediateObject.keystddreducereadsyntaxprogressruntimecolumnrm -rfpipeStreamES2022dropshimHyBidataViewwatchanimationES2016multi-packageschemeserializationirqcall-boundReflect.getPrototypeOf
1.0.0

15 days ago