@corellium/corellium-cli 1.3.8 → 1.5.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.
Files changed (614) hide show
  1. package/.eslintrc.js +12 -16
  2. package/.gitlab-ci.yml +13 -13
  3. package/.nvmrc +1 -1
  4. package/.nycrc +14 -14
  5. package/.prettierrc.js +8 -7
  6. package/README.md +13 -6
  7. package/docs/OVERVIEW.md +57 -27
  8. package/index.js +8 -8
  9. package/lint-staged.config.js +3 -6
  10. package/node_modules/@babel/cli/README.md +1 -1
  11. package/node_modules/@babel/cli/bin/babel-external-helpers.mjs +3 -0
  12. package/node_modules/@babel/cli/bin/babel.mjs +3 -0
  13. package/node_modules/@babel/cli/lib/babel/dir.js +23 -73
  14. package/node_modules/@babel/cli/lib/babel/dir.js.map +1 -0
  15. package/node_modules/@babel/cli/lib/babel/file.js +27 -72
  16. package/node_modules/@babel/cli/lib/babel/file.js.map +1 -0
  17. package/node_modules/@babel/cli/lib/babel/index.js +6 -8
  18. package/node_modules/@babel/cli/lib/babel/index.js.map +1 -0
  19. package/node_modules/@babel/cli/lib/babel/options.js +70 -143
  20. package/node_modules/@babel/cli/lib/babel/options.js.map +1 -0
  21. package/node_modules/@babel/cli/lib/babel/util.js +39 -59
  22. package/node_modules/@babel/cli/lib/babel/util.js.map +1 -0
  23. package/node_modules/@babel/cli/lib/babel/watcher.js +19 -52
  24. package/node_modules/@babel/cli/lib/babel/watcher.js.map +1 -0
  25. package/node_modules/@babel/cli/lib/babel-external-helpers.js +14 -21
  26. package/node_modules/@babel/cli/lib/babel-external-helpers.js.map +1 -0
  27. package/node_modules/@babel/cli/package.json +11 -9
  28. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs +19 -29
  29. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs.map +1 -1
  30. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js +19 -29
  31. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js.map +1 -1
  32. package/node_modules/@jridgewell/resolve-uri/package.json +2 -2
  33. package/node_modules/@jridgewell/sourcemap-codec/README.md +147 -83
  34. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs +351 -91
  35. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs.map +1 -1
  36. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js +354 -90
  37. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js.map +1 -1
  38. package/node_modules/@jridgewell/sourcemap-codec/dist/types/scopes.d.ts +49 -0
  39. package/node_modules/@jridgewell/sourcemap-codec/dist/types/sourcemap-codec.d.ts +2 -0
  40. package/node_modules/@jridgewell/sourcemap-codec/dist/types/strings.d.ts +15 -0
  41. package/node_modules/@jridgewell/sourcemap-codec/dist/types/vlq.d.ts +6 -0
  42. package/node_modules/@jridgewell/sourcemap-codec/package.json +7 -7
  43. package/node_modules/@jridgewell/trace-mapping/README.md +5 -0
  44. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs +202 -174
  45. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs.map +1 -1
  46. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js +216 -182
  47. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js.map +1 -1
  48. package/node_modules/@jridgewell/trace-mapping/dist/types/any-map.d.ts +1 -1
  49. package/node_modules/@jridgewell/trace-mapping/dist/types/binary-search.d.ts +1 -1
  50. package/node_modules/@jridgewell/trace-mapping/dist/types/by-source.d.ts +1 -1
  51. package/node_modules/@jridgewell/trace-mapping/dist/types/sourcemap-segment.d.ts +8 -8
  52. package/node_modules/@jridgewell/trace-mapping/dist/types/trace-mapping.d.ts +33 -28
  53. package/node_modules/@jridgewell/trace-mapping/dist/types/types.d.ts +23 -16
  54. package/node_modules/@jridgewell/trace-mapping/package.json +20 -18
  55. package/node_modules/anymatch/index.d.ts +1 -0
  56. package/node_modules/anymatch/index.js +1 -1
  57. package/node_modules/anymatch/package.json +1 -1
  58. package/node_modules/{form-data/README.md.bak → axios/node_modules/form-data/Readme.md} +4 -4
  59. package/node_modules/{superagent → axios}/node_modules/form-data/lib/form_data.js +8 -5
  60. package/node_modules/{superagent → axios}/node_modules/form-data/package.json +9 -6
  61. package/node_modules/binary-extensions/binary-extensions.json +3 -0
  62. package/node_modules/binary-extensions/license +2 -1
  63. package/node_modules/binary-extensions/package.json +4 -2
  64. package/node_modules/binary-extensions/readme.md +2 -18
  65. package/node_modules/braces/LICENSE +1 -1
  66. package/node_modules/braces/README.md +91 -98
  67. package/node_modules/braces/index.js +3 -3
  68. package/node_modules/braces/lib/compile.js +14 -11
  69. package/node_modules/braces/lib/constants.js +1 -1
  70. package/node_modules/braces/lib/expand.js +9 -9
  71. package/node_modules/braces/lib/parse.js +14 -16
  72. package/node_modules/braces/lib/stringify.js +4 -4
  73. package/node_modules/braces/lib/utils.js +13 -3
  74. package/node_modules/braces/package.json +2 -2
  75. package/node_modules/{call-bind → call-bind-apply-helpers}/.eslintrc +0 -1
  76. package/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
  77. package/node_modules/call-bind-apply-helpers/.nycrc +9 -0
  78. package/node_modules/call-bind-apply-helpers/CHANGELOG.md +23 -0
  79. package/node_modules/{call-bind → call-bind-apply-helpers}/LICENSE +1 -1
  80. package/node_modules/call-bind-apply-helpers/README.md +62 -0
  81. package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
  82. package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
  83. package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
  84. package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
  85. package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
  86. package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
  87. package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
  88. package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
  89. package/node_modules/call-bind-apply-helpers/index.d.ts +46 -0
  90. package/node_modules/call-bind-apply-helpers/index.js +15 -0
  91. package/node_modules/call-bind-apply-helpers/package.json +85 -0
  92. package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
  93. package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
  94. package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
  95. package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
  96. package/node_modules/call-bound/.eslintrc +13 -0
  97. package/node_modules/call-bound/.github/FUNDING.yml +12 -0
  98. package/node_modules/call-bound/.nycrc +9 -0
  99. package/node_modules/call-bound/CHANGELOG.md +34 -0
  100. package/node_modules/call-bound/LICENSE +21 -0
  101. package/node_modules/call-bound/README.md +53 -0
  102. package/node_modules/call-bound/index.d.ts +13 -0
  103. package/node_modules/call-bound/index.js +18 -0
  104. package/node_modules/call-bound/package.json +99 -0
  105. package/node_modules/{call-bind/test/callBound.js → call-bound/test/index.js} +1 -2
  106. package/node_modules/call-bound/tsconfig.json +9 -0
  107. package/node_modules/chokidar/README.md +1 -1
  108. package/node_modules/chokidar/index.js +1 -1
  109. package/node_modules/chokidar/lib/constants.js +1 -0
  110. package/node_modules/chokidar/lib/fsevents-handler.js +2 -0
  111. package/node_modules/chokidar/package.json +5 -20
  112. package/node_modules/chokidar/types/index.d.ts +4 -0
  113. package/node_modules/cliui/CHANGELOG.md +18 -0
  114. package/node_modules/cliui/build/index.d.cts +43 -0
  115. package/node_modules/cliui/package.json +6 -6
  116. package/node_modules/commander/CHANGELOG.md +361 -0
  117. package/node_modules/{@babel/cli/node_modules/commander → commander}/Readme.md +243 -165
  118. package/node_modules/commander/index.js +1881 -0
  119. package/node_modules/{@babel/cli/node_modules/commander → commander}/package.json +19 -9
  120. package/node_modules/commander/typings/index.d.ts +410 -0
  121. package/node_modules/component-emitter/LICENSE +24 -24
  122. package/node_modules/component-emitter/Readme.md +74 -74
  123. package/node_modules/component-emitter/index.js +175 -175
  124. package/node_modules/component-emitter/package.json +3 -2
  125. package/node_modules/convert-source-map/README.md +97 -11
  126. package/node_modules/convert-source-map/index.js +127 -30
  127. package/node_modules/convert-source-map/package.json +3 -9
  128. package/node_modules/cookiejar/cookiejar.js +5 -0
  129. package/node_modules/cookiejar/package.json +1 -1
  130. package/node_modules/debug/README.md +1 -1
  131. package/node_modules/debug/package.json +10 -4
  132. package/node_modules/debug/src/browser.js +4 -1
  133. package/node_modules/debug/src/common.js +57 -39
  134. package/node_modules/debug/src/node.js +2 -2
  135. package/node_modules/dotenv/CHANGELOG.md +133 -1
  136. package/node_modules/dotenv/README-es.md +448 -0
  137. package/node_modules/dotenv/README.md +309 -66
  138. package/node_modules/dotenv/lib/cli-options.js +1 -1
  139. package/node_modules/dotenv/lib/env-options.js +4 -0
  140. package/node_modules/dotenv/lib/main.d.ts +85 -5
  141. package/node_modules/dotenv/lib/main.js +287 -35
  142. package/node_modules/dotenv/package.json +19 -14
  143. package/node_modules/dunder-proto/.eslintrc +5 -0
  144. package/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
  145. package/node_modules/dunder-proto/CHANGELOG.md +24 -0
  146. package/node_modules/dunder-proto/LICENSE +21 -0
  147. package/node_modules/dunder-proto/README.md +54 -0
  148. package/node_modules/dunder-proto/get.d.ts +5 -0
  149. package/node_modules/dunder-proto/get.js +30 -0
  150. package/node_modules/dunder-proto/package.json +76 -0
  151. package/node_modules/dunder-proto/set.d.ts +5 -0
  152. package/node_modules/dunder-proto/set.js +35 -0
  153. package/node_modules/dunder-proto/test/get.js +34 -0
  154. package/node_modules/dunder-proto/test/index.js +4 -0
  155. package/node_modules/dunder-proto/test/set.js +50 -0
  156. package/node_modules/dunder-proto/tsconfig.json +9 -0
  157. package/node_modules/es-define-property/.eslintrc +13 -0
  158. package/node_modules/es-define-property/.github/FUNDING.yml +12 -0
  159. package/node_modules/es-define-property/.nycrc +9 -0
  160. package/node_modules/es-define-property/CHANGELOG.md +29 -0
  161. package/node_modules/es-define-property/LICENSE +21 -0
  162. package/node_modules/es-define-property/README.md +49 -0
  163. package/node_modules/es-define-property/index.d.ts +3 -0
  164. package/node_modules/es-define-property/index.js +14 -0
  165. package/node_modules/es-define-property/package.json +81 -0
  166. package/node_modules/es-define-property/test/index.js +56 -0
  167. package/node_modules/es-define-property/tsconfig.json +10 -0
  168. package/node_modules/es-errors/.eslintrc +5 -0
  169. package/node_modules/es-errors/.github/FUNDING.yml +12 -0
  170. package/node_modules/es-errors/CHANGELOG.md +40 -0
  171. package/node_modules/es-errors/LICENSE +21 -0
  172. package/node_modules/es-errors/README.md +55 -0
  173. package/node_modules/es-errors/eval.d.ts +3 -0
  174. package/node_modules/es-errors/eval.js +4 -0
  175. package/node_modules/es-errors/index.d.ts +3 -0
  176. package/node_modules/es-errors/index.js +4 -0
  177. package/node_modules/es-errors/package.json +80 -0
  178. package/node_modules/es-errors/range.d.ts +3 -0
  179. package/node_modules/es-errors/range.js +4 -0
  180. package/node_modules/es-errors/ref.d.ts +3 -0
  181. package/node_modules/es-errors/ref.js +4 -0
  182. package/node_modules/es-errors/syntax.d.ts +3 -0
  183. package/node_modules/es-errors/syntax.js +4 -0
  184. package/node_modules/es-errors/test/index.js +19 -0
  185. package/node_modules/es-errors/tsconfig.json +49 -0
  186. package/node_modules/es-errors/type.d.ts +3 -0
  187. package/node_modules/es-errors/type.js +4 -0
  188. package/node_modules/es-errors/uri.d.ts +3 -0
  189. package/node_modules/es-errors/uri.js +4 -0
  190. package/node_modules/es-object-atoms/.eslintrc +16 -0
  191. package/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
  192. package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
  193. package/node_modules/es-object-atoms/LICENSE +21 -0
  194. package/node_modules/es-object-atoms/README.md +63 -0
  195. package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
  196. package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
  197. package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
  198. package/node_modules/es-object-atoms/ToObject.js +10 -0
  199. package/node_modules/es-object-atoms/index.d.ts +3 -0
  200. package/node_modules/es-object-atoms/index.js +4 -0
  201. package/node_modules/es-object-atoms/isObject.d.ts +3 -0
  202. package/node_modules/es-object-atoms/isObject.js +6 -0
  203. package/node_modules/es-object-atoms/package.json +80 -0
  204. package/node_modules/es-object-atoms/test/index.js +38 -0
  205. package/node_modules/es-object-atoms/tsconfig.json +6 -0
  206. package/node_modules/escalade/index.d.mts +11 -0
  207. package/node_modules/escalade/index.d.ts +14 -2
  208. package/node_modules/escalade/package.json +18 -5
  209. package/node_modules/escalade/readme.md +1 -1
  210. package/node_modules/escalade/sync/index.d.mts +9 -0
  211. package/node_modules/escalade/sync/index.d.ts +13 -2
  212. package/node_modules/fill-range/index.js +4 -5
  213. package/node_modules/fill-range/package.json +8 -3
  214. package/node_modules/follow-redirects/index.js +186 -98
  215. package/node_modules/follow-redirects/package.json +3 -4
  216. package/node_modules/form-data/Readme.md +5 -7
  217. package/node_modules/form-data/lib/form_data.js +5 -8
  218. package/node_modules/form-data/package.json +9 -6
  219. package/node_modules/function-bind/.eslintrc +11 -5
  220. package/node_modules/function-bind/.github/FUNDING.yml +12 -0
  221. package/node_modules/function-bind/.github/SECURITY.md +3 -0
  222. package/node_modules/function-bind/.nycrc +13 -0
  223. package/node_modules/function-bind/CHANGELOG.md +136 -0
  224. package/node_modules/function-bind/README.md +25 -27
  225. package/node_modules/function-bind/implementation.js +44 -12
  226. package/node_modules/function-bind/package.json +38 -14
  227. package/node_modules/get-intrinsic/.eslintrc +1 -0
  228. package/node_modules/get-intrinsic/CHANGELOG.md +87 -0
  229. package/node_modules/get-intrinsic/index.js +75 -32
  230. package/node_modules/get-intrinsic/package.json +31 -22
  231. package/node_modules/get-intrinsic/test/GetIntrinsic.js +3 -3
  232. package/node_modules/get-proto/.eslintrc +10 -0
  233. package/node_modules/{call-bind → get-proto}/.github/FUNDING.yml +1 -1
  234. package/node_modules/get-proto/.nycrc +9 -0
  235. package/node_modules/get-proto/CHANGELOG.md +21 -0
  236. package/node_modules/get-proto/LICENSE +21 -0
  237. package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
  238. package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
  239. package/node_modules/get-proto/README.md +50 -0
  240. package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
  241. package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
  242. package/node_modules/get-proto/index.d.ts +5 -0
  243. package/node_modules/get-proto/index.js +27 -0
  244. package/node_modules/get-proto/package.json +81 -0
  245. package/node_modules/get-proto/test/index.js +68 -0
  246. package/node_modules/get-proto/tsconfig.json +9 -0
  247. package/node_modules/gopd/.eslintrc +16 -0
  248. package/node_modules/gopd/.github/FUNDING.yml +12 -0
  249. package/node_modules/gopd/CHANGELOG.md +45 -0
  250. package/node_modules/gopd/LICENSE +21 -0
  251. package/node_modules/gopd/README.md +40 -0
  252. package/node_modules/gopd/gOPD.d.ts +1 -0
  253. package/node_modules/gopd/gOPD.js +4 -0
  254. package/node_modules/gopd/index.d.ts +5 -0
  255. package/node_modules/gopd/index.js +15 -0
  256. package/node_modules/gopd/package.json +77 -0
  257. package/node_modules/gopd/test/index.js +36 -0
  258. package/node_modules/gopd/tsconfig.json +9 -0
  259. package/node_modules/has-symbols/CHANGELOG.md +16 -0
  260. package/node_modules/has-symbols/index.d.ts +3 -0
  261. package/node_modules/has-symbols/index.js +1 -0
  262. package/node_modules/has-symbols/package.json +19 -9
  263. package/node_modules/has-symbols/shams.d.ts +3 -0
  264. package/node_modules/has-symbols/shams.js +5 -2
  265. package/node_modules/has-symbols/test/shams/core-js.js +1 -0
  266. package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +1 -0
  267. package/node_modules/has-symbols/test/tests.js +4 -2
  268. package/node_modules/has-symbols/tsconfig.json +10 -0
  269. package/node_modules/hasown/.eslintrc +5 -0
  270. package/node_modules/hasown/.github/FUNDING.yml +12 -0
  271. package/node_modules/hasown/.nycrc +13 -0
  272. package/node_modules/hasown/CHANGELOG.md +40 -0
  273. package/node_modules/hasown/LICENSE +21 -0
  274. package/node_modules/hasown/README.md +40 -0
  275. package/node_modules/hasown/index.d.ts +3 -0
  276. package/node_modules/hasown/index.js +8 -0
  277. package/node_modules/hasown/package.json +92 -0
  278. package/node_modules/hasown/tsconfig.json +6 -0
  279. package/node_modules/make-dir/node_modules/semver/package.json +38 -0
  280. package/node_modules/{@babel/cli → make-dir}/node_modules/semver/semver.js +68 -26
  281. package/node_modules/math-intrinsics/.eslintrc +16 -0
  282. package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
  283. package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
  284. package/node_modules/math-intrinsics/LICENSE +21 -0
  285. package/node_modules/math-intrinsics/README.md +50 -0
  286. package/node_modules/math-intrinsics/abs.d.ts +1 -0
  287. package/node_modules/math-intrinsics/abs.js +4 -0
  288. package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
  289. package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
  290. package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
  291. package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
  292. package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
  293. package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
  294. package/node_modules/math-intrinsics/floor.d.ts +1 -0
  295. package/node_modules/math-intrinsics/floor.js +4 -0
  296. package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
  297. package/node_modules/math-intrinsics/isFinite.js +12 -0
  298. package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
  299. package/node_modules/math-intrinsics/isInteger.js +16 -0
  300. package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
  301. package/node_modules/math-intrinsics/isNaN.js +6 -0
  302. package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
  303. package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
  304. package/node_modules/math-intrinsics/max.d.ts +1 -0
  305. package/node_modules/math-intrinsics/max.js +4 -0
  306. package/node_modules/math-intrinsics/min.d.ts +1 -0
  307. package/node_modules/math-intrinsics/min.js +4 -0
  308. package/node_modules/math-intrinsics/mod.d.ts +3 -0
  309. package/node_modules/math-intrinsics/mod.js +9 -0
  310. package/node_modules/math-intrinsics/package.json +86 -0
  311. package/node_modules/math-intrinsics/pow.d.ts +1 -0
  312. package/node_modules/math-intrinsics/pow.js +4 -0
  313. package/node_modules/math-intrinsics/round.d.ts +1 -0
  314. package/node_modules/math-intrinsics/round.js +4 -0
  315. package/node_modules/math-intrinsics/sign.d.ts +3 -0
  316. package/node_modules/math-intrinsics/sign.js +11 -0
  317. package/node_modules/math-intrinsics/test/index.js +192 -0
  318. package/node_modules/math-intrinsics/tsconfig.json +3 -0
  319. package/node_modules/ms/index.js +1 -1
  320. package/node_modules/ms/license.md +1 -1
  321. package/node_modules/ms/package.json +5 -4
  322. package/node_modules/ms/readme.md +1 -2
  323. package/node_modules/object-inspect/CHANGELOG.md +56 -0
  324. package/node_modules/object-inspect/index.js +38 -9
  325. package/node_modules/object-inspect/package.json +23 -13
  326. package/node_modules/object-inspect/readme.markdown +9 -11
  327. package/node_modules/object-inspect/test/global.js +17 -0
  328. package/node_modules/object-inspect/test/quoteStyle.js +9 -0
  329. package/node_modules/qs/.editorconfig +3 -0
  330. package/node_modules/qs/.eslintrc +3 -2
  331. package/node_modules/qs/CHANGELOG.md +81 -5
  332. package/node_modules/qs/README.md +158 -50
  333. package/node_modules/qs/dist/qs.js +90 -2003
  334. package/node_modules/qs/lib/parse.js +89 -24
  335. package/node_modules/qs/lib/stringify.js +61 -31
  336. package/node_modules/qs/lib/utils.js +54 -38
  337. package/node_modules/qs/package.json +29 -13
  338. package/node_modules/qs/test/empty-keys-cases.js +267 -0
  339. package/node_modules/qs/test/parse.js +468 -47
  340. package/node_modules/qs/test/stringify.js +454 -57
  341. package/node_modules/qs/test/utils.js +126 -0
  342. package/node_modules/side-channel/.editorconfig +9 -0
  343. package/node_modules/side-channel/.eslintrc +2 -1
  344. package/node_modules/side-channel/CHANGELOG.md +45 -0
  345. package/node_modules/side-channel/README.md +60 -1
  346. package/node_modules/side-channel/index.d.ts +14 -0
  347. package/node_modules/side-channel/index.js +21 -102
  348. package/node_modules/side-channel/package.json +40 -22
  349. package/node_modules/side-channel/test/index.js +78 -52
  350. package/node_modules/side-channel/tsconfig.json +9 -0
  351. package/node_modules/{function-bind → side-channel-list}/.editorconfig +3 -14
  352. package/node_modules/side-channel-list/.eslintrc +11 -0
  353. package/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
  354. package/node_modules/side-channel-list/.nycrc +13 -0
  355. package/node_modules/side-channel-list/CHANGELOG.md +15 -0
  356. package/node_modules/side-channel-list/LICENSE +21 -0
  357. package/node_modules/side-channel-list/README.md +62 -0
  358. package/node_modules/side-channel-list/index.d.ts +13 -0
  359. package/node_modules/side-channel-list/index.js +113 -0
  360. package/node_modules/side-channel-list/list.d.ts +14 -0
  361. package/node_modules/side-channel-list/package.json +77 -0
  362. package/node_modules/side-channel-list/test/index.js +104 -0
  363. package/node_modules/side-channel-list/tsconfig.json +9 -0
  364. package/node_modules/side-channel-map/.editorconfig +9 -0
  365. package/node_modules/side-channel-map/.eslintrc +11 -0
  366. package/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
  367. package/node_modules/side-channel-map/.nycrc +13 -0
  368. package/node_modules/side-channel-map/CHANGELOG.md +22 -0
  369. package/node_modules/side-channel-map/LICENSE +21 -0
  370. package/node_modules/side-channel-map/README.md +62 -0
  371. package/node_modules/side-channel-map/index.d.ts +15 -0
  372. package/node_modules/side-channel-map/index.js +68 -0
  373. package/node_modules/side-channel-map/package.json +80 -0
  374. package/node_modules/side-channel-map/test/index.js +114 -0
  375. package/node_modules/side-channel-map/tsconfig.json +9 -0
  376. package/node_modules/side-channel-weakmap/.editorconfig +9 -0
  377. package/node_modules/side-channel-weakmap/.eslintrc +12 -0
  378. package/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
  379. package/node_modules/side-channel-weakmap/.nycrc +13 -0
  380. package/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
  381. package/node_modules/side-channel-weakmap/LICENSE +21 -0
  382. package/node_modules/side-channel-weakmap/README.md +62 -0
  383. package/node_modules/side-channel-weakmap/index.d.ts +15 -0
  384. package/node_modules/side-channel-weakmap/index.js +84 -0
  385. package/node_modules/side-channel-weakmap/package.json +87 -0
  386. package/node_modules/side-channel-weakmap/test/index.js +114 -0
  387. package/node_modules/side-channel-weakmap/tsconfig.json +9 -0
  388. package/node_modules/superagent/node_modules/readable-stream/README.md +1 -1
  389. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_duplex.js +12 -25
  390. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_passthrough.js +2 -4
  391. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_readable.js +176 -273
  392. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_transform.js +26 -37
  393. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_writable.js +118 -174
  394. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/async_iterator.js +10 -37
  395. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/buffer_list.js +20 -47
  396. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/destroy.js +8 -17
  397. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +1 -19
  398. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/from.js +12 -24
  399. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/pipeline.js +5 -16
  400. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/state.js +2 -7
  401. package/node_modules/superagent/node_modules/readable-stream/package.json +1 -1
  402. package/node_modules/{semver → superagent/node_modules/semver}/README.md +132 -36
  403. package/node_modules/{semver → superagent/node_modules/semver}/bin/semver.js +22 -16
  404. package/node_modules/{semver → superagent/node_modules/semver}/classes/comparator.js +39 -34
  405. package/node_modules/{semver → superagent/node_modules/semver}/classes/range.js +72 -37
  406. package/node_modules/{semver → superagent/node_modules/semver}/classes/semver.js +49 -19
  407. package/node_modules/{semver → superagent/node_modules/semver}/functions/coerce.js +14 -6
  408. package/node_modules/superagent/node_modules/semver/functions/diff.js +58 -0
  409. package/node_modules/{semver → superagent/node_modules/semver}/functions/inc.js +3 -2
  410. package/node_modules/superagent/node_modules/semver/functions/parse.js +16 -0
  411. package/node_modules/superagent/node_modules/semver/index.js +89 -0
  412. package/node_modules/{semver → superagent/node_modules/semver}/internal/constants.js +20 -2
  413. package/node_modules/superagent/node_modules/semver/internal/lrucache.js +40 -0
  414. package/node_modules/superagent/node_modules/semver/internal/parse-options.js +15 -0
  415. package/node_modules/{semver → superagent/node_modules/semver}/internal/re.js +41 -6
  416. package/node_modules/{semver → superagent/node_modules/semver}/package.json +29 -26
  417. package/node_modules/{semver → superagent/node_modules/semver}/ranges/intersects.js +1 -1
  418. package/node_modules/{semver → superagent/node_modules/semver}/ranges/subset.js +6 -3
  419. package/node_modules/yargs/browser.d.ts +5 -0
  420. package/node_modules/yargs/build/index.cjs +1 -1
  421. package/node_modules/yargs/build/lib/command.js +2 -0
  422. package/node_modules/yargs/build/lib/completion.js +19 -12
  423. package/node_modules/yargs/build/lib/usage.js +9 -4
  424. package/node_modules/yargs/build/lib/yargs-factory.js +18 -3
  425. package/node_modules/yargs/locales/cs.json +51 -0
  426. package/node_modules/yargs/locales/en.json +4 -0
  427. package/node_modules/yargs/locales/fi.json +1 -1
  428. package/node_modules/yargs/package.json +4 -4
  429. package/node_modules/yargs-parser/CHANGELOG.md +21 -0
  430. package/node_modules/yargs-parser/build/index.cjs +6 -4
  431. package/node_modules/yargs-parser/build/lib/index.js +4 -2
  432. package/node_modules/yargs-parser/build/lib/yargs-parser.js +2 -2
  433. package/node_modules/yargs-parser/package.json +10 -6
  434. package/output/e3e8277b426d4bc636a8ed30e66dd056e6cc9691-corellium-cli-build.tar.gz +0 -0
  435. package/package.json +1 -1
  436. package/renovate.json +11 -58
  437. package/src/clients/Agent.js +40 -37
  438. package/src/clients/Client.js +42 -40
  439. package/src/clients/Instance.js +24 -24
  440. package/src/clients/Webplayer.js +23 -24
  441. package/src/commands/extensions/delete.js +26 -26
  442. package/src/commands/extensions/index.js +6 -11
  443. package/src/commands/extensions/list.js +25 -25
  444. package/src/commands/extensions/load.js +51 -50
  445. package/src/commands/extensions/validate.js +33 -38
  446. package/src/commands/firmware/index.js +6 -9
  447. package/src/commands/firmware/list.js +49 -38
  448. package/src/commands/firmware/load.js +45 -42
  449. package/src/commands/images/create.js +30 -29
  450. package/src/commands/images/delete.js +21 -21
  451. package/src/commands/images/index.js +6 -10
  452. package/src/commands/images/list.js +21 -20
  453. package/src/commands/index.js +2 -2
  454. package/src/commands/instances/apps/index.js +26 -23
  455. package/src/commands/instances/apps/install.js +14 -14
  456. package/src/commands/instances/apps/open.js +17 -17
  457. package/src/commands/instances/create.js +65 -26
  458. package/src/commands/instances/delete.js +24 -25
  459. package/src/commands/instances/file.js +36 -32
  460. package/src/commands/instances/get.js +23 -16
  461. package/src/commands/instances/index.js +8 -8
  462. package/src/commands/instances/input.js +16 -17
  463. package/src/commands/instances/list.js +38 -28
  464. package/src/commands/instances/netmon/disable.js +17 -15
  465. package/src/commands/instances/netmon/download.js +18 -16
  466. package/src/commands/instances/netmon/enable.js +30 -23
  467. package/src/commands/instances/netmon/index.js +6 -11
  468. package/src/commands/instances/netmon/stream.js +18 -16
  469. package/src/commands/instances/ready.js +30 -27
  470. package/src/commands/instances/restoreBackup.js +39 -36
  471. package/src/commands/instances/rotate.js +20 -21
  472. package/src/commands/instances/start.js +23 -24
  473. package/src/commands/instances/stop.js +20 -21
  474. package/src/commands/instances/unlock.js +17 -19
  475. package/src/commands/instances/upgrade.js +38 -34
  476. package/src/commands/login.js +67 -67
  477. package/src/commands/logout.js +10 -12
  478. package/src/commands/mast/constants.js +2 -2
  479. package/src/commands/mast/create-assessment.js +16 -16
  480. package/src/commands/mast/delete-assessment.js +15 -15
  481. package/src/commands/mast/download-report.js +18 -15
  482. package/src/commands/mast/get-assessment.js +14 -14
  483. package/src/commands/mast/get-assessments.js +13 -13
  484. package/src/commands/mast/index.js +7 -7
  485. package/src/commands/mast/start-monitor.js +15 -15
  486. package/src/commands/mast/stop-monitor.js +15 -15
  487. package/src/commands/mast/test.js +19 -16
  488. package/src/commands/projects/create.js +33 -32
  489. package/src/commands/projects/delete.js +26 -26
  490. package/src/commands/projects/index.js +6 -10
  491. package/src/commands/projects/list.js +21 -19
  492. package/src/commands/projects/vpnConfig.js +43 -0
  493. package/src/commands/webplayer/create.js +57 -50
  494. package/src/commands/webplayer/destroy.js +31 -28
  495. package/src/commands/webplayer/index.js +6 -11
  496. package/src/commands/webplayer/list.js +41 -42
  497. package/src/commands/webplayer/login.js +31 -28
  498. package/src/corellium-api.js +11 -11
  499. package/src/error.js +20 -18
  500. package/src/logging.js +15 -15
  501. package/src/profile.js +22 -22
  502. package/src/progress.js +6 -6
  503. package/src/resumable.js +606 -664
  504. package/src/table.js +20 -22
  505. package/src/upload.js +38 -38
  506. package/src/utils.js +63 -64
  507. package/test/test.js +53 -38
  508. package/coverage/cobertura-coverage.xml +0 -9
  509. package/coverage/lcov-report/base.css +0 -224
  510. package/coverage/lcov-report/block-navigation.js +0 -87
  511. package/coverage/lcov-report/favicon.png +0 -0
  512. package/coverage/lcov-report/index.html +0 -101
  513. package/coverage/lcov-report/prettify.css +0 -1
  514. package/coverage/lcov-report/prettify.js +0 -2
  515. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  516. package/coverage/lcov-report/sorter.js +0 -196
  517. package/coverage/lcov.info +0 -0
  518. package/node_modules/@babel/cli/node_modules/commander/CHANGELOG.md +0 -436
  519. package/node_modules/@babel/cli/node_modules/commander/index.js +0 -1649
  520. package/node_modules/@babel/cli/node_modules/commander/typings/index.d.ts +0 -311
  521. package/node_modules/@babel/cli/node_modules/semver/CHANGELOG.md +0 -39
  522. package/node_modules/@babel/cli/node_modules/semver/package.json +0 -28
  523. package/node_modules/@jridgewell/sourcemap-codec/src/sourcemap-codec.ts +0 -198
  524. package/node_modules/braces/CHANGELOG.md +0 -184
  525. package/node_modules/call-bind/.eslintignore +0 -1
  526. package/node_modules/call-bind/CHANGELOG.md +0 -42
  527. package/node_modules/call-bind/README.md +0 -2
  528. package/node_modules/call-bind/callBound.js +0 -15
  529. package/node_modules/call-bind/index.js +0 -47
  530. package/node_modules/call-bind/package.json +0 -80
  531. package/node_modules/call-bind/test/index.js +0 -66
  532. package/node_modules/component-emitter/History.md +0 -75
  533. package/node_modules/function-bind/.jscs.json +0 -176
  534. package/node_modules/function-bind/.npmignore +0 -22
  535. package/node_modules/function-bind/.travis.yml +0 -168
  536. package/node_modules/has/LICENSE-MIT +0 -22
  537. package/node_modules/has/README.md +0 -18
  538. package/node_modules/has/package.json +0 -48
  539. package/node_modules/has/src/index.js +0 -5
  540. package/node_modules/has/test/index.js +0 -10
  541. package/node_modules/lru-cache/README.md +0 -166
  542. package/node_modules/lru-cache/index.js +0 -334
  543. package/node_modules/lru-cache/package.json +0 -34
  544. package/node_modules/semver/LICENSE +0 -15
  545. package/node_modules/semver/functions/diff.js +0 -23
  546. package/node_modules/semver/functions/parse.js +0 -33
  547. package/node_modules/semver/index.js +0 -48
  548. package/node_modules/semver/internal/parse-options.js +0 -11
  549. package/node_modules/side-channel/.eslintignore +0 -1
  550. package/node_modules/superagent/node_modules/form-data/README.md.bak +0 -356
  551. package/node_modules/superagent/node_modules/form-data/Readme.md +0 -356
  552. package/node_modules/yallist/LICENSE +0 -15
  553. package/node_modules/yallist/README.md +0 -204
  554. package/node_modules/yallist/iterator.js +0 -8
  555. package/node_modules/yallist/package.json +0 -29
  556. package/node_modules/yallist/yallist.js +0 -426
  557. /package/node_modules/{superagent → axios}/node_modules/form-data/License +0 -0
  558. /package/node_modules/{superagent → axios}/node_modules/form-data/index.d.ts +0 -0
  559. /package/node_modules/{superagent → axios}/node_modules/form-data/lib/browser.js +0 -0
  560. /package/node_modules/{superagent → axios}/node_modules/form-data/lib/populate.js +0 -0
  561. /package/node_modules/{@babel/cli/node_modules/commander → commander}/LICENSE +0 -0
  562. /package/node_modules/{call-bind → dunder-proto}/.nycrc +0 -0
  563. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.d.ts +0 -0
  564. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.js +0 -0
  565. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/license +0 -0
  566. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/LICENSE +0 -0
  567. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/README.md +0 -0
  568. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/bin/semver +0 -0
  569. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/range.bnf +0 -0
  570. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/package.json +0 -0
  571. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/readme.md +0 -0
  572. /package/node_modules/{@babel/cli/node_modules/pify → pify}/index.js +0 -0
  573. /package/node_modules/{@babel/cli/node_modules/pify → pify}/license +0 -0
  574. /package/node_modules/{@babel/cli/node_modules/pify → pify}/package.json +0 -0
  575. /package/node_modules/{@babel/cli/node_modules/pify → pify}/readme.md +0 -0
  576. /package/node_modules/{@babel/cli/node_modules/slash → slash}/index.js +0 -0
  577. /package/node_modules/{@babel/cli/node_modules/slash → slash}/license +0 -0
  578. /package/node_modules/{@babel/cli/node_modules/slash → slash}/package.json +0 -0
  579. /package/node_modules/{@babel/cli/node_modules/slash → slash}/readme.md +0 -0
  580. /package/node_modules/{lru-cache → superagent/node_modules/semver}/LICENSE +0 -0
  581. /package/node_modules/{semver → superagent/node_modules/semver}/classes/index.js +0 -0
  582. /package/node_modules/{semver → superagent/node_modules/semver}/functions/clean.js +0 -0
  583. /package/node_modules/{semver → superagent/node_modules/semver}/functions/cmp.js +0 -0
  584. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-build.js +0 -0
  585. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-loose.js +0 -0
  586. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare.js +0 -0
  587. /package/node_modules/{semver → superagent/node_modules/semver}/functions/eq.js +0 -0
  588. /package/node_modules/{semver → superagent/node_modules/semver}/functions/gt.js +0 -0
  589. /package/node_modules/{semver → superagent/node_modules/semver}/functions/gte.js +0 -0
  590. /package/node_modules/{semver → superagent/node_modules/semver}/functions/lt.js +0 -0
  591. /package/node_modules/{semver → superagent/node_modules/semver}/functions/lte.js +0 -0
  592. /package/node_modules/{semver → superagent/node_modules/semver}/functions/major.js +0 -0
  593. /package/node_modules/{semver → superagent/node_modules/semver}/functions/minor.js +0 -0
  594. /package/node_modules/{semver → superagent/node_modules/semver}/functions/neq.js +0 -0
  595. /package/node_modules/{semver → superagent/node_modules/semver}/functions/patch.js +0 -0
  596. /package/node_modules/{semver → superagent/node_modules/semver}/functions/prerelease.js +0 -0
  597. /package/node_modules/{semver → superagent/node_modules/semver}/functions/rcompare.js +0 -0
  598. /package/node_modules/{semver → superagent/node_modules/semver}/functions/rsort.js +0 -0
  599. /package/node_modules/{semver → superagent/node_modules/semver}/functions/satisfies.js +0 -0
  600. /package/node_modules/{semver → superagent/node_modules/semver}/functions/sort.js +0 -0
  601. /package/node_modules/{semver → superagent/node_modules/semver}/functions/valid.js +0 -0
  602. /package/node_modules/{semver → superagent/node_modules/semver}/internal/debug.js +0 -0
  603. /package/node_modules/{semver → superagent/node_modules/semver}/internal/identifiers.js +0 -0
  604. /package/node_modules/{semver → superagent/node_modules/semver}/preload.js +0 -0
  605. /package/node_modules/{semver → superagent/node_modules/semver}/range.bnf +0 -0
  606. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/gtr.js +0 -0
  607. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/ltr.js +0 -0
  608. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/max-satisfying.js +0 -0
  609. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-satisfying.js +0 -0
  610. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-version.js +0 -0
  611. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/outside.js +0 -0
  612. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/simplify.js +0 -0
  613. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/to-comparators.js +0 -0
  614. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/valid.js +0 -0
@@ -5,42 +5,49 @@
5
5
  [![NPM Downloads](https://img.shields.io/npm/dm/commander.svg?style=flat)](https://npmcharts.com/compare/commander?minimal=true)
6
6
  [![Install Size](https://packagephobia.now.sh/badge?p=commander)](https://packagephobia.now.sh/result?p=commander)
7
7
 
8
- The complete solution for [node.js](http://nodejs.org) command-line interfaces, inspired by Ruby's [commander](https://github.com/commander-rb/commander).
8
+ The complete solution for [node.js](http://nodejs.org) command-line interfaces.
9
9
 
10
10
  Read this in other languages: English | [简体中文](./Readme_zh-CN.md)
11
11
 
12
12
  - [Commander.js](#commanderjs)
13
13
  - [Installation](#installation)
14
- - [Declaring program variable](#declaring-program-variable)
14
+ - [Declaring _program_ variable](#declaring-program-variable)
15
15
  - [Options](#options)
16
16
  - [Common option types, boolean and value](#common-option-types-boolean-and-value)
17
17
  - [Default option value](#default-option-value)
18
- - [Other option types, negatable boolean and flag|value](#other-option-types-negatable-boolean-and-flagvalue)
18
+ - [Other option types, negatable boolean and boolean|value](#other-option-types-negatable-boolean-and-booleanvalue)
19
19
  - [Custom option processing](#custom-option-processing)
20
20
  - [Required option](#required-option)
21
+ - [Variadic option](#variadic-option)
21
22
  - [Version option](#version-option)
22
23
  - [Commands](#commands)
23
24
  - [Specify the argument syntax](#specify-the-argument-syntax)
24
25
  - [Action handler (sub)commands](#action-handler-subcommands)
25
- - [Git-style executable (sub)commands](#git-style-executable-subcommands)
26
- - [Automated --help](#automated---help)
26
+ - [Stand-alone executable (sub)commands](#stand-alone-executable-subcommands)
27
+ - [Automated help](#automated-help)
27
28
  - [Custom help](#custom-help)
28
29
  - [.usage and .name](#usage-and-name)
30
+ - [.help(cb)](#helpcb)
29
31
  - [.outputHelp(cb)](#outputhelpcb)
32
+ - [.helpInformation()](#helpinformation)
30
33
  - [.helpOption(flags, description)](#helpoptionflags-description)
31
- - [.help(cb)](#helpcb)
34
+ - [.addHelpCommand()](#addhelpcommand)
32
35
  - [Custom event listeners](#custom-event-listeners)
33
36
  - [Bits and pieces](#bits-and-pieces)
37
+ - [.parse() and .parseAsync()](#parse-and-parseasync)
34
38
  - [Avoiding option name clashes](#avoiding-option-name-clashes)
35
39
  - [TypeScript](#typescript)
36
- - [Node options such as --harmony](#node-options-such-as---harmony)
37
- - [Node debugging](#node-debugging)
40
+ - [createCommand()](#createcommand)
41
+ - [Import into ECMAScript Module](#import-into-ecmascript-module)
42
+ - [Node options such as `--harmony`](#node-options-such-as---harmony)
43
+ - [Debugging stand-alone executable subcommands](#debugging-stand-alone-executable-subcommands)
38
44
  - [Override exit handling](#override-exit-handling)
39
45
  - [Examples](#examples)
40
- - [License](#license)
41
46
  - [Support](#support)
42
47
  - [Commander for enterprise](#commander-for-enterprise)
43
48
 
49
+ For information about terms used in this document see: [terminology](./docs/terminology.md)
50
+
44
51
  ## Installation
45
52
 
46
53
  ```bash
@@ -53,33 +60,39 @@ Commander exports a global object which is convenient for quick programs.
53
60
  This is used in the examples in this README for brevity.
54
61
 
55
62
  ```js
56
- const program = require('commander');
63
+ const { program } = require('commander');
57
64
  program.version('0.0.1');
58
65
  ```
59
66
 
60
67
  For larger programs which may use commander in multiple ways, including unit testing, it is better to create a local Command object to use.
61
68
 
62
- ```js
63
- const commander = require('commander');
64
- const program = new commander.Command();
65
- program.version('0.0.1');
66
- ```
69
+ ```js
70
+ const { Command } = require('commander');
71
+ const program = new Command();
72
+ program.version('0.0.1');
73
+ ```
67
74
 
68
75
  ## Options
69
76
 
70
- Options are defined with the `.option()` method, also serving as documentation for the options. Each option can have a short flag (single character) and a long name, separated by a comma or space.
77
+ Options are defined with the `.option()` method, also serving as documentation for the options. Each option can have a short flag (single character) and a long name, separated by a comma or space or vertical bar ('|').
78
+
79
+ The options can be accessed as properties on the Command object. Multi-word options such as "--template-engine" are camel-cased, becoming `program.templateEngine` etc. See also optional new behaviour to [avoid name clashes](#avoiding-option-name-clashes).
80
+
81
+ Multiple short flags may optionally be combined in a single argument following the dash: boolean flags, followed by a single option taking a value (possibly followed by the value).
82
+ For example `-a -b -p 80` may be written as `-ab -p80` or even `-abp80`.
71
83
 
72
- The options can be accessed as properties on the Command object. Multi-word options such as "--template-engine" are camel-cased, becoming `program.templateEngine` etc. Multiple short flags may be combined as a single arg, for example `-abc` is equivalent to `-a -b -c`.
84
+ You can use `--` to indicate the end of the options, and any remaining arguments will be used without being interpreted.
73
85
 
74
- See also optional new behaviour to [avoid name clashes](#avoiding-option-name-clashes).
86
+ Options on the command line are not positional, and can be specified before or after other arguments.
75
87
 
76
88
  ### Common option types, boolean and value
77
89
 
78
- The two most used option types are a boolean flag, and an option which takes a value (declared using angle brackets). Both are `undefined` unless specified on command line.
90
+ The two most used option types are a boolean option, and an option which takes its value
91
+ from the following argument (declared with angle brackets like `--expect <value>`). Both are `undefined` unless specified on command line.
79
92
 
80
- ```js
81
- const program = require('commander');
93
+ Example file: [options-common.js](./examples/options-common.js)
82
94
 
95
+ ```js
83
96
  program
84
97
  .option('-d, --debug', 'output extra debugging')
85
98
  .option('-s, --small', 'small pizza size')
@@ -109,15 +122,15 @@ pizza details:
109
122
  - cheese
110
123
  ```
111
124
 
112
- `program.parse(arguments)` processes the arguments, leaving any args not consumed by the options as the `program.args` array.
125
+ `program.parse(arguments)` processes the arguments, leaving any args not consumed by the program options in the `program.args` array.
113
126
 
114
127
  ### Default option value
115
128
 
116
129
  You can specify a default value for an option which takes a value.
117
130
 
118
- ```js
119
- const program = require('commander');
131
+ Example file: [options-defaults.js](./examples/options-defaults.js)
120
132
 
133
+ ```js
121
134
  program
122
135
  .option('-c, --cheese <type>', 'add the specified type of cheese', 'blue');
123
136
 
@@ -133,17 +146,17 @@ $ pizza-options --cheese stilton
133
146
  cheese: stilton
134
147
  ```
135
148
 
136
- ### Other option types, negatable boolean and flag|value
149
+ ### Other option types, negatable boolean and boolean|value
137
150
 
138
- You can specify a boolean option long name with a leading `no-` to set the option value to false when used.
151
+ You can define a boolean option long name with a leading `no-` to set the option value to false when used.
139
152
  Defined alone this also makes the option true by default.
140
153
 
141
154
  If you define `--foo` first, adding `--no-foo` does not change the default value from what it would
142
- otherwise be. You can specify a default boolean value for a boolean flag and it can be overridden on command line.
155
+ otherwise be. You can specify a default boolean value for a boolean option and it can be overridden on command line.
143
156
 
144
- ```js
145
- const program = require('commander');
157
+ Example file: [options-negatable.js](./examples/options-negatable.js)
146
158
 
159
+ ```js
147
160
  program
148
161
  .option('--no-sauce', 'Remove sauce')
149
162
  .option('--cheese <flavour>', 'cheese flavour', 'mozzarella')
@@ -166,11 +179,12 @@ $ pizza-options --no-sauce --no-cheese
166
179
  You ordered a pizza with no sauce and no cheese
167
180
  ```
168
181
 
169
- You can specify an option which functions as a flag but may also take a value (declared using square brackets).
182
+ You can specify an option which may be used as a boolean option but may optionally take an option-argument
183
+ (declared with square brackets like `--optional [value]`).
170
184
 
171
- ```js
172
- const program = require('commander');
185
+ Example file: [options-boolean-or-value.js](./examples/options-boolean-or-value.js)
173
186
 
187
+ ```js
174
188
  program
175
189
  .option('-c, --cheese [type]', 'Add cheese with optional type');
176
190
 
@@ -190,18 +204,20 @@ $ pizza-options --cheese mozzarella
190
204
  add cheese type mozzarella
191
205
  ```
192
206
 
207
+ For information about possible ambiguous cases, see [options taking varying arguments](./docs/options-taking-varying-arguments.md).
208
+
193
209
  ### Custom option processing
194
210
 
195
- You may specify a function to do custom processing of option values. The callback function receives two parameters, the user specified value and the
196
- previous value for the option. It returns the new value for the option.
211
+ You may specify a function to do custom processing of option-arguments. The callback function receives two parameters,
212
+ the user specified option-argument and the previous value for the option. It returns the new value for the option.
197
213
 
198
- This allows you to coerce the option value to the desired type, or accumulate values, or do entirely custom processing.
214
+ This allows you to coerce the option-argument to the desired type, or accumulate values, or do entirely custom processing.
199
215
 
200
- You can optionally specify the default/starting value for the option after the function.
216
+ You can optionally specify the default/starting value for the option after the function parameter.
201
217
 
202
- ```js
203
- const program = require('commander');
218
+ Example file: [options-custom-processing.js](./examples/options-custom-processing.js)
204
219
 
220
+ ```js
205
221
  function myParseInt(value, dummyPrevious) {
206
222
  // parseInt takes a string and an optional radix
207
223
  return parseInt(value);
@@ -251,22 +267,56 @@ $ custom --list x,y,z
251
267
 
252
268
  ### Required option
253
269
 
254
- You may specify a required (mandatory) option using `.requiredOption`. The option must be specified on the command line, or by having a default value. The method is otherwise the same as `.option` in format, taking flags and description, and optional default value or custom processing.
270
+ You may specify a required (mandatory) option using `.requiredOption`. The option must have a value after parsing, usually specified on the command line, or perhaps from a default value (say from environment). The method is otherwise the same as `.option` in format, taking flags and description, and optional default value or custom processing.
255
271
 
256
- ```js
257
- const program = require('commander');
272
+ Example file: [options-required.js](./examples/options-required.js)
258
273
 
274
+ ```js
259
275
  program
260
276
  .requiredOption('-c, --cheese <type>', 'pizza must have cheese');
261
277
 
262
278
  program.parse(process.argv);
263
279
  ```
264
280
 
265
- ```
281
+ ```bash
266
282
  $ pizza
267
283
  error: required option '-c, --cheese <type>' not specified
268
284
  ```
269
285
 
286
+ ### Variadic option
287
+
288
+ You may make an option variadic by appending `...` to the value placeholder when declaring the option. On the command line you
289
+ can then specify multiple option-arguments, and the parsed option value will be an array. The extra arguments
290
+ are read until the first argument starting with a dash. The special argument `--` stops option processing entirely. If a value
291
+ is specified in the same argument as the option then no further values are read.
292
+
293
+ Example file: [options-variadic.js](./examples/options-variadic.js)
294
+
295
+ ```js
296
+ program
297
+ .option('-n, --number <numbers...>', 'specify numbers')
298
+ .option('-l, --letter [letters...]', 'specify letters');
299
+
300
+ program.parse();
301
+
302
+ console.log('Options: ', program.opts());
303
+ console.log('Remaining arguments: ', program.args);
304
+ ```
305
+
306
+ ```bash
307
+ $ collect -n 1 2 3 --letter a b c
308
+ Options: { number: [ '1', '2', '3' ], letter: [ 'a', 'b', 'c' ] }
309
+ Remaining arguments: []
310
+ $ collect --letter=A -n80 operand
311
+ Options: { number: [ '80' ], letter: [ 'A' ] }
312
+ Remaining arguments: [ 'operand' ]
313
+ $ collect --letter -n 1 -n 2 3 -- operand
314
+ Options: { number: [ '1', '2', '3' ], letter: true }
315
+ Remaining arguments: [ 'operand' ]
316
+ ```
317
+
318
+ For information about possible ambiguous cases, see [options taking varying arguments](./docs/options-taking-varying-arguments.md).
319
+
270
320
  ### Version option
271
321
 
272
322
  The optional `version` method adds handling for displaying the command version. The default option flags are `-V` and `--version`, and when present the command prints the version number and exits.
@@ -281,7 +331,7 @@ $ ./examples/pizza -V
281
331
  ```
282
332
 
283
333
  You may change the flags and description by passing additional parameters to the `version` method, using
284
- the same syntax for flags as the `option` method. The version flags can be named anything, but a long name is required.
334
+ the same syntax for flags as the `option` method.
285
335
 
286
336
  ```js
287
337
  program.version('0.0.1', '-v, --vers', 'output the current version');
@@ -289,7 +339,11 @@ program.version('0.0.1', '-v, --vers', 'output the current version');
289
339
 
290
340
  ## Commands
291
341
 
292
- You can specify (sub)commands for your top-level command using `.command`. There are two ways these can be implemented: using an action handler attached to the command, or as a separate executable file (described in more detail later). In the first parameter to `.command` you specify the command name and any command arguments. The arguments may be `<required>` or `[optional]`, and the last argument may also be `variadic...`.
342
+ You can specify (sub)commands using `.command()` or `.addCommand()`. There are two ways these can be implemented: using an action handler attached to the command, or as a stand-alone executable file (described in more detail later). The subcommands may be nested ([example](./examples/nestedCommands.js)).
343
+
344
+ In the first parameter to `.command()` you specify the command name and any command-arguments. The arguments may be `<required>` or `[optional]`, and the last argument may also be `variadic...`.
345
+
346
+ You can use `.addCommand()` to add an already configured subcommand to the program.
293
347
 
294
348
  For example:
295
349
 
@@ -303,43 +357,52 @@ program
303
357
  console.log('clone command called');
304
358
  });
305
359
 
306
- // Command implemented using separate executable file (description is second parameter to `.command`)
307
- // Returns top-level command for adding more commands.
360
+ // Command implemented using stand-alone executable file (description is second parameter to `.command`)
361
+ // Returns `this` for adding more commands.
308
362
  program
309
363
  .command('start <service>', 'start named service')
310
364
  .command('stop [service]', 'stop named service, or all if no name supplied');
365
+
366
+ // Command prepared separately.
367
+ // Returns `this` for adding more commands.
368
+ program
369
+ .addCommand(build.makeBuildCommand());
311
370
  ```
312
371
 
372
+ Configuration options can be passed with the call to `.command()` and `.addCommand()`. Specifying `hidden: true` will
373
+ remove the command from the generated help output. Specifying `isDefault: true` will run the subcommand if no other
374
+ subcommand is specified ([example](./examples/defaultCommand.js)).
375
+
313
376
  ### Specify the argument syntax
314
377
 
315
- You use `.arguments` to specify the arguments for the top-level command, and for subcommands they are included in the `.command` call. Angled brackets (e.g. `<required>`) indicate required input. Square brackets (e.g. `[optional]`) indicate optional input.
378
+ You use `.arguments` to specify the expected command-arguments for the top-level command, and for subcommands they are usually
379
+ included in the `.command` call. Angled brackets (e.g. `<required>`) indicate required command-arguments.
380
+ Square brackets (e.g. `[optional]`) indicate optional command-arguments.
381
+ You can optionally describe the arguments in the help by supplying a hash as second parameter to `.description()`.
316
382
 
317
- ```js
318
- const program = require('commander');
383
+ Example file: [env](./examples/env)
319
384
 
385
+ ```js
320
386
  program
321
387
  .version('0.1.0')
322
388
  .arguments('<cmd> [env]')
389
+ .description('test command', {
390
+ cmd: 'command to run',
391
+ env: 'environment to run test in'
392
+ })
323
393
  .action(function (cmd, env) {
324
- cmdValue = cmd;
325
- envValue = env;
394
+ console.log('command:', cmd);
395
+ console.log('environment:', env || 'no environment given');
326
396
  });
327
397
 
328
398
  program.parse(process.argv);
329
-
330
- if (typeof cmdValue === 'undefined') {
331
- console.error('no command given!');
332
- process.exit(1);
333
- }
334
- console.log('command:', cmdValue);
335
- console.log('environment:', envValue || "no environment given");
336
399
  ```
337
400
 
338
401
  The last argument of a command can be variadic, and only the last argument. To make an argument variadic you
339
402
  append `...` to the argument name. For example:
340
403
 
341
404
  ```js
342
- const program = require('commander');
405
+ const { program } = require('commander');
343
406
 
344
407
  program
345
408
  .version('0.1.0')
@@ -356,7 +419,7 @@ program
356
419
  program.parse(process.argv);
357
420
  ```
358
421
 
359
- The variadic argument is passed to the action handler as an array. (And this also applies to `program.args`.)
422
+ The variadic argument is passed to the action handler as an array.
360
423
 
361
424
  ### Action handler (sub)commands
362
425
 
@@ -365,7 +428,7 @@ The action handler gets passed a parameter for each argument you declared, and o
365
428
  command object itself. This command argument has the values for the command-specific options added as properties.
366
429
 
367
430
  ```js
368
- const program = require('commander');
431
+ const { program } = require('commander');
369
432
 
370
433
  program
371
434
  .command('rm <dir>')
@@ -390,42 +453,40 @@ async function main() {
390
453
  }
391
454
  ```
392
455
 
393
- A command's options on the command line are validated when the command is used. Any unknown options will be reported as an error. However, if an action-based command does not define an action, then the options are not validated.
394
-
395
- Configuration options can be passed with the call to `.command()`. Specifying `true` for `opts.noHelp` will remove the command from the generated help output.
456
+ A command's options on the command line are validated when the command is used. Any unknown options will be reported as an error.
396
457
 
397
- ### Git-style executable (sub)commands
458
+ ### Stand-alone executable (sub)commands
398
459
 
399
- When `.command()` is invoked with a description argument, this tells commander that you're going to use separate executables for sub-commands, much like `git(1)` and other popular tools.
460
+ When `.command()` is invoked with a description argument, this tells Commander that you're going to use stand-alone executables for subcommands.
400
461
  Commander will search the executables in the directory of the entry script (like `./examples/pm`) with the name `program-subcommand`, like `pm-install`, `pm-search`.
401
462
  You can specify a custom name with the `executableFile` configuration option.
402
463
 
403
464
  You handle the options for an executable (sub)command in the executable, and don't declare them at the top-level.
404
465
 
405
- ```js
406
- // file: ./examples/pm
407
- const program = require('commander');
466
+ Example file: [pm](./examples/pm)
408
467
 
468
+ ```js
409
469
  program
410
470
  .version('0.1.0')
411
471
  .command('install [name]', 'install one or more packages')
412
472
  .command('search [query]', 'search with optional query')
413
- .command('update', 'update installed packages', {executableFile: 'myUpdateSubCommand'})
414
- .command('list', 'list packages installed', {isDefault: true})
415
- .parse(process.argv);
416
- ```
473
+ .command('update', 'update installed packages', { executableFile: 'myUpdateSubCommand' })
474
+ .command('list', 'list packages installed', { isDefault: true });
417
475
 
418
- Configuration options can be passed with the call to `.command()`. Specifying `true` for `opts.noHelp` will remove the command from the generated help output. Specifying `true` for `opts.isDefault` will run the subcommand if no other subcommand is specified.
419
- Specifying a name with `executableFile` will override the default constructed name.
476
+ program.parse(process.argv);
477
+ ```
420
478
 
421
479
  If the program is designed to be installed globally, make sure the executables have proper modes, like `755`.
422
480
 
423
- ## Automated --help
481
+ ## Automated help
482
+
483
+ The help information is auto-generated based on the information commander already knows about your program. The default
484
+ help option is `-h,--help`.
424
485
 
425
- The help information is auto-generated based on the information commander already knows about your program, so the following `--help` info is for free:
486
+ Example file: [pizza](./examples/pizza)
426
487
 
427
488
  ```bash
428
- $ ./examples/pizza --help
489
+ $ node ./examples/pizza --help
429
490
  Usage: pizza [options]
430
491
 
431
492
  An application for pizzas ordering
@@ -433,63 +494,51 @@ An application for pizzas ordering
433
494
  Options:
434
495
  -V, --version output the version number
435
496
  -p, --peppers Add peppers
436
- -P, --pineapple Add pineapple
437
- -b, --bbq Add bbq sauce
438
497
  -c, --cheese <type> Add the specified type of cheese (default: "marble")
439
498
  -C, --no-cheese You do not want any cheese
440
- -h, --help output usage information
499
+ -h, --help display help for command
441
500
  ```
442
501
 
443
- ### Custom help
502
+ A `help` command is added by default if your command has subcommands. It can be used alone, or with a subcommand name to show
503
+ further help for the subcommand. These are effectively the same if the `shell` program has implicit help:
444
504
 
445
- You can display arbitrary `-h, --help` information
446
- by listening for "--help". Commander will automatically
447
- exit once you are done so that the remainder of your program
448
- does not execute causing undesired behaviors, for example
449
- in the following executable "stuff" will not output when
450
- `--help` is used.
505
+ ```bash
506
+ shell help
507
+ shell --help
451
508
 
452
- ```js
453
- #!/usr/bin/env node
509
+ shell help spawn
510
+ shell spawn --help
511
+ ```
454
512
 
455
- const program = require('commander');
513
+ ### Custom help
456
514
 
457
- program
458
- .version('0.1.0')
459
- .option('-f, --foo', 'enable some foo')
460
- .option('-b, --bar', 'enable some bar')
461
- .option('-B, --baz', 'enable some baz');
515
+ You can display extra information by listening for "--help".
462
516
 
463
- // must be before .parse() since
464
- // node's emit() is immediate
517
+ Example file: [custom-help](./examples/custom-help)
518
+
519
+ ```js
520
+ program
521
+ .option('-f, --foo', 'enable some foo');
465
522
 
466
- program.on('--help', function(){
467
- console.log('')
468
- console.log('Examples:');
523
+ // must be before .parse()
524
+ program.on('--help', () => {
525
+ console.log('');
526
+ console.log('Example call:');
469
527
  console.log(' $ custom-help --help');
470
- console.log(' $ custom-help -h');
471
528
  });
472
-
473
- program.parse(process.argv);
474
-
475
- console.log('stuff');
476
529
  ```
477
530
 
478
- Yields the following help output when `node script-name.js -h` or `node script-name.js --help` are run:
531
+ Yields the following help output:
479
532
 
480
533
  ```Text
481
534
  Usage: custom-help [options]
482
535
 
483
536
  Options:
484
- -h, --help output usage information
485
- -V, --version output the version number
486
- -f, --foo enable some foo
487
- -b, --bar enable some bar
488
- -B, --baz enable some baz
537
+ -f, --foo enable some foo
538
+ -h, --help display help for command
489
539
 
490
- Examples:
540
+ Example call:
491
541
  $ custom-help --help
492
- $ custom-help -h
493
542
  ```
494
543
 
495
544
  ### .usage and .name
@@ -509,63 +558,76 @@ The help will start with:
509
558
  Usage: my-command [global options] command
510
559
  ```
511
560
 
561
+ ### .help(cb)
562
+
563
+ Output help information and exit immediately. Optional callback cb allows post-processing of help text before it is displayed.
564
+
512
565
  ### .outputHelp(cb)
513
566
 
514
567
  Output help information without exiting.
515
568
  Optional callback cb allows post-processing of help text before it is displayed.
516
569
 
517
- If you want to display help by default (e.g. if no command was provided), you can use something like:
570
+ ### .helpInformation()
518
571
 
519
- ```js
520
- const program = require('commander');
521
- const colors = require('colors');
522
-
523
- program
524
- .version('0.1.0')
525
- .command('getstream [url]', 'get stream URL')
526
- .parse(process.argv);
527
-
528
- if (!process.argv.slice(2).length) {
529
- program.outputHelp(make_red);
530
- }
531
-
532
- function make_red(txt) {
533
- return colors.red(txt); //display the help text in red on the console
534
- }
535
- ```
572
+ Get the command help information as a string for processing or displaying yourself. (The text does not include the custom help
573
+ from `--help` listeners.)
536
574
 
537
575
  ### .helpOption(flags, description)
538
576
 
539
- Override the default help flags and description.
577
+ Override the default help flags and description. Pass false to disable the built-in help option.
540
578
 
541
579
  ```js
542
580
  program
543
581
  .helpOption('-e, --HELP', 'read more information');
544
582
  ```
545
583
 
546
- ### .help(cb)
584
+ ### .addHelpCommand()
547
585
 
548
- Output help information and exit immediately.
549
- Optional callback cb allows post-processing of help text before it is displayed.
586
+ You can explicitly turn on or off the implicit help command with `.addHelpCommand()` and `.addHelpCommand(false)`.
587
+
588
+ You can both turn on and customise the help command by supplying the name and description:
589
+
590
+ ```js
591
+ program.addHelpCommand('assist [command]', 'show assistance');
592
+ ```
550
593
 
551
594
  ## Custom event listeners
552
595
 
553
- You can execute custom actions by listening to command and option events.
596
+ You can execute custom actions by listening to command and option events.
554
597
 
555
598
  ```js
556
599
  program.on('option:verbose', function () {
557
600
  process.env.VERBOSE = this.verbose;
558
601
  });
559
602
 
560
- // error on unknown commands
561
- program.on('command:*', function () {
562
- console.error('Invalid command: %s\nSee --help for a list of available commands.', program.args.join(' '));
563
- process.exit(1);
603
+ program.on('command:*', function (operands) {
604
+ console.error(`error: unknown command '${operands[0]}'`);
605
+ const availableCommands = program.commands.map(cmd => cmd.name());
606
+ mySuggestBestMatch(operands[0], availableCommands);
607
+ process.exitCode = 1;
564
608
  });
565
609
  ```
566
610
 
567
611
  ## Bits and pieces
568
612
 
613
+ ### .parse() and .parseAsync()
614
+
615
+ The first argument to `.parse` is the array of strings to parse. You may omit the parameter to implicitly use `process.argv`.
616
+
617
+ If the arguments follow different conventions than node you can pass a `from` option in the second parameter:
618
+
619
+ - 'node': default, `argv[0]` is the application and `argv[1]` is the script being run, with user parameters after that
620
+ - 'electron': `argv[1]` varies depending on whether the electron application is packaged
621
+ - 'user': all of the arguments from the user
622
+
623
+ For example:
624
+
625
+ ```js
626
+ program.parse(process.argv); // Explicit, node conventions
627
+ program.parse(); // Implicit, and auto-detect electron
628
+ program.parse(['-f', 'filename'], { from: 'user' });
629
+ ```
630
+
569
631
  ### Avoiding option name clashes
570
632
 
571
633
  The original and default behaviour is that the option values are stored
@@ -580,8 +642,9 @@ There are two new routines to change the behaviour, and the default behaviour ma
580
642
  - `passCommandToAction`: whether to pass command to action handler,
581
643
  or just the options (specify false)
582
644
 
645
+ Example file: [storeOptionsAsProperties-action.js](./examples/storeOptionsAsProperties-action.js)
646
+
583
647
  ```js
584
- // file: ./examples/storeOptionsAsProperties.action.js
585
648
  program
586
649
  .storeOptionsAsProperties(false)
587
650
  .passCommandToAction(false);
@@ -605,31 +668,54 @@ console.log(programOptions.name);
605
668
 
606
669
  ### TypeScript
607
670
 
608
- The Commander package includes its TypeScript Definition file, but also requires the node types which you need to install yourself. e.g.
671
+ The Commander package includes its TypeScript Definition file.
672
+
673
+ If you use `ts-node` and stand-alone executable subcommands written as `.ts` files, you need to call your program through node to get the subcommands called correctly. e.g.
609
674
 
610
675
  ```bash
611
- npm install commander
612
- npm install --save-dev @types/node
676
+ node -r ts-node/register pm.ts
613
677
  ```
614
678
 
615
- If you use `ts-node` and git-style sub-commands written as `.ts` files, you need to call your program through node to get the sub-commands called correctly. e.g.
679
+ ### createCommand()
616
680
 
617
- ```bash
618
- node -r ts-node/register pm.ts
681
+ This factory function creates a new command. It is exported and may be used instead of using `new`, like:
682
+
683
+ ```js
684
+ const { createCommand } = require('commander');
685
+ const program = createCommand();
686
+ ```
687
+
688
+ `createCommand` is also a method of the Command object, and creates a new command rather than a subcommand. This gets used internally
689
+ when creating subcommands using `.command()`, and you may override it to
690
+ customise the new subcommand (examples using [subclass](./examples/custom-command-class.js) and [function](./examples/custom-command-function.js)).
691
+
692
+ ### Import into ECMAScript Module
693
+
694
+ Commander is currently a CommonJS package, and the default export can be imported into an ES Module:
695
+
696
+ ```js
697
+ // index.mjs
698
+ import commander from 'commander';
699
+ const program = commander.program;
700
+ const newCommand = new commander.Command();
619
701
  ```
620
702
 
621
703
  ### Node options such as `--harmony`
622
704
 
623
705
  You can enable `--harmony` option in two ways:
624
706
 
625
- - Use `#! /usr/bin/env node --harmony` in the sub-commands scripts. (Note Windows does not support this pattern.)
626
- - Use the `--harmony` option when call the command, like `node --harmony examples/pm publish`. The `--harmony` option will be preserved when spawning sub-command process.
707
+ - Use `#! /usr/bin/env node --harmony` in the subcommands scripts. (Note Windows does not support this pattern.)
708
+ - Use the `--harmony` option when call the command, like `node --harmony examples/pm publish`. The `--harmony` option will be preserved when spawning subcommand process.
709
+
710
+ ### Debugging stand-alone executable subcommands
627
711
 
628
- ### Node debugging
712
+ An executable subcommand is launched as a separate child process.
629
713
 
630
- If you are using the node inspector for [debugging](https://nodejs.org/en/docs/guides/debugging-getting-started/) git-style executable (sub)commands using `node --inspect` et al,
714
+ If you are using the node inspector for [debugging](https://nodejs.org/en/docs/guides/debugging-getting-started/) executable subcommands using `node --inspect` et al,
631
715
  the inspector port is incremented by 1 for the spawned subcommand.
632
716
 
717
+ If you are using VSCode to debug executable subcommands you need to set the `"autoAttachChildProcesses": true` flag in your launch.json configuration.
718
+
633
719
  ### Override exit handling
634
720
 
635
721
  By default Commander calls `process.exit` when it detects errors, or after displaying the help or version. You can override
@@ -638,7 +724,7 @@ this behaviour and optionally supply a callback. The default override throws a `
638
724
  The override callback is passed a `CommanderError` with properties `exitCode` number, `code` string, and `message`. The default override behaviour is to throw the error, except for async handling of executable subcommand completion which carries on. The normal display of error messages or version or help
639
725
  is not affected by the override which is called after the display.
640
726
 
641
- ``` js
727
+ ```js
642
728
  program.exitOverride();
643
729
 
644
730
  try {
@@ -650,8 +736,10 @@ try {
650
736
 
651
737
  ## Examples
652
738
 
739
+ Example file: [deploy](./examples/deploy)
740
+
653
741
  ```js
654
- const program = require('commander');
742
+ const { program } = require('commander');
655
743
 
656
744
  program
657
745
  .version('0.1.0')
@@ -684,24 +772,14 @@ program
684
772
  console.log(' $ deploy exec async');
685
773
  });
686
774
 
687
- program
688
- .command('*')
689
- .action(function(env){
690
- console.log('deploying "%s"', env);
691
- });
692
-
693
775
  program.parse(process.argv);
694
776
  ```
695
777
 
696
778
  More Demos can be found in the [examples](https://github.com/tj/commander.js/tree/master/examples) directory.
697
779
 
698
- ## License
699
-
700
- [MIT](https://github.com/tj/commander.js/blob/master/LICENSE)
701
-
702
780
  ## Support
703
781
 
704
- Commander 4.x is supported on Node 8 and above, and is likely to work with Node 6 but not tested.
782
+ The current version of Commander is fully supported on Long Term Support versions of Node, and is likely to work with Node 6 but not tested.
705
783
  (For versions of Node below Node 6, use Commander 3.x or 2.x.)
706
784
 
707
785
  The main forum for free and community support is the project [Issues](https://github.com/tj/commander.js/issues) on GitHub.