korext 0.7.0 → 0.8.1

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 (523) hide show
  1. package/README.md +102 -28
  2. package/bin/korext.js +251 -56
  3. package/package.json +21 -14
  4. package/CHANGELOG.md +0 -51
  5. package/dummy.pdf +0 -0
  6. package/korext.json +0 -11
  7. package/node_modules/ansi-regex/index.d.ts +0 -37
  8. package/node_modules/ansi-regex/index.js +0 -10
  9. package/node_modules/ansi-regex/license +0 -9
  10. package/node_modules/ansi-regex/package.json +0 -55
  11. package/node_modules/ansi-regex/readme.md +0 -78
  12. package/node_modules/ansi-styles/index.d.ts +0 -345
  13. package/node_modules/ansi-styles/index.js +0 -163
  14. package/node_modules/ansi-styles/license +0 -9
  15. package/node_modules/ansi-styles/package.json +0 -56
  16. package/node_modules/ansi-styles/readme.md +0 -152
  17. package/node_modules/balanced-match/LICENSE.md +0 -23
  18. package/node_modules/balanced-match/README.md +0 -57
  19. package/node_modules/balanced-match/dist/commonjs/index.d.ts +0 -9
  20. package/node_modules/balanced-match/dist/commonjs/index.d.ts.map +0 -1
  21. package/node_modules/balanced-match/dist/commonjs/index.js +0 -59
  22. package/node_modules/balanced-match/dist/commonjs/index.js.map +0 -1
  23. package/node_modules/balanced-match/dist/commonjs/package.json +0 -3
  24. package/node_modules/balanced-match/dist/esm/index.d.ts +0 -9
  25. package/node_modules/balanced-match/dist/esm/index.d.ts.map +0 -1
  26. package/node_modules/balanced-match/dist/esm/index.js +0 -54
  27. package/node_modules/balanced-match/dist/esm/index.js.map +0 -1
  28. package/node_modules/balanced-match/dist/esm/package.json +0 -3
  29. package/node_modules/balanced-match/package.json +0 -68
  30. package/node_modules/base64-js/LICENSE +0 -21
  31. package/node_modules/base64-js/README.md +0 -34
  32. package/node_modules/base64-js/base64js.min.js +0 -1
  33. package/node_modules/base64-js/index.d.ts +0 -3
  34. package/node_modules/base64-js/index.js +0 -150
  35. package/node_modules/base64-js/package.json +0 -47
  36. package/node_modules/bl/.travis.yml +0 -17
  37. package/node_modules/bl/BufferList.js +0 -396
  38. package/node_modules/bl/LICENSE.md +0 -13
  39. package/node_modules/bl/README.md +0 -247
  40. package/node_modules/bl/bl.js +0 -84
  41. package/node_modules/bl/package.json +0 -37
  42. package/node_modules/bl/test/convert.js +0 -21
  43. package/node_modules/bl/test/indexOf.js +0 -492
  44. package/node_modules/bl/test/isBufferList.js +0 -32
  45. package/node_modules/bl/test/test.js +0 -869
  46. package/node_modules/brace-expansion/LICENSE +0 -23
  47. package/node_modules/brace-expansion/README.md +0 -94
  48. package/node_modules/brace-expansion/dist/commonjs/index.d.ts +0 -6
  49. package/node_modules/brace-expansion/dist/commonjs/index.d.ts.map +0 -1
  50. package/node_modules/brace-expansion/dist/commonjs/index.js +0 -199
  51. package/node_modules/brace-expansion/dist/commonjs/index.js.map +0 -1
  52. package/node_modules/brace-expansion/dist/commonjs/package.json +0 -3
  53. package/node_modules/brace-expansion/dist/esm/index.d.ts +0 -6
  54. package/node_modules/brace-expansion/dist/esm/index.d.ts.map +0 -1
  55. package/node_modules/brace-expansion/dist/esm/index.js +0 -195
  56. package/node_modules/brace-expansion/dist/esm/index.js.map +0 -1
  57. package/node_modules/brace-expansion/dist/esm/package.json +0 -3
  58. package/node_modules/brace-expansion/package.json +0 -64
  59. package/node_modules/buffer/AUTHORS.md +0 -70
  60. package/node_modules/buffer/LICENSE +0 -21
  61. package/node_modules/buffer/README.md +0 -410
  62. package/node_modules/buffer/index.d.ts +0 -186
  63. package/node_modules/buffer/index.js +0 -1817
  64. package/node_modules/buffer/package.json +0 -96
  65. package/node_modules/chalk/index.d.ts +0 -415
  66. package/node_modules/chalk/license +0 -9
  67. package/node_modules/chalk/package.json +0 -68
  68. package/node_modules/chalk/readme.md +0 -341
  69. package/node_modules/chalk/source/index.js +0 -229
  70. package/node_modules/chalk/source/templates.js +0 -134
  71. package/node_modules/chalk/source/util.js +0 -39
  72. package/node_modules/cli-cursor/index.d.ts +0 -45
  73. package/node_modules/cli-cursor/index.js +0 -35
  74. package/node_modules/cli-cursor/license +0 -9
  75. package/node_modules/cli-cursor/package.json +0 -46
  76. package/node_modules/cli-cursor/readme.md +0 -55
  77. package/node_modules/cli-spinners/index.d.ts +0 -128
  78. package/node_modules/cli-spinners/index.js +0 -15
  79. package/node_modules/cli-spinners/license +0 -9
  80. package/node_modules/cli-spinners/package.json +0 -50
  81. package/node_modules/cli-spinners/readme.md +0 -54
  82. package/node_modules/cli-spinners/spinners.json +0 -1622
  83. package/node_modules/clone/.npmignore +0 -4
  84. package/node_modules/clone/LICENSE +0 -18
  85. package/node_modules/clone/README.md +0 -126
  86. package/node_modules/clone/clone.iml +0 -10
  87. package/node_modules/clone/clone.js +0 -166
  88. package/node_modules/clone/package.json +0 -51
  89. package/node_modules/color-convert/CHANGELOG.md +0 -54
  90. package/node_modules/color-convert/LICENSE +0 -21
  91. package/node_modules/color-convert/README.md +0 -68
  92. package/node_modules/color-convert/conversions.js +0 -839
  93. package/node_modules/color-convert/index.js +0 -81
  94. package/node_modules/color-convert/package.json +0 -48
  95. package/node_modules/color-convert/route.js +0 -97
  96. package/node_modules/color-name/LICENSE +0 -8
  97. package/node_modules/color-name/README.md +0 -11
  98. package/node_modules/color-name/index.js +0 -152
  99. package/node_modules/color-name/package.json +0 -28
  100. package/node_modules/commander/LICENSE +0 -22
  101. package/node_modules/commander/Readme.md +0 -1176
  102. package/node_modules/commander/esm.mjs +0 -16
  103. package/node_modules/commander/index.js +0 -24
  104. package/node_modules/commander/lib/argument.js +0 -150
  105. package/node_modules/commander/lib/command.js +0 -2777
  106. package/node_modules/commander/lib/error.js +0 -39
  107. package/node_modules/commander/lib/help.js +0 -747
  108. package/node_modules/commander/lib/option.js +0 -380
  109. package/node_modules/commander/lib/suggestSimilar.js +0 -101
  110. package/node_modules/commander/package-support.json +0 -19
  111. package/node_modules/commander/package.json +0 -82
  112. package/node_modules/commander/typings/esm.d.mts +0 -3
  113. package/node_modules/commander/typings/index.d.ts +0 -1113
  114. package/node_modules/data-uri-to-buffer/README.md +0 -88
  115. package/node_modules/data-uri-to-buffer/dist/index.d.ts +0 -15
  116. package/node_modules/data-uri-to-buffer/dist/index.js +0 -53
  117. package/node_modules/data-uri-to-buffer/dist/index.js.map +0 -1
  118. package/node_modules/data-uri-to-buffer/package.json +0 -62
  119. package/node_modules/data-uri-to-buffer/src/index.ts +0 -68
  120. package/node_modules/defaults/LICENSE +0 -22
  121. package/node_modules/defaults/README.md +0 -39
  122. package/node_modules/defaults/index.js +0 -13
  123. package/node_modules/defaults/package.json +0 -33
  124. package/node_modules/defaults/test.js +0 -34
  125. package/node_modules/fetch-blob/LICENSE +0 -21
  126. package/node_modules/fetch-blob/README.md +0 -106
  127. package/node_modules/fetch-blob/file.d.ts +0 -2
  128. package/node_modules/fetch-blob/file.js +0 -49
  129. package/node_modules/fetch-blob/from.d.ts +0 -26
  130. package/node_modules/fetch-blob/from.js +0 -100
  131. package/node_modules/fetch-blob/index.d.ts +0 -3
  132. package/node_modules/fetch-blob/index.js +0 -250
  133. package/node_modules/fetch-blob/package.json +0 -56
  134. package/node_modules/fetch-blob/streams.cjs +0 -51
  135. package/node_modules/formdata-polyfill/FormData.js +0 -441
  136. package/node_modules/formdata-polyfill/LICENSE +0 -21
  137. package/node_modules/formdata-polyfill/README.md +0 -145
  138. package/node_modules/formdata-polyfill/esm.min.d.ts +0 -5
  139. package/node_modules/formdata-polyfill/esm.min.js +0 -40
  140. package/node_modules/formdata-polyfill/formdata-to-blob.js +0 -39
  141. package/node_modules/formdata-polyfill/formdata.min.js +0 -21
  142. package/node_modules/formdata-polyfill/package.json +0 -50
  143. package/node_modules/glob/LICENSE.md +0 -63
  144. package/node_modules/glob/README.md +0 -1203
  145. package/node_modules/glob/dist/commonjs/glob.d.ts +0 -396
  146. package/node_modules/glob/dist/commonjs/glob.d.ts.map +0 -1
  147. package/node_modules/glob/dist/commonjs/glob.js +0 -248
  148. package/node_modules/glob/dist/commonjs/glob.js.map +0 -1
  149. package/node_modules/glob/dist/commonjs/has-magic.d.ts +0 -14
  150. package/node_modules/glob/dist/commonjs/has-magic.d.ts.map +0 -1
  151. package/node_modules/glob/dist/commonjs/has-magic.js +0 -27
  152. package/node_modules/glob/dist/commonjs/has-magic.js.map +0 -1
  153. package/node_modules/glob/dist/commonjs/ignore.d.ts +0 -24
  154. package/node_modules/glob/dist/commonjs/ignore.d.ts.map +0 -1
  155. package/node_modules/glob/dist/commonjs/ignore.js +0 -119
  156. package/node_modules/glob/dist/commonjs/ignore.js.map +0 -1
  157. package/node_modules/glob/dist/commonjs/index.d.ts +0 -97
  158. package/node_modules/glob/dist/commonjs/index.d.ts.map +0 -1
  159. package/node_modules/glob/dist/commonjs/index.js +0 -68
  160. package/node_modules/glob/dist/commonjs/index.js.map +0 -1
  161. package/node_modules/glob/dist/commonjs/index.min.js +0 -4
  162. package/node_modules/glob/dist/commonjs/index.min.js.map +0 -7
  163. package/node_modules/glob/dist/commonjs/package.json +0 -3
  164. package/node_modules/glob/dist/commonjs/pattern.d.ts +0 -79
  165. package/node_modules/glob/dist/commonjs/pattern.d.ts.map +0 -1
  166. package/node_modules/glob/dist/commonjs/pattern.js +0 -223
  167. package/node_modules/glob/dist/commonjs/pattern.js.map +0 -1
  168. package/node_modules/glob/dist/commonjs/processor.d.ts +0 -59
  169. package/node_modules/glob/dist/commonjs/processor.d.ts.map +0 -1
  170. package/node_modules/glob/dist/commonjs/processor.js +0 -301
  171. package/node_modules/glob/dist/commonjs/processor.js.map +0 -1
  172. package/node_modules/glob/dist/commonjs/walker.d.ts +0 -97
  173. package/node_modules/glob/dist/commonjs/walker.d.ts.map +0 -1
  174. package/node_modules/glob/dist/commonjs/walker.js +0 -387
  175. package/node_modules/glob/dist/commonjs/walker.js.map +0 -1
  176. package/node_modules/glob/dist/esm/glob.d.ts +0 -396
  177. package/node_modules/glob/dist/esm/glob.d.ts.map +0 -1
  178. package/node_modules/glob/dist/esm/glob.js +0 -244
  179. package/node_modules/glob/dist/esm/glob.js.map +0 -1
  180. package/node_modules/glob/dist/esm/has-magic.d.ts +0 -14
  181. package/node_modules/glob/dist/esm/has-magic.d.ts.map +0 -1
  182. package/node_modules/glob/dist/esm/has-magic.js +0 -23
  183. package/node_modules/glob/dist/esm/has-magic.js.map +0 -1
  184. package/node_modules/glob/dist/esm/ignore.d.ts +0 -24
  185. package/node_modules/glob/dist/esm/ignore.d.ts.map +0 -1
  186. package/node_modules/glob/dist/esm/ignore.js +0 -115
  187. package/node_modules/glob/dist/esm/ignore.js.map +0 -1
  188. package/node_modules/glob/dist/esm/index.d.ts +0 -97
  189. package/node_modules/glob/dist/esm/index.d.ts.map +0 -1
  190. package/node_modules/glob/dist/esm/index.js +0 -55
  191. package/node_modules/glob/dist/esm/index.js.map +0 -1
  192. package/node_modules/glob/dist/esm/index.min.js +0 -4
  193. package/node_modules/glob/dist/esm/index.min.js.map +0 -7
  194. package/node_modules/glob/dist/esm/package.json +0 -3
  195. package/node_modules/glob/dist/esm/pattern.d.ts +0 -79
  196. package/node_modules/glob/dist/esm/pattern.d.ts.map +0 -1
  197. package/node_modules/glob/dist/esm/pattern.js +0 -219
  198. package/node_modules/glob/dist/esm/pattern.js.map +0 -1
  199. package/node_modules/glob/dist/esm/processor.d.ts +0 -59
  200. package/node_modules/glob/dist/esm/processor.d.ts.map +0 -1
  201. package/node_modules/glob/dist/esm/processor.js +0 -294
  202. package/node_modules/glob/dist/esm/processor.js.map +0 -1
  203. package/node_modules/glob/dist/esm/walker.d.ts +0 -97
  204. package/node_modules/glob/dist/esm/walker.d.ts.map +0 -1
  205. package/node_modules/glob/dist/esm/walker.js +0 -381
  206. package/node_modules/glob/dist/esm/walker.js.map +0 -1
  207. package/node_modules/glob/package.json +0 -98
  208. package/node_modules/has-flag/index.d.ts +0 -39
  209. package/node_modules/has-flag/index.js +0 -8
  210. package/node_modules/has-flag/license +0 -9
  211. package/node_modules/has-flag/package.json +0 -46
  212. package/node_modules/has-flag/readme.md +0 -89
  213. package/node_modules/ieee754/LICENSE +0 -11
  214. package/node_modules/ieee754/README.md +0 -51
  215. package/node_modules/ieee754/index.d.ts +0 -10
  216. package/node_modules/ieee754/index.js +0 -85
  217. package/node_modules/ieee754/package.json +0 -52
  218. package/node_modules/inherits/LICENSE +0 -16
  219. package/node_modules/inherits/README.md +0 -42
  220. package/node_modules/inherits/inherits.js +0 -9
  221. package/node_modules/inherits/inherits_browser.js +0 -27
  222. package/node_modules/inherits/package.json +0 -29
  223. package/node_modules/is-interactive/index.d.ts +0 -31
  224. package/node_modules/is-interactive/index.js +0 -9
  225. package/node_modules/is-interactive/license +0 -9
  226. package/node_modules/is-interactive/package.json +0 -38
  227. package/node_modules/is-interactive/readme.md +0 -51
  228. package/node_modules/is-unicode-supported/index.d.ts +0 -14
  229. package/node_modules/is-unicode-supported/index.js +0 -13
  230. package/node_modules/is-unicode-supported/license +0 -9
  231. package/node_modules/is-unicode-supported/package.json +0 -41
  232. package/node_modules/is-unicode-supported/readme.md +0 -35
  233. package/node_modules/log-symbols/browser.js +0 -8
  234. package/node_modules/log-symbols/index.d.ts +0 -25
  235. package/node_modules/log-symbols/index.js +0 -19
  236. package/node_modules/log-symbols/license +0 -9
  237. package/node_modules/log-symbols/package.json +0 -52
  238. package/node_modules/log-symbols/readme.md +0 -51
  239. package/node_modules/lru-cache/LICENSE.md +0 -55
  240. package/node_modules/lru-cache/README.md +0 -383
  241. package/node_modules/lru-cache/dist/commonjs/index.d.ts +0 -1323
  242. package/node_modules/lru-cache/dist/commonjs/index.d.ts.map +0 -1
  243. package/node_modules/lru-cache/dist/commonjs/index.js +0 -1595
  244. package/node_modules/lru-cache/dist/commonjs/index.js.map +0 -1
  245. package/node_modules/lru-cache/dist/commonjs/index.min.js +0 -2
  246. package/node_modules/lru-cache/dist/commonjs/index.min.js.map +0 -7
  247. package/node_modules/lru-cache/dist/commonjs/package.json +0 -3
  248. package/node_modules/lru-cache/dist/esm/index.d.ts +0 -1323
  249. package/node_modules/lru-cache/dist/esm/index.d.ts.map +0 -1
  250. package/node_modules/lru-cache/dist/esm/index.js +0 -1591
  251. package/node_modules/lru-cache/dist/esm/index.js.map +0 -1
  252. package/node_modules/lru-cache/dist/esm/index.min.js +0 -2
  253. package/node_modules/lru-cache/dist/esm/index.min.js.map +0 -7
  254. package/node_modules/lru-cache/dist/esm/package.json +0 -3
  255. package/node_modules/lru-cache/package.json +0 -93
  256. package/node_modules/mimic-fn/index.d.ts +0 -54
  257. package/node_modules/mimic-fn/index.js +0 -13
  258. package/node_modules/mimic-fn/license +0 -9
  259. package/node_modules/mimic-fn/package.json +0 -42
  260. package/node_modules/mimic-fn/readme.md +0 -69
  261. package/node_modules/minimatch/LICENSE.md +0 -55
  262. package/node_modules/minimatch/README.md +0 -528
  263. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +0 -2
  264. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +0 -1
  265. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +0 -14
  266. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +0 -1
  267. package/node_modules/minimatch/dist/commonjs/ast.d.ts +0 -22
  268. package/node_modules/minimatch/dist/commonjs/ast.d.ts.map +0 -1
  269. package/node_modules/minimatch/dist/commonjs/ast.js +0 -846
  270. package/node_modules/minimatch/dist/commonjs/ast.js.map +0 -1
  271. package/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts +0 -8
  272. package/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +0 -1
  273. package/node_modules/minimatch/dist/commonjs/brace-expressions.js +0 -150
  274. package/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +0 -1
  275. package/node_modules/minimatch/dist/commonjs/escape.d.ts +0 -15
  276. package/node_modules/minimatch/dist/commonjs/escape.d.ts.map +0 -1
  277. package/node_modules/minimatch/dist/commonjs/escape.js +0 -30
  278. package/node_modules/minimatch/dist/commonjs/escape.js.map +0 -1
  279. package/node_modules/minimatch/dist/commonjs/index.d.ts +0 -174
  280. package/node_modules/minimatch/dist/commonjs/index.d.ts.map +0 -1
  281. package/node_modules/minimatch/dist/commonjs/index.js +0 -1121
  282. package/node_modules/minimatch/dist/commonjs/index.js.map +0 -1
  283. package/node_modules/minimatch/dist/commonjs/package.json +0 -3
  284. package/node_modules/minimatch/dist/commonjs/unescape.d.ts +0 -22
  285. package/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +0 -1
  286. package/node_modules/minimatch/dist/commonjs/unescape.js +0 -38
  287. package/node_modules/minimatch/dist/commonjs/unescape.js.map +0 -1
  288. package/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +0 -2
  289. package/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +0 -1
  290. package/node_modules/minimatch/dist/esm/assert-valid-pattern.js +0 -10
  291. package/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +0 -1
  292. package/node_modules/minimatch/dist/esm/ast.d.ts +0 -22
  293. package/node_modules/minimatch/dist/esm/ast.d.ts.map +0 -1
  294. package/node_modules/minimatch/dist/esm/ast.js +0 -842
  295. package/node_modules/minimatch/dist/esm/ast.js.map +0 -1
  296. package/node_modules/minimatch/dist/esm/brace-expressions.d.ts +0 -8
  297. package/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +0 -1
  298. package/node_modules/minimatch/dist/esm/brace-expressions.js +0 -146
  299. package/node_modules/minimatch/dist/esm/brace-expressions.js.map +0 -1
  300. package/node_modules/minimatch/dist/esm/escape.d.ts +0 -15
  301. package/node_modules/minimatch/dist/esm/escape.d.ts.map +0 -1
  302. package/node_modules/minimatch/dist/esm/escape.js +0 -26
  303. package/node_modules/minimatch/dist/esm/escape.js.map +0 -1
  304. package/node_modules/minimatch/dist/esm/index.d.ts +0 -174
  305. package/node_modules/minimatch/dist/esm/index.d.ts.map +0 -1
  306. package/node_modules/minimatch/dist/esm/index.js +0 -1108
  307. package/node_modules/minimatch/dist/esm/index.js.map +0 -1
  308. package/node_modules/minimatch/dist/esm/package.json +0 -3
  309. package/node_modules/minimatch/dist/esm/unescape.d.ts +0 -22
  310. package/node_modules/minimatch/dist/esm/unescape.d.ts.map +0 -1
  311. package/node_modules/minimatch/dist/esm/unescape.js +0 -34
  312. package/node_modules/minimatch/dist/esm/unescape.js.map +0 -1
  313. package/node_modules/minimatch/package.json +0 -67
  314. package/node_modules/minipass/LICENSE.md +0 -55
  315. package/node_modules/minipass/README.md +0 -825
  316. package/node_modules/minipass/dist/commonjs/index.d.ts +0 -545
  317. package/node_modules/minipass/dist/commonjs/index.d.ts.map +0 -1
  318. package/node_modules/minipass/dist/commonjs/index.js +0 -1038
  319. package/node_modules/minipass/dist/commonjs/index.js.map +0 -1
  320. package/node_modules/minipass/dist/commonjs/package.json +0 -3
  321. package/node_modules/minipass/dist/esm/index.d.ts +0 -545
  322. package/node_modules/minipass/dist/esm/index.d.ts.map +0 -1
  323. package/node_modules/minipass/dist/esm/index.js +0 -1020
  324. package/node_modules/minipass/dist/esm/index.js.map +0 -1
  325. package/node_modules/minipass/dist/esm/package.json +0 -3
  326. package/node_modules/minipass/package.json +0 -77
  327. package/node_modules/node-domexception/.history/README_20210527203617.md +0 -2
  328. package/node_modules/node-domexception/.history/README_20210527212714.md +0 -41
  329. package/node_modules/node-domexception/.history/README_20210527213345.md +0 -36
  330. package/node_modules/node-domexception/.history/README_20210527213411.md +0 -36
  331. package/node_modules/node-domexception/.history/README_20210527213803.md +0 -36
  332. package/node_modules/node-domexception/.history/README_20210527214323.md +0 -38
  333. package/node_modules/node-domexception/.history/README_20210527214408.md +0 -38
  334. package/node_modules/node-domexception/.history/index_20210527203842.js +0 -0
  335. package/node_modules/node-domexception/.history/index_20210527203947.js +0 -8
  336. package/node_modules/node-domexception/.history/index_20210527204259.js +0 -9
  337. package/node_modules/node-domexception/.history/index_20210527204418.js +0 -9
  338. package/node_modules/node-domexception/.history/index_20210527204756.js +0 -11
  339. package/node_modules/node-domexception/.history/index_20210527204833.js +0 -11
  340. package/node_modules/node-domexception/.history/index_20210527211208.js +0 -15
  341. package/node_modules/node-domexception/.history/index_20210527211248.js +0 -15
  342. package/node_modules/node-domexception/.history/index_20210527212722.js +0 -23
  343. package/node_modules/node-domexception/.history/index_20210527212731.js +0 -23
  344. package/node_modules/node-domexception/.history/index_20210527212746.js +0 -15
  345. package/node_modules/node-domexception/.history/index_20210527212900.js +0 -16
  346. package/node_modules/node-domexception/.history/index_20210527213022.js +0 -16
  347. package/node_modules/node-domexception/.history/index_20210527213822.js +0 -16
  348. package/node_modules/node-domexception/.history/index_20210527213843.js +0 -17
  349. package/node_modules/node-domexception/.history/index_20210527213852.js +0 -17
  350. package/node_modules/node-domexception/.history/index_20210527213910.js +0 -16
  351. package/node_modules/node-domexception/.history/index_20210527214034.js +0 -16
  352. package/node_modules/node-domexception/.history/index_20210527214643.js +0 -41
  353. package/node_modules/node-domexception/.history/index_20210527214654.js +0 -41
  354. package/node_modules/node-domexception/.history/index_20210527214700.js +0 -16
  355. package/node_modules/node-domexception/.history/package_20210527203733.json +0 -19
  356. package/node_modules/node-domexception/.history/package_20210527203825.json +0 -16
  357. package/node_modules/node-domexception/.history/package_20210527204621.json +0 -19
  358. package/node_modules/node-domexception/.history/package_20210527204913.json +0 -25
  359. package/node_modules/node-domexception/.history/package_20210527204925.json +0 -25
  360. package/node_modules/node-domexception/.history/package_20210527205145.json +0 -29
  361. package/node_modules/node-domexception/.history/package_20210527205156.json +0 -29
  362. package/node_modules/node-domexception/.history/test_20210527205603.js +0 -0
  363. package/node_modules/node-domexception/.history/test_20210527205957.js +0 -3
  364. package/node_modules/node-domexception/.history/test_20210527210021.js +0 -3
  365. package/node_modules/node-domexception/LICENSE +0 -21
  366. package/node_modules/node-domexception/README.md +0 -46
  367. package/node_modules/node-domexception/index.js +0 -16
  368. package/node_modules/node-domexception/package.json +0 -29
  369. package/node_modules/node-fetch/@types/index.d.ts +0 -219
  370. package/node_modules/node-fetch/LICENSE.md +0 -22
  371. package/node_modules/node-fetch/README.md +0 -872
  372. package/node_modules/node-fetch/package.json +0 -131
  373. package/node_modules/node-fetch/src/body.js +0 -397
  374. package/node_modules/node-fetch/src/errors/abort-error.js +0 -10
  375. package/node_modules/node-fetch/src/errors/base.js +0 -17
  376. package/node_modules/node-fetch/src/errors/fetch-error.js +0 -26
  377. package/node_modules/node-fetch/src/headers.js +0 -267
  378. package/node_modules/node-fetch/src/index.js +0 -417
  379. package/node_modules/node-fetch/src/request.js +0 -313
  380. package/node_modules/node-fetch/src/response.js +0 -160
  381. package/node_modules/node-fetch/src/utils/get-search.js +0 -9
  382. package/node_modules/node-fetch/src/utils/is-redirect.js +0 -11
  383. package/node_modules/node-fetch/src/utils/is.js +0 -87
  384. package/node_modules/node-fetch/src/utils/multipart-parser.js +0 -432
  385. package/node_modules/node-fetch/src/utils/referrer.js +0 -340
  386. package/node_modules/onetime/index.d.ts +0 -64
  387. package/node_modules/onetime/index.js +0 -44
  388. package/node_modules/onetime/license +0 -9
  389. package/node_modules/onetime/package.json +0 -43
  390. package/node_modules/onetime/readme.md +0 -94
  391. package/node_modules/ora/index.d.ts +0 -277
  392. package/node_modules/ora/index.js +0 -407
  393. package/node_modules/ora/license +0 -9
  394. package/node_modules/ora/package.json +0 -57
  395. package/node_modules/ora/readme.md +0 -264
  396. package/node_modules/path-scurry/LICENSE.md +0 -55
  397. package/node_modules/path-scurry/README.md +0 -636
  398. package/node_modules/path-scurry/dist/commonjs/index.d.ts +0 -1115
  399. package/node_modules/path-scurry/dist/commonjs/index.d.ts.map +0 -1
  400. package/node_modules/path-scurry/dist/commonjs/index.js +0 -2018
  401. package/node_modules/path-scurry/dist/commonjs/index.js.map +0 -1
  402. package/node_modules/path-scurry/dist/commonjs/package.json +0 -3
  403. package/node_modules/path-scurry/dist/esm/index.d.ts +0 -1115
  404. package/node_modules/path-scurry/dist/esm/index.d.ts.map +0 -1
  405. package/node_modules/path-scurry/dist/esm/index.js +0 -1983
  406. package/node_modules/path-scurry/dist/esm/index.js.map +0 -1
  407. package/node_modules/path-scurry/dist/esm/package.json +0 -3
  408. package/node_modules/path-scurry/package.json +0 -72
  409. package/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  410. package/node_modules/readable-stream/GOVERNANCE.md +0 -136
  411. package/node_modules/readable-stream/LICENSE +0 -47
  412. package/node_modules/readable-stream/README.md +0 -106
  413. package/node_modules/readable-stream/errors-browser.js +0 -127
  414. package/node_modules/readable-stream/errors.js +0 -116
  415. package/node_modules/readable-stream/experimentalWarning.js +0 -17
  416. package/node_modules/readable-stream/lib/_stream_duplex.js +0 -126
  417. package/node_modules/readable-stream/lib/_stream_passthrough.js +0 -37
  418. package/node_modules/readable-stream/lib/_stream_readable.js +0 -1027
  419. package/node_modules/readable-stream/lib/_stream_transform.js +0 -190
  420. package/node_modules/readable-stream/lib/_stream_writable.js +0 -641
  421. package/node_modules/readable-stream/lib/internal/streams/async_iterator.js +0 -180
  422. package/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -183
  423. package/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -96
  424. package/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -86
  425. package/node_modules/readable-stream/lib/internal/streams/from-browser.js +0 -3
  426. package/node_modules/readable-stream/lib/internal/streams/from.js +0 -52
  427. package/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -86
  428. package/node_modules/readable-stream/lib/internal/streams/state.js +0 -22
  429. package/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  430. package/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  431. package/node_modules/readable-stream/package.json +0 -68
  432. package/node_modules/readable-stream/readable-browser.js +0 -9
  433. package/node_modules/readable-stream/readable.js +0 -16
  434. package/node_modules/restore-cursor/index.d.ts +0 -13
  435. package/node_modules/restore-cursor/index.js +0 -9
  436. package/node_modules/restore-cursor/license +0 -9
  437. package/node_modules/restore-cursor/package.json +0 -52
  438. package/node_modules/restore-cursor/readme.md +0 -26
  439. package/node_modules/safe-buffer/LICENSE +0 -21
  440. package/node_modules/safe-buffer/README.md +0 -584
  441. package/node_modules/safe-buffer/index.d.ts +0 -187
  442. package/node_modules/safe-buffer/index.js +0 -65
  443. package/node_modules/safe-buffer/package.json +0 -51
  444. package/node_modules/signal-exit/LICENSE.txt +0 -16
  445. package/node_modules/signal-exit/README.md +0 -39
  446. package/node_modules/signal-exit/index.js +0 -202
  447. package/node_modules/signal-exit/package.json +0 -38
  448. package/node_modules/signal-exit/signals.js +0 -53
  449. package/node_modules/string_decoder/LICENSE +0 -48
  450. package/node_modules/string_decoder/README.md +0 -47
  451. package/node_modules/string_decoder/lib/string_decoder.js +0 -296
  452. package/node_modules/string_decoder/package.json +0 -34
  453. package/node_modules/strip-ansi/index.d.ts +0 -17
  454. package/node_modules/strip-ansi/index.js +0 -4
  455. package/node_modules/strip-ansi/license +0 -9
  456. package/node_modules/strip-ansi/package.json +0 -54
  457. package/node_modules/strip-ansi/readme.md +0 -46
  458. package/node_modules/supports-color/browser.js +0 -5
  459. package/node_modules/supports-color/index.js +0 -135
  460. package/node_modules/supports-color/license +0 -9
  461. package/node_modules/supports-color/package.json +0 -53
  462. package/node_modules/supports-color/readme.md +0 -76
  463. package/node_modules/util-deprecate/History.md +0 -16
  464. package/node_modules/util-deprecate/LICENSE +0 -24
  465. package/node_modules/util-deprecate/README.md +0 -53
  466. package/node_modules/util-deprecate/browser.js +0 -67
  467. package/node_modules/util-deprecate/node.js +0 -6
  468. package/node_modules/util-deprecate/package.json +0 -27
  469. package/node_modules/wcwidth/.npmignore +0 -1
  470. package/node_modules/wcwidth/LICENSE +0 -30
  471. package/node_modules/wcwidth/Readme.md +0 -33
  472. package/node_modules/wcwidth/combining.js +0 -50
  473. package/node_modules/wcwidth/docs/index.md +0 -65
  474. package/node_modules/wcwidth/index.js +0 -99
  475. package/node_modules/wcwidth/package.json +0 -42
  476. package/node_modules/wcwidth/test/index.js +0 -64
  477. package/node_modules/web-streams-polyfill/LICENSE +0 -22
  478. package/node_modules/web-streams-polyfill/README.md +0 -110
  479. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.js +0 -4765
  480. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.js.map +0 -1
  481. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.min.js +0 -9
  482. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.min.js.map +0 -1
  483. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.mjs +0 -4745
  484. package/node_modules/web-streams-polyfill/dist/polyfill.es2018.mjs.map +0 -1
  485. package/node_modules/web-streams-polyfill/dist/polyfill.es6.js +0 -4838
  486. package/node_modules/web-streams-polyfill/dist/polyfill.es6.js.map +0 -1
  487. package/node_modules/web-streams-polyfill/dist/polyfill.es6.min.js +0 -9
  488. package/node_modules/web-streams-polyfill/dist/polyfill.es6.min.js.map +0 -1
  489. package/node_modules/web-streams-polyfill/dist/polyfill.es6.mjs +0 -4818
  490. package/node_modules/web-streams-polyfill/dist/polyfill.es6.mjs.map +0 -1
  491. package/node_modules/web-streams-polyfill/dist/polyfill.js +0 -5011
  492. package/node_modules/web-streams-polyfill/dist/polyfill.js.map +0 -1
  493. package/node_modules/web-streams-polyfill/dist/polyfill.min.js +0 -9
  494. package/node_modules/web-streams-polyfill/dist/polyfill.min.js.map +0 -1
  495. package/node_modules/web-streams-polyfill/dist/polyfill.mjs +0 -4991
  496. package/node_modules/web-streams-polyfill/dist/polyfill.mjs.map +0 -1
  497. package/node_modules/web-streams-polyfill/dist/ponyfill.es2018.js +0 -4737
  498. package/node_modules/web-streams-polyfill/dist/ponyfill.es2018.js.map +0 -1
  499. package/node_modules/web-streams-polyfill/dist/ponyfill.es2018.mjs +0 -4717
  500. package/node_modules/web-streams-polyfill/dist/ponyfill.es2018.mjs.map +0 -1
  501. package/node_modules/web-streams-polyfill/dist/ponyfill.es6.js +0 -4810
  502. package/node_modules/web-streams-polyfill/dist/ponyfill.es6.js.map +0 -1
  503. package/node_modules/web-streams-polyfill/dist/ponyfill.es6.mjs +0 -4790
  504. package/node_modules/web-streams-polyfill/dist/ponyfill.es6.mjs.map +0 -1
  505. package/node_modules/web-streams-polyfill/dist/ponyfill.js +0 -4983
  506. package/node_modules/web-streams-polyfill/dist/ponyfill.js.map +0 -1
  507. package/node_modules/web-streams-polyfill/dist/ponyfill.mjs +0 -4963
  508. package/node_modules/web-streams-polyfill/dist/ponyfill.mjs.map +0 -1
  509. package/node_modules/web-streams-polyfill/dist/types/polyfill.d.ts +0 -24
  510. package/node_modules/web-streams-polyfill/dist/types/ponyfill.d.ts +0 -780
  511. package/node_modules/web-streams-polyfill/dist/types/ts3.6/polyfill.d.ts +0 -28
  512. package/node_modules/web-streams-polyfill/dist/types/ts3.6/ponyfill.d.ts +0 -821
  513. package/node_modules/web-streams-polyfill/dist/types/tsdoc-metadata.json +0 -11
  514. package/node_modules/web-streams-polyfill/es2018/package.json +0 -14
  515. package/node_modules/web-streams-polyfill/es6/package.json +0 -14
  516. package/node_modules/web-streams-polyfill/package.json +0 -83
  517. package/node_modules/web-streams-polyfill/ponyfill/es2018/package.json +0 -13
  518. package/node_modules/web-streams-polyfill/ponyfill/es6/package.json +0 -13
  519. package/node_modules/web-streams-polyfill/ponyfill/package.json +0 -13
  520. package/src/commands/policy.ts +0 -146
  521. package/test-policy.md +0 -55
  522. package/test_cli.ts +0 -16
  523. package/version.json +0 -18
@@ -1,747 +0,0 @@
1
- const { humanReadableArgName } = require('./argument.js');
2
-
3
- /**
4
- * TypeScript import types for JSDoc, used by Visual Studio Code IntelliSense and `npm run typescript-checkJS`
5
- * https://www.typescriptlang.org/docs/handbook/jsdoc-supported-types.html#import-types
6
- * @typedef { import("./argument.js").Argument } Argument
7
- * @typedef { import("./command.js").Command } Command
8
- * @typedef { import("./option.js").Option } Option
9
- */
10
-
11
- // Although this is a class, methods are static in style to allow override using subclass or just functions.
12
- class Help {
13
- constructor() {
14
- this.helpWidth = undefined;
15
- this.minWidthToWrap = 40;
16
- this.sortSubcommands = false;
17
- this.sortOptions = false;
18
- this.showGlobalOptions = false;
19
- }
20
-
21
- /**
22
- * prepareContext is called by Commander after applying overrides from `Command.configureHelp()`
23
- * and just before calling `formatHelp()`.
24
- *
25
- * Commander just uses the helpWidth and the rest is provided for optional use by more complex subclasses.
26
- *
27
- * @param {{ error?: boolean, helpWidth?: number, outputHasColors?: boolean }} contextOptions
28
- */
29
- prepareContext(contextOptions) {
30
- this.helpWidth = this.helpWidth ?? contextOptions.helpWidth ?? 80;
31
- }
32
-
33
- /**
34
- * Get an array of the visible subcommands. Includes a placeholder for the implicit help command, if there is one.
35
- *
36
- * @param {Command} cmd
37
- * @returns {Command[]}
38
- */
39
-
40
- visibleCommands(cmd) {
41
- const visibleCommands = cmd.commands.filter((cmd) => !cmd._hidden);
42
- const helpCommand = cmd._getHelpCommand();
43
- if (helpCommand && !helpCommand._hidden) {
44
- visibleCommands.push(helpCommand);
45
- }
46
- if (this.sortSubcommands) {
47
- visibleCommands.sort((a, b) => {
48
- // @ts-ignore: because overloaded return type
49
- return a.name().localeCompare(b.name());
50
- });
51
- }
52
- return visibleCommands;
53
- }
54
-
55
- /**
56
- * Compare options for sort.
57
- *
58
- * @param {Option} a
59
- * @param {Option} b
60
- * @returns {number}
61
- */
62
- compareOptions(a, b) {
63
- const getSortKey = (option) => {
64
- // WYSIWYG for order displayed in help. Short used for comparison if present. No special handling for negated.
65
- return option.short
66
- ? option.short.replace(/^-/, '')
67
- : option.long.replace(/^--/, '');
68
- };
69
- return getSortKey(a).localeCompare(getSortKey(b));
70
- }
71
-
72
- /**
73
- * Get an array of the visible options. Includes a placeholder for the implicit help option, if there is one.
74
- *
75
- * @param {Command} cmd
76
- * @returns {Option[]}
77
- */
78
-
79
- visibleOptions(cmd) {
80
- const visibleOptions = cmd.options.filter((option) => !option.hidden);
81
- // Built-in help option.
82
- const helpOption = cmd._getHelpOption();
83
- if (helpOption && !helpOption.hidden) {
84
- // Automatically hide conflicting flags. Bit dubious but a historical behaviour that is convenient for single-command programs.
85
- const removeShort = helpOption.short && cmd._findOption(helpOption.short);
86
- const removeLong = helpOption.long && cmd._findOption(helpOption.long);
87
- if (!removeShort && !removeLong) {
88
- visibleOptions.push(helpOption); // no changes needed
89
- } else if (helpOption.long && !removeLong) {
90
- visibleOptions.push(
91
- cmd.createOption(helpOption.long, helpOption.description),
92
- );
93
- } else if (helpOption.short && !removeShort) {
94
- visibleOptions.push(
95
- cmd.createOption(helpOption.short, helpOption.description),
96
- );
97
- }
98
- }
99
- if (this.sortOptions) {
100
- visibleOptions.sort(this.compareOptions);
101
- }
102
- return visibleOptions;
103
- }
104
-
105
- /**
106
- * Get an array of the visible global options. (Not including help.)
107
- *
108
- * @param {Command} cmd
109
- * @returns {Option[]}
110
- */
111
-
112
- visibleGlobalOptions(cmd) {
113
- if (!this.showGlobalOptions) return [];
114
-
115
- const globalOptions = [];
116
- for (
117
- let ancestorCmd = cmd.parent;
118
- ancestorCmd;
119
- ancestorCmd = ancestorCmd.parent
120
- ) {
121
- const visibleOptions = ancestorCmd.options.filter(
122
- (option) => !option.hidden,
123
- );
124
- globalOptions.push(...visibleOptions);
125
- }
126
- if (this.sortOptions) {
127
- globalOptions.sort(this.compareOptions);
128
- }
129
- return globalOptions;
130
- }
131
-
132
- /**
133
- * Get an array of the arguments if any have a description.
134
- *
135
- * @param {Command} cmd
136
- * @returns {Argument[]}
137
- */
138
-
139
- visibleArguments(cmd) {
140
- // Side effect! Apply the legacy descriptions before the arguments are displayed.
141
- if (cmd._argsDescription) {
142
- cmd.registeredArguments.forEach((argument) => {
143
- argument.description =
144
- argument.description || cmd._argsDescription[argument.name()] || '';
145
- });
146
- }
147
-
148
- // If there are any arguments with a description then return all the arguments.
149
- if (cmd.registeredArguments.find((argument) => argument.description)) {
150
- return cmd.registeredArguments;
151
- }
152
- return [];
153
- }
154
-
155
- /**
156
- * Get the command term to show in the list of subcommands.
157
- *
158
- * @param {Command} cmd
159
- * @returns {string}
160
- */
161
-
162
- subcommandTerm(cmd) {
163
- // Legacy. Ignores custom usage string, and nested commands.
164
- const args = cmd.registeredArguments
165
- .map((arg) => humanReadableArgName(arg))
166
- .join(' ');
167
- return (
168
- cmd._name +
169
- (cmd._aliases[0] ? '|' + cmd._aliases[0] : '') +
170
- (cmd.options.length ? ' [options]' : '') + // simplistic check for non-help option
171
- (args ? ' ' + args : '')
172
- );
173
- }
174
-
175
- /**
176
- * Get the option term to show in the list of options.
177
- *
178
- * @param {Option} option
179
- * @returns {string}
180
- */
181
-
182
- optionTerm(option) {
183
- return option.flags;
184
- }
185
-
186
- /**
187
- * Get the argument term to show in the list of arguments.
188
- *
189
- * @param {Argument} argument
190
- * @returns {string}
191
- */
192
-
193
- argumentTerm(argument) {
194
- return argument.name();
195
- }
196
-
197
- /**
198
- * Get the longest command term length.
199
- *
200
- * @param {Command} cmd
201
- * @param {Help} helper
202
- * @returns {number}
203
- */
204
-
205
- longestSubcommandTermLength(cmd, helper) {
206
- return helper.visibleCommands(cmd).reduce((max, command) => {
207
- return Math.max(
208
- max,
209
- this.displayWidth(
210
- helper.styleSubcommandTerm(helper.subcommandTerm(command)),
211
- ),
212
- );
213
- }, 0);
214
- }
215
-
216
- /**
217
- * Get the longest option term length.
218
- *
219
- * @param {Command} cmd
220
- * @param {Help} helper
221
- * @returns {number}
222
- */
223
-
224
- longestOptionTermLength(cmd, helper) {
225
- return helper.visibleOptions(cmd).reduce((max, option) => {
226
- return Math.max(
227
- max,
228
- this.displayWidth(helper.styleOptionTerm(helper.optionTerm(option))),
229
- );
230
- }, 0);
231
- }
232
-
233
- /**
234
- * Get the longest global option term length.
235
- *
236
- * @param {Command} cmd
237
- * @param {Help} helper
238
- * @returns {number}
239
- */
240
-
241
- longestGlobalOptionTermLength(cmd, helper) {
242
- return helper.visibleGlobalOptions(cmd).reduce((max, option) => {
243
- return Math.max(
244
- max,
245
- this.displayWidth(helper.styleOptionTerm(helper.optionTerm(option))),
246
- );
247
- }, 0);
248
- }
249
-
250
- /**
251
- * Get the longest argument term length.
252
- *
253
- * @param {Command} cmd
254
- * @param {Help} helper
255
- * @returns {number}
256
- */
257
-
258
- longestArgumentTermLength(cmd, helper) {
259
- return helper.visibleArguments(cmd).reduce((max, argument) => {
260
- return Math.max(
261
- max,
262
- this.displayWidth(
263
- helper.styleArgumentTerm(helper.argumentTerm(argument)),
264
- ),
265
- );
266
- }, 0);
267
- }
268
-
269
- /**
270
- * Get the command usage to be displayed at the top of the built-in help.
271
- *
272
- * @param {Command} cmd
273
- * @returns {string}
274
- */
275
-
276
- commandUsage(cmd) {
277
- // Usage
278
- let cmdName = cmd._name;
279
- if (cmd._aliases[0]) {
280
- cmdName = cmdName + '|' + cmd._aliases[0];
281
- }
282
- let ancestorCmdNames = '';
283
- for (
284
- let ancestorCmd = cmd.parent;
285
- ancestorCmd;
286
- ancestorCmd = ancestorCmd.parent
287
- ) {
288
- ancestorCmdNames = ancestorCmd.name() + ' ' + ancestorCmdNames;
289
- }
290
- return ancestorCmdNames + cmdName + ' ' + cmd.usage();
291
- }
292
-
293
- /**
294
- * Get the description for the command.
295
- *
296
- * @param {Command} cmd
297
- * @returns {string}
298
- */
299
-
300
- commandDescription(cmd) {
301
- // @ts-ignore: because overloaded return type
302
- return cmd.description();
303
- }
304
-
305
- /**
306
- * Get the subcommand summary to show in the list of subcommands.
307
- * (Fallback to description for backwards compatibility.)
308
- *
309
- * @param {Command} cmd
310
- * @returns {string}
311
- */
312
-
313
- subcommandDescription(cmd) {
314
- // @ts-ignore: because overloaded return type
315
- return cmd.summary() || cmd.description();
316
- }
317
-
318
- /**
319
- * Get the option description to show in the list of options.
320
- *
321
- * @param {Option} option
322
- * @return {string}
323
- */
324
-
325
- optionDescription(option) {
326
- const extraInfo = [];
327
-
328
- if (option.argChoices) {
329
- extraInfo.push(
330
- // use stringify to match the display of the default value
331
- `choices: ${option.argChoices.map((choice) => JSON.stringify(choice)).join(', ')}`,
332
- );
333
- }
334
- if (option.defaultValue !== undefined) {
335
- // default for boolean and negated more for programmer than end user,
336
- // but show true/false for boolean option as may be for hand-rolled env or config processing.
337
- const showDefault =
338
- option.required ||
339
- option.optional ||
340
- (option.isBoolean() && typeof option.defaultValue === 'boolean');
341
- if (showDefault) {
342
- extraInfo.push(
343
- `default: ${option.defaultValueDescription || JSON.stringify(option.defaultValue)}`,
344
- );
345
- }
346
- }
347
- // preset for boolean and negated are more for programmer than end user
348
- if (option.presetArg !== undefined && option.optional) {
349
- extraInfo.push(`preset: ${JSON.stringify(option.presetArg)}`);
350
- }
351
- if (option.envVar !== undefined) {
352
- extraInfo.push(`env: ${option.envVar}`);
353
- }
354
- if (extraInfo.length > 0) {
355
- const extraDescription = `(${extraInfo.join(', ')})`;
356
- if (option.description) {
357
- return `${option.description} ${extraDescription}`;
358
- }
359
- return extraDescription;
360
- }
361
-
362
- return option.description;
363
- }
364
-
365
- /**
366
- * Get the argument description to show in the list of arguments.
367
- *
368
- * @param {Argument} argument
369
- * @return {string}
370
- */
371
-
372
- argumentDescription(argument) {
373
- const extraInfo = [];
374
- if (argument.argChoices) {
375
- extraInfo.push(
376
- // use stringify to match the display of the default value
377
- `choices: ${argument.argChoices.map((choice) => JSON.stringify(choice)).join(', ')}`,
378
- );
379
- }
380
- if (argument.defaultValue !== undefined) {
381
- extraInfo.push(
382
- `default: ${argument.defaultValueDescription || JSON.stringify(argument.defaultValue)}`,
383
- );
384
- }
385
- if (extraInfo.length > 0) {
386
- const extraDescription = `(${extraInfo.join(', ')})`;
387
- if (argument.description) {
388
- return `${argument.description} ${extraDescription}`;
389
- }
390
- return extraDescription;
391
- }
392
- return argument.description;
393
- }
394
-
395
- /**
396
- * Format a list of items, given a heading and an array of formatted items.
397
- *
398
- * @param {string} heading
399
- * @param {string[]} items
400
- * @param {Help} helper
401
- * @returns string[]
402
- */
403
- formatItemList(heading, items, helper) {
404
- if (items.length === 0) return [];
405
-
406
- return [helper.styleTitle(heading), ...items, ''];
407
- }
408
-
409
- /**
410
- * Group items by their help group heading.
411
- *
412
- * @param {Command[] | Option[]} unsortedItems
413
- * @param {Command[] | Option[]} visibleItems
414
- * @param {Function} getGroup
415
- * @returns {Map<string, Command[] | Option[]>}
416
- */
417
- groupItems(unsortedItems, visibleItems, getGroup) {
418
- const result = new Map();
419
- // Add groups in order of appearance in unsortedItems.
420
- unsortedItems.forEach((item) => {
421
- const group = getGroup(item);
422
- if (!result.has(group)) result.set(group, []);
423
- });
424
- // Add items in order of appearance in visibleItems.
425
- visibleItems.forEach((item) => {
426
- const group = getGroup(item);
427
- if (!result.has(group)) {
428
- result.set(group, []);
429
- }
430
- result.get(group).push(item);
431
- });
432
- return result;
433
- }
434
-
435
- /**
436
- * Generate the built-in help text.
437
- *
438
- * @param {Command} cmd
439
- * @param {Help} helper
440
- * @returns {string}
441
- */
442
-
443
- formatHelp(cmd, helper) {
444
- const termWidth = helper.padWidth(cmd, helper);
445
- const helpWidth = helper.helpWidth ?? 80; // in case prepareContext() was not called
446
-
447
- function callFormatItem(term, description) {
448
- return helper.formatItem(term, termWidth, description, helper);
449
- }
450
-
451
- // Usage
452
- let output = [
453
- `${helper.styleTitle('Usage:')} ${helper.styleUsage(helper.commandUsage(cmd))}`,
454
- '',
455
- ];
456
-
457
- // Description
458
- const commandDescription = helper.commandDescription(cmd);
459
- if (commandDescription.length > 0) {
460
- output = output.concat([
461
- helper.boxWrap(
462
- helper.styleCommandDescription(commandDescription),
463
- helpWidth,
464
- ),
465
- '',
466
- ]);
467
- }
468
-
469
- // Arguments
470
- const argumentList = helper.visibleArguments(cmd).map((argument) => {
471
- return callFormatItem(
472
- helper.styleArgumentTerm(helper.argumentTerm(argument)),
473
- helper.styleArgumentDescription(helper.argumentDescription(argument)),
474
- );
475
- });
476
- output = output.concat(
477
- this.formatItemList('Arguments:', argumentList, helper),
478
- );
479
-
480
- // Options
481
- const optionGroups = this.groupItems(
482
- cmd.options,
483
- helper.visibleOptions(cmd),
484
- (option) => option.helpGroupHeading ?? 'Options:',
485
- );
486
- optionGroups.forEach((options, group) => {
487
- const optionList = options.map((option) => {
488
- return callFormatItem(
489
- helper.styleOptionTerm(helper.optionTerm(option)),
490
- helper.styleOptionDescription(helper.optionDescription(option)),
491
- );
492
- });
493
- output = output.concat(this.formatItemList(group, optionList, helper));
494
- });
495
-
496
- if (helper.showGlobalOptions) {
497
- const globalOptionList = helper
498
- .visibleGlobalOptions(cmd)
499
- .map((option) => {
500
- return callFormatItem(
501
- helper.styleOptionTerm(helper.optionTerm(option)),
502
- helper.styleOptionDescription(helper.optionDescription(option)),
503
- );
504
- });
505
- output = output.concat(
506
- this.formatItemList('Global Options:', globalOptionList, helper),
507
- );
508
- }
509
-
510
- // Commands
511
- const commandGroups = this.groupItems(
512
- cmd.commands,
513
- helper.visibleCommands(cmd),
514
- (sub) => sub.helpGroup() || 'Commands:',
515
- );
516
- commandGroups.forEach((commands, group) => {
517
- const commandList = commands.map((sub) => {
518
- return callFormatItem(
519
- helper.styleSubcommandTerm(helper.subcommandTerm(sub)),
520
- helper.styleSubcommandDescription(helper.subcommandDescription(sub)),
521
- );
522
- });
523
- output = output.concat(this.formatItemList(group, commandList, helper));
524
- });
525
-
526
- return output.join('\n');
527
- }
528
-
529
- /**
530
- * Return display width of string, ignoring ANSI escape sequences. Used in padding and wrapping calculations.
531
- *
532
- * @param {string} str
533
- * @returns {number}
534
- */
535
- displayWidth(str) {
536
- return stripColor(str).length;
537
- }
538
-
539
- /**
540
- * Style the title for displaying in the help. Called with 'Usage:', 'Options:', etc.
541
- *
542
- * @param {string} str
543
- * @returns {string}
544
- */
545
- styleTitle(str) {
546
- return str;
547
- }
548
-
549
- styleUsage(str) {
550
- // Usage has lots of parts the user might like to color separately! Assume default usage string which is formed like:
551
- // command subcommand [options] [command] <foo> [bar]
552
- return str
553
- .split(' ')
554
- .map((word) => {
555
- if (word === '[options]') return this.styleOptionText(word);
556
- if (word === '[command]') return this.styleSubcommandText(word);
557
- if (word[0] === '[' || word[0] === '<')
558
- return this.styleArgumentText(word);
559
- return this.styleCommandText(word); // Restrict to initial words?
560
- })
561
- .join(' ');
562
- }
563
- styleCommandDescription(str) {
564
- return this.styleDescriptionText(str);
565
- }
566
- styleOptionDescription(str) {
567
- return this.styleDescriptionText(str);
568
- }
569
- styleSubcommandDescription(str) {
570
- return this.styleDescriptionText(str);
571
- }
572
- styleArgumentDescription(str) {
573
- return this.styleDescriptionText(str);
574
- }
575
- styleDescriptionText(str) {
576
- return str;
577
- }
578
- styleOptionTerm(str) {
579
- return this.styleOptionText(str);
580
- }
581
- styleSubcommandTerm(str) {
582
- // This is very like usage with lots of parts! Assume default string which is formed like:
583
- // subcommand [options] <foo> [bar]
584
- return str
585
- .split(' ')
586
- .map((word) => {
587
- if (word === '[options]') return this.styleOptionText(word);
588
- if (word[0] === '[' || word[0] === '<')
589
- return this.styleArgumentText(word);
590
- return this.styleSubcommandText(word); // Restrict to initial words?
591
- })
592
- .join(' ');
593
- }
594
- styleArgumentTerm(str) {
595
- return this.styleArgumentText(str);
596
- }
597
- styleOptionText(str) {
598
- return str;
599
- }
600
- styleArgumentText(str) {
601
- return str;
602
- }
603
- styleSubcommandText(str) {
604
- return str;
605
- }
606
- styleCommandText(str) {
607
- return str;
608
- }
609
-
610
- /**
611
- * Calculate the pad width from the maximum term length.
612
- *
613
- * @param {Command} cmd
614
- * @param {Help} helper
615
- * @returns {number}
616
- */
617
-
618
- padWidth(cmd, helper) {
619
- return Math.max(
620
- helper.longestOptionTermLength(cmd, helper),
621
- helper.longestGlobalOptionTermLength(cmd, helper),
622
- helper.longestSubcommandTermLength(cmd, helper),
623
- helper.longestArgumentTermLength(cmd, helper),
624
- );
625
- }
626
-
627
- /**
628
- * Detect manually wrapped and indented strings by checking for line break followed by whitespace.
629
- *
630
- * @param {string} str
631
- * @returns {boolean}
632
- */
633
- preformatted(str) {
634
- return /\n[^\S\r\n]/.test(str);
635
- }
636
-
637
- /**
638
- * Format the "item", which consists of a term and description. Pad the term and wrap the description, indenting the following lines.
639
- *
640
- * So "TTT", 5, "DDD DDDD DD DDD" might be formatted for this.helpWidth=17 like so:
641
- * TTT DDD DDDD
642
- * DD DDD
643
- *
644
- * @param {string} term
645
- * @param {number} termWidth
646
- * @param {string} description
647
- * @param {Help} helper
648
- * @returns {string}
649
- */
650
- formatItem(term, termWidth, description, helper) {
651
- const itemIndent = 2;
652
- const itemIndentStr = ' '.repeat(itemIndent);
653
- if (!description) return itemIndentStr + term;
654
-
655
- // Pad the term out to a consistent width, so descriptions are aligned.
656
- const paddedTerm = term.padEnd(
657
- termWidth + term.length - helper.displayWidth(term),
658
- );
659
-
660
- // Format the description.
661
- const spacerWidth = 2; // between term and description
662
- const helpWidth = this.helpWidth ?? 80; // in case prepareContext() was not called
663
- const remainingWidth = helpWidth - termWidth - spacerWidth - itemIndent;
664
- let formattedDescription;
665
- if (
666
- remainingWidth < this.minWidthToWrap ||
667
- helper.preformatted(description)
668
- ) {
669
- formattedDescription = description;
670
- } else {
671
- const wrappedDescription = helper.boxWrap(description, remainingWidth);
672
- formattedDescription = wrappedDescription.replace(
673
- /\n/g,
674
- '\n' + ' '.repeat(termWidth + spacerWidth),
675
- );
676
- }
677
-
678
- // Construct and overall indent.
679
- return (
680
- itemIndentStr +
681
- paddedTerm +
682
- ' '.repeat(spacerWidth) +
683
- formattedDescription.replace(/\n/g, `\n${itemIndentStr}`)
684
- );
685
- }
686
-
687
- /**
688
- * Wrap a string at whitespace, preserving existing line breaks.
689
- * Wrapping is skipped if the width is less than `minWidthToWrap`.
690
- *
691
- * @param {string} str
692
- * @param {number} width
693
- * @returns {string}
694
- */
695
- boxWrap(str, width) {
696
- if (width < this.minWidthToWrap) return str;
697
-
698
- const rawLines = str.split(/\r\n|\n/);
699
- // split up text by whitespace
700
- const chunkPattern = /[\s]*[^\s]+/g;
701
- const wrappedLines = [];
702
- rawLines.forEach((line) => {
703
- const chunks = line.match(chunkPattern);
704
- if (chunks === null) {
705
- wrappedLines.push('');
706
- return;
707
- }
708
-
709
- let sumChunks = [chunks.shift()];
710
- let sumWidth = this.displayWidth(sumChunks[0]);
711
- chunks.forEach((chunk) => {
712
- const visibleWidth = this.displayWidth(chunk);
713
- // Accumulate chunks while they fit into width.
714
- if (sumWidth + visibleWidth <= width) {
715
- sumChunks.push(chunk);
716
- sumWidth += visibleWidth;
717
- return;
718
- }
719
- wrappedLines.push(sumChunks.join(''));
720
-
721
- const nextChunk = chunk.trimStart(); // trim space at line break
722
- sumChunks = [nextChunk];
723
- sumWidth = this.displayWidth(nextChunk);
724
- });
725
- wrappedLines.push(sumChunks.join(''));
726
- });
727
-
728
- return wrappedLines.join('\n');
729
- }
730
- }
731
-
732
- /**
733
- * Strip style ANSI escape sequences from the string. In particular, SGR (Select Graphic Rendition) codes.
734
- *
735
- * @param {string} str
736
- * @returns {string}
737
- * @package
738
- */
739
-
740
- function stripColor(str) {
741
- // eslint-disable-next-line no-control-regex
742
- const sgrPattern = /\x1b\[\d*(;\d*)*m/g;
743
- return str.replace(sgrPattern, '');
744
- }
745
-
746
- exports.Help = Help;
747
- exports.stripColor = stripColor;