Comparing version 0.0.10 to 0.0.11
@@ -10,8 +10,14 @@ 'use strict'; | ||
/** | ||
* Captures the argument name if it contains `<` and `>` to signify the argument is required. | ||
* Tests if the name contains the required sequence (`<` and `>`). | ||
* @type {RegExp} | ||
*/ | ||
const nameRegExp = /^\s*(?:<(.+)>|\[(.+)\])\s*$/; | ||
const requiredRegExp = /^\s*(?:<(.+)>|\[(.+)\])\s*(\.\.\.\s*)?$/; | ||
/** | ||
* Tests if the name contains the multiple sequence. | ||
* @type {RegExp} | ||
*/ | ||
const multipleRegExp = /^(.*)\.\.\.\s*$/; | ||
/** | ||
* Defines a argument. | ||
@@ -25,10 +31,15 @@ */ | ||
* `params.name` below for usage. | ||
* @param {Function} [params.callback] - ????????????????????????????? | ||
* @param {Function} [params.callback] - A function to call when the argument has been | ||
* processed. This happens parsing is complete. | ||
* @param {String} [params.desc] - The description of the argument used in the help output. | ||
* @param {Boolean} [params.hidden=false] - When `true`, the argument is not displayed on the | ||
* help screen or auto-suggest. | ||
* @param {Boolean} [params.multiple=false] - When `true`, the value becomes an array with all | ||
* remaining parsed arguments. Any subsequent argument definitions after a `multiple` argument | ||
* are ignored. | ||
* @param {String} [params.name] - The name of the argument. If the name is wrapped in angle | ||
* brackets (`<`, `>`), then the brackets are trimmed off and the argument is flagged as | ||
* required (unless `params.required` is explicitly set to `false`). If the name is wrapped in | ||
* square brackets (`[`, `]`), then the brackets are trimmed off. | ||
* square brackets (`[`, `]`), then the brackets are trimmed off. If the name ends with `...` | ||
* and `params.multiple` is not specified, then it will set `params.multiple` to `true`. | ||
* @param {Boolean} [params.regex] - A regular expression used to validate the value. | ||
@@ -61,3 +72,4 @@ * @param {Boolean} [params.required=false] - Marks the option value as required. | ||
const m = params.name.match(nameRegExp); | ||
// check if the name contains a required sequence | ||
let m = params.name.match(requiredRegExp); | ||
if (m) { | ||
@@ -67,5 +79,14 @@ if (params.required === undefined && m[1]) { | ||
} | ||
params.name = (m[1] || m[2]).trim(); | ||
params.name = (m[1] || m[2]).trim() + (m[3] || ''); | ||
} | ||
// check if the name contains a multiple sequence | ||
m = params.name.match(multipleRegExp); | ||
if (m) { | ||
if (params.multiple === undefined) { | ||
params.multiple = true; | ||
} | ||
params.name = m[1].trim(); | ||
} | ||
Object.assign(this, params); | ||
@@ -107,2 +128,2 @@ | ||
exports.default = Argument; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImFyZ3VtZW50LmpzIl0sIm5hbWVzIjpbIm5hbWVSZWdFeHAiLCJBcmd1bWVudCIsImNvbnN0cnVjdG9yIiwibmFtZU9yUGFyYW1zIiwicGFyYW1zIiwibmFtZSIsIkFycmF5IiwiaXNBcnJheSIsIlR5cGVFcnJvciIsIm0iLCJtYXRjaCIsInJlcXVpcmVkIiwidW5kZWZpbmVkIiwidHJpbSIsIk9iamVjdCIsImFzc2lnbiIsImhpZGRlbiIsInR5cGUiLCJ0cmFuc2Zvcm0iLCJ2YWx1ZSIsIm1pbiIsIkVycm9yIiwibWF4Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFFQTs7OztBQUlBLE1BQU1BLGFBQWEsNkJBQW5COztBQUVBOzs7QUFHZSxNQUFNQyxRQUFOLENBQWU7QUFDN0I7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQWtCQUMsYUFBWUMsWUFBWixFQUEwQjtBQUN6Qjs7Ozs7QUFLQSxNQUFJQyxTQUFTRCxZQUFiOztBQUVBLE1BQUksT0FBT0EsWUFBUCxLQUF3QixRQUE1QixFQUFzQztBQUNyQ0MsWUFBUztBQUNSQyxVQUFNRjtBQURFLElBQVQ7QUFJQSxHQUxELE1BS08sSUFBSSxDQUFDQSxZQUFMLEVBQW1CO0FBQ3pCQyxZQUFTLEVBQVQ7QUFFQSxHQUhNLE1BR0EsSUFBSSxPQUFPRCxZQUFQLEtBQXdCLFFBQXhCLElBQW9DRyxNQUFNQyxPQUFOLENBQWNKLFlBQWQsQ0FBeEMsRUFBcUU7QUFDM0UsU0FBTSxJQUFJSyxTQUFKLENBQWMsaUNBQWQsQ0FBTjtBQUNBOztBQUVELE1BQUksQ0FBQ0osT0FBT0MsSUFBUixJQUFnQixPQUFPRCxPQUFPQyxJQUFkLEtBQXVCLFFBQTNDLEVBQXFEO0FBQ3BELFNBQU1HLFVBQVUsaURBQVYsQ0FBTjtBQUNBOztBQUVELFFBQU1DLElBQUlMLE9BQU9DLElBQVAsQ0FBWUssS0FBWixDQUFrQlYsVUFBbEIsQ0FBVjtBQUNBLE1BQUlTLENBQUosRUFBTztBQUNOLE9BQUlMLE9BQU9PLFFBQVAsS0FBb0JDLFNBQXBCLElBQWlDSCxFQUFFLENBQUYsQ0FBckMsRUFBMkM7QUFDMUNMLFdBQU9PLFFBQVAsR0FBa0IsSUFBbEI7QUFDQTtBQUNEUCxVQUFPQyxJQUFQLEdBQWMsQ0FBQ0ksRUFBRSxDQUFGLEtBQVFBLEVBQUUsQ0FBRixDQUFULEVBQWVJLElBQWYsRUFBZDtBQUNBOztBQUVEQyxTQUFPQyxNQUFQLENBQWMsSUFBZCxFQUFvQlgsTUFBcEI7O0FBRUE7O0FBRUEsT0FBS1ksTUFBTCxHQUFnQixDQUFDLENBQUNaLE9BQU9ZLE1BQXpCO0FBQ0EsT0FBS0wsUUFBTCxHQUFnQixDQUFDLENBQUNQLE9BQU9PLFFBQXpCO0FBQ0EsT0FBS00sSUFBTCxHQUFnQixzQkFBVWIsT0FBT2EsSUFBakIsRUFBdUIsUUFBdkIsQ0FBaEI7QUFDQTs7QUFFRDs7Ozs7OztBQU9BQyxXQUFVQyxLQUFWLEVBQWlCO0FBQ2hCQSxVQUFRLDJCQUFlQSxLQUFmLEVBQXNCLEtBQUtGLElBQTNCLENBQVI7O0FBRUEsVUFBUSxLQUFLQSxJQUFiO0FBQ0MsUUFBSyxhQUFMO0FBQ0EsUUFBSyxLQUFMO0FBQ0EsUUFBSyxRQUFMO0FBQ0MsUUFBSSxLQUFLRyxHQUFMLEtBQWEsSUFBYixJQUFxQkQsUUFBUSxLQUFLQyxHQUF0QyxFQUEyQztBQUMxQyxXQUFNLElBQUlDLEtBQUosQ0FBVywwQ0FBeUMsS0FBS0QsR0FBSSxFQUE3RCxDQUFOO0FBQ0E7QUFDRCxRQUFJLEtBQUtFLEdBQUwsS0FBYSxJQUFiLElBQXFCSCxRQUFRLEtBQUtHLEdBQXRDLEVBQTJDO0FBQzFDLFdBQU0sSUFBSUQsS0FBSixDQUFXLHVDQUFzQyxLQUFLQyxHQUFJLEVBQTFELENBQU47QUFDQTtBQUNEO0FBVkY7O0FBYUEsU0FBT0gsS0FBUDtBQUNBO0FBcEY0QjtrQkFBVGxCLFEiLCJmaWxlIjoiYXJndW1lbnQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjaGVja1R5cGUsIHRyYW5zZm9ybVZhbHVlIH0gZnJvbSAnLi90eXBlcyc7XG5cbi8qKlxuICogQ2FwdHVyZXMgdGhlIGFyZ3VtZW50IG5hbWUgaWYgaXQgY29udGFpbnMgYDxgIGFuZCBgPmAgdG8gc2lnbmlmeSB0aGUgYXJndW1lbnQgaXMgcmVxdWlyZWQuXG4gKiBAdHlwZSB7UmVnRXhwfVxuICovXG5jb25zdCBuYW1lUmVnRXhwID0gL15cXHMqKD86PCguKyk+fFxcWyguKylcXF0pXFxzKiQvO1xuXG4vKipcbiAqIERlZmluZXMgYSBhcmd1bWVudC5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQXJndW1lbnQge1xuXHQvKipcblx0ICogQ3JlYXRlcyBhbiBhcmd1bWVudCBkZXNjcmlwdG9yLlxuXHQgKlxuXHQgKiBAcGFyYW0ge1N0cmluZ3xPYmplY3R9IFtuYW1lT3JQYXJhbXNdIC0gVmFyaW91cyBwYXJhbWV0ZXJzLiBJZiB2YWx1ZSBpcyBhIGBTdHJpbmdgLCB0aGVuIHNlZVxuXHQgKiBgcGFyYW1zLm5hbWVgIGJlbG93IGZvciB1c2FnZS5cblx0ICogQHBhcmFtIHtGdW5jdGlvbn0gW3BhcmFtcy5jYWxsYmFja10gLSA/Pz8/Pz8/Pz8/Pz8/Pz8/Pz8/Pz8/Pz8/Pz8/P1xuXHQgKiBAcGFyYW0ge1N0cmluZ30gW3BhcmFtcy5kZXNjXSAtIFRoZSBkZXNjcmlwdGlvbiBvZiB0aGUgYXJndW1lbnQgdXNlZCBpbiB0aGUgaGVscCBvdXRwdXQuXG5cdCAqIEBwYXJhbSB7Qm9vbGVhbn0gW3BhcmFtcy5oaWRkZW49ZmFsc2VdIC0gV2hlbiBgdHJ1ZWAsIHRoZSBhcmd1bWVudCBpcyBub3QgZGlzcGxheWVkIG9uIHRoZVxuXHQgKiBoZWxwIHNjcmVlbiBvciBhdXRvLXN1Z2dlc3QuXG5cdCAqIEBwYXJhbSB7U3RyaW5nfSBbcGFyYW1zLm5hbWVdIC0gVGhlIG5hbWUgb2YgdGhlIGFyZ3VtZW50LiBJZiB0aGUgbmFtZSBpcyB3cmFwcGVkIGluIGFuZ2xlXG5cdCAqIGJyYWNrZXRzIChgPGAsIGA+YCksIHRoZW4gdGhlIGJyYWNrZXRzIGFyZSB0cmltbWVkIG9mZiBhbmQgdGhlIGFyZ3VtZW50IGlzIGZsYWdnZWQgYXNcblx0ICogcmVxdWlyZWQgKHVubGVzcyBgcGFyYW1zLnJlcXVpcmVkYCBpcyBleHBsaWNpdGx5IHNldCB0byBgZmFsc2VgKS4gSWYgdGhlIG5hbWUgaXMgd3JhcHBlZCBpblxuXHQgKiBzcXVhcmUgYnJhY2tldHMgKGBbYCwgYF1gKSwgdGhlbiB0aGUgYnJhY2tldHMgYXJlIHRyaW1tZWQgb2ZmLlxuXHQgKiBAcGFyYW0ge0Jvb2xlYW59IFtwYXJhbXMucmVnZXhdIC0gQSByZWd1bGFyIGV4cHJlc3Npb24gdXNlZCB0byB2YWxpZGF0ZSB0aGUgdmFsdWUuXG5cdCAqIEBwYXJhbSB7Qm9vbGVhbn0gW3BhcmFtcy5yZXF1aXJlZD1mYWxzZV0gLSBNYXJrcyB0aGUgb3B0aW9uIHZhbHVlIGFzIHJlcXVpcmVkLlxuXHQgKiBAcGFyYW0ge1N0cmluZ30gW3BhcmFtcy50eXBlXSAtIFRoZSBhcmd1bWVudCB0eXBlIHRvIGNvZXJjZSB0aGUgZGF0YSB0eXBlIGludG8uXG5cdCAqIEBhY2Nlc3MgcHVibGljXG5cdCAqL1xuXHRjb25zdHJ1Y3RvcihuYW1lT3JQYXJhbXMpIHtcblx0XHQvKlxuXHRcdHsgbmFtZTogJ3BhdGgnLCByZXF1aXJlZDogdHJ1ZSwgcmVnZXg6IC9eXFwvLywgZGVzYzogJ3RoZSBwYXRoIHRvIHJlcXVlc3QnIH0sXG5cdFx0eyBuYW1lOiAnanNvbicsIHR5cGU6ICdqc29uJywgZGVzYzogJ2FuIG9wdGlvbiBKU09OIHBheWxvYWQgdG8gc2VuZCcgfVxuXHRcdCovXG5cblx0XHRsZXQgcGFyYW1zID0gbmFtZU9yUGFyYW1zO1xuXG5cdFx0aWYgKHR5cGVvZiBuYW1lT3JQYXJhbXMgPT09ICdzdHJpbmcnKSB7XG5cdFx0XHRwYXJhbXMgPSB7XG5cdFx0XHRcdG5hbWU6IG5hbWVPclBhcmFtc1xuXHRcdFx0fTtcblxuXHRcdH0gZWxzZSBpZiAoIW5hbWVPclBhcmFtcykge1xuXHRcdFx0cGFyYW1zID0ge307XG5cblx0XHR9IGVsc2UgaWYgKHR5cGVvZiBuYW1lT3JQYXJhbXMgIT09ICdvYmplY3QnIHx8IEFycmF5LmlzQXJyYXkobmFtZU9yUGFyYW1zKSkge1xuXHRcdFx0dGhyb3cgbmV3IFR5cGVFcnJvcignRXhwZWN0ZWQgcGFyYW1zIHRvIGJlIGFuIG9iamVjdCcpO1xuXHRcdH1cblxuXHRcdGlmICghcGFyYW1zLm5hbWUgfHwgdHlwZW9mIHBhcmFtcy5uYW1lICE9PSAnc3RyaW5nJykge1xuXHRcdFx0dGhyb3cgVHlwZUVycm9yKCdFeHBlY3RlZCBhcmd1bWVudCBuYW1lIHRvIGJlIGEgbm9uLWVtcHR5IHN0cmluZycpO1xuXHRcdH1cblxuXHRcdGNvbnN0IG0gPSBwYXJhbXMubmFtZS5tYXRjaChuYW1lUmVnRXhwKTtcblx0XHRpZiAobSkge1xuXHRcdFx0aWYgKHBhcmFtcy5yZXF1aXJlZCA9PT0gdW5kZWZpbmVkICYmIG1bMV0pIHtcblx0XHRcdFx0cGFyYW1zLnJlcXVpcmVkID0gdHJ1ZTtcblx0XHRcdH1cblx0XHRcdHBhcmFtcy5uYW1lID0gKG1bMV0gfHwgbVsyXSkudHJpbSgpO1xuXHRcdH1cblxuXHRcdE9iamVjdC5hc3NpZ24odGhpcywgcGFyYW1zKTtcblxuXHRcdC8vIFRPRE86IHBhcmFtcy5yZWdleFxuXG5cdFx0dGhpcy5oaWRkZW4gICA9ICEhcGFyYW1zLmhpZGRlbjtcblx0XHR0aGlzLnJlcXVpcmVkID0gISFwYXJhbXMucmVxdWlyZWQ7XG5cdFx0dGhpcy50eXBlICAgICA9IGNoZWNrVHlwZShwYXJhbXMudHlwZSwgJ3N0cmluZycpO1xuXHR9XG5cblx0LyoqXG5cdCAqIFRyYW5zZm9ybXMgdGhlIGdpdmVuIGFyZ3VtZW50IHZhbHVlIGJhc2VkIG9uIGl0cyB0eXBlLlxuXHQgKlxuXHQgKiBAcGFyYW0geyp9IHZhbHVlIC0gVGhlIHZhbHVlIHRvIHRyYW5zZm9ybS5cblx0ICogQHJldHVybnMgeyp9XG5cdCAqIEBhY2Nlc3MgcHVibGljXG5cdCAqL1xuXHR0cmFuc2Zvcm0odmFsdWUpIHtcblx0XHR2YWx1ZSA9IHRyYW5zZm9ybVZhbHVlKHZhbHVlLCB0aGlzLnR5cGUpO1xuXG5cdFx0c3dpdGNoICh0aGlzLnR5cGUpIHtcblx0XHRcdGNhc2UgJ3Bvc2l0aXZlSW50Jzpcblx0XHRcdGNhc2UgJ2ludCc6XG5cdFx0XHRjYXNlICdudW1iZXInOlxuXHRcdFx0XHRpZiAodGhpcy5taW4gIT09IG51bGwgJiYgdmFsdWUgPCB0aGlzLm1pbikge1xuXHRcdFx0XHRcdHRocm93IG5ldyBFcnJvcihgVmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gb3IgZXF1YWwgdG8gJHt0aGlzLm1pbn1gKTtcblx0XHRcdFx0fVxuXHRcdFx0XHRpZiAodGhpcy5tYXggIT09IG51bGwgJiYgdmFsdWUgPiB0aGlzLm1heCkge1xuXHRcdFx0XHRcdHRocm93IG5ldyBFcnJvcihgVmFsdWUgbXVzdCBiZSBsZXNzIHRoYW4gb3IgZXF1YWwgdG8gJHt0aGlzLm1heH1gKTtcblx0XHRcdFx0fVxuXHRcdFx0XHRicmVhaztcblx0XHR9XG5cblx0XHRyZXR1cm4gdmFsdWU7XG5cdH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["argument.js"],"names":["requiredRegExp","multipleRegExp","Argument","constructor","nameOrParams","params","name","Array","isArray","TypeError","m","match","required","undefined","trim","multiple","Object","assign","hidden","type","transform","value","min","Error","max"],"mappings":";;;;;;AAAA;;AAEA;;;;AAIA,MAAMA,iBAAiB,yCAAvB;;AAEA;;;;AAIA,MAAMC,iBAAiB,iBAAvB;;AAEA;;;AAGe,MAAMC,QAAN,CAAe;AAC7B;;;;;;;;;;;;;;;;;;;;;;;AAuBAC,aAAYC,YAAZ,EAA0B;AACzB;;;;;AAKA,MAAIC,SAASD,YAAb;;AAEA,MAAI,OAAOA,YAAP,KAAwB,QAA5B,EAAsC;AACrCC,YAAS;AACRC,UAAMF;AADE,IAAT;AAIA,GALD,MAKO,IAAI,CAACA,YAAL,EAAmB;AACzBC,YAAS,EAAT;AAEA,GAHM,MAGA,IAAI,OAAOD,YAAP,KAAwB,QAAxB,IAAoCG,MAAMC,OAAN,CAAcJ,YAAd,CAAxC,EAAqE;AAC3E,SAAM,IAAIK,SAAJ,CAAc,iCAAd,CAAN;AACA;;AAED,MAAI,CAACJ,OAAOC,IAAR,IAAgB,OAAOD,OAAOC,IAAd,KAAuB,QAA3C,EAAqD;AACpD,SAAMG,UAAU,iDAAV,CAAN;AACA;;AAED;AACA,MAAIC,IAAIL,OAAOC,IAAP,CAAYK,KAAZ,CAAkBX,cAAlB,CAAR;AACA,MAAIU,CAAJ,EAAO;AACN,OAAIL,OAAOO,QAAP,KAAoBC,SAApB,IAAiCH,EAAE,CAAF,CAArC,EAA2C;AAC1CL,WAAOO,QAAP,GAAkB,IAAlB;AACA;AACDP,UAAOC,IAAP,GAAc,CAACI,EAAE,CAAF,KAAQA,EAAE,CAAF,CAAT,EAAeI,IAAf,MAAyBJ,EAAE,CAAF,KAAQ,EAAjC,CAAd;AACA;;AAED;AACAA,MAAIL,OAAOC,IAAP,CAAYK,KAAZ,CAAkBV,cAAlB,CAAJ;AACA,MAAIS,CAAJ,EAAO;AACN,OAAIL,OAAOU,QAAP,KAAoBF,SAAxB,EAAmC;AAClCR,WAAOU,QAAP,GAAkB,IAAlB;AACA;AACDV,UAAOC,IAAP,GAAcI,EAAE,CAAF,EAAKI,IAAL,EAAd;AACA;;AAEDE,SAAOC,MAAP,CAAc,IAAd,EAAoBZ,MAApB;;AAEA;;AAEA,OAAKa,MAAL,GAAgB,CAAC,CAACb,OAAOa,MAAzB;AACA,OAAKN,QAAL,GAAgB,CAAC,CAACP,OAAOO,QAAzB;AACA,OAAKO,IAAL,GAAgB,sBAAUd,OAAOc,IAAjB,EAAuB,QAAvB,CAAhB;AACA;;AAED;;;;;;;AAOAC,WAAUC,KAAV,EAAiB;AAChBA,UAAQ,2BAAeA,KAAf,EAAsB,KAAKF,IAA3B,CAAR;;AAEA,UAAQ,KAAKA,IAAb;AACC,QAAK,aAAL;AACA,QAAK,KAAL;AACA,QAAK,QAAL;AACC,QAAI,KAAKG,GAAL,KAAa,IAAb,IAAqBD,QAAQ,KAAKC,GAAtC,EAA2C;AAC1C,WAAM,IAAIC,KAAJ,CAAW,0CAAyC,KAAKD,GAAI,EAA7D,CAAN;AACA;AACD,QAAI,KAAKE,GAAL,KAAa,IAAb,IAAqBH,QAAQ,KAAKG,GAAtC,EAA2C;AAC1C,WAAM,IAAID,KAAJ,CAAW,uCAAsC,KAAKC,GAAI,EAA1D,CAAN;AACA;AACD;AAVF;;AAaA,SAAOH,KAAP;AACA;AAnG4B;kBAATnB,Q","file":"argument.js","sourcesContent":["import { checkType, transformValue } from './types';\n\n/**\n * Tests if the name contains the required sequence (`<` and `>`).\n * @type {RegExp}\n */\nconst requiredRegExp = /^\\s*(?:<(.+)>|\\[(.+)\\])\\s*(\\.\\.\\.\\s*)?$/;\n\n/**\n * Tests if the name contains the multiple sequence.\n * @type {RegExp}\n */\nconst multipleRegExp = /^(.*)\\.\\.\\.\\s*$/;\n\n/**\n * Defines a argument.\n */\nexport default class Argument {\n\t/**\n\t * Creates an argument descriptor.\n\t *\n\t * @param {String|Object} [nameOrParams] - Various parameters. If value is a `String`, then see\n\t * `params.name` below for usage.\n\t * @param {Function} [params.callback] - A function to call when the argument has been\n\t * processed. This happens parsing is complete.\n\t * @param {String} [params.desc] - The description of the argument used in the help output.\n\t * @param {Boolean} [params.hidden=false] - When `true`, the argument is not displayed on the\n\t * help screen or auto-suggest.\n\t * @param {Boolean} [params.multiple=false] - When `true`, the value becomes an array with all\n\t * remaining parsed arguments. Any subsequent argument definitions after a `multiple` argument\n\t * are ignored.\n\t * @param {String} [params.name] - The name of the argument. If the name is wrapped in angle\n\t * brackets (`<`, `>`), then the brackets are trimmed off and the argument is flagged as\n\t * required (unless `params.required` is explicitly set to `false`). If the name is wrapped in\n\t * square brackets (`[`, `]`), then the brackets are trimmed off. If the name ends with `...`\n\t * and `params.multiple` is not specified, then it will set `params.multiple` to `true`.\n\t * @param {Boolean} [params.regex] - A regular expression used to validate the value.\n\t * @param {Boolean} [params.required=false] - Marks the option value as required.\n\t * @param {String} [params.type] - The argument type to coerce the data type into.\n\t * @access public\n\t */\n\tconstructor(nameOrParams) {\n\t\t/*\n\t\t{ name: 'path', required: true, regex: /^\\//, desc: 'the path to request' },\n\t\t{ name: 'json', type: 'json', desc: 'an option JSON payload to send' }\n\t\t*/\n\n\t\tlet params = nameOrParams;\n\n\t\tif (typeof nameOrParams === 'string') {\n\t\t\tparams = {\n\t\t\t\tname: nameOrParams\n\t\t\t};\n\n\t\t} else if (!nameOrParams) {\n\t\t\tparams = {};\n\n\t\t} else if (typeof nameOrParams !== 'object' || Array.isArray(nameOrParams)) {\n\t\t\tthrow new TypeError('Expected params to be an object');\n\t\t}\n\n\t\tif (!params.name || typeof params.name !== 'string') {\n\t\t\tthrow TypeError('Expected argument name to be a non-empty string');\n\t\t}\n\n\t\t// check if the name contains a required sequence\n\t\tlet m = params.name.match(requiredRegExp);\n\t\tif (m) {\n\t\t\tif (params.required === undefined && m[1]) {\n\t\t\t\tparams.required = true;\n\t\t\t}\n\t\t\tparams.name = (m[1] || m[2]).trim() + (m[3] || '');\n\t\t}\n\n\t\t// check if the name contains a multiple sequence\n\t\tm = params.name.match(multipleRegExp);\n\t\tif (m) {\n\t\t\tif (params.multiple === undefined) {\n\t\t\t\tparams.multiple = true;\n\t\t\t}\n\t\t\tparams.name = m[1].trim();\n\t\t}\n\n\t\tObject.assign(this, params);\n\n\t\t// TODO: params.regex\n\n\t\tthis.hidden   = !!params.hidden;\n\t\tthis.required = !!params.required;\n\t\tthis.type     = checkType(params.type, 'string');\n\t}\n\n\t/**\n\t * Transforms the given argument value based on its type.\n\t *\n\t * @param {*} value - The value to transform.\n\t * @returns {*}\n\t * @access public\n\t */\n\ttransform(value) {\n\t\tvalue = transformValue(value, this.type);\n\n\t\tswitch (this.type) {\n\t\t\tcase 'positiveInt':\n\t\t\tcase 'int':\n\t\t\tcase 'number':\n\t\t\t\tif (this.min !== null && value < this.min) {\n\t\t\t\t\tthrow new Error(`Value must be greater than or equal to ${this.min}`);\n\t\t\t\t}\n\t\t\t\tif (this.max !== null && value > this.max) {\n\t\t\t\t\tthrow new Error(`Value must be less than or equal to ${this.max}`);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn value;\n\t}\n}\n"]} |
{ | ||
"name": "cli-kit", | ||
"version": "0.0.10", | ||
"version": "0.0.11", | ||
"description": "Everything you need to create awesome command line interfaces", | ||
@@ -72,3 +72,3 @@ "main": "./dist/index.js", | ||
"gulp-util": "^3.0.8", | ||
"mocha": "^5.0.0", | ||
"mocha": "^5.0.1", | ||
"nyc": "^11.4.1", | ||
@@ -75,0 +75,0 @@ "sinon": "^4.3.0", |
@@ -104,2 +104,5 @@ > Note: cli-kit is under development. | ||
// When `true`, captures all subsequent argument values into an array | ||
multiple: false, | ||
// Overrides the brackets and forces the argument to be required or optional. | ||
@@ -110,3 +113,6 @@ required: false, | ||
type: 'string' | ||
} | ||
}, | ||
// Adding `...` will capture all subsequent argument values into an array | ||
'arg4...' | ||
], | ||
@@ -113,0 +119,0 @@ |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
AI-detected possible typosquat
Supply chain riskAI has identified this package as a potential typosquat of a more popular package. This suggests that the package may be intentionally mimicking another package's name, description, or other metadata.
Found 1 instance in 1 package
319771
1326
304
0