ahmad-module 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ahmad-module might be problematic. Click here for more details.

Files changed (759) hide show
  1. package/.bin/sshpk-conv +12 -0
  2. package/.bin/sshpk-conv.cmd +17 -0
  3. package/.bin/sshpk-conv.ps1 +28 -0
  4. package/.bin/sshpk-sign +12 -0
  5. package/.bin/sshpk-sign.cmd +17 -0
  6. package/.bin/sshpk-sign.ps1 +28 -0
  7. package/.bin/sshpk-verify +12 -0
  8. package/.bin/sshpk-verify.cmd +17 -0
  9. package/.bin/sshpk-verify.ps1 +28 -0
  10. package/.bin/uuid +12 -0
  11. package/.bin/uuid.cmd +17 -0
  12. package/.bin/uuid.ps1 +28 -0
  13. package/ajv/.tonic_example.js +20 -0
  14. package/ajv/LICENSE +22 -0
  15. package/ajv/README.md +1497 -0
  16. package/ajv/dist/ajv.bundle.js +7189 -0
  17. package/ajv/dist/ajv.min.js +3 -0
  18. package/ajv/dist/ajv.min.js.map +1 -0
  19. package/ajv/lib/ajv.d.ts +397 -0
  20. package/ajv/lib/ajv.js +506 -0
  21. package/ajv/lib/cache.js +26 -0
  22. package/ajv/lib/compile/async.js +90 -0
  23. package/ajv/lib/compile/equal.js +5 -0
  24. package/ajv/lib/compile/error_classes.js +34 -0
  25. package/ajv/lib/compile/formats.js +142 -0
  26. package/ajv/lib/compile/index.js +387 -0
  27. package/ajv/lib/compile/resolve.js +270 -0
  28. package/ajv/lib/compile/rules.js +66 -0
  29. package/ajv/lib/compile/schema_obj.js +9 -0
  30. package/ajv/lib/compile/ucs2length.js +20 -0
  31. package/ajv/lib/compile/util.js +239 -0
  32. package/ajv/lib/data.js +49 -0
  33. package/ajv/lib/definition_schema.js +37 -0
  34. package/ajv/lib/dot/_limit.jst +113 -0
  35. package/ajv/lib/dot/_limitItems.jst +12 -0
  36. package/ajv/lib/dot/_limitLength.jst +12 -0
  37. package/ajv/lib/dot/_limitProperties.jst +12 -0
  38. package/ajv/lib/dot/allOf.jst +32 -0
  39. package/ajv/lib/dot/anyOf.jst +46 -0
  40. package/ajv/lib/dot/coerce.def +51 -0
  41. package/ajv/lib/dot/comment.jst +9 -0
  42. package/ajv/lib/dot/const.jst +11 -0
  43. package/ajv/lib/dot/contains.jst +55 -0
  44. package/ajv/lib/dot/custom.jst +191 -0
  45. package/ajv/lib/dot/defaults.def +47 -0
  46. package/ajv/lib/dot/definitions.def +203 -0
  47. package/ajv/lib/dot/dependencies.jst +79 -0
  48. package/ajv/lib/dot/enum.jst +30 -0
  49. package/ajv/lib/dot/errors.def +194 -0
  50. package/ajv/lib/dot/format.jst +106 -0
  51. package/ajv/lib/dot/if.jst +73 -0
  52. package/ajv/lib/dot/items.jst +98 -0
  53. package/ajv/lib/dot/missing.def +39 -0
  54. package/ajv/lib/dot/multipleOf.jst +22 -0
  55. package/ajv/lib/dot/not.jst +43 -0
  56. package/ajv/lib/dot/oneOf.jst +54 -0
  57. package/ajv/lib/dot/pattern.jst +14 -0
  58. package/ajv/lib/dot/properties.jst +245 -0
  59. package/ajv/lib/dot/propertyNames.jst +52 -0
  60. package/ajv/lib/dot/ref.jst +85 -0
  61. package/ajv/lib/dot/required.jst +108 -0
  62. package/ajv/lib/dot/uniqueItems.jst +62 -0
  63. package/ajv/lib/dot/validate.jst +276 -0
  64. package/ajv/lib/dotjs/README.md +3 -0
  65. package/ajv/lib/dotjs/_limit.js +163 -0
  66. package/ajv/lib/dotjs/_limitItems.js +80 -0
  67. package/ajv/lib/dotjs/_limitLength.js +85 -0
  68. package/ajv/lib/dotjs/_limitProperties.js +80 -0
  69. package/ajv/lib/dotjs/allOf.js +42 -0
  70. package/ajv/lib/dotjs/anyOf.js +73 -0
  71. package/ajv/lib/dotjs/comment.js +14 -0
  72. package/ajv/lib/dotjs/const.js +56 -0
  73. package/ajv/lib/dotjs/contains.js +81 -0
  74. package/ajv/lib/dotjs/custom.js +228 -0
  75. package/ajv/lib/dotjs/dependencies.js +168 -0
  76. package/ajv/lib/dotjs/enum.js +66 -0
  77. package/ajv/lib/dotjs/format.js +150 -0
  78. package/ajv/lib/dotjs/if.js +103 -0
  79. package/ajv/lib/dotjs/index.js +33 -0
  80. package/ajv/lib/dotjs/items.js +140 -0
  81. package/ajv/lib/dotjs/multipleOf.js +80 -0
  82. package/ajv/lib/dotjs/not.js +84 -0
  83. package/ajv/lib/dotjs/oneOf.js +73 -0
  84. package/ajv/lib/dotjs/pattern.js +75 -0
  85. package/ajv/lib/dotjs/properties.js +335 -0
  86. package/ajv/lib/dotjs/propertyNames.js +81 -0
  87. package/ajv/lib/dotjs/ref.js +124 -0
  88. package/ajv/lib/dotjs/required.js +270 -0
  89. package/ajv/lib/dotjs/uniqueItems.js +86 -0
  90. package/ajv/lib/dotjs/validate.js +482 -0
  91. package/ajv/lib/keyword.js +146 -0
  92. package/ajv/lib/refs/data.json +17 -0
  93. package/ajv/lib/refs/json-schema-draft-04.json +149 -0
  94. package/ajv/lib/refs/json-schema-draft-06.json +154 -0
  95. package/ajv/lib/refs/json-schema-draft-07.json +168 -0
  96. package/ajv/lib/refs/json-schema-secure.json +94 -0
  97. package/ajv/package.json +106 -0
  98. package/ajv/scripts/.eslintrc.yml +3 -0
  99. package/ajv/scripts/bundle.js +61 -0
  100. package/ajv/scripts/compile-dots.js +73 -0
  101. package/ajv/scripts/info +10 -0
  102. package/ajv/scripts/prepare-tests +12 -0
  103. package/ajv/scripts/publish-built-version +32 -0
  104. package/ajv/scripts/travis-gh-pages +23 -0
  105. package/asn1/Jenkinsfile +65 -0
  106. package/asn1/LICENSE +19 -0
  107. package/asn1/README.md +50 -0
  108. package/asn1/lib/ber/errors.js +13 -0
  109. package/asn1/lib/ber/index.js +27 -0
  110. package/asn1/lib/ber/reader.js +262 -0
  111. package/asn1/lib/ber/types.js +36 -0
  112. package/asn1/lib/ber/writer.js +317 -0
  113. package/asn1/lib/index.js +20 -0
  114. package/asn1/package.json +31 -0
  115. package/assert-plus/AUTHORS +6 -0
  116. package/assert-plus/CHANGES.md +14 -0
  117. package/assert-plus/README.md +162 -0
  118. package/assert-plus/assert.js +211 -0
  119. package/assert-plus/package.json +23 -0
  120. package/asynckit/LICENSE +21 -0
  121. package/asynckit/README.md +233 -0
  122. package/asynckit/bench.js +76 -0
  123. package/asynckit/index.js +6 -0
  124. package/asynckit/lib/abort.js +29 -0
  125. package/asynckit/lib/async.js +34 -0
  126. package/asynckit/lib/defer.js +26 -0
  127. package/asynckit/lib/iterate.js +75 -0
  128. package/asynckit/lib/readable_asynckit.js +91 -0
  129. package/asynckit/lib/readable_parallel.js +25 -0
  130. package/asynckit/lib/readable_serial.js +25 -0
  131. package/asynckit/lib/readable_serial_ordered.js +29 -0
  132. package/asynckit/lib/state.js +37 -0
  133. package/asynckit/lib/streamify.js +141 -0
  134. package/asynckit/lib/terminator.js +29 -0
  135. package/asynckit/package.json +63 -0
  136. package/asynckit/parallel.js +43 -0
  137. package/asynckit/serial.js +17 -0
  138. package/asynckit/serialOrdered.js +75 -0
  139. package/asynckit/stream.js +21 -0
  140. package/aws-sign2/LICENSE +55 -0
  141. package/aws-sign2/README.md +4 -0
  142. package/aws-sign2/index.js +212 -0
  143. package/aws-sign2/package.json +17 -0
  144. package/aws4/.github/FUNDING.yml +3 -0
  145. package/aws4/.travis.yml +9 -0
  146. package/aws4/LICENSE +19 -0
  147. package/aws4/README.md +183 -0
  148. package/aws4/aws4.js +373 -0
  149. package/aws4/lru.js +96 -0
  150. package/aws4/package.json +17 -0
  151. package/axios/CHANGELOG.md +775 -0
  152. package/axios/LICENSE +19 -0
  153. package/axios/README.md +868 -0
  154. package/axios/SECURITY.md +5 -0
  155. package/axios/UPGRADE_GUIDE.md +162 -0
  156. package/axios/dist/axios.js +2193 -0
  157. package/axios/dist/axios.map +1 -0
  158. package/axios/dist/axios.min.js +3 -0
  159. package/axios/dist/axios.min.map +1 -0
  160. package/axios/index.d.ts +168 -0
  161. package/axios/index.js +1 -0
  162. package/axios/lib/adapters/README.md +37 -0
  163. package/axios/lib/adapters/http.js +331 -0
  164. package/axios/lib/adapters/xhr.js +189 -0
  165. package/axios/lib/axios.js +56 -0
  166. package/axios/lib/cancel/Cancel.js +19 -0
  167. package/axios/lib/cancel/CancelToken.js +57 -0
  168. package/axios/lib/cancel/isCancel.js +5 -0
  169. package/axios/lib/core/Axios.js +148 -0
  170. package/axios/lib/core/InterceptorManager.js +54 -0
  171. package/axios/lib/core/README.md +8 -0
  172. package/axios/lib/core/buildFullPath.js +20 -0
  173. package/axios/lib/core/createError.js +18 -0
  174. package/axios/lib/core/dispatchRequest.js +82 -0
  175. package/axios/lib/core/enhanceError.js +42 -0
  176. package/axios/lib/core/mergeConfig.js +87 -0
  177. package/axios/lib/core/settle.js +25 -0
  178. package/axios/lib/core/transformData.js +22 -0
  179. package/axios/lib/defaults.js +134 -0
  180. package/axios/lib/helpers/README.md +7 -0
  181. package/axios/lib/helpers/bind.js +11 -0
  182. package/axios/lib/helpers/buildURL.js +70 -0
  183. package/axios/lib/helpers/combineURLs.js +14 -0
  184. package/axios/lib/helpers/cookies.js +53 -0
  185. package/axios/lib/helpers/deprecatedMethod.js +24 -0
  186. package/axios/lib/helpers/isAbsoluteURL.js +14 -0
  187. package/axios/lib/helpers/isAxiosError.js +11 -0
  188. package/axios/lib/helpers/isURLSameOrigin.js +68 -0
  189. package/axios/lib/helpers/normalizeHeaderName.js +12 -0
  190. package/axios/lib/helpers/parseHeaders.js +53 -0
  191. package/axios/lib/helpers/spread.js +27 -0
  192. package/axios/lib/helpers/validator.js +105 -0
  193. package/axios/lib/utils.js +349 -0
  194. package/axios/package.json +84 -0
  195. package/bcrypt-pbkdf/CONTRIBUTING.md +13 -0
  196. package/bcrypt-pbkdf/LICENSE +66 -0
  197. package/bcrypt-pbkdf/README.md +45 -0
  198. package/bcrypt-pbkdf/index.js +556 -0
  199. package/bcrypt-pbkdf/package.json +15 -0
  200. package/caseless/LICENSE +28 -0
  201. package/caseless/README.md +45 -0
  202. package/caseless/index.js +67 -0
  203. package/caseless/package.json +27 -0
  204. package/caseless/test.js +67 -0
  205. package/combined-stream/License +19 -0
  206. package/combined-stream/Readme.md +138 -0
  207. package/combined-stream/lib/combined_stream.js +208 -0
  208. package/combined-stream/package.json +25 -0
  209. package/combined-stream/yarn.lock +17 -0
  210. package/core-util-is/LICENSE +19 -0
  211. package/core-util-is/README.md +3 -0
  212. package/core-util-is/float.patch +604 -0
  213. package/core-util-is/lib/util.js +107 -0
  214. package/core-util-is/package.json +32 -0
  215. package/core-util-is/test.js +68 -0
  216. package/dashdash/CHANGES.md +364 -0
  217. package/dashdash/LICENSE.txt +24 -0
  218. package/dashdash/README.md +574 -0
  219. package/dashdash/etc/dashdash.bash_completion.in +389 -0
  220. package/dashdash/lib/dashdash.js +1055 -0
  221. package/dashdash/package.json +26 -0
  222. package/delayed-stream/License +19 -0
  223. package/delayed-stream/Makefile +7 -0
  224. package/delayed-stream/Readme.md +141 -0
  225. package/delayed-stream/lib/delayed_stream.js +107 -0
  226. package/delayed-stream/package.json +27 -0
  227. package/ecc-jsbn/LICENSE +21 -0
  228. package/ecc-jsbn/README.md +8 -0
  229. package/ecc-jsbn/index.js +58 -0
  230. package/ecc-jsbn/lib/LICENSE-jsbn +40 -0
  231. package/ecc-jsbn/lib/ec.js +561 -0
  232. package/ecc-jsbn/lib/sec.js +170 -0
  233. package/ecc-jsbn/package.json +40 -0
  234. package/ecc-jsbn/test.js +14 -0
  235. package/extend/.editorconfig +20 -0
  236. package/extend/.eslintrc +17 -0
  237. package/extend/.jscs.json +175 -0
  238. package/extend/.travis.yml +230 -0
  239. package/extend/CHANGELOG.md +83 -0
  240. package/extend/LICENSE +23 -0
  241. package/extend/README.md +81 -0
  242. package/extend/component.json +32 -0
  243. package/extend/index.js +117 -0
  244. package/extend/package.json +42 -0
  245. package/extsprintf/.gitmodules +0 -0
  246. package/extsprintf/LICENSE +19 -0
  247. package/extsprintf/Makefile +24 -0
  248. package/extsprintf/Makefile.targ +285 -0
  249. package/extsprintf/README.md +46 -0
  250. package/extsprintf/jsl.node.conf +137 -0
  251. package/extsprintf/lib/extsprintf.js +183 -0
  252. package/extsprintf/package.json +14 -0
  253. package/fast-deep-equal/LICENSE +21 -0
  254. package/fast-deep-equal/README.md +96 -0
  255. package/fast-deep-equal/es6/index.d.ts +2 -0
  256. package/fast-deep-equal/es6/index.js +72 -0
  257. package/fast-deep-equal/es6/react.d.ts +2 -0
  258. package/fast-deep-equal/es6/react.js +79 -0
  259. package/fast-deep-equal/index.d.ts +4 -0
  260. package/fast-deep-equal/index.js +46 -0
  261. package/fast-deep-equal/package.json +61 -0
  262. package/fast-deep-equal/react.d.ts +2 -0
  263. package/fast-deep-equal/react.js +53 -0
  264. package/fast-json-stable-stringify/.eslintrc.yml +26 -0
  265. package/fast-json-stable-stringify/.github/FUNDING.yml +1 -0
  266. package/fast-json-stable-stringify/.travis.yml +8 -0
  267. package/fast-json-stable-stringify/LICENSE +21 -0
  268. package/fast-json-stable-stringify/README.md +131 -0
  269. package/fast-json-stable-stringify/benchmark/index.js +31 -0
  270. package/fast-json-stable-stringify/benchmark/test.json +137 -0
  271. package/fast-json-stable-stringify/example/key_cmp.js +7 -0
  272. package/fast-json-stable-stringify/example/nested.js +3 -0
  273. package/fast-json-stable-stringify/example/str.js +3 -0
  274. package/fast-json-stable-stringify/example/value_cmp.js +7 -0
  275. package/fast-json-stable-stringify/index.d.ts +4 -0
  276. package/fast-json-stable-stringify/index.js +59 -0
  277. package/fast-json-stable-stringify/package.json +52 -0
  278. package/fast-json-stable-stringify/test/cmp.js +13 -0
  279. package/fast-json-stable-stringify/test/nested.js +44 -0
  280. package/fast-json-stable-stringify/test/str.js +46 -0
  281. package/fast-json-stable-stringify/test/to-json.js +22 -0
  282. package/follow-redirects/LICENSE +18 -0
  283. package/follow-redirects/README.md +155 -0
  284. package/follow-redirects/debug.js +15 -0
  285. package/follow-redirects/http.js +1 -0
  286. package/follow-redirects/https.js +1 -0
  287. package/follow-redirects/index.js +598 -0
  288. package/follow-redirects/package.json +59 -0
  289. package/forever-agent/LICENSE +55 -0
  290. package/forever-agent/README.md +4 -0
  291. package/forever-agent/index.js +138 -0
  292. package/forever-agent/package.json +17 -0
  293. package/form-data/License +19 -0
  294. package/form-data/README.md +234 -0
  295. package/form-data/README.md.bak +234 -0
  296. package/form-data/lib/browser.js +2 -0
  297. package/form-data/lib/form_data.js +457 -0
  298. package/form-data/lib/populate.js +10 -0
  299. package/form-data/package.json +65 -0
  300. package/form-data/yarn.lock +2662 -0
  301. package/getpass/.travis.yml +9 -0
  302. package/getpass/LICENSE +18 -0
  303. package/getpass/README.md +32 -0
  304. package/getpass/lib/index.js +123 -0
  305. package/getpass/package.json +18 -0
  306. package/har-schema/LICENSE +13 -0
  307. package/har-schema/README.md +49 -0
  308. package/har-schema/lib/afterRequest.json +30 -0
  309. package/har-schema/lib/beforeRequest.json +30 -0
  310. package/har-schema/lib/browser.json +20 -0
  311. package/har-schema/lib/cache.json +21 -0
  312. package/har-schema/lib/content.json +29 -0
  313. package/har-schema/lib/cookie.json +36 -0
  314. package/har-schema/lib/creator.json +20 -0
  315. package/har-schema/lib/entry.json +53 -0
  316. package/har-schema/lib/har.json +13 -0
  317. package/har-schema/lib/header.json +20 -0
  318. package/har-schema/lib/index.js +22 -0
  319. package/har-schema/lib/log.json +36 -0
  320. package/har-schema/lib/page.json +32 -0
  321. package/har-schema/lib/pageTimings.json +18 -0
  322. package/har-schema/lib/postData.json +43 -0
  323. package/har-schema/lib/query.json +20 -0
  324. package/har-schema/lib/request.json +57 -0
  325. package/har-schema/lib/response.json +54 -0
  326. package/har-schema/lib/timings.json +42 -0
  327. package/har-schema/package.json +54 -0
  328. package/har-validator/LICENSE +9 -0
  329. package/har-validator/README.md +43 -0
  330. package/har-validator/lib/async.js +105 -0
  331. package/har-validator/lib/error.js +17 -0
  332. package/har-validator/lib/promise.js +102 -0
  333. package/har-validator/package.json +43 -0
  334. package/http-signature/.dir-locals.el +6 -0
  335. package/http-signature/CHANGES.md +46 -0
  336. package/http-signature/LICENSE +18 -0
  337. package/http-signature/README.md +79 -0
  338. package/http-signature/http_signing.md +363 -0
  339. package/http-signature/lib/index.js +29 -0
  340. package/http-signature/lib/parser.js +315 -0
  341. package/http-signature/lib/signer.js +401 -0
  342. package/http-signature/lib/utils.js +112 -0
  343. package/http-signature/lib/verify.js +88 -0
  344. package/http-signature/package.json +39 -0
  345. package/is-typedarray/LICENSE.md +18 -0
  346. package/is-typedarray/README.md +16 -0
  347. package/is-typedarray/index.js +41 -0
  348. package/is-typedarray/package.json +30 -0
  349. package/is-typedarray/test.js +34 -0
  350. package/isstream/.jshintrc +59 -0
  351. package/isstream/.travis.yml +12 -0
  352. package/isstream/LICENSE.md +11 -0
  353. package/isstream/README.md +66 -0
  354. package/isstream/isstream.js +27 -0
  355. package/isstream/package.json +33 -0
  356. package/isstream/test.js +168 -0
  357. package/jsbn/LICENSE +40 -0
  358. package/jsbn/README.md +175 -0
  359. package/jsbn/example.html +12 -0
  360. package/jsbn/example.js +3 -0
  361. package/jsbn/index.js +1357 -0
  362. package/jsbn/package.json +21 -0
  363. package/json-schema/LICENSE +195 -0
  364. package/json-schema/README.md +3 -0
  365. package/json-schema/lib/links.js +65 -0
  366. package/json-schema/lib/validate.js +271 -0
  367. package/json-schema/package.json +24 -0
  368. package/json-schema-traverse/.eslintrc.yml +27 -0
  369. package/json-schema-traverse/.travis.yml +8 -0
  370. package/json-schema-traverse/LICENSE +21 -0
  371. package/json-schema-traverse/README.md +83 -0
  372. package/json-schema-traverse/index.js +89 -0
  373. package/json-schema-traverse/package.json +43 -0
  374. package/json-schema-traverse/spec/.eslintrc.yml +6 -0
  375. package/json-schema-traverse/spec/fixtures/schema.js +125 -0
  376. package/json-schema-traverse/spec/index.spec.js +171 -0
  377. package/json-stringify-safe/CHANGELOG.md +14 -0
  378. package/json-stringify-safe/LICENSE +15 -0
  379. package/json-stringify-safe/Makefile +35 -0
  380. package/json-stringify-safe/README.md +52 -0
  381. package/json-stringify-safe/package.json +31 -0
  382. package/json-stringify-safe/stringify.js +27 -0
  383. package/json-stringify-safe/test/mocha.opts +2 -0
  384. package/json-stringify-safe/test/stringify_test.js +246 -0
  385. package/jsprim/CHANGES.md +53 -0
  386. package/jsprim/CONTRIBUTING.md +19 -0
  387. package/jsprim/LICENSE +19 -0
  388. package/jsprim/README.md +287 -0
  389. package/jsprim/lib/jsprim.js +735 -0
  390. package/jsprim/package.json +20 -0
  391. package/m3u8stream/LICENSE +21 -0
  392. package/m3u8stream/README.md +81 -0
  393. package/m3u8stream/dist/dash-mpd-parser.d.ts +11 -0
  394. package/m3u8stream/dist/dash-mpd-parser.js +183 -0
  395. package/m3u8stream/dist/dash-mpd-parser.js.map +1 -0
  396. package/m3u8stream/dist/index.d.ts +31 -0
  397. package/m3u8stream/dist/index.js +180 -0
  398. package/m3u8stream/dist/index.js.map +1 -0
  399. package/m3u8stream/dist/m3u8-parser.d.ts +18 -0
  400. package/m3u8stream/dist/m3u8-parser.js +111 -0
  401. package/m3u8stream/dist/m3u8-parser.js.map +1 -0
  402. package/m3u8stream/dist/parse-time.d.ts +16 -0
  403. package/m3u8stream/dist/parse-time.js +59 -0
  404. package/m3u8stream/dist/parse-time.js.map +1 -0
  405. package/m3u8stream/dist/parser.d.ts +19 -0
  406. package/m3u8stream/dist/parser.js +3 -0
  407. package/m3u8stream/dist/parser.js.map +1 -0
  408. package/m3u8stream/dist/queue.d.ts +39 -0
  409. package/m3u8stream/dist/queue.js +58 -0
  410. package/m3u8stream/dist/queue.js.map +1 -0
  411. package/m3u8stream/node_modules/sax/LICENSE +41 -0
  412. package/m3u8stream/node_modules/sax/README.md +225 -0
  413. package/m3u8stream/node_modules/sax/lib/sax.js +1565 -0
  414. package/m3u8stream/node_modules/sax/package.json +25 -0
  415. package/m3u8stream/package.json +54 -0
  416. package/mime-db/HISTORY.md +507 -0
  417. package/mime-db/LICENSE +23 -0
  418. package/mime-db/README.md +100 -0
  419. package/mime-db/db.json +8519 -0
  420. package/mime-db/index.js +12 -0
  421. package/mime-db/package.json +60 -0
  422. package/mime-types/HISTORY.md +397 -0
  423. package/mime-types/LICENSE +23 -0
  424. package/mime-types/README.md +113 -0
  425. package/mime-types/index.js +188 -0
  426. package/mime-types/package.json +44 -0
  427. package/miniget/LICENSE +21 -0
  428. package/miniget/README.md +111 -0
  429. package/miniget/dist/index.d.ts +65 -0
  430. package/miniget/dist/index.js +281 -0
  431. package/miniget/dist/index.js.map +1 -0
  432. package/miniget/package.json +49 -0
  433. package/oauth-sign/LICENSE +55 -0
  434. package/oauth-sign/README.md +11 -0
  435. package/oauth-sign/index.js +146 -0
  436. package/oauth-sign/package.json +23 -0
  437. package/package.json +11 -0
  438. package/performance-now/.tm_properties +7 -0
  439. package/performance-now/.travis.yml +6 -0
  440. package/performance-now/README.md +30 -0
  441. package/performance-now/lib/performance-now.js +36 -0
  442. package/performance-now/lib/performance-now.js.map +10 -0
  443. package/performance-now/license.txt +7 -0
  444. package/performance-now/package.json +35 -0
  445. package/performance-now/src/index.d.ts +8 -0
  446. package/performance-now/src/performance-now.coffee +17 -0
  447. package/performance-now/test/mocha.opts +3 -0
  448. package/performance-now/test/performance-now.coffee +43 -0
  449. package/performance-now/test/scripts/delayed-call.coffee +11 -0
  450. package/performance-now/test/scripts/delayed-require.coffee +12 -0
  451. package/performance-now/test/scripts/difference.coffee +6 -0
  452. package/performance-now/test/scripts/initial-value.coffee +10 -0
  453. package/performance-now/test/scripts.coffee +27 -0
  454. package/psl/.env +0 -0
  455. package/psl/LICENSE +9 -0
  456. package/psl/README.md +211 -0
  457. package/psl/browserstack-logo.svg +90 -0
  458. package/psl/data/rules.json +9376 -0
  459. package/psl/dist/psl.js +10187 -0
  460. package/psl/dist/psl.min.js +1 -0
  461. package/psl/index.js +269 -0
  462. package/psl/package.json +43 -0
  463. package/punycode/LICENSE-MIT.txt +20 -0
  464. package/punycode/README.md +122 -0
  465. package/punycode/package.json +58 -0
  466. package/punycode/punycode.es6.js +441 -0
  467. package/punycode/punycode.js +440 -0
  468. package/qs/.editorconfig +43 -0
  469. package/qs/.eslintrc +37 -0
  470. package/qs/.github/FUNDING.yml +12 -0
  471. package/qs/.nycrc +13 -0
  472. package/qs/CHANGELOG.md +250 -0
  473. package/qs/LICENSE.md +29 -0
  474. package/qs/README.md +510 -0
  475. package/qs/bower.json +21 -0
  476. package/qs/component.json +15 -0
  477. package/qs/dist/qs.js +648 -0
  478. package/qs/lib/formats.js +18 -0
  479. package/qs/lib/index.js +11 -0
  480. package/qs/lib/parse.js +175 -0
  481. package/qs/lib/stringify.js +217 -0
  482. package/qs/lib/utils.js +215 -0
  483. package/qs/package.json +54 -0
  484. package/qs/test/index.js +7 -0
  485. package/qs/test/parse.js +649 -0
  486. package/qs/test/stringify.js +642 -0
  487. package/qs/test/utils.js +65 -0
  488. package/request/CHANGELOG.md +717 -0
  489. package/request/LICENSE +55 -0
  490. package/request/README.md +1133 -0
  491. package/request/index.js +155 -0
  492. package/request/lib/auth.js +167 -0
  493. package/request/lib/cookies.js +38 -0
  494. package/request/lib/getProxyFromURI.js +79 -0
  495. package/request/lib/har.js +205 -0
  496. package/request/lib/hawk.js +89 -0
  497. package/request/lib/helpers.js +66 -0
  498. package/request/lib/multipart.js +112 -0
  499. package/request/lib/oauth.js +148 -0
  500. package/request/lib/querystring.js +50 -0
  501. package/request/lib/redirect.js +154 -0
  502. package/request/lib/tunnel.js +175 -0
  503. package/request/package.json +86 -0
  504. package/request/request.js +1553 -0
  505. package/safe-buffer/LICENSE +21 -0
  506. package/safe-buffer/README.md +584 -0
  507. package/safe-buffer/index.d.ts +187 -0
  508. package/safe-buffer/index.js +65 -0
  509. package/safe-buffer/package.json +51 -0
  510. package/safer-buffer/LICENSE +21 -0
  511. package/safer-buffer/Porting-Buffer.md +268 -0
  512. package/safer-buffer/Readme.md +156 -0
  513. package/safer-buffer/dangerous.js +58 -0
  514. package/safer-buffer/package.json +34 -0
  515. package/safer-buffer/safer.js +77 -0
  516. package/safer-buffer/tests.js +406 -0
  517. package/sax/AUTHORS +10 -0
  518. package/sax/LICENSE +32 -0
  519. package/sax/LICENSE-W3C.html +188 -0
  520. package/sax/README.md +216 -0
  521. package/sax/component.json +12 -0
  522. package/sax/examples/big-not-pretty.xml +8002 -0
  523. package/sax/examples/example.js +29 -0
  524. package/sax/examples/get-products.js +58 -0
  525. package/sax/examples/hello-world.js +4 -0
  526. package/sax/examples/not-pretty.xml +8 -0
  527. package/sax/examples/pretty-print.js +74 -0
  528. package/sax/examples/shopping.xml +2 -0
  529. package/sax/examples/strict.dtd +870 -0
  530. package/sax/examples/test.html +15 -0
  531. package/sax/examples/test.xml +1254 -0
  532. package/sax/lib/sax.js +1355 -0
  533. package/sax/package.json +12 -0
  534. package/sax/test/attribute-name.js +33 -0
  535. package/sax/test/attribute-no-space.js +75 -0
  536. package/sax/test/buffer-overrun.js +26 -0
  537. package/sax/test/case.js +50 -0
  538. package/sax/test/cdata-chunked.js +11 -0
  539. package/sax/test/cdata-end-split.js +15 -0
  540. package/sax/test/cdata-fake-end.js +28 -0
  541. package/sax/test/cdata-multiple.js +15 -0
  542. package/sax/test/cdata.js +10 -0
  543. package/sax/test/cyrillic.js +8 -0
  544. package/sax/test/duplicate-attribute.js +13 -0
  545. package/sax/test/end_empty_stream.js +5 -0
  546. package/sax/test/entities.js +10 -0
  547. package/sax/test/entity-mega.js +16 -0
  548. package/sax/test/flush.js +13 -0
  549. package/sax/test/index.js +86 -0
  550. package/sax/test/issue-23.js +43 -0
  551. package/sax/test/issue-30.js +24 -0
  552. package/sax/test/issue-35.js +15 -0
  553. package/sax/test/issue-47.js +12 -0
  554. package/sax/test/issue-49.js +31 -0
  555. package/sax/test/issue-84.js +13 -0
  556. package/sax/test/parser-position.js +28 -0
  557. package/sax/test/script-close-better.js +12 -0
  558. package/sax/test/script.js +12 -0
  559. package/sax/test/self-closing-child-strict.js +44 -0
  560. package/sax/test/self-closing-child.js +44 -0
  561. package/sax/test/self-closing-tag.js +25 -0
  562. package/sax/test/stray-ending.js +17 -0
  563. package/sax/test/trailing-attribute-no-value.js +10 -0
  564. package/sax/test/trailing-non-whitespace.js +18 -0
  565. package/sax/test/unclosed-root.js +11 -0
  566. package/sax/test/unquoted.js +18 -0
  567. package/sax/test/utf8-split.js +32 -0
  568. package/sax/test/xmlns-as-tag-name.js +15 -0
  569. package/sax/test/xmlns-issue-41.js +68 -0
  570. package/sax/test/xmlns-rebinding.js +63 -0
  571. package/sax/test/xmlns-strict.js +74 -0
  572. package/sax/test/xmlns-unbound-element.js +33 -0
  573. package/sax/test/xmlns-unbound.js +15 -0
  574. package/sax/test/xmlns-xml-default-ns.js +31 -0
  575. package/sax/test/xmlns-xml-default-prefix-attribute.js +36 -0
  576. package/sax/test/xmlns-xml-default-prefix.js +21 -0
  577. package/sax/test/xmlns-xml-default-redefine.js +41 -0
  578. package/simple-csv-reader/.editorconfig +8 -0
  579. package/simple-csv-reader/LICENSE +21 -0
  580. package/simple-csv-reader/README.md +32 -0
  581. package/simple-csv-reader/dist/simple-csv-reader.min.js +2 -0
  582. package/simple-csv-reader/dist/simple-csv-reader.min.js.map +1 -0
  583. package/simple-csv-reader/gulpfile.js +26 -0
  584. package/simple-csv-reader/index.js +131 -0
  585. package/simple-csv-reader/package.json +38 -0
  586. package/sshpk/.travis.yml +11 -0
  587. package/sshpk/Jenkinsfile +86 -0
  588. package/sshpk/LICENSE +18 -0
  589. package/sshpk/README.md +804 -0
  590. package/sshpk/bin/sshpk-conv +243 -0
  591. package/sshpk/bin/sshpk-sign +191 -0
  592. package/sshpk/bin/sshpk-verify +167 -0
  593. package/sshpk/lib/algs.js +168 -0
  594. package/sshpk/lib/certificate.js +410 -0
  595. package/sshpk/lib/dhe.js +397 -0
  596. package/sshpk/lib/ed-compat.js +92 -0
  597. package/sshpk/lib/errors.js +84 -0
  598. package/sshpk/lib/fingerprint.js +220 -0
  599. package/sshpk/lib/formats/auto.js +124 -0
  600. package/sshpk/lib/formats/dnssec.js +287 -0
  601. package/sshpk/lib/formats/openssh-cert.js +352 -0
  602. package/sshpk/lib/formats/pem.js +290 -0
  603. package/sshpk/lib/formats/pkcs1.js +373 -0
  604. package/sshpk/lib/formats/pkcs8.js +631 -0
  605. package/sshpk/lib/formats/putty.js +194 -0
  606. package/sshpk/lib/formats/rfc4253.js +166 -0
  607. package/sshpk/lib/formats/ssh-private.js +262 -0
  608. package/sshpk/lib/formats/ssh.js +115 -0
  609. package/sshpk/lib/formats/x509-pem.js +88 -0
  610. package/sshpk/lib/formats/x509.js +752 -0
  611. package/sshpk/lib/identity.js +373 -0
  612. package/sshpk/lib/index.js +40 -0
  613. package/sshpk/lib/key.js +294 -0
  614. package/sshpk/lib/private-key.js +247 -0
  615. package/sshpk/lib/signature.js +314 -0
  616. package/sshpk/lib/ssh-buffer.js +149 -0
  617. package/sshpk/lib/utils.js +404 -0
  618. package/sshpk/man/man1/sshpk-conv.1 +135 -0
  619. package/sshpk/man/man1/sshpk-sign.1 +81 -0
  620. package/sshpk/man/man1/sshpk-verify.1 +68 -0
  621. package/sshpk/package.json +60 -0
  622. package/tough-cookie/LICENSE +12 -0
  623. package/tough-cookie/README.md +527 -0
  624. package/tough-cookie/lib/cookie.js +1482 -0
  625. package/tough-cookie/lib/memstore.js +181 -0
  626. package/tough-cookie/lib/pathMatch.js +61 -0
  627. package/tough-cookie/lib/permuteDomain.js +56 -0
  628. package/tough-cookie/lib/pubsuffix-psl.js +38 -0
  629. package/tough-cookie/lib/store.js +75 -0
  630. package/tough-cookie/lib/version.js +2 -0
  631. package/tough-cookie/package.json +78 -0
  632. package/tunnel-agent/LICENSE +55 -0
  633. package/tunnel-agent/README.md +4 -0
  634. package/tunnel-agent/index.js +244 -0
  635. package/tunnel-agent/package.json +22 -0
  636. package/tweetnacl/AUTHORS.md +28 -0
  637. package/tweetnacl/CHANGELOG.md +221 -0
  638. package/tweetnacl/LICENSE +24 -0
  639. package/tweetnacl/PULL_REQUEST_TEMPLATE.md +20 -0
  640. package/tweetnacl/README.md +459 -0
  641. package/tweetnacl/nacl-fast.js +2388 -0
  642. package/tweetnacl/nacl-fast.min.js +2 -0
  643. package/tweetnacl/nacl.d.ts +98 -0
  644. package/tweetnacl/nacl.js +1175 -0
  645. package/tweetnacl/nacl.min.js +1 -0
  646. package/tweetnacl/package.json +58 -0
  647. package/uri-js/LICENSE +11 -0
  648. package/uri-js/README.md +203 -0
  649. package/uri-js/dist/es5/uri.all.d.ts +59 -0
  650. package/uri-js/dist/es5/uri.all.js +1443 -0
  651. package/uri-js/dist/es5/uri.all.js.map +1 -0
  652. package/uri-js/dist/es5/uri.all.min.d.ts +59 -0
  653. package/uri-js/dist/es5/uri.all.min.js +3 -0
  654. package/uri-js/dist/es5/uri.all.min.js.map +1 -0
  655. package/uri-js/dist/esnext/index.d.ts +1 -0
  656. package/uri-js/dist/esnext/index.js +17 -0
  657. package/uri-js/dist/esnext/index.js.map +1 -0
  658. package/uri-js/dist/esnext/regexps-iri.d.ts +3 -0
  659. package/uri-js/dist/esnext/regexps-iri.js +3 -0
  660. package/uri-js/dist/esnext/regexps-iri.js.map +1 -0
  661. package/uri-js/dist/esnext/regexps-uri.d.ts +4 -0
  662. package/uri-js/dist/esnext/regexps-uri.js +42 -0
  663. package/uri-js/dist/esnext/regexps-uri.js.map +1 -0
  664. package/uri-js/dist/esnext/schemes/http.d.ts +3 -0
  665. package/uri-js/dist/esnext/schemes/http.js +28 -0
  666. package/uri-js/dist/esnext/schemes/http.js.map +1 -0
  667. package/uri-js/dist/esnext/schemes/https.d.ts +3 -0
  668. package/uri-js/dist/esnext/schemes/https.js +9 -0
  669. package/uri-js/dist/esnext/schemes/https.js.map +1 -0
  670. package/uri-js/dist/esnext/schemes/mailto.d.ts +12 -0
  671. package/uri-js/dist/esnext/schemes/mailto.js +148 -0
  672. package/uri-js/dist/esnext/schemes/mailto.js.map +1 -0
  673. package/uri-js/dist/esnext/schemes/urn-uuid.d.ts +7 -0
  674. package/uri-js/dist/esnext/schemes/urn-uuid.js +23 -0
  675. package/uri-js/dist/esnext/schemes/urn-uuid.js.map +1 -0
  676. package/uri-js/dist/esnext/schemes/urn.d.ts +10 -0
  677. package/uri-js/dist/esnext/schemes/urn.js +49 -0
  678. package/uri-js/dist/esnext/schemes/urn.js.map +1 -0
  679. package/uri-js/dist/esnext/schemes/ws.d.ts +7 -0
  680. package/uri-js/dist/esnext/schemes/ws.js +41 -0
  681. package/uri-js/dist/esnext/schemes/ws.js.map +1 -0
  682. package/uri-js/dist/esnext/schemes/wss.d.ts +3 -0
  683. package/uri-js/dist/esnext/schemes/wss.js +9 -0
  684. package/uri-js/dist/esnext/schemes/wss.js.map +1 -0
  685. package/uri-js/dist/esnext/uri.d.ts +59 -0
  686. package/uri-js/dist/esnext/uri.js +480 -0
  687. package/uri-js/dist/esnext/uri.js.map +1 -0
  688. package/uri-js/dist/esnext/util.d.ts +6 -0
  689. package/uri-js/dist/esnext/util.js +36 -0
  690. package/uri-js/dist/esnext/util.js.map +1 -0
  691. package/uri-js/package.json +77 -0
  692. package/uri-js/yarn.lock +2558 -0
  693. package/uuid/AUTHORS +5 -0
  694. package/uuid/CHANGELOG.md +119 -0
  695. package/uuid/LICENSE.md +21 -0
  696. package/uuid/README.md +276 -0
  697. package/uuid/bin/uuid +65 -0
  698. package/uuid/index.js +8 -0
  699. package/uuid/lib/bytesToUuid.js +26 -0
  700. package/uuid/lib/md5-browser.js +216 -0
  701. package/uuid/lib/md5.js +25 -0
  702. package/uuid/lib/rng-browser.js +34 -0
  703. package/uuid/lib/rng.js +8 -0
  704. package/uuid/lib/sha1-browser.js +89 -0
  705. package/uuid/lib/sha1.js +25 -0
  706. package/uuid/lib/v35.js +57 -0
  707. package/uuid/package.json +49 -0
  708. package/uuid/v1.js +109 -0
  709. package/uuid/v3.js +4 -0
  710. package/uuid/v4.js +29 -0
  711. package/uuid/v5.js +3 -0
  712. package/verror/CHANGES.md +28 -0
  713. package/verror/CONTRIBUTING.md +19 -0
  714. package/verror/LICENSE +19 -0
  715. package/verror/README.md +528 -0
  716. package/verror/lib/verror.js +451 -0
  717. package/verror/package.json +22 -0
  718. package/xml2js/.travis.yml +5 -0
  719. package/xml2js/83.coffee +6 -0
  720. package/xml2js/LICENSE +19 -0
  721. package/xml2js/README.md +248 -0
  722. package/xml2js/canon.xml +482 -0
  723. package/xml2js/lib/xml2js.js +299 -0
  724. package/xml2js/package.json +47 -0
  725. package/xml2js/text.coffee +11 -0
  726. package/xml2js/text.xml +485 -0
  727. package/youtube-search/.travis.yml +5 -0
  728. package/youtube-search/README.md +61 -0
  729. package/youtube-search/index.d.ts +77 -0
  730. package/youtube-search/index.js +111 -0
  731. package/youtube-search/package.json +29 -0
  732. package/youtube-search/tests/test-search.js +32 -0
  733. package/ytdl-core/LICENSE +21 -0
  734. package/ytdl-core/README.md +238 -0
  735. package/ytdl-core/lib/cache.js +54 -0
  736. package/ytdl-core/lib/format-utils.js +250 -0
  737. package/ytdl-core/lib/formats.js +524 -0
  738. package/ytdl-core/lib/index.js +214 -0
  739. package/ytdl-core/lib/info-extras.js +365 -0
  740. package/ytdl-core/lib/info.js +495 -0
  741. package/ytdl-core/lib/sig.js +122 -0
  742. package/ytdl-core/lib/url-utils.js +91 -0
  743. package/ytdl-core/lib/utils.js +286 -0
  744. package/ytdl-core/node_modules/sax/LICENSE +41 -0
  745. package/ytdl-core/node_modules/sax/README.md +225 -0
  746. package/ytdl-core/node_modules/sax/lib/sax.js +1565 -0
  747. package/ytdl-core/node_modules/sax/package.json +25 -0
  748. package/ytdl-core/package.json +61 -0
  749. package/ytdl-core/typings/index.d.ts +426 -0
  750. package/ytdl-getinfo/.travis.yml +3 -0
  751. package/ytdl-getinfo/README.md +77 -0
  752. package/ytdl-getinfo/index.js +105 -0
  753. package/ytdl-getinfo/package.json +33 -0
  754. package/ytdl-getinfo/playlist.js +50 -0
  755. package/ytdl-getinfo/test/test.js +68 -0
  756. package/ytdl-getinfo/updater.js +42 -0
  757. package/ytdl-getinfo/yarn.lock +533 -0
  758. package/ytdl-getinfo/ytdl/.gitkeep +0 -0
  759. package/ytdl-getinfo/ytdl/youtube-dl.exe +0 -0
@@ -0,0 +1,1055 @@
1
+ /**
2
+ * dashdash - A light, featureful and explicit option parsing library for
3
+ * node.js.
4
+ */
5
+ // vim: set ts=4 sts=4 sw=4 et:
6
+
7
+ var assert = require('assert-plus');
8
+ var format = require('util').format;
9
+ var fs = require('fs');
10
+ var path = require('path');
11
+
12
+
13
+ var DEBUG = true;
14
+ if (DEBUG) {
15
+ var debug = console.warn;
16
+ } else {
17
+ var debug = function () {};
18
+ }
19
+
20
+
21
+
22
+ // ---- internal support stuff
23
+
24
+ // Replace {{variable}} in `s` with the template data in `d`.
25
+ function renderTemplate(s, d) {
26
+ return s.replace(/{{([a-zA-Z]+)}}/g, function (match, key) {
27
+ return d.hasOwnProperty(key) ? d[key] : match;
28
+ });
29
+ }
30
+
31
+ /**
32
+ * Return a shallow copy of the given object;
33
+ */
34
+ function shallowCopy(obj) {
35
+ if (!obj) {
36
+ return (obj);
37
+ }
38
+ var copy = {};
39
+ Object.keys(obj).forEach(function (k) {
40
+ copy[k] = obj[k];
41
+ });
42
+ return (copy);
43
+ }
44
+
45
+
46
+ function space(n) {
47
+ var s = '';
48
+ for (var i = 0; i < n; i++) {
49
+ s += ' ';
50
+ }
51
+ return s;
52
+ }
53
+
54
+
55
+ function makeIndent(arg, deflen, name) {
56
+ if (arg === null || arg === undefined)
57
+ return space(deflen);
58
+ else if (typeof (arg) === 'number')
59
+ return space(arg);
60
+ else if (typeof (arg) === 'string')
61
+ return arg;
62
+ else
63
+ assert.fail('invalid "' + name + '": not a string or number: ' + arg);
64
+ }
65
+
66
+
67
+ /**
68
+ * Return an array of lines wrapping the given text to the given width.
69
+ * This splits on whitespace. Single tokens longer than `width` are not
70
+ * broken up.
71
+ */
72
+ function textwrap(s, width) {
73
+ var words = s.trim().split(/\s+/);
74
+ var lines = [];
75
+ var line = '';
76
+ words.forEach(function (w) {
77
+ var newLength = line.length + w.length;
78
+ if (line.length > 0)
79
+ newLength += 1;
80
+ if (newLength > width) {
81
+ lines.push(line);
82
+ line = '';
83
+ }
84
+ if (line.length > 0)
85
+ line += ' ';
86
+ line += w;
87
+ });
88
+ lines.push(line);
89
+ return lines;
90
+ }
91
+
92
+
93
+ /**
94
+ * Transform an option name to a "key" that is used as the field
95
+ * on the `opts` object returned from `<parser>.parse()`.
96
+ *
97
+ * Transformations:
98
+ * - '-' -> '_': This allow one to use hyphen in option names (common)
99
+ * but not have to do silly things like `opt["dry-run"]` to access the
100
+ * parsed results.
101
+ */
102
+ function optionKeyFromName(name) {
103
+ return name.replace(/-/g, '_');
104
+ }
105
+
106
+
107
+
108
+ // ---- Option types
109
+
110
+ function parseBool(option, optstr, arg) {
111
+ return Boolean(arg);
112
+ }
113
+
114
+ function parseString(option, optstr, arg) {
115
+ assert.string(arg, 'arg');
116
+ return arg;
117
+ }
118
+
119
+ function parseNumber(option, optstr, arg) {
120
+ assert.string(arg, 'arg');
121
+ var num = Number(arg);
122
+ if (isNaN(num)) {
123
+ throw new Error(format('arg for "%s" is not a number: "%s"',
124
+ optstr, arg));
125
+ }
126
+ return num;
127
+ }
128
+
129
+ function parseInteger(option, optstr, arg) {
130
+ assert.string(arg, 'arg');
131
+ var num = Number(arg);
132
+ if (!/^[0-9-]+$/.test(arg) || isNaN(num)) {
133
+ throw new Error(format('arg for "%s" is not an integer: "%s"',
134
+ optstr, arg));
135
+ }
136
+ return num;
137
+ }
138
+
139
+ function parsePositiveInteger(option, optstr, arg) {
140
+ assert.string(arg, 'arg');
141
+ var num = Number(arg);
142
+ if (!/^[0-9]+$/.test(arg) || isNaN(num) || num === 0) {
143
+ throw new Error(format('arg for "%s" is not a positive integer: "%s"',
144
+ optstr, arg));
145
+ }
146
+ return num;
147
+ }
148
+
149
+ /**
150
+ * Supported date args:
151
+ * - epoch second times (e.g. 1396031701)
152
+ * - ISO 8601 format: YYYY-MM-DD[THH:MM:SS[.sss][Z]]
153
+ * 2014-03-28T18:35:01.489Z
154
+ * 2014-03-28T18:35:01.489
155
+ * 2014-03-28T18:35:01Z
156
+ * 2014-03-28T18:35:01
157
+ * 2014-03-28
158
+ */
159
+ function parseDate(option, optstr, arg) {
160
+ assert.string(arg, 'arg');
161
+ var date;
162
+ if (/^\d+$/.test(arg)) {
163
+ // epoch seconds
164
+ date = new Date(Number(arg) * 1000);
165
+ /* JSSTYLED */
166
+ } else if (/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?Z?)?$/i.test(arg)) {
167
+ // ISO 8601 format
168
+ date = new Date(arg);
169
+ } else {
170
+ throw new Error(format('arg for "%s" is not a valid date format: "%s"',
171
+ optstr, arg));
172
+ }
173
+ if (date.toString() === 'Invalid Date') {
174
+ throw new Error(format('arg for "%s" is an invalid date: "%s"',
175
+ optstr, arg));
176
+ }
177
+ return date;
178
+ }
179
+
180
+ var optionTypes = {
181
+ bool: {
182
+ takesArg: false,
183
+ parseArg: parseBool
184
+ },
185
+ string: {
186
+ takesArg: true,
187
+ helpArg: 'ARG',
188
+ parseArg: parseString
189
+ },
190
+ number: {
191
+ takesArg: true,
192
+ helpArg: 'NUM',
193
+ parseArg: parseNumber
194
+ },
195
+ integer: {
196
+ takesArg: true,
197
+ helpArg: 'INT',
198
+ parseArg: parseInteger
199
+ },
200
+ positiveInteger: {
201
+ takesArg: true,
202
+ helpArg: 'INT',
203
+ parseArg: parsePositiveInteger
204
+ },
205
+ date: {
206
+ takesArg: true,
207
+ helpArg: 'DATE',
208
+ parseArg: parseDate
209
+ },
210
+ arrayOfBool: {
211
+ takesArg: false,
212
+ array: true,
213
+ parseArg: parseBool
214
+ },
215
+ arrayOfString: {
216
+ takesArg: true,
217
+ helpArg: 'ARG',
218
+ array: true,
219
+ parseArg: parseString
220
+ },
221
+ arrayOfNumber: {
222
+ takesArg: true,
223
+ helpArg: 'NUM',
224
+ array: true,
225
+ parseArg: parseNumber
226
+ },
227
+ arrayOfInteger: {
228
+ takesArg: true,
229
+ helpArg: 'INT',
230
+ array: true,
231
+ parseArg: parseInteger
232
+ },
233
+ arrayOfPositiveInteger: {
234
+ takesArg: true,
235
+ helpArg: 'INT',
236
+ array: true,
237
+ parseArg: parsePositiveInteger
238
+ },
239
+ arrayOfDate: {
240
+ takesArg: true,
241
+ helpArg: 'INT',
242
+ array: true,
243
+ parseArg: parseDate
244
+ },
245
+ };
246
+
247
+
248
+
249
+ // ---- Parser
250
+
251
+ /**
252
+ * Parser constructor.
253
+ *
254
+ * @param config {Object} The parser configuration
255
+ * - options {Array} Array of option specs. See the README for how to
256
+ * specify each option spec.
257
+ * - allowUnknown {Boolean} Default false. Whether to throw on unknown
258
+ * options. If false, then unknown args are included in the _args array.
259
+ * - interspersed {Boolean} Default true. Whether to allow interspersed
260
+ * arguments (non-options) and options. E.g.:
261
+ * node tool.js arg1 arg2 -v
262
+ * '-v' is after some args here. If `interspersed: false` then '-v'
263
+ * would not be parsed out. Note that regardless of `interspersed`
264
+ * the presence of '--' will stop option parsing, as all good
265
+ * option parsers should.
266
+ */
267
+ function Parser(config) {
268
+ assert.object(config, 'config');
269
+ assert.arrayOfObject(config.options, 'config.options');
270
+ assert.optionalBool(config.interspersed, 'config.interspersed');
271
+ var self = this;
272
+
273
+ // Allow interspersed arguments (true by default).
274
+ this.interspersed = (config.interspersed !== undefined
275
+ ? config.interspersed : true);
276
+
277
+ // Don't allow unknown flags (true by default).
278
+ this.allowUnknown = (config.allowUnknown !== undefined
279
+ ? config.allowUnknown : false);
280
+
281
+ this.options = config.options.map(function (o) { return shallowCopy(o); });
282
+ this.optionFromName = {};
283
+ this.optionFromEnv = {};
284
+ for (var i = 0; i < this.options.length; i++) {
285
+ var o = this.options[i];
286
+ if (o.group !== undefined && o.group !== null) {
287
+ assert.optionalString(o.group,
288
+ format('config.options.%d.group', i));
289
+ continue;
290
+ }
291
+ assert.ok(optionTypes[o.type],
292
+ format('invalid config.options.%d.type: "%s" in %j',
293
+ i, o.type, o));
294
+ assert.optionalString(o.name, format('config.options.%d.name', i));
295
+ assert.optionalArrayOfString(o.names,
296
+ format('config.options.%d.names', i));
297
+ assert.ok((o.name || o.names) && !(o.name && o.names),
298
+ format('exactly one of "name" or "names" required: %j', o));
299
+ assert.optionalString(o.help, format('config.options.%d.help', i));
300
+ var env = o.env || [];
301
+ if (typeof (env) === 'string') {
302
+ env = [env];
303
+ }
304
+ assert.optionalArrayOfString(env, format('config.options.%d.env', i));
305
+ assert.optionalString(o.helpGroup,
306
+ format('config.options.%d.helpGroup', i));
307
+ assert.optionalBool(o.helpWrap,
308
+ format('config.options.%d.helpWrap', i));
309
+ assert.optionalBool(o.hidden, format('config.options.%d.hidden', i));
310
+
311
+ if (o.name) {
312
+ o.names = [o.name];
313
+ } else {
314
+ assert.string(o.names[0],
315
+ format('config.options.%d.names is empty', i));
316
+ }
317
+ o.key = optionKeyFromName(o.names[0]);
318
+ o.names.forEach(function (n) {
319
+ if (self.optionFromName[n]) {
320
+ throw new Error(format(
321
+ 'option name collision: "%s" used in %j and %j',
322
+ n, self.optionFromName[n], o));
323
+ }
324
+ self.optionFromName[n] = o;
325
+ });
326
+ env.forEach(function (n) {
327
+ if (self.optionFromEnv[n]) {
328
+ throw new Error(format(
329
+ 'option env collision: "%s" used in %j and %j',
330
+ n, self.optionFromEnv[n], o));
331
+ }
332
+ self.optionFromEnv[n] = o;
333
+ });
334
+ }
335
+ }
336
+
337
+ Parser.prototype.optionTakesArg = function optionTakesArg(option) {
338
+ return optionTypes[option.type].takesArg;
339
+ };
340
+
341
+ /**
342
+ * Parse options from the given argv.
343
+ *
344
+ * @param inputs {Object} Optional.
345
+ * - argv {Array} Optional. The argv to parse. Defaults to
346
+ * `process.argv`.
347
+ * - slice {Number} The index into argv at which options/args begin.
348
+ * Default is 2, as appropriate for `process.argv`.
349
+ * - env {Object} Optional. The env to use for 'env' entries in the
350
+ * option specs. Defaults to `process.env`.
351
+ * @returns {Object} Parsed `opts`. It has special keys `_args` (the
352
+ * remaining args from `argv`) and `_order` (gives the order that
353
+ * options were specified).
354
+ */
355
+ Parser.prototype.parse = function parse(inputs) {
356
+ var self = this;
357
+
358
+ // Old API was `parse([argv, [slice]])`
359
+ if (Array.isArray(arguments[0])) {
360
+ inputs = {argv: arguments[0], slice: arguments[1]};
361
+ }
362
+
363
+ assert.optionalObject(inputs, 'inputs');
364
+ if (!inputs) {
365
+ inputs = {};
366
+ }
367
+ assert.optionalArrayOfString(inputs.argv, 'inputs.argv');
368
+ //assert.optionalNumber(slice, 'slice');
369
+ var argv = inputs.argv || process.argv;
370
+ var slice = inputs.slice !== undefined ? inputs.slice : 2;
371
+ var args = argv.slice(slice);
372
+ var env = inputs.env || process.env;
373
+ var opts = {};
374
+ var _order = [];
375
+
376
+ function addOpt(option, optstr, key, val, from) {
377
+ var type = optionTypes[option.type];
378
+ var parsedVal = type.parseArg(option, optstr, val);
379
+ if (type.array) {
380
+ if (!opts[key]) {
381
+ opts[key] = [];
382
+ }
383
+ if (type.arrayFlatten && Array.isArray(parsedVal)) {
384
+ for (var i = 0; i < parsedVal.length; i++) {
385
+ opts[key].push(parsedVal[i]);
386
+ }
387
+ } else {
388
+ opts[key].push(parsedVal);
389
+ }
390
+ } else {
391
+ opts[key] = parsedVal;
392
+ }
393
+ var item = { key: key, value: parsedVal, from: from };
394
+ _order.push(item);
395
+ }
396
+
397
+ // Parse args.
398
+ var _args = [];
399
+ var i = 0;
400
+ outer: while (i < args.length) {
401
+ var arg = args[i];
402
+
403
+ // End of options marker.
404
+ if (arg === '--') {
405
+ i++;
406
+ break;
407
+
408
+ // Long option
409
+ } else if (arg.slice(0, 2) === '--') {
410
+ var name = arg.slice(2);
411
+ var val = null;
412
+ var idx = name.indexOf('=');
413
+ if (idx !== -1) {
414
+ val = name.slice(idx + 1);
415
+ name = name.slice(0, idx);
416
+ }
417
+ var option = this.optionFromName[name];
418
+ if (!option) {
419
+ if (!this.allowUnknown)
420
+ throw new Error(format('unknown option: "--%s"', name));
421
+ else if (this.interspersed)
422
+ _args.push(arg);
423
+ else
424
+ break outer;
425
+ } else {
426
+ var takesArg = this.optionTakesArg(option);
427
+ if (val !== null && !takesArg) {
428
+ throw new Error(format('argument given to "--%s" option '
429
+ + 'that does not take one: "%s"', name, arg));
430
+ }
431
+ if (!takesArg) {
432
+ addOpt(option, '--'+name, option.key, true, 'argv');
433
+ } else if (val !== null) {
434
+ addOpt(option, '--'+name, option.key, val, 'argv');
435
+ } else if (i + 1 >= args.length) {
436
+ throw new Error(format('do not have enough args for "--%s" '
437
+ + 'option', name));
438
+ } else {
439
+ addOpt(option, '--'+name, option.key, args[i + 1], 'argv');
440
+ i++;
441
+ }
442
+ }
443
+
444
+ // Short option
445
+ } else if (arg[0] === '-' && arg.length > 1) {
446
+ var j = 1;
447
+ var allFound = true;
448
+ while (j < arg.length) {
449
+ var name = arg[j];
450
+ var option = this.optionFromName[name];
451
+ if (!option) {
452
+ allFound = false;
453
+ if (this.allowUnknown) {
454
+ if (this.interspersed) {
455
+ _args.push(arg);
456
+ break;
457
+ } else
458
+ break outer;
459
+ } else if (arg.length > 2) {
460
+ throw new Error(format(
461
+ 'unknown option: "-%s" in "%s" group',
462
+ name, arg));
463
+ } else {
464
+ throw new Error(format('unknown option: "-%s"', name));
465
+ }
466
+ } else if (this.optionTakesArg(option)) {
467
+ break;
468
+ }
469
+ j++;
470
+ }
471
+
472
+ j = 1;
473
+ while (allFound && j < arg.length) {
474
+ var name = arg[j];
475
+ var val = arg.slice(j + 1); // option val if it takes an arg
476
+ var option = this.optionFromName[name];
477
+ var takesArg = this.optionTakesArg(option);
478
+ if (!takesArg) {
479
+ addOpt(option, '-'+name, option.key, true, 'argv');
480
+ } else if (val) {
481
+ addOpt(option, '-'+name, option.key, val, 'argv');
482
+ break;
483
+ } else {
484
+ if (i + 1 >= args.length) {
485
+ throw new Error(format('do not have enough args '
486
+ + 'for "-%s" option', name));
487
+ }
488
+ addOpt(option, '-'+name, option.key, args[i + 1], 'argv');
489
+ i++;
490
+ break;
491
+ }
492
+ j++;
493
+ }
494
+
495
+ // An interspersed arg
496
+ } else if (this.interspersed) {
497
+ _args.push(arg);
498
+
499
+ // An arg and interspersed args are not allowed, so done options.
500
+ } else {
501
+ break outer;
502
+ }
503
+ i++;
504
+ }
505
+ _args = _args.concat(args.slice(i));
506
+
507
+ // Parse environment.
508
+ Object.keys(this.optionFromEnv).forEach(function (envname) {
509
+ var val = env[envname];
510
+ if (val === undefined)
511
+ return;
512
+ var option = self.optionFromEnv[envname];
513
+ if (opts[option.key] !== undefined)
514
+ return;
515
+ var takesArg = self.optionTakesArg(option);
516
+ if (takesArg) {
517
+ addOpt(option, envname, option.key, val, 'env');
518
+ } else if (val !== '') {
519
+ // Boolean envvar handling:
520
+ // - VAR=<empty-string> not set (as if the VAR was not set)
521
+ // - VAR=0 false
522
+ // - anything else true
523
+ addOpt(option, envname, option.key, (val !== '0'), 'env');
524
+ }
525
+ });
526
+
527
+ // Apply default values.
528
+ this.options.forEach(function (o) {
529
+ if (opts[o.key] === undefined) {
530
+ if (o.default !== undefined) {
531
+ opts[o.key] = o.default;
532
+ } else if (o.type && optionTypes[o.type].default !== undefined) {
533
+ opts[o.key] = optionTypes[o.type].default;
534
+ }
535
+ }
536
+ });
537
+
538
+ opts._order = _order;
539
+ opts._args = _args;
540
+ return opts;
541
+ };
542
+
543
+
544
+ /**
545
+ * Return help output for the current options.
546
+ *
547
+ * E.g.: if the current options are:
548
+ * [{names: ['help', 'h'], type: 'bool', help: 'Show help and exit.'}]
549
+ * then this would return:
550
+ * ' -h, --help Show help and exit.\n'
551
+ *
552
+ * @param config {Object} Config for controlling the option help output.
553
+ * - indent {Number|String} Default 4. An indent/prefix to use for
554
+ * each option line.
555
+ * - nameSort {String} Default is 'length'. By default the names are
556
+ * sorted to put the short opts first (i.e. '-h, --help' preferred
557
+ * to '--help, -h'). Set to 'none' to not do this sorting.
558
+ * - maxCol {Number} Default 80. Note that long tokens in a help string
559
+ * can go past this.
560
+ * - helpCol {Number} Set to specify a specific column at which
561
+ * option help will be aligned. By default this is determined
562
+ * automatically.
563
+ * - minHelpCol {Number} Default 20.
564
+ * - maxHelpCol {Number} Default 40.
565
+ * - includeEnv {Boolean} Default false. If true, a note stating the `env`
566
+ * envvar (if specified for this option) will be appended to the help
567
+ * output.
568
+ * - includeDefault {Boolean} Default false. If true, a note stating
569
+ * the `default` for this option, if any, will be appended to the help
570
+ * output.
571
+ * - helpWrap {Boolean} Default true. Wrap help text in helpCol..maxCol
572
+ * bounds.
573
+ * @returns {String}
574
+ */
575
+ Parser.prototype.help = function help(config) {
576
+ config = config || {};
577
+ assert.object(config, 'config');
578
+
579
+ var indent = makeIndent(config.indent, 4, 'config.indent');
580
+ var headingIndent = makeIndent(config.headingIndent,
581
+ Math.round(indent.length / 2), 'config.headingIndent');
582
+
583
+ assert.optionalString(config.nameSort, 'config.nameSort');
584
+ var nameSort = config.nameSort || 'length';
585
+ assert.ok(~['length', 'none'].indexOf(nameSort),
586
+ 'invalid "config.nameSort"');
587
+ assert.optionalNumber(config.maxCol, 'config.maxCol');
588
+ assert.optionalNumber(config.maxHelpCol, 'config.maxHelpCol');
589
+ assert.optionalNumber(config.minHelpCol, 'config.minHelpCol');
590
+ assert.optionalNumber(config.helpCol, 'config.helpCol');
591
+ assert.optionalBool(config.includeEnv, 'config.includeEnv');
592
+ assert.optionalBool(config.includeDefault, 'config.includeDefault');
593
+ assert.optionalBool(config.helpWrap, 'config.helpWrap');
594
+ var maxCol = config.maxCol || 80;
595
+ var minHelpCol = config.minHelpCol || 20;
596
+ var maxHelpCol = config.maxHelpCol || 40;
597
+
598
+ var lines = [];
599
+ var maxWidth = 0;
600
+ this.options.forEach(function (o) {
601
+ if (o.hidden) {
602
+ return;
603
+ }
604
+ if (o.group !== undefined && o.group !== null) {
605
+ // We deal with groups in the next pass
606
+ lines.push(null);
607
+ return;
608
+ }
609
+ var type = optionTypes[o.type];
610
+ var arg = o.helpArg || type.helpArg || 'ARG';
611
+ var line = '';
612
+ var names = o.names.slice();
613
+ if (nameSort === 'length') {
614
+ names.sort(function (a, b) {
615
+ if (a.length < b.length)
616
+ return -1;
617
+ else if (b.length < a.length)
618
+ return 1;
619
+ else
620
+ return 0;
621
+ })
622
+ }
623
+ names.forEach(function (name, i) {
624
+ if (i > 0)
625
+ line += ', ';
626
+ if (name.length === 1) {
627
+ line += '-' + name
628
+ if (type.takesArg)
629
+ line += ' ' + arg;
630
+ } else {
631
+ line += '--' + name
632
+ if (type.takesArg)
633
+ line += '=' + arg;
634
+ }
635
+ });
636
+ maxWidth = Math.max(maxWidth, line.length);
637
+ lines.push(line);
638
+ });
639
+
640
+ // Add help strings.
641
+ var helpCol = config.helpCol;
642
+ if (!helpCol) {
643
+ helpCol = maxWidth + indent.length + 2;
644
+ helpCol = Math.min(Math.max(helpCol, minHelpCol), maxHelpCol);
645
+ }
646
+ var i = -1;
647
+ this.options.forEach(function (o) {
648
+ if (o.hidden) {
649
+ return;
650
+ }
651
+ i++;
652
+
653
+ if (o.group !== undefined && o.group !== null) {
654
+ if (o.group === '') {
655
+ // Support a empty string "group" to have a blank line between
656
+ // sets of options.
657
+ lines[i] = '';
658
+ } else {
659
+ // Render the group heading with the heading-specific indent.
660
+ lines[i] = (i === 0 ? '' : '\n') + headingIndent +
661
+ o.group + ':';
662
+ }
663
+ return;
664
+ }
665
+
666
+ var helpDefault;
667
+ if (config.includeDefault) {
668
+ if (o.default !== undefined) {
669
+ helpDefault = format('Default: %j', o.default);
670
+ } else if (o.type && optionTypes[o.type].default !== undefined) {
671
+ helpDefault = format('Default: %j',
672
+ optionTypes[o.type].default);
673
+ }
674
+ }
675
+
676
+ var line = lines[i] = indent + lines[i];
677
+ if (!o.help && !(config.includeEnv && o.env) && !helpDefault) {
678
+ return;
679
+ }
680
+ var n = helpCol - line.length;
681
+ if (n >= 0) {
682
+ line += space(n);
683
+ } else {
684
+ line += '\n' + space(helpCol);
685
+ }
686
+
687
+ var helpEnv = '';
688
+ if (o.env && o.env.length && config.includeEnv) {
689
+ helpEnv += 'Environment: ';
690
+ var type = optionTypes[o.type];
691
+ var arg = o.helpArg || type.helpArg || 'ARG';
692
+ var envs = (Array.isArray(o.env) ? o.env : [o.env]).map(
693
+ function (e) {
694
+ if (type.takesArg) {
695
+ return e + '=' + arg;
696
+ } else {
697
+ return e + '=1';
698
+ }
699
+ }
700
+ );
701
+ helpEnv += envs.join(', ');
702
+ }
703
+ var help = (o.help || '').trim();
704
+ if (o.helpWrap !== false && config.helpWrap !== false) {
705
+ // Wrap help description normally.
706
+ if (help.length && !~'.!?"\''.indexOf(help.slice(-1))) {
707
+ help += '.';
708
+ }
709
+ if (help.length) {
710
+ help += ' ';
711
+ }
712
+ help += helpEnv;
713
+ if (helpDefault) {
714
+ if (helpEnv) {
715
+ help += '. ';
716
+ }
717
+ help += helpDefault;
718
+ }
719
+ line += textwrap(help, maxCol - helpCol).join(
720
+ '\n' + space(helpCol));
721
+ } else {
722
+ // Do not wrap help description, but indent newlines appropriately.
723
+ var helpLines = help.split('\n').filter(
724
+ function (ln) { return ln.length });
725
+ if (helpEnv !== '') {
726
+ helpLines.push(helpEnv);
727
+ }
728
+ if (helpDefault) {
729
+ helpLines.push(helpDefault);
730
+ }
731
+ line += helpLines.join('\n' + space(helpCol));
732
+ }
733
+
734
+ lines[i] = line;
735
+ });
736
+
737
+ var rv = '';
738
+ if (lines.length > 0) {
739
+ rv = lines.join('\n') + '\n';
740
+ }
741
+ return rv;
742
+ };
743
+
744
+
745
+ /**
746
+ * Return a string suitable for a Bash completion file for this tool.
747
+ *
748
+ * @param args.name {String} The tool name.
749
+ * @param args.specExtra {String} Optional. Extra Bash code content to add
750
+ * to the end of the "spec". Typically this is used to append Bash
751
+ * "complete_TYPE" functions for custom option types. See
752
+ * "examples/ddcompletion.js" for an example.
753
+ * @param args.argtypes {Array} Optional. Array of completion types for
754
+ * positional args (i.e. non-options). E.g.
755
+ * argtypes = ['fruit', 'veggie', 'file']
756
+ * will result in completion of fruits for the first arg, veggies for the
757
+ * second, and filenames for the third and subsequent positional args.
758
+ * If not given, positional args will use Bash's 'default' completion.
759
+ * See `specExtra` for providing Bash `complete_TYPE` functions, e.g.
760
+ * `complete_fruit` and `complete_veggie` in this example.
761
+ */
762
+ Parser.prototype.bashCompletion = function bashCompletion(args) {
763
+ assert.object(args, 'args');
764
+ assert.string(args.name, 'args.name');
765
+ assert.optionalString(args.specExtra, 'args.specExtra');
766
+ assert.optionalArrayOfString(args.argtypes, 'args.argtypes');
767
+
768
+ return bashCompletionFromOptions({
769
+ name: args.name,
770
+ specExtra: args.specExtra,
771
+ argtypes: args.argtypes,
772
+ options: this.options
773
+ });
774
+ };
775
+
776
+
777
+ // ---- Bash completion
778
+
779
+ const BASH_COMPLETION_TEMPLATE_PATH = path.join(
780
+ __dirname, '../etc/dashdash.bash_completion.in');
781
+
782
+ /**
783
+ * Return the Bash completion "spec" (the string value for the "{{spec}}"
784
+ * var in the "dashdash.bash_completion.in" template) for this tool.
785
+ *
786
+ * The "spec" is Bash code that defines the CLI options and subcmds for
787
+ * the template's completion code. It looks something like this:
788
+ *
789
+ * local cmd_shortopts="-J ..."
790
+ * local cmd_longopts="--help ..."
791
+ * local cmd_optargs="-p=tritonprofile ..."
792
+ *
793
+ * @param args.options {Array} The array of dashdash option specs.
794
+ * @param args.context {String} Optional. A context string for the "local cmd*"
795
+ * vars in the spec. By default it is the empty string. When used to
796
+ * scope for completion on a *sub-command* (e.g. for "git log" on a "git"
797
+ * tool), then it would have a value (e.g. "__log"). See
798
+ * <http://github.com/trentm/node-cmdln> Bash completion for details.
799
+ * @param opts.includeHidden {Boolean} Optional. Default false. By default
800
+ * hidden options and subcmds are "excluded". Here excluded means they
801
+ * won't be offered as a completion, but if used, their argument type
802
+ * will be completed. "Hidden" options and subcmds are ones with the
803
+ * `hidden: true` attribute to exclude them from default help output.
804
+ * @param args.argtypes {Array} Optional. Array of completion types for
805
+ * positional args (i.e. non-options). E.g.
806
+ * argtypes = ['fruit', 'veggie', 'file']
807
+ * will result in completion of fruits for the first arg, veggies for the
808
+ * second, and filenames for the third and subsequent positional args.
809
+ * If not given, positional args will use Bash's 'default' completion.
810
+ * See `specExtra` for providing Bash `complete_TYPE` functions, e.g.
811
+ * `complete_fruit` and `complete_veggie` in this example.
812
+ */
813
+ function bashCompletionSpecFromOptions(args) {
814
+ assert.object(args, 'args');
815
+ assert.object(args.options, 'args.options');
816
+ assert.optionalString(args.context, 'args.context');
817
+ assert.optionalBool(args.includeHidden, 'args.includeHidden');
818
+ assert.optionalArrayOfString(args.argtypes, 'args.argtypes');
819
+
820
+ var context = args.context || '';
821
+ var includeHidden = (args.includeHidden === undefined
822
+ ? false : args.includeHidden);
823
+
824
+ var spec = [];
825
+ var shortopts = [];
826
+ var longopts = [];
827
+ var optargs = [];
828
+ (args.options || []).forEach(function (o) {
829
+ if (o.group !== undefined && o.group !== null) {
830
+ // Skip group headers.
831
+ return;
832
+ }
833
+
834
+ var optNames = o.names || [o.name];
835
+ var optType = getOptionType(o.type);
836
+ if (optType.takesArg) {
837
+ var completionType = o.completionType ||
838
+ optType.completionType || o.type;
839
+ optNames.forEach(function (optName) {
840
+ if (optName.length === 1) {
841
+ if (includeHidden || !o.hidden) {
842
+ shortopts.push('-' + optName);
843
+ }
844
+ // Include even hidden options in `optargs` so that bash
845
+ // completion of its arg still works.
846
+ optargs.push('-' + optName + '=' + completionType);
847
+ } else {
848
+ if (includeHidden || !o.hidden) {
849
+ longopts.push('--' + optName);
850
+ }
851
+ optargs.push('--' + optName + '=' + completionType);
852
+ }
853
+ });
854
+ } else {
855
+ optNames.forEach(function (optName) {
856
+ if (includeHidden || !o.hidden) {
857
+ if (optName.length === 1) {
858
+ shortopts.push('-' + optName);
859
+ } else {
860
+ longopts.push('--' + optName);
861
+ }
862
+ }
863
+ });
864
+ }
865
+ });
866
+
867
+ spec.push(format('local cmd%s_shortopts="%s"',
868
+ context, shortopts.sort().join(' ')));
869
+ spec.push(format('local cmd%s_longopts="%s"',
870
+ context, longopts.sort().join(' ')));
871
+ spec.push(format('local cmd%s_optargs="%s"',
872
+ context, optargs.sort().join(' ')));
873
+ if (args.argtypes) {
874
+ spec.push(format('local cmd%s_argtypes="%s"',
875
+ context, args.argtypes.join(' ')));
876
+ }
877
+ return spec.join('\n');
878
+ }
879
+
880
+
881
+ /**
882
+ * Return a string suitable for a Bash completion file for this tool.
883
+ *
884
+ * @param args.name {String} The tool name.
885
+ * @param args.options {Array} The array of dashdash option specs.
886
+ * @param args.specExtra {String} Optional. Extra Bash code content to add
887
+ * to the end of the "spec". Typically this is used to append Bash
888
+ * "complete_TYPE" functions for custom option types. See
889
+ * "examples/ddcompletion.js" for an example.
890
+ * @param args.argtypes {Array} Optional. Array of completion types for
891
+ * positional args (i.e. non-options). E.g.
892
+ * argtypes = ['fruit', 'veggie', 'file']
893
+ * will result in completion of fruits for the first arg, veggies for the
894
+ * second, and filenames for the third and subsequent positional args.
895
+ * If not given, positional args will use Bash's 'default' completion.
896
+ * See `specExtra` for providing Bash `complete_TYPE` functions, e.g.
897
+ * `complete_fruit` and `complete_veggie` in this example.
898
+ */
899
+ function bashCompletionFromOptions(args) {
900
+ assert.object(args, 'args');
901
+ assert.object(args.options, 'args.options');
902
+ assert.string(args.name, 'args.name');
903
+ assert.optionalString(args.specExtra, 'args.specExtra');
904
+ assert.optionalArrayOfString(args.argtypes, 'args.argtypes');
905
+
906
+ // Gather template data.
907
+ var data = {
908
+ name: args.name,
909
+ date: new Date(),
910
+ spec: bashCompletionSpecFromOptions({
911
+ options: args.options,
912
+ argtypes: args.argtypes
913
+ }),
914
+ };
915
+ if (args.specExtra) {
916
+ data.spec += '\n\n' + args.specExtra;
917
+ }
918
+
919
+ // Render template.
920
+ var template = fs.readFileSync(BASH_COMPLETION_TEMPLATE_PATH, 'utf8');
921
+ return renderTemplate(template, data);
922
+ }
923
+
924
+
925
+
926
+ // ---- exports
927
+
928
+ function createParser(config) {
929
+ return new Parser(config);
930
+ }
931
+
932
+ /**
933
+ * Parse argv with the given options.
934
+ *
935
+ * @param config {Object} A merge of all the available fields from
936
+ * `dashdash.Parser` and `dashdash.Parser.parse`: options, interspersed,
937
+ * argv, env, slice.
938
+ */
939
+ function parse(config) {
940
+ assert.object(config, 'config');
941
+ assert.optionalArrayOfString(config.argv, 'config.argv');
942
+ assert.optionalObject(config.env, 'config.env');
943
+ var config = shallowCopy(config);
944
+ var argv = config.argv;
945
+ delete config.argv;
946
+ var env = config.env;
947
+ delete config.env;
948
+
949
+ var parser = new Parser(config);
950
+ return parser.parse({argv: argv, env: env});
951
+ }
952
+
953
+
954
+ /**
955
+ * Add a new option type.
956
+ *
957
+ * @params optionType {Object}:
958
+ * - name {String} Required.
959
+ * - takesArg {Boolean} Required. Whether this type of option takes an
960
+ * argument on process.argv. Typically this is true for all but the
961
+ * "bool" type.
962
+ * - helpArg {String} Required iff `takesArg === true`. The string to
963
+ * show in generated help for options of this type.
964
+ * - parseArg {Function} Require. `function (option, optstr, arg)` parser
965
+ * that takes a string argument and returns an instance of the
966
+ * appropriate type, or throws an error if the arg is invalid.
967
+ * - array {Boolean} Optional. Set to true if this is an 'arrayOf' type
968
+ * that collects multiple usages of the option in process.argv and
969
+ * puts results in an array.
970
+ * - arrayFlatten {Boolean} Optional. XXX
971
+ * - default Optional. Default value for options of this type, if no
972
+ * default is specified in the option type usage.
973
+ */
974
+ function addOptionType(optionType) {
975
+ assert.object(optionType, 'optionType');
976
+ assert.string(optionType.name, 'optionType.name');
977
+ assert.bool(optionType.takesArg, 'optionType.takesArg');
978
+ if (optionType.takesArg) {
979
+ assert.string(optionType.helpArg, 'optionType.helpArg');
980
+ }
981
+ assert.func(optionType.parseArg, 'optionType.parseArg');
982
+ assert.optionalBool(optionType.array, 'optionType.array');
983
+ assert.optionalBool(optionType.arrayFlatten, 'optionType.arrayFlatten');
984
+
985
+ optionTypes[optionType.name] = {
986
+ takesArg: optionType.takesArg,
987
+ helpArg: optionType.helpArg,
988
+ parseArg: optionType.parseArg,
989
+ array: optionType.array,
990
+ arrayFlatten: optionType.arrayFlatten,
991
+ default: optionType.default
992
+ }
993
+ }
994
+
995
+
996
+ function getOptionType(name) {
997
+ assert.string(name, 'name');
998
+ return optionTypes[name];
999
+ }
1000
+
1001
+
1002
+ /**
1003
+ * Return a synopsis string for the given option spec.
1004
+ *
1005
+ * Examples:
1006
+ * > synopsisFromOpt({names: ['help', 'h'], type: 'bool'});
1007
+ * '[ --help | -h ]'
1008
+ * > synopsisFromOpt({name: 'file', type: 'string', helpArg: 'FILE'});
1009
+ * '[ --file=FILE ]'
1010
+ */
1011
+ function synopsisFromOpt(o) {
1012
+ assert.object(o, 'o');
1013
+
1014
+ if (o.hasOwnProperty('group')) {
1015
+ return null;
1016
+ }
1017
+ var names = o.names || [o.name];
1018
+ // `type` here could be undefined if, for example, the command has a
1019
+ // dashdash option spec with a bogus 'type'.
1020
+ var type = getOptionType(o.type);
1021
+ var helpArg = o.helpArg || (type && type.helpArg) || 'ARG';
1022
+ var parts = [];
1023
+ names.forEach(function (name) {
1024
+ var part = (name.length === 1 ? '-' : '--') + name;
1025
+ if (type && type.takesArg) {
1026
+ part += (name.length === 1 ? ' ' + helpArg : '=' + helpArg);
1027
+ }
1028
+ parts.push(part);
1029
+ });
1030
+ return ('[ ' + parts.join(' | ') + ' ]');
1031
+ };
1032
+
1033
+
1034
+ module.exports = {
1035
+ createParser: createParser,
1036
+ Parser: Parser,
1037
+ parse: parse,
1038
+ addOptionType: addOptionType,
1039
+ getOptionType: getOptionType,
1040
+ synopsisFromOpt: synopsisFromOpt,
1041
+
1042
+ // Bash completion-related exports
1043
+ BASH_COMPLETION_TEMPLATE_PATH: BASH_COMPLETION_TEMPLATE_PATH,
1044
+ bashCompletionFromOptions: bashCompletionFromOptions,
1045
+ bashCompletionSpecFromOptions: bashCompletionSpecFromOptions,
1046
+
1047
+ // Export the parseFoo parsers because they might be useful as primitives
1048
+ // for custom option types.
1049
+ parseBool: parseBool,
1050
+ parseString: parseString,
1051
+ parseNumber: parseNumber,
1052
+ parseInteger: parseInteger,
1053
+ parsePositiveInteger: parsePositiveInteger,
1054
+ parseDate: parseDate
1055
+ };