@pnpm/exe 11.0.0-beta.0 → 11.0.0-beta.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 (200) hide show
  1. package/dist/node_modules/@gar/promise-retry/lib/index.js +28 -0
  2. package/dist/node_modules/@gar/promise-retry/package.json +48 -0
  3. package/dist/node_modules/@npmcli/agent/package.json +7 -7
  4. package/dist/node_modules/@npmcli/fs/package.json +4 -4
  5. package/dist/node_modules/abbrev/package.json +11 -15
  6. package/dist/node_modules/cacache/package.json +10 -11
  7. package/dist/node_modules/glob/dist/commonjs/glob.js +2 -1
  8. package/dist/node_modules/glob/dist/commonjs/index.min.js +4 -0
  9. package/dist/node_modules/glob/dist/commonjs/pattern.js +4 -0
  10. package/dist/node_modules/glob/dist/esm/glob.js +2 -1
  11. package/dist/node_modules/glob/dist/esm/index.min.js +4 -0
  12. package/dist/node_modules/glob/dist/esm/pattern.js +4 -0
  13. package/dist/node_modules/glob/package.json +38 -37
  14. package/dist/node_modules/graceful-fs/graceful-fs.js +1 -1
  15. package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js +460 -525
  16. package/dist/node_modules/iconv-lite/encodings/dbcs-data.js +179 -182
  17. package/dist/node_modules/iconv-lite/encodings/index.js +15 -15
  18. package/dist/node_modules/iconv-lite/encodings/internal.js +168 -148
  19. package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js +55 -52
  20. package/dist/node_modules/iconv-lite/encodings/sbcs-data.js +174 -175
  21. package/dist/node_modules/iconv-lite/encodings/utf16.js +121 -131
  22. package/dist/node_modules/iconv-lite/encodings/utf32.js +226 -238
  23. package/dist/node_modules/iconv-lite/encodings/utf7.js +208 -215
  24. package/dist/node_modules/iconv-lite/lib/bom-handling.js +30 -34
  25. package/dist/node_modules/iconv-lite/lib/helpers/merge-exports.js +13 -0
  26. package/dist/node_modules/iconv-lite/lib/index.js +125 -123
  27. package/dist/node_modules/iconv-lite/lib/streams.js +92 -96
  28. package/dist/node_modules/iconv-lite/package.json +34 -8
  29. package/dist/node_modules/isexe/package.json +65 -18
  30. package/dist/node_modules/lru-cache/dist/commonjs/index.js +134 -85
  31. package/dist/node_modules/lru-cache/dist/commonjs/index.min.js +1 -1
  32. package/dist/node_modules/lru-cache/dist/esm/index.js +134 -85
  33. package/dist/node_modules/lru-cache/dist/esm/index.min.js +1 -1
  34. package/dist/node_modules/lru-cache/package.json +18 -41
  35. package/dist/node_modules/make-fetch-happen/lib/remote.js +1 -1
  36. package/dist/node_modules/make-fetch-happen/package.json +10 -10
  37. package/dist/node_modules/minipass-fetch/lib/body.js +25 -15
  38. package/dist/node_modules/minipass-fetch/package.json +7 -7
  39. package/dist/node_modules/minipass-sized/dist/commonjs/index.js +69 -0
  40. package/dist/node_modules/minipass-sized/dist/esm/index.js +64 -0
  41. package/dist/node_modules/minipass-sized/package.json +39 -9
  42. package/dist/node_modules/node-gyp/.release-please-manifest.json +1 -1
  43. package/dist/node_modules/node-gyp/bin/node-gyp.js +7 -0
  44. package/dist/node_modules/node-gyp/gyp/.release-please-manifest.json +1 -1
  45. package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +3 -3
  46. package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +26 -1
  47. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +1 -1
  48. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +3 -4
  49. package/dist/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +1 -1
  50. package/dist/node_modules/node-gyp/gyp/pyproject.toml +1 -1
  51. package/dist/node_modules/node-gyp/lib/build.js +2 -2
  52. package/dist/node_modules/node-gyp/lib/find-python.js +2 -8
  53. package/dist/node_modules/node-gyp/lib/find-visualstudio.js +11 -5
  54. package/dist/node_modules/node-gyp/lib/install.js +1 -1
  55. package/dist/node_modules/node-gyp/lib/process-release.js +3 -3
  56. package/dist/node_modules/node-gyp/package.json +13 -13
  57. package/dist/node_modules/nopt/package.json +5 -5
  58. package/dist/node_modules/proc-log/lib/index.js +10 -5
  59. package/dist/node_modules/proc-log/package.json +5 -5
  60. package/dist/node_modules/retry/lib/retry.js +2 -2
  61. package/dist/node_modules/retry/lib/retry_operation.js +10 -6
  62. package/dist/node_modules/retry/package.json +6 -2
  63. package/dist/node_modules/ssri/lib/index.js +33 -63
  64. package/dist/node_modules/ssri/package.json +17 -17
  65. package/dist/node_modules/unique-filename/package.json +5 -5
  66. package/dist/node_modules/unique-slug/package.json +4 -4
  67. package/dist/node_modules/which/package.json +29 -20
  68. package/dist/pnpm.mjs +63952 -54674
  69. package/dist/worker.js +601 -2162
  70. package/package.json +8 -8
  71. package/dist/node_modules/@isaacs/cliui/dist/commonjs/ansi-regex/index.js +0 -16
  72. package/dist/node_modules/@isaacs/cliui/dist/commonjs/ansi-styles/index.js +0 -170
  73. package/dist/node_modules/@isaacs/cliui/dist/commonjs/eastasianwidth/index.js +0 -307
  74. package/dist/node_modules/@isaacs/cliui/dist/commonjs/emoji-regex/index.js +0 -7
  75. package/dist/node_modules/@isaacs/cliui/dist/commonjs/index.js +0 -322
  76. package/dist/node_modules/@isaacs/cliui/dist/commonjs/index.min.js +0 -12
  77. package/dist/node_modules/@isaacs/cliui/dist/commonjs/string-width/index.js +0 -49
  78. package/dist/node_modules/@isaacs/cliui/dist/commonjs/strip-ansi/index.js +0 -8
  79. package/dist/node_modules/@isaacs/cliui/dist/commonjs/wrap-ansi/index.js +0 -176
  80. package/dist/node_modules/@isaacs/cliui/dist/esm/ansi-regex/index.js +0 -12
  81. package/dist/node_modules/@isaacs/cliui/dist/esm/ansi-styles/index.js +0 -167
  82. package/dist/node_modules/@isaacs/cliui/dist/esm/eastasianwidth/index.js +0 -299
  83. package/dist/node_modules/@isaacs/cliui/dist/esm/emoji-regex/index.js +0 -3
  84. package/dist/node_modules/@isaacs/cliui/dist/esm/index.js +0 -317
  85. package/dist/node_modules/@isaacs/cliui/dist/esm/index.min.js +0 -12
  86. package/dist/node_modules/@isaacs/cliui/dist/esm/string-width/index.js +0 -46
  87. package/dist/node_modules/@isaacs/cliui/dist/esm/strip-ansi/index.js +0 -4
  88. package/dist/node_modules/@isaacs/cliui/dist/esm/wrap-ansi/index.js +0 -172
  89. package/dist/node_modules/@isaacs/cliui/package.json +0 -163
  90. package/dist/node_modules/cross-spawn/LICENSE +0 -21
  91. package/dist/node_modules/cross-spawn/index.js +0 -39
  92. package/dist/node_modules/cross-spawn/lib/enoent.js +0 -59
  93. package/dist/node_modules/cross-spawn/lib/parse.js +0 -91
  94. package/dist/node_modules/cross-spawn/lib/util/escape.js +0 -47
  95. package/dist/node_modules/cross-spawn/lib/util/readShebang.js +0 -23
  96. package/dist/node_modules/cross-spawn/lib/util/resolveCommand.js +0 -52
  97. package/dist/node_modules/cross-spawn/package.json +0 -73
  98. package/dist/node_modules/encoding/.prettierrc.js +0 -8
  99. package/dist/node_modules/encoding/LICENSE +0 -16
  100. package/dist/node_modules/encoding/lib/encoding.js +0 -83
  101. package/dist/node_modules/encoding/package.json +0 -18
  102. package/dist/node_modules/err-code/.eslintrc.json +0 -7
  103. package/dist/node_modules/err-code/bower.json +0 -30
  104. package/dist/node_modules/err-code/index.js +0 -47
  105. package/dist/node_modules/err-code/index.umd.js +0 -51
  106. package/dist/node_modules/err-code/package.json +0 -34
  107. package/dist/node_modules/foreground-child/LICENSE +0 -15
  108. package/dist/node_modules/foreground-child/dist/commonjs/all-signals.js +0 -58
  109. package/dist/node_modules/foreground-child/dist/commonjs/index.js +0 -123
  110. package/dist/node_modules/foreground-child/dist/commonjs/proxy-signals.js +0 -38
  111. package/dist/node_modules/foreground-child/dist/commonjs/watchdog.js +0 -50
  112. package/dist/node_modules/foreground-child/dist/esm/all-signals.js +0 -52
  113. package/dist/node_modules/foreground-child/dist/esm/index.js +0 -115
  114. package/dist/node_modules/foreground-child/dist/esm/proxy-signals.js +0 -34
  115. package/dist/node_modules/foreground-child/dist/esm/watchdog.js +0 -46
  116. package/dist/node_modules/foreground-child/package.json +0 -106
  117. package/dist/node_modules/glob/dist/esm/bin.d.mts +0 -3
  118. package/dist/node_modules/glob/dist/esm/bin.mjs +0 -346
  119. package/dist/node_modules/iconv-lite/.github/dependabot.yml +0 -11
  120. package/dist/node_modules/iconv-lite/.idea/codeStyles/Project.xml +0 -47
  121. package/dist/node_modules/iconv-lite/.idea/codeStyles/codeStyleConfig.xml +0 -5
  122. package/dist/node_modules/iconv-lite/.idea/iconv-lite.iml +0 -12
  123. package/dist/node_modules/iconv-lite/.idea/inspectionProfiles/Project_Default.xml +0 -6
  124. package/dist/node_modules/iconv-lite/.idea/modules.xml +0 -8
  125. package/dist/node_modules/iconv-lite/.idea/vcs.xml +0 -6
  126. package/dist/node_modules/isexe/LICENSE +0 -15
  127. package/dist/node_modules/isexe/index.js +0 -57
  128. package/dist/node_modules/isexe/mode.js +0 -41
  129. package/dist/node_modules/isexe/windows.js +0 -42
  130. package/dist/node_modules/jackspeak/dist/commonjs/index.js +0 -944
  131. package/dist/node_modules/jackspeak/dist/commonjs/index.min.js +0 -33
  132. package/dist/node_modules/jackspeak/dist/commonjs/package.json +0 -3
  133. package/dist/node_modules/jackspeak/dist/esm/index.js +0 -936
  134. package/dist/node_modules/jackspeak/dist/esm/index.min.js +0 -33
  135. package/dist/node_modules/jackspeak/dist/esm/package.json +0 -3
  136. package/dist/node_modules/jackspeak/package.json +0 -115
  137. package/dist/node_modules/lru-cache/LICENSE +0 -15
  138. package/dist/node_modules/minipass-sized/index.js +0 -67
  139. package/dist/node_modules/minipass-sized/node_modules/minipass/LICENSE +0 -15
  140. package/dist/node_modules/minipass-sized/node_modules/minipass/index.js +0 -649
  141. package/dist/node_modules/minipass-sized/node_modules/minipass/package.json +0 -56
  142. package/dist/node_modules/minipass-sized/package-lock.json +0 -3464
  143. package/dist/node_modules/node-gyp/node_modules/isexe/dist/commonjs/package.json +0 -3
  144. package/dist/node_modules/node-gyp/node_modules/isexe/dist/esm/package.json +0 -3
  145. package/dist/node_modules/node-gyp/node_modules/isexe/package.json +0 -78
  146. package/dist/node_modules/node-gyp/node_modules/which/LICENSE +0 -15
  147. package/dist/node_modules/node-gyp/node_modules/which/package.json +0 -52
  148. package/dist/node_modules/package-json-from-dist/dist/commonjs/index.js +0 -134
  149. package/dist/node_modules/package-json-from-dist/dist/commonjs/package.json +0 -3
  150. package/dist/node_modules/package-json-from-dist/dist/esm/index.js +0 -129
  151. package/dist/node_modules/package-json-from-dist/dist/esm/package.json +0 -3
  152. package/dist/node_modules/package-json-from-dist/package.json +0 -68
  153. package/dist/node_modules/path-key/index.js +0 -16
  154. package/dist/node_modules/path-key/license +0 -9
  155. package/dist/node_modules/path-key/package.json +0 -39
  156. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.js +0 -1589
  157. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/index.min.js +0 -2
  158. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/commonjs/package.json +0 -3
  159. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.js +0 -1585
  160. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/esm/index.min.js +0 -2
  161. package/dist/node_modules/path-scurry/node_modules/lru-cache/dist/esm/package.json +0 -3
  162. package/dist/node_modules/path-scurry/node_modules/lru-cache/package.json +0 -101
  163. package/dist/node_modules/promise-retry/index.js +0 -52
  164. package/dist/node_modules/promise-retry/package.json +0 -37
  165. package/dist/node_modules/retry/equation.gif +0 -0
  166. package/dist/node_modules/shebang-command/index.js +0 -19
  167. package/dist/node_modules/shebang-command/license +0 -9
  168. package/dist/node_modules/shebang-command/package.json +0 -34
  169. package/dist/node_modules/shebang-regex/index.js +0 -2
  170. package/dist/node_modules/shebang-regex/license +0 -9
  171. package/dist/node_modules/shebang-regex/package.json +0 -35
  172. package/dist/node_modules/signal-exit/LICENSE.txt +0 -16
  173. package/dist/node_modules/signal-exit/dist/cjs/browser.js +0 -10
  174. package/dist/node_modules/signal-exit/dist/cjs/index.js +0 -279
  175. package/dist/node_modules/signal-exit/dist/cjs/package.json +0 -3
  176. package/dist/node_modules/signal-exit/dist/cjs/signals.js +0 -42
  177. package/dist/node_modules/signal-exit/dist/mjs/browser.js +0 -4
  178. package/dist/node_modules/signal-exit/dist/mjs/index.js +0 -275
  179. package/dist/node_modules/signal-exit/dist/mjs/package.json +0 -3
  180. package/dist/node_modules/signal-exit/dist/mjs/signals.js +0 -39
  181. package/dist/node_modules/signal-exit/package.json +0 -106
  182. package/dist/node_modules/which/bin/node-which +0 -52
  183. package/dist/node_modules/which/which.js +0 -125
  184. /package/dist/node_modules/{promise-retry → @gar/promise-retry}/LICENSE +0 -0
  185. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/commonjs/index.js +0 -0
  186. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/commonjs/index.min.js +0 -0
  187. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/commonjs/options.js +0 -0
  188. /package/dist/node_modules/{@isaacs/cliui → isexe}/dist/commonjs/package.json +0 -0
  189. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/commonjs/posix.js +0 -0
  190. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/commonjs/win32.js +0 -0
  191. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/esm/index.js +0 -0
  192. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/esm/index.min.js +0 -0
  193. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/esm/options.js +0 -0
  194. /package/dist/node_modules/{@isaacs/cliui → isexe}/dist/esm/package.json +0 -0
  195. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/esm/posix.js +0 -0
  196. /package/dist/node_modules/{node-gyp/node_modules/isexe → isexe}/dist/esm/win32.js +0 -0
  197. /package/dist/node_modules/{foreground-child → minipass-sized}/dist/commonjs/package.json +0 -0
  198. /package/dist/node_modules/{foreground-child → minipass-sized}/dist/esm/package.json +0 -0
  199. /package/dist/node_modules/{node-gyp/node_modules/which → which}/bin/which.js +0 -0
  200. /package/dist/node_modules/{node-gyp/node_modules/which → which}/lib/index.js +0 -0
@@ -1,944 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.jack = exports.Jack = exports.isConfigOption = exports.isConfigOptionOfType = exports.isConfigType = void 0;
4
- const node_util_1 = require("node:util");
5
- const min_1 = require("@isaacs/cliui/min");
6
- const node_path_1 = require("node:path");
7
- const isConfigType = (t) => typeof t === 'string' &&
8
- (t === 'string' || t === 'number' || t === 'boolean');
9
- exports.isConfigType = isConfigType;
10
- const isValidValue = (v, type, multi) => {
11
- if (multi) {
12
- if (!Array.isArray(v))
13
- return false;
14
- return !v.some((v) => !isValidValue(v, type, false));
15
- }
16
- if (Array.isArray(v))
17
- return false;
18
- return typeof v === type;
19
- };
20
- const isValidOption = (v, vo) => !!vo &&
21
- (Array.isArray(v) ? v.every(x => isValidOption(x, vo)) : vo.includes(v));
22
- /**
23
- * Determine whether an unknown object is a {@link ConfigOption} based only
24
- * on its `type` and `multiple` property
25
- */
26
- const isConfigOptionOfType = (o, type, multi) => !!o &&
27
- typeof o === 'object' &&
28
- 'type' in o &&
29
- (0, exports.isConfigType)(o.type) &&
30
- o.type === type &&
31
- !!o.multiple === multi;
32
- exports.isConfigOptionOfType = isConfigOptionOfType;
33
- /**
34
- * Determine whether an unknown object is a {@link ConfigOption} based on
35
- * it having all valid properties
36
- */
37
- const isConfigOption = (o, type, multi) => (0, exports.isConfigOptionOfType)(o, type, multi) &&
38
- undefOrType(o.short, 'string') &&
39
- undefOrType(o.description, 'string') &&
40
- undefOrType(o.hint, 'string') &&
41
- undefOrType(o.validate, 'function') &&
42
- (o.type === 'boolean' ?
43
- o.validOptions === undefined
44
- : undefOrTypeArray(o.validOptions, o.type)) &&
45
- (o.default === undefined || isValidValue(o.default, type, multi));
46
- exports.isConfigOption = isConfigOption;
47
- const isHeading = (r) => r.type === 'heading';
48
- const isDescription = (r) => r.type === 'description';
49
- const width = Math.min(process?.stdout?.columns ?? 80, 80);
50
- // indentation spaces from heading level
51
- const indent = (n) => (n - 1) * 2;
52
- const toEnvKey = (pref, key) => [pref, key.replace(/[^a-zA-Z0-9]+/g, ' ')]
53
- .join(' ')
54
- .trim()
55
- .toUpperCase()
56
- .replace(/ /g, '_');
57
- const toEnvVal = (value, delim = '\n') => {
58
- const str = typeof value === 'string' ? value
59
- : typeof value === 'boolean' ?
60
- value ? '1'
61
- : '0'
62
- : typeof value === 'number' ? String(value)
63
- : Array.isArray(value) ?
64
- value.map((v) => toEnvVal(v)).join(delim)
65
- : /* c8 ignore start */ undefined;
66
- if (typeof str !== 'string') {
67
- throw new Error(`could not serialize value to environment: ${JSON.stringify(value)}`, { cause: { code: 'JACKSPEAK' } });
68
- }
69
- /* c8 ignore stop */
70
- return str;
71
- };
72
- const fromEnvVal = (env, type, multiple, delim = '\n') => (multiple ?
73
- env ? env.split(delim).map(v => fromEnvVal(v, type, false))
74
- : []
75
- : type === 'string' ? env
76
- : type === 'boolean' ? env === '1'
77
- : +env.trim());
78
- const undefOrType = (v, t) => v === undefined || typeof v === t;
79
- const undefOrTypeArray = (v, t) => v === undefined || (Array.isArray(v) && v.every(x => typeof x === t));
80
- // print the value type, for error message reporting
81
- const valueType = (v) => typeof v === 'string' ? 'string'
82
- : typeof v === 'boolean' ? 'boolean'
83
- : typeof v === 'number' ? 'number'
84
- : Array.isArray(v) ?
85
- `${joinTypes([...new Set(v.map(v => valueType(v)))])}[]`
86
- : `${v.type}${v.multiple ? '[]' : ''}`;
87
- const joinTypes = (types) => types.length === 1 && typeof types[0] === 'string' ?
88
- types[0]
89
- : `(${types.join('|')})`;
90
- const validateFieldMeta = (field, fieldMeta) => {
91
- if (fieldMeta) {
92
- if (field.type !== undefined && field.type !== fieldMeta.type) {
93
- throw new TypeError(`invalid type`, {
94
- cause: {
95
- found: field.type,
96
- wanted: [fieldMeta.type, undefined],
97
- },
98
- });
99
- }
100
- if (field.multiple !== undefined &&
101
- !!field.multiple !== fieldMeta.multiple) {
102
- throw new TypeError(`invalid multiple`, {
103
- cause: {
104
- found: field.multiple,
105
- wanted: [fieldMeta.multiple, undefined],
106
- },
107
- });
108
- }
109
- return fieldMeta;
110
- }
111
- if (!(0, exports.isConfigType)(field.type)) {
112
- throw new TypeError(`invalid type`, {
113
- cause: {
114
- found: field.type,
115
- wanted: ['string', 'number', 'boolean'],
116
- },
117
- });
118
- }
119
- return {
120
- type: field.type,
121
- multiple: !!field.multiple,
122
- };
123
- };
124
- const validateField = (o, type, multiple) => {
125
- const validateValidOptions = (def, validOptions) => {
126
- if (!undefOrTypeArray(validOptions, type)) {
127
- throw new TypeError('invalid validOptions', {
128
- cause: {
129
- found: validOptions,
130
- wanted: valueType({ type, multiple: true }),
131
- },
132
- });
133
- }
134
- if (def !== undefined && validOptions !== undefined) {
135
- const valid = Array.isArray(def) ?
136
- def.every(v => validOptions.includes(v))
137
- : validOptions.includes(def);
138
- if (!valid) {
139
- throw new TypeError('invalid default value not in validOptions', {
140
- cause: {
141
- found: def,
142
- wanted: validOptions,
143
- },
144
- });
145
- }
146
- }
147
- };
148
- if (o.default !== undefined &&
149
- !isValidValue(o.default, type, multiple)) {
150
- throw new TypeError('invalid default value', {
151
- cause: {
152
- found: o.default,
153
- wanted: valueType({ type, multiple }),
154
- },
155
- });
156
- }
157
- if ((0, exports.isConfigOptionOfType)(o, 'number', false) ||
158
- (0, exports.isConfigOptionOfType)(o, 'number', true)) {
159
- validateValidOptions(o.default, o.validOptions);
160
- }
161
- else if ((0, exports.isConfigOptionOfType)(o, 'string', false) ||
162
- (0, exports.isConfigOptionOfType)(o, 'string', true)) {
163
- validateValidOptions(o.default, o.validOptions);
164
- }
165
- else if ((0, exports.isConfigOptionOfType)(o, 'boolean', false) ||
166
- (0, exports.isConfigOptionOfType)(o, 'boolean', true)) {
167
- if (o.hint !== undefined) {
168
- throw new TypeError('cannot provide hint for flag');
169
- }
170
- if (o.validOptions !== undefined) {
171
- throw new TypeError('cannot provide validOptions for flag');
172
- }
173
- }
174
- return o;
175
- };
176
- const toParseArgsOptionsConfig = (options) => {
177
- return Object.entries(options).reduce((acc, [longOption, o]) => {
178
- const p = {
179
- type: 'string',
180
- multiple: !!o.multiple,
181
- ...(typeof o.short === 'string' ? { short: o.short } : undefined),
182
- };
183
- const setNoBool = () => {
184
- if (!longOption.startsWith('no-') && !options[`no-${longOption}`]) {
185
- acc[`no-${longOption}`] = {
186
- type: 'boolean',
187
- multiple: !!o.multiple,
188
- };
189
- }
190
- };
191
- const setDefault = (def, fn) => {
192
- if (def !== undefined) {
193
- p.default = fn(def);
194
- }
195
- };
196
- if ((0, exports.isConfigOption)(o, 'number', false)) {
197
- setDefault(o.default, String);
198
- }
199
- else if ((0, exports.isConfigOption)(o, 'number', true)) {
200
- setDefault(o.default, d => d.map(v => String(v)));
201
- }
202
- else if ((0, exports.isConfigOption)(o, 'string', false) ||
203
- (0, exports.isConfigOption)(o, 'string', true)) {
204
- setDefault(o.default, v => v);
205
- }
206
- else if ((0, exports.isConfigOption)(o, 'boolean', false) ||
207
- (0, exports.isConfigOption)(o, 'boolean', true)) {
208
- p.type = 'boolean';
209
- setDefault(o.default, v => v);
210
- setNoBool();
211
- }
212
- acc[longOption] = p;
213
- return acc;
214
- }, {});
215
- };
216
- /**
217
- * Class returned by the {@link jack} function and all configuration
218
- * definition methods. This is what gets chained together.
219
- */
220
- class Jack {
221
- #configSet;
222
- #shorts;
223
- #options;
224
- #fields = [];
225
- #env;
226
- #envPrefix;
227
- #allowPositionals;
228
- #usage;
229
- #usageMarkdown;
230
- constructor(options = {}) {
231
- this.#options = options;
232
- this.#allowPositionals = options.allowPositionals !== false;
233
- this.#env =
234
- this.#options.env === undefined ? process.env : this.#options.env;
235
- this.#envPrefix = options.envPrefix;
236
- // We need to fib a little, because it's always the same object, but it
237
- // starts out as having an empty config set. Then each method that adds
238
- // fields returns `this as Jack<C & { ...newConfigs }>`
239
- this.#configSet = Object.create(null);
240
- this.#shorts = Object.create(null);
241
- }
242
- /**
243
- * Resulting definitions, suitable to be passed to Node's `util.parseArgs`,
244
- * but also including `description` and `short` fields, if set.
245
- */
246
- get definitions() {
247
- return this.#configSet;
248
- }
249
- /** map of `{ <short>: <long> }` strings for each short name defined */
250
- get shorts() {
251
- return this.#shorts;
252
- }
253
- /**
254
- * options passed to the {@link Jack} constructor
255
- */
256
- get jackOptions() {
257
- return this.#options;
258
- }
259
- /**
260
- * the data used to generate {@link Jack#usage} and
261
- * {@link Jack#usageMarkdown} content.
262
- */
263
- get usageFields() {
264
- return this.#fields;
265
- }
266
- /**
267
- * Set the default value (which will still be overridden by env or cli)
268
- * as if from a parsed config file. The optional `source` param, if
269
- * provided, will be included in error messages if a value is invalid or
270
- * unknown.
271
- */
272
- setConfigValues(values, source = '') {
273
- try {
274
- this.validate(values);
275
- }
276
- catch (er) {
277
- if (source && er instanceof Error) {
278
- /* c8 ignore next */
279
- const cause = typeof er.cause === 'object' ? er.cause : {};
280
- er.cause = { ...cause, path: source };
281
- Error.captureStackTrace(er, this.setConfigValues);
282
- }
283
- throw er;
284
- }
285
- for (const [field, value] of Object.entries(values)) {
286
- const my = this.#configSet[field];
287
- // already validated, just for TS's benefit
288
- /* c8 ignore start */
289
- if (!my) {
290
- throw new Error('unexpected field in config set: ' + field, {
291
- cause: {
292
- code: 'JACKSPEAK',
293
- found: field,
294
- },
295
- });
296
- }
297
- /* c8 ignore stop */
298
- my.default = value;
299
- }
300
- return this;
301
- }
302
- /**
303
- * Parse a string of arguments, and return the resulting
304
- * `{ values, positionals }` object.
305
- *
306
- * If an {@link JackOptions#envPrefix} is set, then it will read default
307
- * values from the environment, and write the resulting values back
308
- * to the environment as well.
309
- *
310
- * Environment values always take precedence over any other value, except
311
- * an explicit CLI setting.
312
- */
313
- parse(args = process.argv) {
314
- this.loadEnvDefaults();
315
- const p = this.parseRaw(args);
316
- this.applyDefaults(p);
317
- this.writeEnv(p);
318
- return p;
319
- }
320
- loadEnvDefaults() {
321
- if (this.#envPrefix) {
322
- for (const [field, my] of Object.entries(this.#configSet)) {
323
- const ek = toEnvKey(this.#envPrefix, field);
324
- const env = this.#env[ek];
325
- if (env !== undefined) {
326
- my.default = fromEnvVal(env, my.type, !!my.multiple, my.delim);
327
- }
328
- }
329
- }
330
- }
331
- applyDefaults(p) {
332
- for (const [field, c] of Object.entries(this.#configSet)) {
333
- if (c.default !== undefined && !(field in p.values)) {
334
- //@ts-ignore
335
- p.values[field] = c.default;
336
- }
337
- }
338
- }
339
- /**
340
- * Only parse the command line arguments passed in.
341
- * Does not strip off the `node script.js` bits, so it must be just the
342
- * arguments you wish to have parsed.
343
- * Does not read from or write to the environment, or set defaults.
344
- */
345
- parseRaw(args) {
346
- if (args === process.argv) {
347
- args = args.slice(process._eval !== undefined ? 1 : 2);
348
- }
349
- const result = (0, node_util_1.parseArgs)({
350
- args,
351
- options: toParseArgsOptionsConfig(this.#configSet),
352
- // always strict, but using our own logic
353
- strict: false,
354
- allowPositionals: this.#allowPositionals,
355
- tokens: true,
356
- });
357
- const p = {
358
- values: {},
359
- positionals: [],
360
- };
361
- for (const token of result.tokens) {
362
- if (token.kind === 'positional') {
363
- p.positionals.push(token.value);
364
- if (this.#options.stopAtPositional ||
365
- this.#options.stopAtPositionalTest?.(token.value)) {
366
- p.positionals.push(...args.slice(token.index + 1));
367
- break;
368
- }
369
- }
370
- else if (token.kind === 'option') {
371
- let value = undefined;
372
- if (token.name.startsWith('no-')) {
373
- const my = this.#configSet[token.name];
374
- const pname = token.name.substring('no-'.length);
375
- const pos = this.#configSet[pname];
376
- if (pos &&
377
- pos.type === 'boolean' &&
378
- (!my ||
379
- (my.type === 'boolean' && !!my.multiple === !!pos.multiple))) {
380
- value = false;
381
- token.name = pname;
382
- }
383
- }
384
- const my = this.#configSet[token.name];
385
- if (!my) {
386
- throw new Error(`Unknown option '${token.rawName}'. ` +
387
- `To specify a positional argument starting with a '-', ` +
388
- `place it at the end of the command after '--', as in ` +
389
- `'-- ${token.rawName}'`, {
390
- cause: {
391
- code: 'JACKSPEAK',
392
- found: token.rawName + (token.value ? `=${token.value}` : ''),
393
- },
394
- });
395
- }
396
- if (value === undefined) {
397
- if (token.value === undefined) {
398
- if (my.type !== 'boolean') {
399
- throw new Error(`No value provided for ${token.rawName}, expected ${my.type}`, {
400
- cause: {
401
- code: 'JACKSPEAK',
402
- name: token.rawName,
403
- wanted: valueType(my),
404
- },
405
- });
406
- }
407
- value = true;
408
- }
409
- else {
410
- if (my.type === 'boolean') {
411
- throw new Error(`Flag ${token.rawName} does not take a value, received '${token.value}'`, { cause: { code: 'JACKSPEAK', found: token } });
412
- }
413
- if (my.type === 'string') {
414
- value = token.value;
415
- }
416
- else {
417
- value = +token.value;
418
- if (value !== value) {
419
- throw new Error(`Invalid value '${token.value}' provided for ` +
420
- `'${token.rawName}' option, expected number`, {
421
- cause: {
422
- code: 'JACKSPEAK',
423
- name: token.rawName,
424
- found: token.value,
425
- wanted: 'number',
426
- },
427
- });
428
- }
429
- }
430
- }
431
- }
432
- if (my.multiple) {
433
- const pv = p.values;
434
- const tn = pv[token.name] ?? [];
435
- pv[token.name] = tn;
436
- tn.push(value);
437
- }
438
- else {
439
- const pv = p.values;
440
- pv[token.name] = value;
441
- }
442
- }
443
- }
444
- for (const [field, value] of Object.entries(p.values)) {
445
- const valid = this.#configSet[field]?.validate;
446
- const validOptions = this.#configSet[field]?.validOptions;
447
- const cause = validOptions && !isValidOption(value, validOptions) ?
448
- { name: field, found: value, validOptions }
449
- : valid && !valid(value) ? { name: field, found: value }
450
- : undefined;
451
- if (cause) {
452
- throw new Error(`Invalid value provided for --${field}: ${JSON.stringify(value)}`, { cause: { ...cause, code: 'JACKSPEAK' } });
453
- }
454
- }
455
- return p;
456
- }
457
- /**
458
- * do not set fields as 'no-foo' if 'foo' exists and both are bools
459
- * just set foo.
460
- */
461
- #noNoFields(f, val, s = f) {
462
- if (!f.startsWith('no-') || typeof val !== 'boolean')
463
- return;
464
- const yes = f.substring('no-'.length);
465
- // recurse so we get the core config key we care about.
466
- this.#noNoFields(yes, val, s);
467
- if (this.#configSet[yes]?.type === 'boolean') {
468
- throw new Error(`do not set '${s}', instead set '${yes}' as desired.`, { cause: { code: 'JACKSPEAK', found: s, wanted: yes } });
469
- }
470
- }
471
- /**
472
- * Validate that any arbitrary object is a valid configuration `values`
473
- * object. Useful when loading config files or other sources.
474
- */
475
- validate(o) {
476
- if (!o || typeof o !== 'object') {
477
- throw new Error('Invalid config: not an object', {
478
- cause: { code: 'JACKSPEAK', found: o },
479
- });
480
- }
481
- const opts = o;
482
- for (const field in o) {
483
- const value = opts[field];
484
- /* c8 ignore next - for TS */
485
- if (value === undefined)
486
- continue;
487
- this.#noNoFields(field, value);
488
- const config = this.#configSet[field];
489
- if (!config) {
490
- throw new Error(`Unknown config option: ${field}`, {
491
- cause: { code: 'JACKSPEAK', found: field },
492
- });
493
- }
494
- if (!isValidValue(value, config.type, !!config.multiple)) {
495
- throw new Error(`Invalid value ${valueType(value)} for ${field}, expected ${valueType(config)}`, {
496
- cause: {
497
- code: 'JACKSPEAK',
498
- name: field,
499
- found: value,
500
- wanted: valueType(config),
501
- },
502
- });
503
- }
504
- const cause = config.validOptions && !isValidOption(value, config.validOptions) ?
505
- { name: field, found: value, validOptions: config.validOptions }
506
- : config.validate && !config.validate(value) ?
507
- { name: field, found: value }
508
- : undefined;
509
- if (cause) {
510
- throw new Error(`Invalid config value for ${field}: ${JSON.stringify(value)}`, {
511
- cause: { ...cause, code: 'JACKSPEAK' },
512
- });
513
- }
514
- }
515
- }
516
- writeEnv(p) {
517
- if (!this.#env || !this.#envPrefix)
518
- return;
519
- for (const [field, value] of Object.entries(p.values)) {
520
- const my = this.#configSet[field];
521
- this.#env[toEnvKey(this.#envPrefix, field)] = toEnvVal(value, my?.delim);
522
- }
523
- }
524
- /**
525
- * Add a heading to the usage output banner
526
- */
527
- heading(text, level, { pre = false } = {}) {
528
- if (level === undefined) {
529
- level = this.#fields.some(r => isHeading(r)) ? 2 : 1;
530
- }
531
- this.#fields.push({ type: 'heading', text, level, pre });
532
- return this;
533
- }
534
- /**
535
- * Add a long-form description to the usage output at this position.
536
- */
537
- description(text, { pre } = {}) {
538
- this.#fields.push({ type: 'description', text, pre });
539
- return this;
540
- }
541
- /**
542
- * Add one or more number fields.
543
- */
544
- num(fields) {
545
- return this.#addFieldsWith(fields, 'number', false);
546
- }
547
- /**
548
- * Add one or more multiple number fields.
549
- */
550
- numList(fields) {
551
- return this.#addFieldsWith(fields, 'number', true);
552
- }
553
- /**
554
- * Add one or more string option fields.
555
- */
556
- opt(fields) {
557
- return this.#addFieldsWith(fields, 'string', false);
558
- }
559
- /**
560
- * Add one or more multiple string option fields.
561
- */
562
- optList(fields) {
563
- return this.#addFieldsWith(fields, 'string', true);
564
- }
565
- /**
566
- * Add one or more flag fields.
567
- */
568
- flag(fields) {
569
- return this.#addFieldsWith(fields, 'boolean', false);
570
- }
571
- /**
572
- * Add one or more multiple flag fields.
573
- */
574
- flagList(fields) {
575
- return this.#addFieldsWith(fields, 'boolean', true);
576
- }
577
- /**
578
- * Generic field definition method. Similar to flag/flagList/number/etc,
579
- * but you must specify the `type` (and optionally `multiple` and `delim`)
580
- * fields on each one, or Jack won't know how to define them.
581
- */
582
- addFields(fields) {
583
- return this.#addFields(this, fields);
584
- }
585
- #addFieldsWith(fields, type, multiple) {
586
- return this.#addFields(this, fields, {
587
- type,
588
- multiple,
589
- });
590
- }
591
- #addFields(next, fields, opt) {
592
- Object.assign(next.#configSet, Object.fromEntries(Object.entries(fields).map(([name, field]) => {
593
- this.#validateName(name, field);
594
- const { type, multiple } = validateFieldMeta(field, opt);
595
- const value = { ...field, type, multiple };
596
- validateField(value, type, multiple);
597
- next.#fields.push({ type: 'config', name, value });
598
- return [name, value];
599
- })));
600
- return next;
601
- }
602
- #validateName(name, field) {
603
- if (!/^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$/.test(name)) {
604
- throw new TypeError(`Invalid option name: ${name}, ` +
605
- `must be '-' delimited ASCII alphanumeric`);
606
- }
607
- if (this.#configSet[name]) {
608
- throw new TypeError(`Cannot redefine option ${name}`);
609
- }
610
- if (this.#shorts[name]) {
611
- throw new TypeError(`Cannot redefine option ${name}, already ` +
612
- `in use for ${this.#shorts[name]}`);
613
- }
614
- if (field.short) {
615
- if (!/^[a-zA-Z0-9]$/.test(field.short)) {
616
- throw new TypeError(`Invalid ${name} short option: ${field.short}, ` +
617
- 'must be 1 ASCII alphanumeric character');
618
- }
619
- if (this.#shorts[field.short]) {
620
- throw new TypeError(`Invalid ${name} short option: ${field.short}, ` +
621
- `already in use for ${this.#shorts[field.short]}`);
622
- }
623
- this.#shorts[field.short] = name;
624
- this.#shorts[name] = name;
625
- }
626
- }
627
- /**
628
- * Return the usage banner for the given configuration
629
- */
630
- usage() {
631
- if (this.#usage)
632
- return this.#usage;
633
- let headingLevel = 1;
634
- //@ts-ignore
635
- const ui = (0, min_1.cliui)({ width });
636
- const first = this.#fields[0];
637
- let start = first?.type === 'heading' ? 1 : 0;
638
- if (first?.type === 'heading') {
639
- ui.div({
640
- padding: [0, 0, 0, 0],
641
- text: normalize(first.text),
642
- });
643
- }
644
- ui.div({ padding: [0, 0, 0, 0], text: 'Usage:' });
645
- if (this.#options.usage) {
646
- ui.div({
647
- text: this.#options.usage,
648
- padding: [0, 0, 0, 2],
649
- });
650
- }
651
- else {
652
- const cmd = (0, node_path_1.basename)(String(process.argv[1]));
653
- const shortFlags = [];
654
- const shorts = [];
655
- const flags = [];
656
- const opts = [];
657
- for (const [field, config] of Object.entries(this.#configSet)) {
658
- if (config.short) {
659
- if (config.type === 'boolean')
660
- shortFlags.push(config.short);
661
- else
662
- shorts.push([config.short, config.hint || field]);
663
- }
664
- else {
665
- if (config.type === 'boolean')
666
- flags.push(field);
667
- else
668
- opts.push([field, config.hint || field]);
669
- }
670
- }
671
- const sf = shortFlags.length ? ' -' + shortFlags.join('') : '';
672
- const so = shorts.map(([k, v]) => ` --${k}=<${v}>`).join('');
673
- const lf = flags.map(k => ` --${k}`).join('');
674
- const lo = opts.map(([k, v]) => ` --${k}=<${v}>`).join('');
675
- const usage = `${cmd}${sf}${so}${lf}${lo}`.trim();
676
- ui.div({
677
- text: usage,
678
- padding: [0, 0, 0, 2],
679
- });
680
- }
681
- ui.div({ padding: [0, 0, 0, 0], text: '' });
682
- const maybeDesc = this.#fields[start];
683
- if (maybeDesc && isDescription(maybeDesc)) {
684
- const print = normalize(maybeDesc.text, maybeDesc.pre);
685
- start++;
686
- ui.div({ padding: [0, 0, 0, 0], text: print });
687
- ui.div({ padding: [0, 0, 0, 0], text: '' });
688
- }
689
- const { rows, maxWidth } = this.#usageRows(start);
690
- // every heading/description after the first gets indented by 2
691
- // extra spaces.
692
- for (const row of rows) {
693
- if (row.left) {
694
- // If the row is too long, don't wrap it
695
- // Bump the right-hand side down a line to make room
696
- const configIndent = indent(Math.max(headingLevel, 2));
697
- if (row.left.length > maxWidth - 3) {
698
- ui.div({ text: row.left, padding: [0, 0, 0, configIndent] });
699
- ui.div({ text: row.text, padding: [0, 0, 0, maxWidth] });
700
- }
701
- else {
702
- ui.div({
703
- text: row.left,
704
- padding: [0, 1, 0, configIndent],
705
- width: maxWidth,
706
- }, { padding: [0, 0, 0, 0], text: row.text });
707
- }
708
- if (row.skipLine) {
709
- ui.div({ padding: [0, 0, 0, 0], text: '' });
710
- }
711
- }
712
- else {
713
- if (isHeading(row)) {
714
- const { level } = row;
715
- headingLevel = level;
716
- // only h1 and h2 have bottom padding
717
- // h3-h6 do not
718
- const b = level <= 2 ? 1 : 0;
719
- ui.div({ ...row, padding: [0, 0, b, indent(level)] });
720
- }
721
- else {
722
- ui.div({ ...row, padding: [0, 0, 1, indent(headingLevel + 1)] });
723
- }
724
- }
725
- }
726
- return (this.#usage = ui.toString());
727
- }
728
- /**
729
- * Return the usage banner markdown for the given configuration
730
- */
731
- usageMarkdown() {
732
- if (this.#usageMarkdown)
733
- return this.#usageMarkdown;
734
- const out = [];
735
- let headingLevel = 1;
736
- const first = this.#fields[0];
737
- let start = first?.type === 'heading' ? 1 : 0;
738
- if (first?.type === 'heading') {
739
- out.push(`# ${normalizeOneLine(first.text)}`);
740
- }
741
- out.push('Usage:');
742
- if (this.#options.usage) {
743
- out.push(normalizeMarkdown(this.#options.usage, true));
744
- }
745
- else {
746
- const cmd = (0, node_path_1.basename)(String(process.argv[1]));
747
- const shortFlags = [];
748
- const shorts = [];
749
- const flags = [];
750
- const opts = [];
751
- for (const [field, config] of Object.entries(this.#configSet)) {
752
- if (config.short) {
753
- if (config.type === 'boolean')
754
- shortFlags.push(config.short);
755
- else
756
- shorts.push([config.short, config.hint || field]);
757
- }
758
- else {
759
- if (config.type === 'boolean')
760
- flags.push(field);
761
- else
762
- opts.push([field, config.hint || field]);
763
- }
764
- }
765
- const sf = shortFlags.length ? ' -' + shortFlags.join('') : '';
766
- const so = shorts.map(([k, v]) => ` --${k}=<${v}>`).join('');
767
- const lf = flags.map(k => ` --${k}`).join('');
768
- const lo = opts.map(([k, v]) => ` --${k}=<${v}>`).join('');
769
- const usage = `${cmd}${sf}${so}${lf}${lo}`.trim();
770
- out.push(normalizeMarkdown(usage, true));
771
- }
772
- const maybeDesc = this.#fields[start];
773
- if (maybeDesc && isDescription(maybeDesc)) {
774
- out.push(normalizeMarkdown(maybeDesc.text, maybeDesc.pre));
775
- start++;
776
- }
777
- const { rows } = this.#usageRows(start);
778
- // heading level in markdown is number of # ahead of text
779
- for (const row of rows) {
780
- if (row.left) {
781
- out.push('#'.repeat(headingLevel + 1) +
782
- ' ' +
783
- normalizeOneLine(row.left, true));
784
- if (row.text)
785
- out.push(normalizeMarkdown(row.text));
786
- }
787
- else if (isHeading(row)) {
788
- const { level } = row;
789
- headingLevel = level;
790
- out.push(`${'#'.repeat(headingLevel)} ${normalizeOneLine(row.text, row.pre)}`);
791
- }
792
- else {
793
- out.push(normalizeMarkdown(row.text, !!row.pre));
794
- }
795
- }
796
- return (this.#usageMarkdown = out.join('\n\n') + '\n');
797
- }
798
- #usageRows(start) {
799
- // turn each config type into a row, and figure out the width of the
800
- // left hand indentation for the option descriptions.
801
- const maxMax = Math.max(12, Math.min(26, Math.floor(width / 3)));
802
- let maxWidth = 8;
803
- let prev = undefined;
804
- const rows = [];
805
- for (const field of this.#fields.slice(start)) {
806
- if (field.type !== 'config') {
807
- if (prev?.type === 'config')
808
- prev.skipLine = true;
809
- prev = undefined;
810
- field.text = normalize(field.text, !!field.pre);
811
- rows.push(field);
812
- continue;
813
- }
814
- const { value } = field;
815
- const desc = value.description || '';
816
- const mult = value.multiple ? 'Can be set multiple times' : '';
817
- const opts = value.validOptions?.length ?
818
- 'Valid options: ' +
819
- value.validOptions.map(v => JSON.stringify(v)).join(', ')
820
- : '';
821
- const dmDelim = desc.includes('\n') ? '\n\n' : '\n';
822
- const extra = [opts, mult].join(dmDelim).trim();
823
- const text = (normalize(desc) + dmDelim + extra).trim();
824
- const hint = value.hint ||
825
- (value.type === 'number' ? 'n'
826
- : value.type === 'string' ? field.name
827
- : undefined);
828
- const short = !value.short ? ''
829
- : value.type === 'boolean' ? `-${value.short} `
830
- : `-${value.short}<${hint}> `;
831
- const left = value.type === 'boolean' ?
832
- `${short}--${field.name}`
833
- : `${short}--${field.name}=<${hint}>`;
834
- const row = { text, left, type: 'config' };
835
- if (text.length > width - maxMax) {
836
- row.skipLine = true;
837
- }
838
- if (prev && left.length > maxMax)
839
- prev.skipLine = true;
840
- prev = row;
841
- const len = left.length + 4;
842
- if (len > maxWidth && len < maxMax) {
843
- maxWidth = len;
844
- }
845
- rows.push(row);
846
- }
847
- return { rows, maxWidth };
848
- }
849
- /**
850
- * Return the configuration options as a plain object
851
- */
852
- toJSON() {
853
- return Object.fromEntries(Object.entries(this.#configSet).map(([field, def]) => [
854
- field,
855
- {
856
- type: def.type,
857
- ...(def.multiple ? { multiple: true } : {}),
858
- ...(def.delim ? { delim: def.delim } : {}),
859
- ...(def.short ? { short: def.short } : {}),
860
- ...(def.description ?
861
- { description: normalize(def.description) }
862
- : {}),
863
- ...(def.validate ? { validate: def.validate } : {}),
864
- ...(def.validOptions ? { validOptions: def.validOptions } : {}),
865
- ...(def.default !== undefined ? { default: def.default } : {}),
866
- ...(def.hint ? { hint: def.hint } : {}),
867
- },
868
- ]));
869
- }
870
- /**
871
- * Custom printer for `util.inspect`
872
- */
873
- [node_util_1.inspect.custom](_, options) {
874
- return `Jack ${(0, node_util_1.inspect)(this.toJSON(), options)}`;
875
- }
876
- }
877
- exports.Jack = Jack;
878
- /**
879
- * Main entry point. Create and return a {@link Jack} object.
880
- */
881
- const jack = (options = {}) => new Jack(options);
882
- exports.jack = jack;
883
- // Unwrap and un-indent, so we can wrap description
884
- // strings however makes them look nice in the code.
885
- const normalize = (s, pre = false) => {
886
- if (pre)
887
- // prepend a ZWSP to each line so cliui doesn't strip it.
888
- return s
889
- .split('\n')
890
- .map(l => `\u200b${l}`)
891
- .join('\n');
892
- return s
893
- .split(/^\s*```\s*$/gm)
894
- .map((s, i) => {
895
- if (i % 2 === 1) {
896
- if (!s.trim()) {
897
- return `\`\`\`\n\`\`\`\n`;
898
- }
899
- // outdent the ``` blocks, but preserve whitespace otherwise.
900
- const split = s.split('\n');
901
- // throw out the \n at the start and end
902
- split.pop();
903
- split.shift();
904
- const si = split.reduce((shortest, l) => {
905
- /* c8 ignore next */
906
- const ind = l.match(/^\s*/)?.[0] ?? '';
907
- if (ind.length)
908
- return Math.min(ind.length, shortest);
909
- else
910
- return shortest;
911
- }, Infinity);
912
- /* c8 ignore next */
913
- const i = isFinite(si) ? si : 0;
914
- return ('\n```\n' +
915
- split.map(s => `\u200b${s.substring(i)}`).join('\n') +
916
- '\n```\n');
917
- }
918
- return (s
919
- // remove single line breaks, except for lists
920
- .replace(/([^\n])\n[ \t]*([^\n])/g, (_, $1, $2) => !/^[-*]/.test($2) ? `${$1} ${$2}` : `${$1}\n${$2}`)
921
- // normalize mid-line whitespace
922
- .replace(/([^\n])[ \t]+([^\n])/g, '$1 $2')
923
- // two line breaks are enough
924
- .replace(/\n{3,}/g, '\n\n')
925
- // remove any spaces at the start of a line
926
- .replace(/\n[ \t]+/g, '\n')
927
- .trim());
928
- })
929
- .join('\n');
930
- };
931
- // normalize for markdown printing, remove leading spaces on lines
932
- const normalizeMarkdown = (s, pre = false) => {
933
- const n = normalize(s, pre).replace(/\\/g, '\\\\');
934
- return pre ?
935
- `\`\`\`\n${n.replace(/\u200b/g, '')}\n\`\`\``
936
- : n.replace(/\n +/g, '\n').trim();
937
- };
938
- const normalizeOneLine = (s, pre = false) => {
939
- const n = normalize(s, pre)
940
- .replace(/[\s\u200b]+/g, ' ')
941
- .trim();
942
- return pre ? `\`${n}\`` : n;
943
- };
944
- //# sourceMappingURL=index.js.map