@decaf-ts/utils 0.2.6 → 0.2.8

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 (157) hide show
  1. package/LICENSE.md +0 -0
  2. package/README.md +0 -0
  3. package/bin/build-scripts.cjs +1885 -1423
  4. package/bin/tag-release.cjs +1876 -1420
  5. package/bin/tag-release.sh +0 -0
  6. package/bin/update-scripts.cjs +1881 -1425
  7. package/dist/assets/slogans.json +0 -0
  8. package/dist/utils.cjs +86 -689
  9. package/dist/utils.esm.cjs +78 -674
  10. package/lib/assets/slogans.json +0 -0
  11. package/lib/bin/build-scripts.d.ts +0 -0
  12. package/lib/bin/tag-release.d.ts +0 -0
  13. package/lib/bin/update-scripts.d.ts +0 -0
  14. package/lib/cli/command.cjs +6 -7
  15. package/lib/cli/command.d.ts +5 -5
  16. package/lib/cli/commands/build-scripts.cjs +9 -3
  17. package/lib/cli/commands/build-scripts.d.ts +1 -1
  18. package/lib/cli/commands/index.cjs +0 -0
  19. package/lib/cli/commands/index.d.ts +0 -0
  20. package/lib/cli/commands/tag-release.cjs +1 -1
  21. package/lib/cli/commands/tag-release.d.ts +1 -1
  22. package/lib/cli/commands/update-scripts.cjs +1 -1
  23. package/lib/cli/commands/update-scripts.d.ts +1 -1
  24. package/lib/cli/constants.cjs +0 -0
  25. package/lib/cli/constants.d.ts +0 -0
  26. package/lib/cli/index.cjs +0 -0
  27. package/lib/cli/index.d.ts +0 -0
  28. package/lib/cli/types.cjs +1 -1
  29. package/lib/cli/types.d.ts +1 -1
  30. package/lib/esm/assets/slogans.json +0 -0
  31. package/lib/esm/bin/build-scripts.d.ts +0 -0
  32. package/lib/esm/bin/build-scripts.js +0 -0
  33. package/lib/esm/bin/tag-release.d.ts +0 -0
  34. package/lib/esm/bin/tag-release.js +0 -0
  35. package/lib/esm/bin/update-scripts.d.ts +0 -0
  36. package/lib/esm/bin/update-scripts.js +0 -0
  37. package/lib/esm/cli/command.d.ts +5 -5
  38. package/lib/esm/cli/command.js +2 -3
  39. package/lib/esm/cli/commands/build-scripts.d.ts +1 -1
  40. package/lib/esm/cli/commands/build-scripts.js +9 -3
  41. package/lib/esm/cli/commands/index.d.ts +0 -0
  42. package/lib/esm/cli/commands/index.js +0 -0
  43. package/lib/esm/cli/commands/tag-release.d.ts +1 -1
  44. package/lib/esm/cli/commands/tag-release.js +1 -1
  45. package/lib/esm/cli/commands/update-scripts.d.ts +1 -1
  46. package/lib/esm/cli/commands/update-scripts.js +1 -1
  47. package/lib/esm/cli/constants.d.ts +0 -0
  48. package/lib/esm/cli/constants.js +0 -0
  49. package/lib/esm/cli/index.d.ts +0 -0
  50. package/lib/esm/cli/index.js +0 -0
  51. package/lib/esm/cli/types.d.ts +1 -1
  52. package/lib/esm/cli/types.js +1 -1
  53. package/lib/esm/index.d.ts +2 -2
  54. package/lib/esm/index.js +2 -2
  55. package/lib/esm/input/index.d.ts +0 -0
  56. package/lib/esm/input/index.js +0 -0
  57. package/lib/esm/input/input.d.ts +1 -2
  58. package/lib/esm/input/input.js +2 -2
  59. package/lib/esm/input/types.d.ts +83 -0
  60. package/lib/esm/input/types.js +1 -1
  61. package/lib/esm/output/common.d.ts +3 -3
  62. package/lib/esm/output/common.js +2 -2
  63. package/lib/esm/output/index.d.ts +1 -3
  64. package/lib/esm/output/index.js +2 -4
  65. package/lib/esm/utils/constants.d.ts +0 -77
  66. package/lib/esm/utils/constants.js +1 -114
  67. package/lib/esm/utils/environment.d.ts +1 -1
  68. package/lib/esm/utils/environment.js +2 -2
  69. package/lib/esm/utils/fs.d.ts +0 -0
  70. package/lib/esm/utils/fs.js +2 -2
  71. package/lib/esm/utils/http.d.ts +1 -1
  72. package/lib/esm/utils/http.js +2 -2
  73. package/lib/esm/utils/index.d.ts +0 -0
  74. package/lib/esm/utils/index.js +0 -0
  75. package/lib/esm/utils/md.d.ts +0 -0
  76. package/lib/esm/utils/md.js +0 -0
  77. package/lib/esm/utils/tests.d.ts +0 -0
  78. package/lib/esm/utils/tests.js +0 -0
  79. package/lib/esm/utils/text.d.ts +0 -0
  80. package/lib/esm/utils/text.js +0 -0
  81. package/lib/esm/utils/timeout.d.ts +0 -0
  82. package/lib/esm/utils/timeout.js +0 -0
  83. package/lib/esm/utils/types.d.ts +0 -0
  84. package/lib/esm/utils/types.js +0 -0
  85. package/lib/esm/utils/utils.d.ts +2 -2
  86. package/lib/esm/utils/utils.js +2 -2
  87. package/lib/esm/utils/web.d.ts +0 -0
  88. package/lib/esm/utils/web.js +0 -0
  89. package/lib/esm/writers/OutputWriter.d.ts +0 -0
  90. package/lib/esm/writers/OutputWriter.js +0 -0
  91. package/lib/esm/writers/RegexpOutputWriter.d.ts +0 -0
  92. package/lib/esm/writers/RegexpOutputWriter.js +0 -0
  93. package/lib/esm/writers/StandardOutputWriter.d.ts +2 -2
  94. package/lib/esm/writers/StandardOutputWriter.js +2 -2
  95. package/lib/esm/writers/index.d.ts +0 -0
  96. package/lib/esm/writers/index.js +0 -0
  97. package/lib/esm/writers/types.d.ts +0 -0
  98. package/lib/esm/writers/types.js +0 -0
  99. package/lib/index.cjs +2 -2
  100. package/lib/index.d.ts +2 -2
  101. package/lib/input/index.cjs +0 -0
  102. package/lib/input/index.d.ts +0 -0
  103. package/lib/input/input.cjs +2 -2
  104. package/lib/input/input.d.ts +1 -2
  105. package/lib/input/types.cjs +1 -1
  106. package/lib/input/types.d.ts +83 -0
  107. package/lib/output/common.cjs +2 -2
  108. package/lib/output/common.d.ts +3 -3
  109. package/lib/output/index.cjs +1 -3
  110. package/lib/output/index.d.ts +1 -3
  111. package/lib/utils/constants.cjs +2 -115
  112. package/lib/utils/constants.d.ts +0 -77
  113. package/lib/utils/environment.cjs +3 -3
  114. package/lib/utils/environment.d.ts +1 -1
  115. package/lib/utils/fs.cjs +2 -2
  116. package/lib/utils/fs.d.ts +0 -0
  117. package/lib/utils/http.cjs +2 -2
  118. package/lib/utils/http.d.ts +1 -1
  119. package/lib/utils/index.cjs +0 -0
  120. package/lib/utils/index.d.ts +0 -0
  121. package/lib/utils/md.cjs +0 -0
  122. package/lib/utils/md.d.ts +0 -0
  123. package/lib/utils/tests.cjs +0 -0
  124. package/lib/utils/tests.d.ts +0 -0
  125. package/lib/utils/text.cjs +0 -0
  126. package/lib/utils/text.d.ts +0 -0
  127. package/lib/utils/timeout.cjs +0 -0
  128. package/lib/utils/timeout.d.ts +0 -0
  129. package/lib/utils/types.cjs +0 -0
  130. package/lib/utils/types.d.ts +0 -0
  131. package/lib/utils/utils.cjs +2 -2
  132. package/lib/utils/utils.d.ts +2 -2
  133. package/lib/utils/web.cjs +0 -0
  134. package/lib/utils/web.d.ts +0 -0
  135. package/lib/writers/OutputWriter.cjs +0 -0
  136. package/lib/writers/OutputWriter.d.ts +0 -0
  137. package/lib/writers/RegexpOutputWriter.cjs +0 -0
  138. package/lib/writers/RegexpOutputWriter.d.ts +0 -0
  139. package/lib/writers/StandardOutputWriter.cjs +2 -2
  140. package/lib/writers/StandardOutputWriter.d.ts +2 -2
  141. package/lib/writers/index.cjs +0 -0
  142. package/lib/writers/index.d.ts +0 -0
  143. package/lib/writers/types.cjs +0 -0
  144. package/lib/writers/types.d.ts +0 -0
  145. package/package.json +5 -2
  146. package/lib/esm/output/logging.d.ts +0 -177
  147. package/lib/esm/output/logging.js +0 -349
  148. package/lib/esm/output/types.d.ts +0 -203
  149. package/lib/esm/output/types.js +0 -2
  150. package/lib/esm/utils/accumulator.d.ts +0 -105
  151. package/lib/esm/utils/accumulator.js +0 -144
  152. package/lib/output/logging.cjs +0 -354
  153. package/lib/output/logging.d.ts +0 -177
  154. package/lib/output/types.cjs +0 -3
  155. package/lib/output/types.d.ts +0 -203
  156. package/lib/utils/accumulator.cjs +0 -148
  157. package/lib/utils/accumulator.d.ts +0 -105
@@ -1,9 +1,11 @@
1
- import { style } from 'styled-string-builder';
2
1
  import prompts from 'prompts';
3
2
  import { parseArgs } from 'util';
3
+ import { Logging, DefaultLoggingConfig } from '@decaf-ts/logging';
4
4
  import fs from 'fs';
5
5
  import path from 'path';
6
6
  import { spawn } from 'child_process';
7
+ import { style } from 'styled-string-builder';
8
+ import { ObjectAccumulator } from 'typed-object-accumulator';
7
9
  import https from 'https';
8
10
  import { rollup } from 'rollup';
9
11
  import typescript from '@rollup/plugin-typescript';
@@ -11,528 +13,6 @@ import commonjs from '@rollup/plugin-commonjs';
11
13
  import { nodeResolve } from '@rollup/plugin-node-resolve';
12
14
  import json from '@rollup/plugin-json';
13
15
 
14
- /**
15
- * @description Default encoding for text operations.
16
- * @summary The standard UTF-8 encoding used for text processing.
17
- * @const {string} Encoding
18
- * @memberOf @decaf-ts/utils
19
- */
20
- const Encoding = "utf-8";
21
- /**
22
- * @description Regular expression for semantic versioning.
23
- * @summary A regex pattern to match and parse semantic version strings.
24
- * @const {RegExp} SemVersionRegex
25
- * @memberOf @decaf-ts/utils
26
- */
27
- const SemVersionRegex = /^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z])))/g;
28
- /**
29
- * @description Enum for semantic version components.
30
- * @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.
31
- * @enum {string}
32
- * @memberOf @decaf-ts/utils
33
- */
34
- var SemVersion;
35
- (function (SemVersion) {
36
- /** Patch version for backwards-compatible bug fixes. */
37
- SemVersion["PATCH"] = "patch";
38
- /** Minor version for backwards-compatible new features. */
39
- SemVersion["MINOR"] = "minor";
40
- /** Major version for changes that break backwards compatibility. */
41
- SemVersion["MAJOR"] = "major";
42
- })(SemVersion || (SemVersion = {}));
43
- /**
44
- * @description Flag to indicate non-CI environment.
45
- * @summary Used to specify that a command should run outside of a Continuous Integration environment.
46
- * @const {string} NoCIFLag
47
- * @memberOf @decaf-ts/utils
48
- */
49
- const NoCIFLag = "-no-ci";
50
- /**
51
- * @description Key for the setup script in package.json.
52
- * @summary Identifies the script that runs after package installation.
53
- * @const {string} SetupScriptKey
54
- * @memberOf @decaf-ts/utils
55
- */
56
- const SetupScriptKey = "postinstall";
57
- /**
58
- * @description Enum for various authentication tokens.
59
- * @summary Defines the file names for storing different types of authentication tokens.
60
- * @enum {string}
61
- * @memberOf @decaf-ts/utils
62
- */
63
- var Tokens;
64
- (function (Tokens) {
65
- /** Git authentication token file name. */
66
- Tokens["GIT"] = ".token";
67
- /** NPM authentication token file name. */
68
- Tokens["NPM"] = ".npmtoken";
69
- /** Docker authentication token file name. */
70
- Tokens["DOCKER"] = ".dockertoken";
71
- /** Confluence authentication token file name. */
72
- Tokens["CONFLUENCE"] = ".confluence-token";
73
- })(Tokens || (Tokens = {}));
74
- /**
75
- * @description Enum for log levels.
76
- * @summary Defines different levels of logging for the application.
77
- * @enum {string}
78
- * @memberOf @decaf-ts/utils
79
- */
80
- var LogLevel;
81
- (function (LogLevel) {
82
- /** Error events that are likely to cause problems. */
83
- LogLevel["error"] = "error";
84
- /** Routine information, such as ongoing status or performance. */
85
- LogLevel["info"] = "info";
86
- /** Additional relevant information. */
87
- LogLevel["verbose"] = "verbose";
88
- /** Debug or trace information. */
89
- LogLevel["debug"] = "debug";
90
- /** way too verbose or silly information. */
91
- LogLevel["silly"] = "silly";
92
- })(LogLevel || (LogLevel = {}));
93
- /**
94
- * @description Numeric values associated with log levels.
95
- * @summary Provides a numeric representation of log levels for comparison and filtering.
96
- * @const {Object} NumericLogLevels
97
- * @property {number} error - Numeric value for error level (0).
98
- * @property {number} info - Numeric value for info level (2).
99
- * @property {number} verbose - Numeric value for verbose level (4).
100
- * @property {number} debug - Numeric value for debug level (5).
101
- * @property {number} silly - Numeric value for silly level (8).
102
- * @memberOf @decaf-ts/utils
103
- */
104
- const NumericLogLevels = {
105
- error: 2,
106
- info: 4,
107
- verbose: 6,
108
- debug: 7,
109
- silly: 9,
110
- };
111
- /**
112
- * @description Default theme for styling log output.
113
- * @summary Defines the default color and style settings for various components of log messages.
114
- * @const DefaultTheme
115
- * @typedef {Theme} DefaultTheme
116
- * @property {Object} class - Styling for class names.
117
- * @property {number} class.fg - Foreground color code for class names (4).
118
- * @property {Object} id - Styling for identifiers.
119
- * @property {number} id.fg - Foreground color code for identifiers (36).
120
- * @property {Object} stack - Styling for stack traces (empty object).
121
- * @property {Object} timestamp - Styling for timestamps (empty object).
122
- * @property {Object} message - Styling for different types of messages.
123
- * @property {Object} message.error - Styling for error messages.
124
- * @property {number} message.error.fg - Foreground color code for error messages (34).
125
- * @property {Object} method - Styling for method names (empty object).
126
- * @property {Object} logLevel - Styling for different log levels.
127
- * @property {Object} logLevel.error - Styling for error level logs.
128
- * @property {number} logLevel.error.fg - Foreground color code for error level logs (6).
129
- * @property {Object} logLevel.info - Styling for info level logs (empty object).
130
- * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).
131
- * @property {Object} logLevel.debug - Styling for debug level logs.
132
- * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (7).
133
- * @memberOf @decaf-ts/utils
134
- */
135
- const DefaultTheme = {
136
- class: {
137
- fg: 34,
138
- },
139
- id: {
140
- fg: 36,
141
- },
142
- stack: {},
143
- timestamp: {},
144
- message: {
145
- error: {
146
- fg: 31,
147
- },
148
- },
149
- method: {},
150
- logLevel: {
151
- error: {
152
- fg: 31,
153
- style: ["bold"],
154
- },
155
- info: {},
156
- verbose: {},
157
- debug: {
158
- fg: 33,
159
- },
160
- },
161
- };
162
- /**
163
- * @description Default configuration for logging.
164
- * @summary Defines the default settings for the logging system, including verbosity, log level, styling, and timestamp format.
165
- * @const DefaultLoggingConfig
166
- * @typedef {LoggingConfig} DefaultLoggingConfig
167
- * @property {number} verbose - Verbosity level (0).
168
- * @property {LogLevel} level - Default log level (LogLevel.info).
169
- * @property {boolean} style - Whether to apply styling to log output (false).
170
- * @property {boolean} timestamp - Whether to include timestamps in log messages (true).
171
- * @property {string} timestampFormat - Format for timestamps ("HH:mm:ss.SSS").
172
- * @property {boolean} context - Whether to include context information in log messages (true).
173
- * @property {Theme} theme - The theme to use for styling log messages (DefaultTheme).
174
- * @memberOf @decaf-ts/utils
175
- */
176
- const DefaultLoggingConfig = {
177
- verbose: 0,
178
- level: LogLevel.info,
179
- logLevel: true,
180
- style: false,
181
- separator: " - ",
182
- timestamp: true,
183
- timestampFormat: "HH:mm:ss.SSS",
184
- context: true,
185
- theme: DefaultTheme,
186
- };
187
- const AbortCode = "Aborted";
188
-
189
- /**
190
- * @description A minimal logger implementation.
191
- * @summary MiniLogger is a lightweight logging class that implements the VerbosityLogger interface.
192
- * It provides basic logging functionality with support for different log levels and verbosity.
193
- *
194
- * @class
195
- */
196
- class MiniLogger {
197
- /**
198
- * @description Creates a new MiniLogger instance.
199
- * @summary Initializes a MiniLogger with the given class name, optional configuration, and method name.
200
- *
201
- * @param context - The name of the class using this logger.
202
- * @param [conf] - Optional logging configuration. Defaults to Info level and verbosity 0.
203
- * @param [id] - Optional unique identifier for the logger instance.
204
- */
205
- constructor(context, conf, id) {
206
- this.context = context;
207
- this.conf = conf;
208
- this.id = id;
209
- }
210
- config(key) {
211
- if (this.conf && key in this.conf)
212
- return this.conf[key];
213
- return Logging.getConfig()[key];
214
- }
215
- for(method, config) {
216
- method = method
217
- ? typeof method === "string"
218
- ? method
219
- : method.name
220
- : undefined;
221
- return Logging.for([this.context, method].join("."), this.id, config);
222
- }
223
- /**
224
- * @description Creates a formatted log string.
225
- * @summary Generates a log string with timestamp, colored log level, and message.
226
- *
227
- * @param level - The log level as a string.
228
- * @param message
229
- * @param stack
230
- * @return A formatted log string.
231
- */
232
- createLog(level, message, stack) {
233
- const log = [];
234
- const style = this.config("style");
235
- if (this.config("timestamp")) {
236
- const date = new Date().toISOString();
237
- const timestamp = style ? Logging.theme(date, "timestamp", level) : date;
238
- log.push(timestamp);
239
- }
240
- if (this.config("logLevel")) {
241
- const lvl = style
242
- ? Logging.theme(level, "logLevel", level)
243
- : level;
244
- log.push(lvl);
245
- }
246
- if (this.config("context")) {
247
- const context = style
248
- ? Logging.theme(this.context, "class", level)
249
- : this.context;
250
- log.push(context);
251
- }
252
- const msg = style
253
- ? Logging.theme(typeof message === "string" ? message : message.message, "message", level)
254
- : typeof message === "string"
255
- ? message
256
- : message.message;
257
- log.push(msg);
258
- if (stack || message instanceof Error) {
259
- stack = style
260
- ? Logging.theme((stack || message.stack), "stack", level)
261
- : stack;
262
- log.push(`\nStack trace:\n${stack}`);
263
- }
264
- return log.join(this.config("separator"));
265
- }
266
- /**
267
- * @description Logs a message with the specified log level.
268
- * @summary Checks if the message should be logged based on the current log level,
269
- * then uses the appropriate console method to output the log.
270
- *
271
- * @param level - The log level of the message.
272
- * @param msg - The message to be logged.
273
- * @param stack
274
- */
275
- log(level, msg, stack) {
276
- if (NumericLogLevels[this.config("level")] <
277
- NumericLogLevels[level])
278
- return;
279
- let method;
280
- switch (level) {
281
- case LogLevel.info:
282
- method = console.log;
283
- break;
284
- case LogLevel.verbose:
285
- case LogLevel.debug:
286
- method = console.debug;
287
- break;
288
- case LogLevel.error:
289
- method = console.error;
290
- break;
291
- default:
292
- throw new Error("Invalid log level");
293
- }
294
- method(this.createLog(level, msg, stack));
295
- }
296
- /**
297
- * @description LLogs a `way too verbose` or a silly message.
298
- * @summary Logs a message at the Silly level if the current verbosity allows it.
299
- *
300
- * @param msg - The message to be logged.
301
- * @param verbosity - The verbosity level of the message (default: 0).
302
- */
303
- silly(msg, verbosity = 0) {
304
- if (this.config("verbose") >= verbosity)
305
- this.log(LogLevel.verbose, msg);
306
- }
307
- /**
308
- * @description Logs a verbose message.
309
- * @summary Logs a message at the Verbose level if the current verbosity allows it.
310
- *
311
- * @param msg - The message to be logged.
312
- * @param verbosity - The verbosity level of the message (default: 0).
313
- */
314
- verbose(msg, verbosity = 0) {
315
- if (this.config("verbose") >= verbosity)
316
- this.log(LogLevel.verbose, msg);
317
- }
318
- /**
319
- * @description Logs an info message.
320
- * @summary Logs a message at the Info level.
321
- *
322
- * @param msg - The message to be logged.
323
- */
324
- info(msg) {
325
- this.log(LogLevel.info, msg);
326
- }
327
- /**
328
- * @description Logs a debug message.
329
- * @summary Logs a message at the Debug level.
330
- *
331
- * @param msg - The message to be logged.
332
- */
333
- debug(msg) {
334
- this.log(LogLevel.debug, msg);
335
- }
336
- /**
337
- * @description Logs an error message.
338
- * @summary Logs a message at the Error level.
339
- *
340
- * @param msg - The message to be logged.
341
- */
342
- error(msg) {
343
- this.log(LogLevel.error, msg);
344
- }
345
- setConfig(config) {
346
- this.conf = { ...(this.conf || {}), ...config };
347
- }
348
- }
349
- /**
350
- * @description A static class for managing logging operations.
351
- * @summary The Logging class provides a centralized logging mechanism with support for
352
- * different log levels and verbosity. It uses a singleton pattern to maintain a global
353
- * logger instance and allows creating specific loggers for different classes and methods.
354
- *
355
- * @class
356
- */
357
- class Logging {
358
- /**
359
- * @description Factory function for creating logger instances.
360
- * @summary A function that creates new VerbosityLogger instances. By default, it creates a MiniLogger.
361
- */
362
- static { this._factory = (object, config, id) => {
363
- return new MiniLogger(object, config, id);
364
- }; }
365
- /**
366
- * @description Configuration for the logging system.
367
- * @summary Stores the global verbosity level and log level settings.
368
- */
369
- static { this._config = DefaultLoggingConfig; }
370
- /**
371
- * @description Private constructor to prevent instantiation.
372
- * @summary Ensures that the Logging class cannot be instantiated as it's designed to be used statically.
373
- */
374
- constructor() { }
375
- /**
376
- * @description Setter for the logging configuration.
377
- * @summary Allows updating the global logging configuration.
378
- *
379
- * @param config - An object containing verbosity and log level settings.
380
- */
381
- static setConfig(config) {
382
- Object.assign(this._config, config);
383
- }
384
- static getConfig() {
385
- return Object.assign({}, this._config);
386
- }
387
- /**
388
- * @description Retrieves or creates the global logger instance.
389
- * @summary Returns the existing global logger or creates a new one if it doesn't exist.
390
- *
391
- * @return The global VerbosityLogger instance.
392
- */
393
- static get() {
394
- this.global = this.global ? this.global : this._factory("Logging");
395
- return this.global;
396
- }
397
- /**
398
- * @description Logs a verbose message.
399
- * @summary Delegates the verbose logging to the global logger instance.
400
- *
401
- * @param msg - The message to be logged.
402
- * @param verbosity - The verbosity level of the message (default: 0).
403
- */
404
- static verbose(msg, verbosity = 0) {
405
- return this.get().verbose(msg, verbosity);
406
- }
407
- /**
408
- * @description Logs an info message.
409
- * @summary Delegates the info logging to the global logger instance.
410
- *
411
- * @param msg - The message to be logged.
412
- */
413
- static info(msg) {
414
- return this.get().info(msg);
415
- }
416
- /**
417
- * @description Logs a debug message.
418
- * @summary Delegates the debug logging to the global logger instance.
419
- *
420
- * @param msg - The message to be logged.
421
- */
422
- static debug(msg) {
423
- return this.get().debug(msg);
424
- }
425
- /**
426
- * @description Logs a silly message.
427
- * @summary Delegates the debug logging to the global logger instance.
428
- *
429
- * @param msg - The message to be logged.
430
- */
431
- static silly(msg) {
432
- return this.get().silly(msg);
433
- }
434
- /**
435
- * @description Logs an error message.
436
- * @summary Delegates the error logging to the global logger instance.
437
- *
438
- * @param msg - The message to be logged.
439
- */
440
- static error(msg) {
441
- return this.get().error(msg);
442
- }
443
- static for(object, id, config) {
444
- object = typeof object === "string" ? object : object.name;
445
- id = typeof id === "string" ? id : undefined;
446
- config = typeof id === "object" ? id : config;
447
- return this._factory(object, config, id);
448
- }
449
- /**
450
- * @description Creates a logger for a specific reason or context.
451
- *
452
- * @summary This static method creates a new logger instance using the factory function,
453
- * based on a given reason or context.
454
- *
455
- * @param reason - A string describing the reason or context for creating this logger.
456
- * @param id
457
- * @returns A new VerbosityLogger or ClassLogger instance.
458
- */
459
- static because(reason, id) {
460
- return this._factory(reason, this._config, id);
461
- }
462
- static theme(text, type, loggerLevel, template = DefaultTheme) {
463
- if (!this._config.style)
464
- return text;
465
- const logger = Logging.get().for(this.theme);
466
- function apply(txt, option, value) {
467
- try {
468
- const t = txt;
469
- let c = style(t);
470
- function applyColor(val, isBg = false) {
471
- let f = isBg ? c.background : c.foreground;
472
- if (!Array.isArray(val)) {
473
- return f.call(c, value);
474
- }
475
- switch (val.length) {
476
- case 1:
477
- f = isBg ? c.bgColor256 : c.color256;
478
- return f(val[0]);
479
- case 3:
480
- f = isBg ? c.bgRgb : c.rgb;
481
- return c.rgb(val[0], val[1], val[2]);
482
- default:
483
- logger.error(`Not a valid color option: ${option}`);
484
- return style(t);
485
- }
486
- }
487
- function applyStyle(v) {
488
- if (typeof v === "number") {
489
- c = c.style(v);
490
- }
491
- else {
492
- c = c[v];
493
- }
494
- }
495
- switch (option) {
496
- case "bg":
497
- case "fg":
498
- return applyColor(value).text;
499
- case "style":
500
- if (Array.isArray(value)) {
501
- value.forEach(applyStyle);
502
- }
503
- else {
504
- applyStyle(value);
505
- }
506
- return c.text;
507
- default:
508
- logger.error(`Not a valid theme option: ${option}`);
509
- return t;
510
- }
511
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
512
- }
513
- catch (e) {
514
- logger.error(`Error applying style: ${option} with value ${value}`);
515
- return txt;
516
- }
517
- }
518
- const individualTheme = template[type];
519
- if (!individualTheme || !Object.keys(individualTheme).length) {
520
- return text;
521
- }
522
- let actualTheme = individualTheme;
523
- const logLevels = Object.assign({}, LogLevel);
524
- if (Object.keys(individualTheme)[0] in logLevels)
525
- actualTheme =
526
- individualTheme[loggerLevel] || {};
527
- return Object.keys(actualTheme).reduce((acc, key) => {
528
- const val = actualTheme[key];
529
- if (val)
530
- return apply(acc, key, val);
531
- return acc;
532
- }, text);
533
- }
534
- }
535
-
536
16
  /**
537
17
  * @description Represents a user input prompt with various configuration options.
538
18
  * @summary This class provides a flexible interface for creating and managing user input prompts.
@@ -1316,6 +796,68 @@ function escapeRegExp(string) {
1316
796
  return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
1317
797
  }
1318
798
 
799
+ /**
800
+ * @description Default encoding for text operations.
801
+ * @summary The standard UTF-8 encoding used for text processing.
802
+ * @const {string} Encoding
803
+ * @memberOf @decaf-ts/utils
804
+ */
805
+ const Encoding = "utf-8";
806
+ /**
807
+ * @description Regular expression for semantic versioning.
808
+ * @summary A regex pattern to match and parse semantic version strings.
809
+ * @const {RegExp} SemVersionRegex
810
+ * @memberOf @decaf-ts/utils
811
+ */
812
+ const SemVersionRegex = /^(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z-]+(?:\.[0-9A-Za-z])))/g;
813
+ /**
814
+ * @description Enum for semantic version components.
815
+ * @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.
816
+ * @enum {string}
817
+ * @memberOf @decaf-ts/utils
818
+ */
819
+ var SemVersion;
820
+ (function (SemVersion) {
821
+ /** Patch version for backwards-compatible bug fixes. */
822
+ SemVersion["PATCH"] = "patch";
823
+ /** Minor version for backwards-compatible new features. */
824
+ SemVersion["MINOR"] = "minor";
825
+ /** Major version for changes that break backwards compatibility. */
826
+ SemVersion["MAJOR"] = "major";
827
+ })(SemVersion || (SemVersion = {}));
828
+ /**
829
+ * @description Flag to indicate non-CI environment.
830
+ * @summary Used to specify that a command should run outside of a Continuous Integration environment.
831
+ * @const {string} NoCIFLag
832
+ * @memberOf @decaf-ts/utils
833
+ */
834
+ const NoCIFLag = "-no-ci";
835
+ /**
836
+ * @description Key for the setup script in package.json.
837
+ * @summary Identifies the script that runs after package installation.
838
+ * @const {string} SetupScriptKey
839
+ * @memberOf @decaf-ts/utils
840
+ */
841
+ const SetupScriptKey = "postinstall";
842
+ /**
843
+ * @description Enum for various authentication tokens.
844
+ * @summary Defines the file names for storing different types of authentication tokens.
845
+ * @enum {string}
846
+ * @memberOf @decaf-ts/utils
847
+ */
848
+ var Tokens;
849
+ (function (Tokens) {
850
+ /** Git authentication token file name. */
851
+ Tokens["GIT"] = ".token";
852
+ /** NPM authentication token file name. */
853
+ Tokens["NPM"] = ".npmtoken";
854
+ /** Docker authentication token file name. */
855
+ Tokens["DOCKER"] = ".dockertoken";
856
+ /** Confluence authentication token file name. */
857
+ Tokens["CONFLUENCE"] = ".confluence-token";
858
+ })(Tokens || (Tokens = {}));
859
+ const AbortCode = "Aborted";
860
+
1319
861
  /**
1320
862
  * @description A standard output writer for handling command execution output.
1321
863
  * @summary This class implements the OutputWriter interface and provides methods for
@@ -2853,7 +2395,7 @@ const colors = [
2853
2395
  /**
2854
2396
  * @description Prints a styled banner to the console.
2855
2397
  * @summary Generates and prints a colorful ASCII art banner with a random slogan.
2856
- * @param {VerbosityLogger} [logger] - Optional logger for verbose output.
2398
+ * @param {Logger} [logger] - Optional logger for verbose output.
2857
2399
  * @function printBanner
2858
2400
  * @mermaid
2859
2401
  * sequenceDiagram
@@ -2925,150 +2467,6 @@ function getSlogan(i) {
2925
2467
  }
2926
2468
  }
2927
2469
 
2928
- /**
2929
- * @class ObjectAccumulator
2930
- * @template T - The type of the accumulated object, extends object
2931
- * @description A class that accumulates objects and provides type-safe access to their properties.
2932
- * It allows for dynamic addition of properties while maintaining type information.
2933
- * @summary Accumulates objects and maintains type information for accumulated properties
2934
- * @memberOf utils
2935
- */
2936
- class ObjectAccumulator {
2937
- constructor() {
2938
- Object.defineProperty(this, "__size", {
2939
- value: 0,
2940
- writable: true,
2941
- configurable: false,
2942
- enumerable: false,
2943
- });
2944
- }
2945
- /**
2946
- * @protected
2947
- * @description Expands the accumulator with properties from a new object
2948
- * @summary Adds new properties to the accumulator
2949
- * @template V - The type of the object being expanded
2950
- * @param {V} value - The object to expand with
2951
- * @returns {void}
2952
- */
2953
- expand(value) {
2954
- Object.entries(value).forEach(([k, v]) => {
2955
- Object.defineProperty(this, k, {
2956
- get: () => v,
2957
- set: (val) => {
2958
- v = val;
2959
- },
2960
- configurable: true,
2961
- enumerable: true,
2962
- });
2963
- });
2964
- }
2965
- /**
2966
- * @description Accumulates a new object into the accumulator
2967
- * @summary Adds properties from a new object to the accumulator, maintaining type information
2968
- * @template V - The type of the object being accumulated
2969
- * @param {V} value - The object to accumulate
2970
- * @returns A new ObjectAccumulator instance with updated type information
2971
- * @mermaid
2972
- * sequenceDiagram
2973
- * participant A as Accumulator
2974
- * participant O as Object
2975
- * A->>O: Get entries
2976
- * loop For each entry
2977
- * A->>A: Define property
2978
- * end
2979
- * A->>A: Update size
2980
- * A->>A: Return updated accumulator
2981
- */
2982
- accumulate(value) {
2983
- this.expand(value);
2984
- this.__size = this.__size + Object.keys(value).length;
2985
- return this;
2986
- }
2987
- /**
2988
- * @description Retrieves a value from the accumulator by its key
2989
- * @summary Gets a value from the accumulated object using a type-safe key
2990
- * @template K - The key type, must be a key of this
2991
- * @param {K} key - The key of the value to retrieve
2992
- * @returns {any | undefined} The value associated with the key, or undefined if not found
2993
- */
2994
- get(key) {
2995
- return this[key];
2996
- }
2997
- /**
2998
- * @description Checks if a key exists in the accumulator
2999
- * @summary Determines whether the accumulator contains a specific key
3000
- * @param {string} key - The key to check for existence
3001
- * @returns {boolean} True if the key exists, false otherwise
3002
- */
3003
- has(key) {
3004
- return !!this[key];
3005
- }
3006
- /**
3007
- * @description Removes a key-value pair from the accumulator
3008
- * @summary Deletes a property from the accumulated object
3009
- * @param {string} key - The key of the property to remove
3010
- * @returns {} The accumulator instance with the specified property removed
3011
- */
3012
- remove(key) {
3013
- if (!(key in this))
3014
- return this;
3015
- delete this[key];
3016
- this.__size--;
3017
- return this;
3018
- }
3019
- /**
3020
- * @description Retrieves all keys from the accumulator
3021
- * @summary Gets an array of all accumulated property keys
3022
- * @returns {string[]} An array of keys as strings
3023
- */
3024
- keys() {
3025
- return Object.keys(this);
3026
- }
3027
- /**
3028
- * @description Retrieves all values from the accumulator
3029
- * @summary Gets an array of all accumulated property values
3030
- * @returns An array of values
3031
- */
3032
- values() {
3033
- return Object.values(this);
3034
- }
3035
- /**
3036
- * @description Gets the number of key-value pairs in the accumulator
3037
- * @summary Returns the count of accumulated properties
3038
- * @returns {number} The number of key-value pairs
3039
- */
3040
- size() {
3041
- return this.__size;
3042
- }
3043
- /**
3044
- * @description Clears all accumulated key-value pairs
3045
- * @summary Removes all properties from the accumulator and returns a new empty instance
3046
- * @returns {ObjectAccumulator<never>} A new empty ObjectAccumulator instance
3047
- */
3048
- clear() {
3049
- return new ObjectAccumulator();
3050
- }
3051
- /**
3052
- * @description Executes a callback for each key-value pair in the accumulator
3053
- * @summary Iterates over all accumulated properties, calling a function for each
3054
- * @param {function(any, string, number): void} callback - The function to execute for each entry
3055
- * @returns {void}
3056
- */
3057
- forEach(callback) {
3058
- Object.entries(this).forEach(([key, value], i) => callback(value, key, i));
3059
- }
3060
- /**
3061
- * @description Creates a new array with the results of calling a provided function on every element in the accumulator
3062
- * @summary Maps each accumulated property to a new value using a callback function
3063
- * @template R - The type of the mapped values
3064
- * @param {function(any, string,number): R} callback - Function that produces an element of the new array
3065
- * @returns {R[]} A new array with each element being the result of the callback function
3066
- */
3067
- map(callback) {
3068
- return Object.entries(this).map(([key, value], i) => callback(value, key, i));
3069
- }
3070
- }
3071
-
3072
2470
  /**
3073
2471
  * @function isBrowser
3074
2472
  * @description Determines if the current environment is a browser by checking the prototype chain of the global object.
@@ -3375,7 +2773,7 @@ class HttpClient {
3375
2773
  }
3376
2774
  }
3377
2775
 
3378
- const VERSION_STRING = "0.2.6";
2776
+ const VERSION_STRING = "0.2.7";
3379
2777
  var Modes;
3380
2778
  (function (Modes) {
3381
2779
  Modes["CJS"] = "commonjs";
@@ -3480,7 +2878,12 @@ class BuildScripts extends Command {
3480
2878
  writeFile(`bin/${cmd}.cjs`, data);
3481
2879
  }
3482
2880
  }
3483
- async bundle(mode, isDev, isLib, entryFile = "src/index.ts", nameOverride = this.pkgName, externals, include = ["prompts", "styled-string-builder"]) {
2881
+ async bundle(mode, isDev, isLib, entryFile = "src/index.ts", nameOverride = this.pkgName, externals, include = [
2882
+ "prompts",
2883
+ "styled-string-builder",
2884
+ "typed-object-accumulator",
2885
+ "@decaf-ts/logging",
2886
+ ]) {
3484
2887
  const isEsm = mode === Modes.ESM;
3485
2888
  const pkgName = this.pkgName;
3486
2889
  const ext = Array.from(new Set([
@@ -3496,6 +2899,7 @@ class BuildScripts extends Command {
3496
2899
  "child_process",
3497
2900
  "util",
3498
2901
  "https",
2902
+ "tslib",
3499
2903
  ],
3500
2904
  ...(externals || []),
3501
2905
  ]));
@@ -4416,12 +3820,12 @@ class RegexpOutputWriter extends StandardOutputWriter {
4416
3820
  * @description Represents the current version of the module.
4417
3821
  * @summary This constant stores the version number of the @asdasdasd/utils module.
4418
3822
  * The actual version number is replaced during the build process,
4419
- * with the placeholder "0.2.6" being substituted with the current version.
3823
+ * with the placeholder "0.2.7" being substituted with the current version.
4420
3824
  *
4421
3825
  * @const VERSION
4422
3826
  * @memberOf module:@decaf-ts/utils
4423
3827
  */
4424
- const VERSION = "0.2.6";
3828
+ const VERSION = "0.2.7";
4425
3829
 
4426
- export { AbortCode, BuildScripts, Command, DefaultCommandOptions, DefaultCommandValues, DefaultLoggingConfig, DefaultTheme, Encoding, Environment, HttpClient, LogLevel, Logging, MiniLogger, NoCIFLag, NumericLogLevels, RegexpOutputWriter, ReleaseScript, SemVersion, SemVersionRegex, SetupScriptKey, StandardOutputWriter, TemplateSync, Tokens, UserInput, VERSION, chainAbortController, copyFile, deletePath, escapeRegExp, getAllFiles, getDependencies, getPackage, getPackageVersion, getSlogan, installDependencies, installIfNotAvailable, lockify, normalizeImport, padEnd, patchFile, patchPlaceholders, patchString, printBanner, pushToGit, readFile, renameFile, runCommand, setPackageAttribute, spawnCommand, toCamelCase, toENVFormat, toKebabCase, toPascalCase, toSnakeCase, updateDependencies, writeFile };
4427
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"utils.esm.cjs","sources":["../src/utils/constants.ts","../src/output/logging.ts","../src/input/input.ts","../src/cli/constants.ts","../src/utils/text.ts","../src/writers/StandardOutputWriter.ts","../src/utils/utils.ts","../src/utils/fs.ts","../src/output/common.ts","../src/utils/accumulator.ts","../src/utils/web.ts","../src/utils/environment.ts","../src/cli/command.ts","../src/utils/http.ts","../src/cli/commands/build-scripts.ts","../src/cli/commands/tag-release.ts","../src/cli/commands/update-scripts.ts","../src/writers/RegexpOutputWriter.ts","../src/index.ts"],"sourcesContent":["import { LoggingConfig, Theme } from \"../output/types\";\n\n/**\n * @description Default encoding for text operations.\n * @summary The standard UTF-8 encoding used for text processing.\n * @const {string} Encoding\n * @memberOf @decaf-ts/utils\n */\nexport const Encoding = \"utf-8\";\n\n/**\n * @description Regular expression for semantic versioning.\n * @summary A regex pattern to match and parse semantic version strings.\n * @const {RegExp} SemVersionRegex\n * @memberOf @decaf-ts/utils\n */\nexport const SemVersionRegex =\n  /^(\\d+)\\.(\\d+)\\.(\\d+)(?:-([0-9A-Za-z-]+(?:\\.[0-9A-Za-z])))/g;\n\n/**\n * @description Enum for semantic version components.\n * @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.\n * @enum {string}\n * @memberOf @decaf-ts/utils\n */\nexport enum SemVersion {\n  /** Patch version for backwards-compatible bug fixes. */\n  PATCH = \"patch\",\n  /** Minor version for backwards-compatible new features. */\n  MINOR = \"minor\",\n  /** Major version for changes that break backwards compatibility. */\n  MAJOR = \"major\",\n}\n\n/**\n * @description Flag to indicate non-CI environment.\n * @summary Used to specify that a command should run outside of a Continuous Integration environment.\n * @const {string} NoCIFLag\n * @memberOf @decaf-ts/utils\n */\nexport const NoCIFLag = \"-no-ci\";\n\n/**\n * @description Key for the setup script in package.json.\n * @summary Identifies the script that runs after package installation.\n * @const {string} SetupScriptKey\n * @memberOf @decaf-ts/utils\n */\nexport const SetupScriptKey = \"postinstall\";\n\n/**\n * @description Enum for various authentication tokens.\n * @summary Defines the file names for storing different types of authentication tokens.\n * @enum {string}\n * @memberOf @decaf-ts/utils\n */\nexport enum Tokens {\n  /** Git authentication token file name. */\n  GIT = \".token\",\n  /** NPM authentication token file name. */\n  NPM = \".npmtoken\",\n  /** Docker authentication token file name. */\n  DOCKER = \".dockertoken\",\n  /** Confluence authentication token file name. */\n  CONFLUENCE = \".confluence-token\",\n}\n\n/**\n * @description Enum for log levels.\n * @summary Defines different levels of logging for the application.\n * @enum {string}\n * @memberOf @decaf-ts/utils\n */\nexport enum LogLevel {\n  /** Error events that are likely to cause problems. */\n  error = \"error\",\n  /** Routine information, such as ongoing status or performance. */\n  info = \"info\",\n  /** Additional relevant information. */\n  verbose = \"verbose\",\n  /** Debug or trace information. */\n  debug = \"debug\",\n  /** way too verbose or silly information. */\n  silly = \"silly\",\n}\n\n/**\n * @description Numeric values associated with log levels.\n * @summary Provides a numeric representation of log levels for comparison and filtering.\n * @const {Object} NumericLogLevels\n * @property {number} error - Numeric value for error level (0).\n * @property {number} info - Numeric value for info level (2).\n * @property {number} verbose - Numeric value for verbose level (4).\n * @property {number} debug - Numeric value for debug level (5).\n * @property {number} silly - Numeric value for silly level (8).\n * @memberOf @decaf-ts/utils\n */\nexport const NumericLogLevels = {\n  error: 2,\n  info: 4,\n  verbose: 6,\n  debug: 7,\n  silly: 9,\n};\n\n/**\n * @description Default theme for styling log output.\n * @summary Defines the default color and style settings for various components of log messages.\n * @const DefaultTheme\n * @typedef {Theme} DefaultTheme\n * @property {Object} class - Styling for class names.\n * @property {number} class.fg - Foreground color code for class names (4).\n * @property {Object} id - Styling for identifiers.\n * @property {number} id.fg - Foreground color code for identifiers (36).\n * @property {Object} stack - Styling for stack traces (empty object).\n * @property {Object} timestamp - Styling for timestamps (empty object).\n * @property {Object} message - Styling for different types of messages.\n * @property {Object} message.error - Styling for error messages.\n * @property {number} message.error.fg - Foreground color code for error messages (34).\n * @property {Object} method - Styling for method names (empty object).\n * @property {Object} logLevel - Styling for different log levels.\n * @property {Object} logLevel.error - Styling for error level logs.\n * @property {number} logLevel.error.fg - Foreground color code for error level logs (6).\n * @property {Object} logLevel.info - Styling for info level logs (empty object).\n * @property {Object} logLevel.verbose - Styling for verbose level logs (empty object).\n * @property {Object} logLevel.debug - Styling for debug level logs.\n * @property {number} logLevel.debug.fg - Foreground color code for debug level logs (7).\n * @memberOf @decaf-ts/utils\n */\nexport const DefaultTheme: Theme = {\n  class: {\n    fg: 34,\n  },\n  id: {\n    fg: 36,\n  },\n  stack: {},\n  timestamp: {},\n  message: {\n    error: {\n      fg: 31,\n    },\n  },\n  method: {},\n  logLevel: {\n    error: {\n      fg: 31,\n      style: [\"bold\"],\n    },\n    info: {},\n    verbose: {},\n    debug: {\n      fg: 33,\n    },\n  },\n};\n\n/**\n * @description Default configuration for logging.\n * @summary Defines the default settings for the logging system, including verbosity, log level, styling, and timestamp format.\n * @const DefaultLoggingConfig\n * @typedef {LoggingConfig} DefaultLoggingConfig\n * @property {number} verbose - Verbosity level (0).\n * @property {LogLevel} level - Default log level (LogLevel.info).\n * @property {boolean} style - Whether to apply styling to log output (false).\n * @property {boolean} timestamp - Whether to include timestamps in log messages (true).\n * @property {string} timestampFormat - Format for timestamps (\"HH:mm:ss.SSS\").\n * @property {boolean} context - Whether to include context information in log messages (true).\n * @property {Theme} theme - The theme to use for styling log messages (DefaultTheme).\n * @memberOf @decaf-ts/utils\n */\nexport const DefaultLoggingConfig: LoggingConfig = {\n  verbose: 0,\n  level: LogLevel.info,\n  logLevel: true,\n  style: false,\n  separator: \" - \",\n  timestamp: true,\n  timestampFormat: \"HH:mm:ss.SSS\",\n  context: true,\n  theme: DefaultTheme,\n};\n\nexport const AbortCode = \"Aborted\";\n","import {\n  DefaultLoggingConfig,\n  DefaultTheme,\n  LogLevel,\n  NumericLogLevels,\n} from \"../utils/constants\";\nimport {\n  LoggingConfig,\n  LoggingContext,\n  StringLike,\n  Theme,\n  ThemeOption,\n  ThemeOptionByLogLevel,\n  VerbosityLogger,\n} from \"./types\";\nimport { ColorizeOptions, style, StyledString } from \"styled-string-builder\";\n\n/**\n * @description A minimal logger implementation.\n * @summary MiniLogger is a lightweight logging class that implements the VerbosityLogger interface.\n * It provides basic logging functionality with support for different log levels and verbosity.\n *\n * @class\n */\nexport class MiniLogger implements VerbosityLogger {\n  /**\n   * @description Creates a new MiniLogger instance.\n   * @summary Initializes a MiniLogger with the given class name, optional configuration, and method name.\n   *\n   * @param context - The name of the class using this logger.\n   * @param [conf] - Optional logging configuration. Defaults to Info level and verbosity 0.\n   * @param [id] - Optional unique identifier for the logger instance.\n   */\n  constructor(\n    protected context: string,\n    protected conf?: Partial<LoggingConfig>,\n    protected id?: string\n  ) {}\n\n  protected config(\n    key: keyof LoggingConfig\n  ): LoggingConfig[keyof LoggingConfig] {\n    if (this.conf && key in this.conf) return this.conf[key];\n    return Logging.getConfig()[key];\n  }\n\n  for(\n    method?: string | ((...args: any[]) => any),\n    config?: Partial<LoggingConfig>\n  ): VerbosityLogger {\n    method = method\n      ? typeof method === \"string\"\n        ? method\n        : method.name\n      : undefined;\n\n    return Logging.for([this.context, method].join(\".\"), this.id, config);\n  }\n\n  /**\n   * @description Creates a formatted log string.\n   * @summary Generates a log string with timestamp, colored log level, and message.\n   *\n   * @param level - The log level as a string.\n   * @param message\n   * @param stack\n   * @return A formatted log string.\n   */\n  protected createLog(\n    level: LogLevel,\n    message: StringLike | Error,\n    stack?: string\n  ): string {\n    const log: string[] = [];\n    const style = this.config(\"style\");\n    if (this.config(\"timestamp\")) {\n      const date = new Date().toISOString();\n      const timestamp = style ? Logging.theme(date, \"timestamp\", level) : date;\n      log.push(timestamp);\n    }\n\n    if (this.config(\"logLevel\")) {\n      const lvl: string = style\n        ? Logging.theme(level, \"logLevel\", level)\n        : level;\n      log.push(lvl);\n    }\n\n    if (this.config(\"context\")) {\n      const context: string = style\n        ? Logging.theme(this.context, \"class\", level)\n        : this.context;\n      log.push(context);\n    }\n\n    const msg: string = style\n      ? Logging.theme(\n          typeof message === \"string\" ? message : (message as Error).message,\n          \"message\",\n          level\n        )\n      : typeof message === \"string\"\n        ? message\n        : (message as Error).message;\n    log.push(msg);\n    if (stack || message instanceof Error) {\n      stack = style\n        ? Logging.theme(\n            (stack || (message as Error).stack) as string,\n            \"stack\",\n            level\n          )\n        : stack;\n      log.push(`\\nStack trace:\\n${stack}`);\n    }\n\n    return log.join(this.config(\"separator\") as string);\n  }\n\n  /**\n   * @description Logs a message with the specified log level.\n   * @summary Checks if the message should be logged based on the current log level,\n   * then uses the appropriate console method to output the log.\n   *\n   * @param level - The log level of the message.\n   * @param msg - The message to be logged.\n   * @param stack\n   */\n  protected log(\n    level: LogLevel,\n    msg: StringLike | Error,\n    stack?: string\n  ): void {\n    if (\n      NumericLogLevels[this.config(\"level\") as LogLevel] <\n      NumericLogLevels[level]\n    )\n      return;\n    let method;\n    switch (level) {\n      case LogLevel.info:\n        method = console.log;\n        break;\n      case LogLevel.verbose:\n      case LogLevel.debug:\n        method = console.debug;\n        break;\n      case LogLevel.error:\n        method = console.error;\n        break;\n      default:\n        throw new Error(\"Invalid log level\");\n    }\n    method(this.createLog(level, msg, stack));\n  }\n\n  /**\n   * @description LLogs a `way too verbose` or a silly message.\n   * @summary Logs a message at the Silly level if the current verbosity allows it.\n   *\n   * @param msg - The message to be logged.\n   * @param verbosity - The verbosity level of the message (default: 0).\n   */\n  silly(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs a verbose message.\n   * @summary Logs a message at the Verbose level if the current verbosity allows it.\n   *\n   * @param msg - The message to be logged.\n   * @param verbosity - The verbosity level of the message (default: 0).\n   */\n  verbose(msg: StringLike, verbosity: number = 0): void {\n    if ((this.config(\"verbose\") as number) >= verbosity)\n      this.log(LogLevel.verbose, msg);\n  }\n\n  /**\n   * @description Logs an info message.\n   * @summary Logs a message at the Info level.\n   *\n   * @param msg - The message to be logged.\n   */\n  info(msg: StringLike): void {\n    this.log(LogLevel.info, msg);\n  }\n\n  /**\n   * @description Logs a debug message.\n   * @summary Logs a message at the Debug level.\n   *\n   * @param msg - The message to be logged.\n   */\n  debug(msg: StringLike): void {\n    this.log(LogLevel.debug, msg);\n  }\n\n  /**\n   * @description Logs an error message.\n   * @summary Logs a message at the Error level.\n   *\n   * @param msg - The message to be logged.\n   */\n  error(msg: StringLike | Error): void {\n    this.log(LogLevel.error, msg);\n  }\n\n  setConfig(config: Partial<LoggingConfig>) {\n    this.conf = { ...(this.conf || {}), ...config };\n  }\n}\n\n/**\n * @description A static class for managing logging operations.\n * @summary The Logging class provides a centralized logging mechanism with support for\n * different log levels and verbosity. It uses a singleton pattern to maintain a global\n * logger instance and allows creating specific loggers for different classes and methods.\n *\n * @class\n */\nexport class Logging {\n  /**\n   * @description The global logger instance.\n   * @summary A singleton instance of VerbosityLogger used for global logging.\n   */\n  private static global?: VerbosityLogger;\n\n  /**\n   * @description Factory function for creating logger instances.\n   * @summary A function that creates new VerbosityLogger instances. By default, it creates a MiniLogger.\n   */\n  private static _factory: (\n    object: string,\n    config?: Partial<LoggingConfig>,\n    id?: string\n  ) => VerbosityLogger = (\n    object: string,\n    config?: Partial<LoggingConfig>,\n    id?: string\n  ) => {\n    return new MiniLogger(object, config, id);\n  };\n  /**\n   * @description Configuration for the logging system.\n   * @summary Stores the global verbosity level and log level settings.\n   */\n  private static _config: LoggingConfig = DefaultLoggingConfig;\n\n  /**\n   * @description Private constructor to prevent instantiation.\n   * @summary Ensures that the Logging class cannot be instantiated as it's designed to be used statically.\n   */\n  private constructor() {}\n\n  /**\n   * @description Setter for the logging configuration.\n   * @summary Allows updating the global logging configuration.\n   *\n   * @param config - An object containing verbosity and log level settings.\n   */\n  static setConfig(config: Partial<LoggingConfig>) {\n    Object.assign(this._config, config);\n  }\n\n  static getConfig(): LoggingConfig {\n    return Object.assign({}, this._config);\n  }\n\n  /**\n   * @description Retrieves or creates the global logger instance.\n   * @summary Returns the existing global logger or creates a new one if it doesn't exist.\n   *\n   * @return The global VerbosityLogger instance.\n   */\n  static get(): VerbosityLogger {\n    this.global = this.global ? this.global : this._factory(\"Logging\");\n    return this.global;\n  }\n\n  /**\n   * @description Logs a verbose message.\n   * @summary Delegates the verbose logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   * @param verbosity - The verbosity level of the message (default: 0).\n   */\n  static verbose(msg: StringLike, verbosity: number = 0): void {\n    return this.get().verbose(msg, verbosity);\n  }\n\n  /**\n   * @description Logs an info message.\n   * @summary Delegates the info logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static info(msg: StringLike): void {\n    return this.get().info(msg);\n  }\n\n  /**\n   * @description Logs a debug message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static debug(msg: StringLike): void {\n    return this.get().debug(msg);\n  }\n\n  /**\n   * @description Logs a silly message.\n   * @summary Delegates the debug logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static silly(msg: StringLike): void {\n    return this.get().silly(msg);\n  }\n\n  /**\n   * @description Logs an error message.\n   * @summary Delegates the error logging to the global logger instance.\n   *\n   * @param msg - The message to be logged.\n   */\n  static error(msg: StringLike): void {\n    return this.get().error(msg);\n  }\n\n  static for(\n    object: LoggingContext,\n    id?: string | Partial<LoggingConfig>,\n    config?: Partial<LoggingConfig>\n  ): VerbosityLogger {\n    object = typeof object === \"string\" ? object : object.name;\n    id = typeof id === \"string\" ? id : undefined;\n    config = typeof id === \"object\" ? (id as Partial<LoggingConfig>) : config;\n    return this._factory(object, config, id);\n  }\n\n  /**\n   * @description Creates a logger for a specific reason or context.\n   *\n   * @summary This static method creates a new logger instance using the factory function,\n   * based on a given reason or context.\n   *\n   * @param reason - A string describing the reason or context for creating this logger.\n   * @param id\n   * @returns A new VerbosityLogger or ClassLogger instance.\n   */\n  static because(reason: string, id?: string): VerbosityLogger {\n    return this._factory(reason, this._config, id);\n  }\n\n  static theme(\n    text: string,\n    type: keyof Theme | keyof LogLevel,\n    loggerLevel: LogLevel,\n    template: Theme = DefaultTheme\n  ) {\n    if (!this._config.style) return text;\n    const logger = Logging.get().for(this.theme);\n\n    function apply(\n      txt: string,\n      option: keyof ThemeOption,\n      value: number | [number] | [number, number, number] | number[] | string[]\n    ): string {\n      try {\n        const t: string | StyledString = txt;\n        let c = style(t);\n\n        function applyColor(\n          val: number | [number] | [number, number, number],\n          isBg = false\n        ): StyledString {\n          let f:\n            | typeof c.background\n            | typeof c.foreground\n            | typeof c.rgb\n            | typeof c.color256 = isBg ? c.background : c.foreground;\n          if (!Array.isArray(val)) {\n            return (f as typeof c.background | typeof c.foreground).call(\n              c,\n              value as number\n            );\n          }\n          switch (val.length) {\n            case 1:\n              f = isBg ? c.bgColor256 : c.color256;\n              return (f as typeof c.bgColor256 | typeof c.color256)(val[0]);\n            case 3:\n              f = isBg ? c.bgRgb : c.rgb;\n              return c.rgb(val[0], val[1], val[2]);\n            default:\n              logger.error(`Not a valid color option: ${option}`);\n              return style(t as string);\n          }\n        }\n\n        function applyStyle(v: number | string): void {\n          if (typeof v === \"number\") {\n            c = c.style(v);\n          } else {\n            c = c[v as keyof ColorizeOptions] as StyledString;\n          }\n        }\n\n        switch (option) {\n          case \"bg\":\n          case \"fg\":\n            return applyColor(value as number).text;\n          case \"style\":\n            if (Array.isArray(value)) {\n              value.forEach(applyStyle);\n            } else {\n              applyStyle(value as number | string);\n            }\n            return c.text;\n          default:\n            logger.error(`Not a valid theme option: ${option}`);\n            return t;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      } catch (e: unknown) {\n        logger.error(`Error applying style: ${option} with value ${value}`);\n        return txt;\n      }\n    }\n\n    const individualTheme = template[type as keyof Theme];\n    if (!individualTheme || !Object.keys(individualTheme).length) {\n      return text;\n    }\n\n    let actualTheme: ThemeOption = individualTheme as ThemeOption;\n\n    const logLevels = Object.assign({}, LogLevel);\n    if (Object.keys(individualTheme)[0] in logLevels)\n      actualTheme =\n        (individualTheme as ThemeOptionByLogLevel)[loggerLevel] || {};\n\n    return Object.keys(actualTheme).reduce((acc: string, key: string) => {\n      const val = (actualTheme as ThemeOption)[key as keyof ThemeOption];\n      if (val)\n        return apply(\n          acc,\n          key as keyof ThemeOption,\n          val as\n            | number\n            | [number]\n            | [number, number, number]\n            | number[]\n            | string[]\n        );\n      return acc;\n    }, text);\n  }\n}\n","import {\n  Answers,\n  Choice,\n  Falsy,\n  InitialReturnValue,\n  PrevCaller,\n  PromptObject,\n  PromptType,\n  ValueOrFunc,\n} from \"prompts\";\nimport prompts from \"prompts\";\nimport { parseArgs, ParseArgsConfig } from \"util\";\nimport { Writable, Readable } from \"stream\";\nimport { Logging } from \"../output/logging\";\nimport { Kleur } from \"../output/types\";\nimport { ParseArgsOptionsConfig, ParseArgsResult } from \"./types\";\n\n/**\n * @description Represents a user input prompt with various configuration options.\n * @summary This class provides a flexible interface for creating and managing user input prompts.\n * It implements the PromptObject interface from the 'prompts' library and offers methods to set\n * various properties of the prompt. The class also includes static methods for common input scenarios\n * and argument parsing.\n *\n * @template R - The type of the prompt name, extending string.\n *\n * @param name - The name of the prompt, used as the key in the returned answers object.\n *\n * @class\n */\nexport class UserInput<R extends string = string> implements PromptObject<R> {\n  private static readonly logger = Logging.for(UserInput);\n  /**\n   * @description The type of the prompt.\n   * @summary Determines the input method (e.g., text, number, confirm).\n   */\n  type: PromptType | Falsy | PrevCaller<R, PromptType | Falsy> = \"text\";\n\n  /**\n   * @description The name of the prompt.\n   * @summary Used as the key in the returned answers object.\n   */\n  name: ValueOrFunc<R>;\n\n  /**\n   * @description The message displayed to the user.\n   * @summary The question or instruction presented to the user.\n   */\n  message?: ValueOrFunc<string> | undefined;\n\n  /**\n   * @description The initial value of the prompt.\n   * @summary The default value presented to the user.\n   */\n  initial?:\n    | InitialReturnValue\n    | PrevCaller<R, InitialReturnValue | Promise<InitialReturnValue>>\n    | undefined;\n\n  /**\n   * @description The style of the prompt.\n   * @summary Determines the visual style of the prompt.\n   */\n  style?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The format function for the input.\n   * @summary A function to format the user's input before it's returned.\n   */\n  format?: PrevCaller<R, void> | undefined;\n\n  /**\n   * @description The validation function for the input.\n   * @summary A function to validate the user's input.\n   */\n  validate?:\n    | PrevCaller<R, boolean | string | Promise<boolean | string>>\n    | undefined;\n\n  /**\n   * @description The onState callback function.\n   * @summary A function called when the state of the prompt changes.\n   */\n  onState?: PrevCaller<R, void> | undefined;\n\n  onRender?: ((kleur: Kleur) => void) | undefined;\n\n  /**\n   * @description The minimum value for number inputs.\n   * @summary The lowest number the user can input.\n   */\n  min?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The maximum value for number inputs.\n   * @summary The highest number the user can input.\n   */\n  max?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description Whether to allow float values for number inputs.\n   * @summary If true, allows decimal numbers.\n   */\n  float?: boolean | PrevCaller<R, boolean | Falsy> | undefined;\n\n  /**\n   * @description The number of decimal places to round to for float inputs.\n   * @summary Determines the precision of float inputs.\n   */\n  round?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description Instructions for the user.\n   * @summary Additional guidance provided to the user.\n   */\n  instructions?: string | boolean | undefined;\n\n  /**\n   * @description The increment value for number inputs.\n   * @summary The step size when increasing or decreasing the number.\n   */\n  increment?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The separator for list inputs.\n   * @summary The character used to separate list items.\n   */\n  separator?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The active option style for select inputs.\n   * @summary The style applied to the currently selected option.\n   */\n  active?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The inactive option style for select inputs.\n   * @summary The style applied to non-selected options.\n   */\n  inactive?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  choices?: Choice[] | PrevCaller<R, Choice[] | Falsy> | undefined;\n\n  /**\n   * @description The hint text for the prompt.\n   * @summary Additional information displayed to the user.\n   */\n  hint?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The warning text for the prompt.\n   * @summary A warning message displayed to the user.\n   */\n  warn?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  suggest?: ((input: any, choices: Choice[]) => Promise<any>) | undefined;\n\n  /**\n   * @description The limit for list inputs.\n   * @summary The maximum number of items that can be selected.\n   */\n  limit?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The mask for password inputs.\n   * @summary The character used to hide the user's input.\n   */\n  mask?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The stdout stream for the prompt.\n   * @summary The output stream used by the prompt.\n   */\n  stdout?: Writable | undefined;\n\n  /**\n   * @description The stdin stream for the prompt.\n   * @summary The input stream used by the prompt.\n   */\n  stdin?: Readable | undefined;\n\n  /**\n   * @description Creates a new UserInput instance.\n   * @summary Initializes a new UserInput object with the given name.\n   *\n   * @param name - The name of the prompt.\n   */\n  constructor(name: ValueOrFunc<R>) {\n    this.name = name;\n  }\n\n  /**\n   * @description Sets the type of the prompt.\n   * @summary Configures the input method for the prompt.\n   *\n   * @param type - The type of the prompt.\n   * @returns This UserInput instance for method chaining.\n   */\n  setType(type: PromptType | Falsy | PrevCaller<R, PromptType | Falsy>): this {\n    UserInput.logger.verbose(`Setting type to: ${type}`);\n    this.type = type;\n    return this;\n  }\n\n  /**\n   * @description Sets the message of the prompt.\n   * @summary Configures the question or instruction presented to the user.\n   *\n   * @param value - The message to be displayed.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMessage(value: ValueOrFunc<string> | undefined): this {\n    UserInput.logger.verbose(`Setting message to: ${value}`);\n    this.message = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the initial value of the prompt.\n   * @summary Configures the default value presented to the user.\n   *\n   * @param value - The initial value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInitial(\n    value:\n      | InitialReturnValue\n      | PrevCaller<R, InitialReturnValue | Promise<InitialReturnValue>>\n      | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting initial value to: ${value}`);\n    this.initial = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the style of the prompt.\n   * @summary Configures the visual style of the prompt.\n   *\n   * @param value - The style to be applied.\n   * @returns This UserInput instance for method chaining.\n   */\n  setStyle(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting style to: ${value}`);\n    this.style = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the format function of the prompt.\n   * @summary Configures a function to format the user's input before it's returned.\n   *\n   * @param value - The format function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setFormat(value: PrevCaller<R, void> | undefined): this {\n    UserInput.logger.verbose(`Setting format function`);\n    this.format = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the validation function of the prompt.\n   * @summary Configures a function to validate the user's input.\n   *\n   * @param value - The validation function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setValidate(\n    value:\n      | PrevCaller<R, boolean | string | Promise<boolean | string>>\n      | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting validate function`);\n    this.validate = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the onState callback of the prompt.\n   * @summary Configures a function to be called when the state of the prompt changes.\n   *\n   * @param value - The onState callback function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setOnState(value: PrevCaller<R, void> | undefined): this {\n    UserInput.logger.verbose(`Setting onState callback`);\n    this.onState = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the onRender callback of the prompt.\n   * @summary Configures a function to be called when the prompt is rendered.\n   *\n   * @param value - The onRender callback function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setOnRender(value: ((kleur: Kleur) => void) | undefined): this {\n    UserInput.logger.verbose(`Setting onRender callback`);\n    this.onRender = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the minimum value for number inputs.\n   * @summary Configures the lowest number the user can input.\n   *\n   * @param value - The minimum value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMin(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting min value to: ${value}`);\n    this.min = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the maximum value for number inputs.\n   * @summary Configures the highest number the user can input.\n   *\n   * @param value - The maximum value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMax(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting max value to: ${value}`);\n    this.max = value;\n    return this;\n  }\n\n  /**\n   * @description Sets whether to allow float values for number inputs.\n   * @summary Configures whether decimal numbers are allowed.\n   *\n   * @param value - Whether to allow float values.\n   * @returns This UserInput instance for method chaining.\n   */\n  setFloat(value: boolean | PrevCaller<R, boolean | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting float to: ${value}`);\n    this.float = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the number of decimal places to round to for float inputs.\n   * @summary Configures the precision of float inputs.\n   *\n   * @param value - The number of decimal places.\n   * @returns This UserInput instance for method chaining.\n   */\n  setRound(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting round to: ${value}`);\n    this.round = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the instructions for the user.\n   * @summary Configures additional guidance provided to the user.\n   *\n   * @param value - The instructions.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInstructions(value: string | boolean | undefined): this {\n    UserInput.logger.verbose(`Setting instructions to: ${value}`);\n    this.instructions = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the increment value for number inputs.\n   * @summary Configures the step size when increasing or decreasing the number.\n   *\n   * @param value - The increment value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setIncrement(\n    value: number | PrevCaller<R, number | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting increment to: ${value}`);\n    this.increment = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the separator for list inputs.\n   * @summary Configures the character used to separate list items.\n   *\n   * @param value - The separator character.\n   * @returns This UserInput instance for method chaining.\n   */\n  setSeparator(\n    value: string | PrevCaller<R, string | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting separator to: ${value}`);\n    this.separator = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the active option style for select inputs.\n   * @summary Configures the style applied to the currently selected option.\n   *\n   * @param value - The active option style.\n   * @returns This UserInput instance for method chaining.\n   */\n  setActive(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting active style to: ${value}`);\n    this.active = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the inactive option style for select inputs.\n   * @summary Configures the style applied to non-selected options.\n   *\n   * @param value - The inactive option style.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInactive(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting inactive style to: ${value}`);\n    this.inactive = value;\n    return this;\n  }\n\n  setChoices(\n    value: Choice[] | PrevCaller<R, Choice[] | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting choices: ${JSON.stringify(value)}`);\n    this.choices = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the hint text for the prompt.\n   * @summary Configures additional information displayed to the user.\n   *\n   * @param value - The hint text.\n   * @returns This UserInput instance for method chaining.\n   */\n  setHint(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting hint to: ${value}`);\n    this.hint = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the warning text for the prompt.\n   * @summary Configures a warning message displayed to the user.\n   *\n   * @param value - The warning text.\n   * @returns This UserInput instance for method chaining.\n   */\n  setWarn(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting warn to: ${value}`);\n    this.warn = value;\n    return this;\n  }\n\n  setSuggest(\n    value: ((input: any, choices: Choice[]) => Promise<any>) | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting suggest function`);\n    this.suggest = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the limit for list inputs.\n   * @summary Configures the maximum number of items that can be selected in list-type prompts.\n   * @template R - The type of the prompt name, extending string.\n   * @param value - The maximum number of items that can be selected, or a function to determine this value.\n   * @return This UserInput instance for method chaining.\n   */\n  setLimit(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting limit to: ${value}`);\n    this.limit = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the mask for password inputs.\n   * @summary Configures the character used to hide the user's input in password-type prompts.\n   * @template R - The type of the prompt name, extending string.\n   * @param value - The character used to mask the input, or a function to determine this value.\n   * @return This UserInput instance for method chaining.\n   */\n  setMask(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting mask to: ${value}`);\n    this.mask = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the stdout stream for the prompt.\n   * @summary Configures the output stream used by the prompt for displaying messages and results.\n   * @param value - The Writable stream to be used as stdout.\n   * @return This UserInput instance for method chaining.\n   */\n  setStdout(value: Writable | undefined): this {\n    UserInput.logger.verbose(`Setting stdout stream`);\n    this.stdout = value;\n    return this;\n  }\n  /**\n   * @description Sets the stdin stream for the prompt.\n   * @summary Configures the input stream used by the prompt for receiving user input.\n   * @param value - The Readable stream to be used as stdin.\n   * @return This UserInput instance for method chaining.\n   */\n  setStdin(value: Readable | undefined): this {\n    this.stdin = value;\n    return this;\n  }\n\n  /**\n   * @description Asks the user for input based on the current UserInput configuration.\n   * @summary Prompts the user and returns their response as a single value.\n   * @template R - The type of the prompt name, extending string.\n   * @return A Promise that resolves to the user's answer.\n   */\n  async ask() {\n    return (await UserInput.ask(this))[this.name as keyof Answers<R>];\n  }\n\n  /**\n   * @description Asks the user one or more questions based on the provided UserInput configurations.\n   * @summary Prompts the user with one or more questions and returns their answers as an object.\n   * @template R - The type of the prompt name, extending string.\n   * @param question - A single UserInput instance or an array of UserInput instances.\n   * @return A Promise that resolves to an object containing the user's answers.\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant A as ask method\n   *   participant P as prompts library\n   *   A->>P: Call prompts with question(s)\n   *   P->>U: Display prompt(s)\n   *   U->>P: Provide input\n   *   P->>A: Return answers\n   *   A->>A: Process answers\n   *   A-->>Caller: Return processed answers\n   */\n  static async ask<R extends string = string>(\n    question: UserInput<R> | UserInput<R>[]\n  ) {\n    const log = UserInput.logger.for(this.ask);\n    if (!Array.isArray(question)) {\n      question = [question];\n    }\n    let answers: Answers<R>;\n    try {\n      log.verbose(\n        `Asking questions: ${question.map((q) => q.name).join(\", \")}`\n      );\n      answers = await prompts(question);\n      log.verbose(`Received answers: ${JSON.stringify(answers, null, 2)}`);\n    } catch (error: unknown) {\n      throw new Error(`Error while getting input: ${error}`);\n    }\n    return answers;\n  }\n\n  /**\n   * @description Asks the user for a number input.\n   * @summary Prompts the user to enter a number, with optional minimum, maximum, and initial values.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param min - The minimum allowed value (optional).\n   * @param max - The maximum allowed value (optional).\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to the number entered by the user.\n   */\n  static async askNumber(\n    name: string,\n    question: string,\n    min?: number,\n    max?: number,\n    initial?: number\n  ): Promise<number> {\n    const log = UserInput.logger.for(this.askNumber);\n    log.verbose(\n      `Asking number input: undefined, question: ${question}, min: ${min}, max: ${max}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"number\");\n\n    if (typeof min === \"number\") userInput.setMin(min);\n\n    if (typeof max === \"number\") userInput.setMax(max);\n\n    if (typeof initial === \"number\") userInput.setInitial(initial);\n\n    return (await this.ask(userInput))[name];\n  }\n\n  /**\n   * @description Asks the user for a text input.\n   * @summary Prompts the user to enter text, with optional masking and initial value.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param mask - The character used to mask the input (optional, for password-like inputs).\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to the text entered by the user.\n   */\n  static async askText(\n    name: string,\n    question: string,\n    mask: string | undefined = undefined,\n    initial?: string\n  ): Promise<string> {\n    const log = UserInput.logger.for(this.askText);\n    log.verbose(\n      `Asking text input: undefined, question: ${question}, mask: ${mask}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name).setMessage(question);\n\n    if (mask) userInput.setMask(mask);\n    if (typeof initial === \"string\") userInput.setInitial(initial);\n    return (await this.ask(userInput))[name];\n  }\n\n  /**\n   * @description Asks the user for a confirmation (yes/no).\n   * @summary Prompts the user with a yes/no question and returns a boolean result.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to a boolean representing the user's answer.\n   */\n  static async askConfirmation(\n    name: string,\n    question: string,\n    initial?: boolean\n  ): Promise<boolean> {\n    const log = UserInput.logger.for(this.askConfirmation);\n    log.verbose(\n      `Asking confirmation input: undefined, question: ${question}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"confirm\");\n\n    if (typeof initial !== \"undefined\") userInput.setInitial(initial);\n    return (await this.ask(userInput))[name];\n  }\n  /**\n   * @description Repeatedly asks for input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid input from the user, allowing for a specified number of attempts.\n   *\n   * @template R - The type of the expected result.\n   * @param input - The UserInput instance to use for prompting.\n   * @param test - A function to validate the user's input.\n   * @param limit - The maximum number of attempts allowed (default is 1).\n   * @param defaultConfirmation\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant I as insist method\n   *   participant A as ask method\n   *   participant T as test function\n   *   participant C as askConfirmation method\n   *   loop Until valid input or limit reached\n   *     I->>A: Call ask with input\n   *     A->>U: Prompt user\n   *     U->>A: Provide input\n   *     A->>I: Return result\n   *     I->>T: Test result\n   *     alt Test passes\n   *       I->>C: Ask for confirmation\n   *       C->>U: Confirm input\n   *       U->>C: Provide confirmation\n   *       C->>I: Return confirmation\n   *       alt Confirmed\n   *         I-->>Caller: Return valid result\n   *       else Not confirmed\n   *         I->>I: Continue loop\n   *       end\n   *     else Test fails\n   *       I->>I: Continue loop\n   *     end\n   *   end\n   *   I-->>Caller: Return undefined if limit reached\n   */\n  static async insist<R>(\n    input: UserInput,\n    test: (res: string | number) => boolean,\n    defaultConfirmation: boolean,\n    limit = 1\n  ): Promise<R | undefined> {\n    const log = UserInput.logger.for(this.insist);\n    log.verbose(\n      `Insisting on input: ${input.name}, test: ${test.toString()}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    let result: string | number | undefined = undefined;\n    let count = 0;\n    let confirmation: boolean;\n    try {\n      do {\n        result = (await UserInput.ask(input))[\n          input.name as keyof Answers<string>\n        ] as string;\n        if (!test(result)) {\n          result = undefined;\n          continue;\n        }\n        confirmation = await UserInput.askConfirmation(\n          `${input.name}-confirm`,\n          `Is the ${input.type} correct?`,\n          defaultConfirmation\n        );\n        if (!confirmation) result = undefined;\n      } while (typeof result === \"undefined\" && limit > 1 && count++ < limit);\n    } catch (e: unknown) {\n      log.error(`Error while insisting: ${e}`);\n      throw e;\n    }\n\n    if (typeof result === \"undefined\") log.info(\"no selection...\");\n    return result as R | undefined;\n  }\n  /**\n   * @description Repeatedly asks for text input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid text input from the user, allowing for a specified number of attempts.\n   *\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param test - A function to validate the user's input.\n   * @param mask - The character used to mask the input (optional, for password-like inputs).\n   * @param initial - The initial value presented to the user (optional).\n   * @param defaultConfirmation\n   * @param limit - The maximum number of attempts allowed (default is -1, meaning unlimited).\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   */\n  static async insistForText(\n    name: string,\n    question: string,\n    test: (res: string) => boolean,\n    mask: string | undefined = undefined,\n    initial?: string,\n    defaultConfirmation = false,\n    limit = -1\n  ): Promise<string> {\n    const log = UserInput.logger.for(this.insistForText);\n    log.verbose(\n      `Insisting for text input: undefined, question: ${question}, test: ${test.toString()}, mask: ${mask}, initial: ${initial}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    const userInput = new UserInput(name).setMessage(question);\n\n    if (mask) userInput.setMask(mask);\n    if (typeof initial === \"string\") userInput.setInitial(initial);\n    return (await this.insist(\n      userInput,\n      test as (res: string | number) => boolean,\n      defaultConfirmation,\n      limit\n    )) as string;\n  }\n  /**\n   * @description Repeatedly asks for number input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid number input from the user, allowing for a specified number of attempts.\n   *\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param test - A function to validate the user's input.\n   * @param min - The minimum allowed value (optional).\n   * @param max - The maximum allowed value (optional).\n   * @param initial - The initial value presented to the user (optional).\n   * @param defaultConfirmation\n   * @param limit - The maximum number of attempts allowed (default is -1, meaning unlimited).\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   */\n  static async insistForNumber(\n    name: string,\n    question: string,\n    test: (res: number) => boolean,\n    min?: number,\n    max?: number,\n    initial?: number,\n    defaultConfirmation = false,\n    limit = -1\n  ): Promise<number> {\n    const log = UserInput.logger.for(this.insistForNumber);\n    log.verbose(\n      `Insisting for number input: undefined, question: ${question}, test: ${test.toString()}, min: ${min}, max: ${max}, initial: ${initial}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"number\");\n\n    if (typeof min === \"number\") userInput.setMin(min);\n\n    if (typeof max === \"number\") userInput.setMax(max);\n\n    if (typeof initial === \"number\") userInput.setInitial(initial);\n    return (await this.insist(\n      userInput,\n      test as (res: string | number) => boolean,\n      defaultConfirmation,\n      limit\n    )) as number;\n  }\n\n  /**\n   * @description Parses command-line arguments based on the provided options.\n   * @summary Uses Node.js's util.parseArgs to parse command-line arguments and return the result.\n   * @param options - Configuration options for parsing arguments.\n   * @return An object containing the parsed arguments.\n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Caller\n   *   participant P as parseArgs method\n   *   participant U as util.parseArgs\n   *   C->>P: Call with options\n   *   P->>P: Prepare args object\n   *   P->>U: Call parseArgs with prepared args\n   *   U->>P: Return parsed result\n   *   P-->>C: Return ParseArgsResult\n   */\n  static parseArgs(options: ParseArgsOptionsConfig): ParseArgsResult {\n    const log = UserInput.logger.for(this.parseArgs);\n    const args: ParseArgsConfig = {\n      args: process.argv.slice(2),\n      options: options,\n    };\n    log.debug(`Parsing arguments: ${JSON.stringify(args, null, 2)}`);\n    try {\n      return parseArgs(args);\n    } catch (error: unknown) {\n      log.debug(\n        `Error while parsing arguments:\\n${JSON.stringify(args, null, 2)}\\n | options\\n${JSON.stringify(options, null, 2)}\\n | ${error}`\n      );\n      throw new Error(`Error while parsing arguments: ${error}`);\n    }\n  }\n}\n","/**\n * @description Default command options for CLI commands.\n * @summary Defines the structure and default values for common command-line options used across various CLI commands.\n * @const DefaultCommandOptions\n * @typedef {Object} DefaultCommandOptions\n * @property {Object} verbose - Verbosity level option.\n * @property {string} verbose.type - The type of the verbose option (number).\n * @property {string} verbose.short - The short flag for the verbose option (V).\n * @property {number} verbose.default - The default value for verbosity (0).\n * @property {Object} version - Version display option.\n * @property {string} version.type - The type of the version option (boolean).\n * @property {string} version.short - The short flag for the version option (v).\n * @property {undefined} version.default - The default value for version display (undefined).\n * @property {Object} help - Help display option.\n * @property {string} help.type - The type of the help option (boolean).\n * @property {string} help.short - The short flag for the help option (h).\n * @property {boolean} help.default - The default value for help display (false).\n * @property {Object} logLevel - Log level option.\n * @property {string} logLevel.type - The type of the logLevel option (string).\n * @property {string} logLevel.default - The default value for log level (\"info\").\n * @property {Object} logStyle - Log styling option.\n * @property {string} logStyle.type - The type of the logStyle option (boolean).\n * @property {boolean} logStyle.default - The default value for log styling (true).\n * @property {Object} timestamp - Timestamp display option.\n * @property {string} timestamp.type - The type of the timestamp option (boolean).\n * @property {boolean} timestamp.default - The default value for timestamp display (true).\n * @property {Object} banner - Banner display option.\n * @property {string} banner.type - The type of the banner option (boolean).\n * @property {boolean} banner.default - The default value for banner display (false).\n */\nexport const DefaultCommandOptions = {\n  verbose: {\n    type: \"boolean\",\n    short: \"V\",\n    default: undefined,\n  },\n  version: {\n    type: \"boolean\",\n    short: \"v\",\n    default: undefined,\n  },\n  help: {\n    type: \"boolean\",\n    short: \"h\",\n    default: false,\n  },\n  logLevel: {\n    type: \"string\",\n    default: \"info\",\n  },\n  logStyle: {\n    type: \"boolean\",\n    default: true,\n  },\n  timestamp: {\n    type: \"boolean\",\n    default: true,\n  },\n  banner: {\n    type: \"boolean\",\n    default: true,\n  },\n};\n\n/**\n * @description Default command values derived from DefaultCommandOptions.\n * @summary Creates an object with the default values of all options defined in DefaultCommandOptions.\n * @const DefaultCommandValues\n * @typedef {Object} DefaultCommandValues\n * @property {unknown} [key: string] - The default value for each option in DefaultCommandOptions.\n */\nexport const DefaultCommandValues: {\n  [k in keyof typeof DefaultCommandOptions]: unknown;\n} = Object.keys(DefaultCommandOptions).reduce(\n  (acc: Record<keyof typeof DefaultCommandOptions, unknown>, key: string) => {\n    acc[key as keyof typeof DefaultCommandOptions] =\n      DefaultCommandOptions[key as keyof typeof DefaultCommandOptions].default;\n    return acc;\n  },\n  {} as Record<keyof typeof DefaultCommandValues, unknown>\n);\n","/**\n * @description Pads the end of a string with a specified character.\n * @summary Extends the input string to a specified length by adding a padding character to the end.\n * If the input string is already longer than the specified length, it is returned unchanged.\n *\n * @param {string} str - The input string to be padded.\n * @param {number} length - The desired total length of the resulting string.\n * @param {string} [char=\" \"] - The character to use for padding. Defaults to a space.\n * @return {string} The padded string.\n * @throws {Error} If the padding character is not exactly one character long.\n *\n * @function padEnd\n *\n * @memberOf module:TextUtils\n */\nexport function padEnd(\n  str: string,\n  length: number,\n  char: string = \" \"\n): string {\n  if (char.length !== 1)\n    throw new Error(\"Invalid character length for padding. must be one!\");\n  return str.padEnd(length, char);\n}\n\n/**\n * @description Replaces placeholders in a string with provided values.\n * @summary Interpolates a string by replacing placeholders of the form ${variableName}\n * with corresponding values from the provided object. If a placeholder doesn't have\n * a corresponding value, it is left unchanged in the string.\n *\n * @param {string} input - The input string containing placeholders to be replaced.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @return {string} The interpolated string with placeholders replaced by their corresponding values.\n *\n * @function patchPlaceholders\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchString\n *   participant String.replace\n *   Caller->>patchString: Call with input and values\n *   patchString->>String.replace: Call with regex and replacement function\n *   String.replace->>patchString: Return replaced string\n *   patchString-->>Caller: Return patched string\n *\n * @memberOf module:TextUtils\n */\nexport function patchPlaceholders(\n  input: string,\n  values: Record<string, number | string>\n): string {\n  return input.replace(\n    /\\$\\{([a-zA-Z0-9_]+)\\}/g,\n    (match, variable) => (values[variable as string] as string) || match\n  );\n}\n\nexport function patchString(\n  input: string,\n  values: Record<string, number | string>,\n  flags: string = \"g\"\n): string {\n  Object.entries(values).forEach(([key, val]) => {\n    const regexp = new RegExp(escapeRegExp(key), flags);\n    input = input.replace(regexp, val as string);\n  });\n  return input;\n}\n\n/**\n * @description Converts a string to camelCase.\n * @summary Transforms the input string into camelCase format, where words are joined without spaces\n * and each word after the first starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to camelCase.\n *\n * @function toCamelCase\n *\n * @memberOf module:TextUtils\n */\nexport function toCamelCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word, index) =>\n      index === 0 ? word.toLowerCase() : word.toUpperCase()\n    )\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Converts a string to ENVIRONMENT_VARIABLE format.\n * @summary Transforms the input string into uppercase with words separated by underscores,\n * typically used for environment variable names.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.\n *\n * @function toENVFormat\n *\n * @memberOf module:TextUtils\n */\nexport function toENVFormat(text: string): string {\n  return toSnakeCase(text).toUpperCase();\n}\n\n/**\n * @description Converts a string to snake_case.\n * @summary Transforms the input string into lowercase with words separated by underscores.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to snake_case.\n *\n * @function toSnakeCase\n *\n * @memberOf module:TextUtils\n */\nexport function toSnakeCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1_$2\")\n    .replace(/[\\s-]+/g, \"_\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to kebab-case.\n * @summary Transforms the input string into lowercase with words separated by hyphens.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to kebab-case.\n *\n * @function toKebabCase\n *\n * @memberOf module:TextUtils\n */\nexport function toKebabCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n    .replace(/[\\s_]+/g, \"-\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to PascalCase.\n * @summary Transforms the input string into PascalCase format, where words are joined without spaces\n * and each word starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to PascalCase.\n *\n * @function toPascalCase\n *\n * @memberOf module:TextUtils\n */\nexport function toPascalCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word) => word.toUpperCase())\n    .replace(/\\s+/g, \"\");\n}\n\nexport function escapeRegExp(string: string) {\n  return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"); // $& means the whole matched string\n}\n","import { Encoding } from \"../utils/constants\";\nimport { OutputWriter } from \"./OutputWriter\";\nimport { PromiseExecutor } from \"../utils/types\";\nimport { OutputType } from \"./types\";\nimport { Logging } from \"../output/logging\";\nimport { VerbosityLogger } from \"../output/types\";\nimport { style } from \"styled-string-builder\";\n\n/**\n * @description A standard output writer for handling command execution output.\n * @summary This class implements the OutputWriter interface and provides methods for\n * handling various types of output from command execution, including standard output,\n * error output, and exit codes. It also includes utility methods for parsing commands\n * and resolving or rejecting promises based on execution results.\n *\n * @template R - The type of the resolved value, defaulting to number.\n *\n * @param lock - A PromiseExecutor to control the asynchronous flow.\n * @param args - Additional arguments (unused in the current implementation).\n *\n * @class\n */\nexport class StandardOutputWriter<R = string> implements OutputWriter {\n  protected logger: VerbosityLogger;\n\n  /**\n   * @description Initializes a new instance of StandardOutputWriter.\n   * @summary Constructs the StandardOutputWriter with a lock mechanism and optional arguments.\n   *\n   * @param cmd\n   * @param lock - A PromiseExecutor to control the asynchronous flow.\n   * @param args - Additional arguments (currently unused).\n   */\n  constructor(\n    protected cmd: string,\n    protected lock: PromiseExecutor<R>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: unknown[]\n  ) {\n    this.logger = Logging.for(this.cmd);\n  }\n\n  /**\n   * @description Logs output to the console.\n   * @summary Formats and logs the given data with a timestamp and type indicator.\n   *\n   * @param type - The type of output (stdout or stderr).\n   * @param data - The data to be logged.\n   */\n  protected log(type: OutputType, data: string | Buffer) {\n    data = Buffer.isBuffer(data) ? data.toString(Encoding) : data;\n    const log = type === \"stderr\" ? style(data).red.text : data;\n    this.logger.info(log);\n  }\n\n  /**\n   * @description Handles standard output data.\n   * @summary Logs the given chunk as standard output.\n   *\n   * @param chunk - The data chunk to be logged.\n   */\n  data(chunk: any) {\n    this.log(\"stdout\", String(chunk));\n  }\n\n  /**\n   * @description Handles error output data.\n   * @summary Logs the given chunk as error output.\n   *\n   * @param chunk - The error data chunk to be logged.\n   */\n  error(chunk: any) {\n    this.log(\"stderr\", String(chunk));\n  }\n\n  /**\n   * @description Handles error objects.\n   * @summary Logs the error message from the given Error object.\n   *\n   * @param err - The Error object to be logged.\n   */\n  errors(err: Error) {\n    this.log(\"stderr\", `Error executing command exited : ${err}`);\n  }\n\n  /**\n   * @description Handles the exit of a command.\n   * @summary Logs the exit code and resolves or rejects the promise based on the code.\n   *\n   * @param code - The exit code of the command.\n   * @param logs\n   */\n  exit(code: number | string, logs: string[]) {\n    this.log(\n      \"stdout\",\n      `command exited code : ${code === 0 ? style(code.toString()).green.text : style(code === null ? \"null\" : code.toString()).red.text}`\n    );\n    if (code === 0) {\n      this.resolve(logs.map((l) => l.trim()).join(\"\\n\") as R);\n    } else {\n      this.reject(new Error(logs.length ? logs.join(\"\\n\") : code.toString()));\n    }\n  }\n\n  /**\n   * @description Parses a command string or array into components.\n   * @summary Converts the command into a consistent format and stores it, then returns it split into command and arguments.\n   *\n   * @param command - The command as a string or array of strings.\n   * @return A tuple containing the command and its arguments as separate elements.\n   */\n  parseCommand(command: string | string[]): [string, string[]] {\n    command = typeof command === \"string\" ? command.split(\" \") : command;\n    this.cmd = command.join(\" \");\n    return [command[0], command.slice(1)];\n  }\n\n  /**\n   * @description Resolves the promise with a success message.\n   * @summary Logs a success message and resolves the promise with the given reason.\n   *\n   * @param reason - The reason for resolving the promise.\n   */\n  protected resolve(reason: R) {\n    this.log(\n      \"stdout\",\n      `${this.cmd} executed successfully: ${style(reason ? \"ran to completion\" : (reason as string)).green}`\n    );\n    this.lock.resolve(reason);\n  }\n\n  /**\n   * @description Rejects the promise with an error message.\n   * @summary Logs an error message and rejects the promise with the given reason.\n   *\n   * @param reason - The reason for rejecting the promise, either a number (exit code) or a string.\n   */\n  protected reject(reason: number | string | Error) {\n    if (!(reason instanceof Error)) {\n      reason = new Error(\n        typeof reason === \"number\" ? `Exit code ${reason}` : reason\n      );\n    }\n    this.log(\n      \"stderr\",\n      `${this.cmd} failed to execute: ${style(reason.message).red}`\n    );\n    this.lock.reject(reason);\n  }\n}\n","import {\n  ChildProcessWithoutNullStreams,\n  spawn,\n  SpawnOptionsWithoutStdio,\n} from \"child_process\";\nimport { StandardOutputWriter } from \"../writers/StandardOutputWriter\";\nimport { CommandResult } from \"./types\";\nimport { Logging } from \"../output/logging\";\nimport { OutputWriterConstructor } from \"../writers/types\";\nimport { VerbosityLogger } from \"../output/types\";\nimport { AbortCode } from \"./constants\";\n\n/**\n * @description Creates a locked version of a function.\n * @summary This higher-order function takes a function and returns a new function that ensures\n * sequential execution of the original function, even when called multiple times concurrently.\n * It uses a Promise-based locking mechanism to queue function calls.\n *\n * @template R - The return type of the input function.\n *\n * @param f - The function to be locked. It can take any number of parameters and return a value of type R.\n * @return A new function with the same signature as the input function, but with sequential execution guaranteed.\n *\n * @function lockify\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant LockedFunction\n *   participant OriginalFunction\n *   Caller->>LockedFunction: Call with params\n *   LockedFunction->>LockedFunction: Check current lock\n *   alt Lock is resolved\n *     LockedFunction->>OriginalFunction: Execute with params\n *     OriginalFunction-->>LockedFunction: Return result\n *     LockedFunction-->>Caller: Return result\n *   else Lock is pending\n *     LockedFunction->>LockedFunction: Queue execution\n *     LockedFunction-->>Caller: Return promise\n *     Note over LockedFunction: Wait for previous execution\n *     LockedFunction->>OriginalFunction: Execute with params\n *     OriginalFunction-->>LockedFunction: Return result\n *     LockedFunction-->>Caller: Resolve promise with result\n *   end\n *   LockedFunction->>LockedFunction: Update lock\n *\n * @memberOf @decaf-ts/utils\n */\nexport function lockify<R>(f: (...params: unknown[]) => R) {\n  let lock: Promise<R | void> = Promise.resolve();\n  return (...params: unknown[]) => {\n    const result = lock.then(() => f(...params));\n    lock = result.catch(() => {});\n    return result;\n  };\n}\n\nexport function chainAbortController(\n  controller: AbortController,\n  ...signals: AbortSignal[]\n): AbortController;\nexport function chainAbortController(\n  ...signals: AbortSignal[]\n): AbortController;\nexport function chainAbortController(\n  argument0: AbortController | AbortSignal,\n  ...remainder: AbortSignal[]\n): AbortController {\n  let signals: AbortSignal[];\n  let controller: AbortController;\n\n  // normalize args\n  if (argument0 instanceof AbortSignal) {\n    controller = new AbortController();\n    signals = [argument0, ...remainder];\n  } else {\n    controller = argument0;\n    signals = remainder;\n  }\n\n  // if the controller is already aborted, exit early\n  if (controller.signal.aborted) {\n    return controller;\n  }\n\n  const handler = () => controller.abort();\n\n  for (const signal of signals) {\n    // check before adding! (and assume there is no possible way that the signal could\n    // abort between the `if` check and adding the event listener)\n    if (signal.aborted) {\n      controller.abort();\n      break;\n    }\n    signal.addEventListener(\"abort\", handler, {\n      once: true,\n      signal: controller.signal,\n    });\n  }\n\n  return controller;\n}\n\nexport function spawnCommand<R = string>(\n  output: StandardOutputWriter<R>,\n  command: string,\n  opts: SpawnOptionsWithoutStdio,\n  abort: AbortController,\n  logger: VerbosityLogger\n): ChildProcessWithoutNullStreams {\n  function spawnInner(command: string, controller: AbortController) {\n    const [cmd, argz] = output.parseCommand(command);\n    logger.info(`Running command: ${cmd}`);\n    logger.debug(`with args: ${argz.join(\" \")}`);\n    const childProcess = spawn(cmd, argz, {\n      ...opts,\n      cwd: opts.cwd || process.cwd(),\n      env: Object.assign({}, process.env, opts.env, { PATH: process.env.PATH }),\n      shell: opts.shell || false,\n      signal: controller.signal,\n    });\n    logger.verbose(`pid : ${childProcess.pid}`);\n    return childProcess;\n  }\n\n  const m = command.match(/[<>$#]/g);\n  if (m)\n    throw new Error(\n      `Invalid command: ${command}. contains invalid characters: ${m}`\n    );\n  if (command.includes(\" | \")) {\n    const cmds = command.split(\" | \");\n    const spawns = [];\n    const controllers = new Array(cmds.length);\n    controllers[0] = abort;\n    for (let i = 0; i < cmds.length; i++) {\n      if (i !== 0)\n        controllers[i] = chainAbortController(controllers[i - 1].signal);\n      spawns.push(spawnInner(cmds[i], controllers[i]));\n      if (i === 0) continue;\n      spawns[i - 1].stdout.pipe(spawns[i].stdin);\n    }\n    return spawns[cmds.length - 1];\n  }\n\n  return spawnInner(command, abort);\n}\n\n/**\n * @description Executes a command asynchronously with customizable output handling.\n * @summary This function runs a shell command as a child process, providing fine-grained\n * control over its execution and output handling. It supports custom output writers,\n * allows for command abortion, and captures both stdout and stderr.\n *\n * @template R - The type of the resolved value from the command execution.\n *\n * @param command - The command to run, either as a string or an array of strings.\n * @param opts - Spawn options for the child process. Defaults to an empty object.\n * @param outputConstructor - Constructor for the output writer. Defaults to StandardOutputWriter.\n * @param args - Additional arguments to pass to the output constructor.\n * @return {CommandResult} A promise that resolves to the command result of type R.\n *\n * @function runCommand\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant runCommand\n *   participant OutputWriter\n *   participant ChildProcess\n *   Caller->>runCommand: Call with command and options\n *   runCommand->>OutputWriter: Create new instance\n *   runCommand->>OutputWriter: Parse command\n *   runCommand->>ChildProcess: Spawn process\n *   ChildProcess-->>runCommand: Return process object\n *   runCommand->>ChildProcess: Set up event listeners\n *   loop For each stdout data\n *     ChildProcess->>runCommand: Emit stdout data\n *     runCommand->>OutputWriter: Handle stdout data\n *   end\n *   loop For each stderr data\n *     ChildProcess->>runCommand: Emit stderr data\n *     runCommand->>OutputWriter: Handle stderr data\n *   end\n *   ChildProcess->>runCommand: Emit error (if any)\n *   runCommand->>OutputWriter: Handle error\n *   ChildProcess->>runCommand: Emit exit\n *   runCommand->>OutputWriter: Handle exit\n *   OutputWriter-->>runCommand: Resolve or reject promise\n *   runCommand-->>Caller: Return CommandResult\n *\n * @memberOf @decaf-ts/utils\n */\nexport function runCommand<R = string>(\n  command: string,\n  opts: SpawnOptionsWithoutStdio = {},\n  outputConstructor: OutputWriterConstructor<\n    R,\n    StandardOutputWriter<R>,\n    Error\n  > = StandardOutputWriter<R>,\n  ...args: unknown[]\n): CommandResult<R> {\n  const logger = Logging.for(runCommand);\n  const abort = new AbortController();\n\n  const result: Omit<CommandResult, \"promise\" | \"pipe\"> = {\n    abort: abort,\n    command: command,\n    logs: [],\n    errs: [],\n  };\n\n  const lock = new Promise<R>((resolve, reject) => {\n    let output;\n    try {\n      output = new outputConstructor(\n        command,\n        {\n          resolve,\n          reject,\n        },\n        ...args\n      );\n\n      result.cmd = spawnCommand<R>(output, command, opts, abort, logger);\n    } catch (e: unknown) {\n      return reject(new Error(`Error running command ${command}: ${e}`));\n    }\n\n    result.cmd.stdout.setEncoding(\"utf8\");\n\n    result.cmd.stdout.on(\"data\", (chunk: any) => {\n      chunk = chunk.toString();\n      result.logs.push(chunk);\n      output.data(chunk);\n    });\n\n    result.cmd.stderr.on(\"data\", (data: any) => {\n      data = data.toString();\n      result.errs.push(data);\n      output.error(data);\n    });\n\n    result.cmd.once(\"error\", (err: Error) => {\n      output.exit(err.message, result.errs);\n    });\n\n    result.cmd.once(\"exit\", (code: number = 0) => {\n      if (abort.signal.aborted && code === null) code = AbortCode as any;\n      output.exit(code, code === 0 ? result.logs : result.errs);\n    });\n  });\n\n  Object.assign(result, {\n    promise: lock,\n    pipe: async <E>(cb: (r: R) => E) => {\n      const l = logger.for(\"pipe\");\n      try {\n        l.verbose(`Executing pipe function ${command}...`);\n        const result: R = await lock;\n        l.verbose(`Piping output to ${cb.name}: ${result}`);\n        return cb(result);\n      } catch (e: unknown) {\n        l.error(`Error piping command output: ${e}`);\n        throw e;\n      }\n    },\n  });\n\n  return result as CommandResult<R>;\n}\n","import fs from \"fs\";\nimport path from \"path\";\nimport { Logging } from \"../output/logging\";\nimport { patchString } from \"./text\";\nimport { runCommand } from \"./utils\";\nimport { DependencyMap, SimpleDependencyMap } from \"./types\";\n\nconst logger = Logging.for(\"fs\");\n\n/**\n * @description Patches a file with given values.\n * @summary Reads a file, applies patches using TextUtils, and writes the result back to the file.\n *\n * @param {string} path - The path to the file to be patched.\n * @param {Record<string, number | string>} values - The values to patch into the file.\n * @return {void}\n *\n * @function patchFile\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchFile\n *   participant fs\n *   participant readFile\n *   participant TextUtils\n *   participant writeFile\n *   Caller->>patchFile: Call with path and values\n *   patchFile->>fs: Check if file exists\n *   patchFile->>readFile: Read file content\n *   readFile->>fs: Read file\n *   fs-->>readFile: Return file content\n *   readFile-->>patchFile: Return file content\n *   patchFile->>TextUtils: Patch string\n *   TextUtils-->>patchFile: Return patched content\n *   patchFile->>writeFile: Write patched content\n *   writeFile->>fs: Write to file\n *   fs-->>writeFile: File written\n *   writeFile-->>patchFile: File written\n *   patchFile-->>Caller: Patching complete\n *\n * @memberOf module:fs-utils\n */\nexport function patchFile(\n  path: string,\n  values: Record<string, number | string>\n) {\n  const log = logger.for(patchFile);\n  if (!fs.existsSync(path))\n    throw new Error(`File not found at path \"${path}\".`);\n  let content = readFile(path);\n\n  try {\n    log.verbose(`Patching file \"${path}\"...`);\n    log.debug(`with value: ${JSON.stringify(values)}`);\n    content = patchString(content, values);\n  } catch (error: unknown) {\n    throw new Error(`Error patching file: ${error}`);\n  }\n  writeFile(path, content);\n}\n\n/**\n * @description Reads a file and returns its content.\n * @summary Reads the content of a file at the specified path and returns it as a string.\n *\n * @param {string} path - The path to the file to be read.\n * @return {string} The content of the file.\n *\n * @function readFile\n *\n * @memberOf module:utils\n */\nexport function readFile(path: string): string {\n  const log = logger.for(readFile);\n  try {\n    log.verbose(`Reading file \"${path}\"...`);\n    return fs.readFileSync(path, \"utf8\");\n  } catch (error: unknown) {\n    log.verbose(`Error reading file \"${path}\": ${error}`);\n    throw new Error(`Error reading file \"${path}\": ${error}`);\n  }\n}\n\n/**\n * @description Writes data to a file.\n * @summary Writes the provided data to a file at the specified path.\n *\n * @param {string} path - The path to the file to be written.\n * @param {string | Buffer} data - The data to be written to the file.\n * @return {void}\n *\n * @function writeFile\n *\n * @memberOf module:utils\n */\nexport function writeFile(path: string, data: string | Buffer): void {\n  const log = logger.for(writeFile);\n  try {\n    log.verbose(`Writing file \"${path} with ${data.length} bytes...`);\n    fs.writeFileSync(path, data, \"utf8\");\n  } catch (error: unknown) {\n    log.verbose(`Error writing file \"${path}\": ${error}`);\n    throw new Error(`Error writing file \"${path}\": ${error}`);\n  }\n}\n\n/**\n * @description Retrieves all files recursively from a directory.\n * @summary Traverses through directories and subdirectories to collect all file paths.\n *\n * @param {string} p - The path to start searching from.\n * @param filter\n * @return {string[]} Array of file paths.\n *\n * @function getAllFiles\n *\n * @memberOf module:fs-utils\n */\nexport function getAllFiles(\n  p: string,\n  filter?: (f: string, i?: number) => boolean\n): string[] {\n  const log = logger.for(getAllFiles);\n  const files: string[] = [];\n\n  try {\n    log.verbose(`Retrieving all files from \"${p}\"...`);\n    const entries = fs.readdirSync(p);\n\n    entries.forEach((entry) => {\n      const fullPath = path.join(p, entry);\n      const stat = fs.statSync(fullPath);\n\n      if (stat.isFile()) {\n        files.push(fullPath);\n      } else if (stat.isDirectory()) {\n        files.push(...getAllFiles(fullPath));\n      }\n    });\n    if (!filter) return files;\n    return files.filter(filter);\n  } catch (error: unknown) {\n    log.verbose(`Error retrieving files from \"${p}\": ${error}`);\n    throw new Error(`Error retrieving files from \"${p}\": ${error}`);\n  }\n}\n\nexport async function renameFile(source: string, dest: string) {\n  const log = logger.for(renameFile);\n  let descriptorSource, descriptorDest;\n\n  try {\n    descriptorSource = fs.statSync(source);\n  } catch (error: unknown) {\n    log.verbose(`Source path \"${source}\" does not exist: ${error}`);\n    throw new Error(`Source path \"${source}\" does not exist: ${error}`);\n  }\n\n  try {\n    descriptorDest = fs.statSync(dest);\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    // do nothing. its ok\n  }\n  if (descriptorDest) {\n    log.verbose(`Destination path \"${dest}\" already exists`);\n    throw new Error(`Destination path \"${dest}\" already exists`);\n  }\n\n  try {\n    log.verbose(\n      `Renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}...`\n    );\n    fs.renameSync(source, dest);\n    log.verbose(`Successfully renamed to \"${dest}\"`);\n  } catch (error: unknown) {\n    log.verbose(\n      `Error renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}\": ${error}`\n    );\n    throw new Error(\n      `Error renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}\": ${error}`\n    );\n  }\n}\n\nexport function copyFile(source: string, dest: string) {\n  const log = logger.for(copyFile);\n  let descriptorSource, descriptorDest;\n  try {\n    descriptorSource = fs.statSync(source);\n  } catch (error: unknown) {\n    log.verbose(`Source path \"${source}\" does not exist: ${error}`);\n    throw new Error(`Source path \"${source}\" does not exist: ${error}`);\n  }\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptorDest = fs.statSync(dest);\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (error: unknown) {\n    if (descriptorSource.isDirectory()) {\n      log.verbose(`Dest path \"${dest}\" does not exist. creating`);\n      fs.mkdirSync(dest, { recursive: true });\n    }\n  }\n\n  try {\n    log.verbose(\n      `Copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}...`\n    );\n    fs.cpSync(source, dest, { recursive: true });\n  } catch (error: unknown) {\n    log.verbose(\n      `Error copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}: ${error}`\n    );\n    throw new Error(\n      `Error copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}: ${error}`\n    );\n  }\n}\n\nexport function deletePath(p: string) {\n  const log = logger.for(deletePath);\n  try {\n    const descriptor = fs.statSync(p);\n    if (descriptor.isFile()) {\n      log.verbose(`Deleting file \"${p}...`);\n      fs.rmSync(p, { recursive: true, force: true });\n    } else if (descriptor.isDirectory())\n      fs.rmSync(p, { recursive: true, force: true });\n  } catch (error: unknown) {\n    log.verbose(`Error Deleting \"${p}\": ${error}`);\n    throw new Error(`Error Deleting \"${p}\": ${error}`);\n  }\n}\n\n/**\n * @description Retrieves package information from package.json.\n * @summary Loads and parses the package.json file from a specified directory or the current working directory. Can return the entire package object or a specific property.\n * @param {string} [p=process.cwd()] - The directory path where the package.json file is located.\n * @param {string} [property] - Optional. The specific property to retrieve from package.json.\n * @return {object | string} The parsed contents of package.json or the value of the specified property.\n * @function getPackage\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant getPackage\n *   participant readFile\n *   participant JSON\n *   Caller->>getPackage: Call with path and optional property\n *   getPackage->>readFile: Read package.json\n *   readFile-->>getPackage: Return file content\n *   getPackage->>JSON: Parse file content\n *   JSON-->>getPackage: Return parsed object\n *   alt property specified\n *     getPackage->>getPackage: Check if property exists\n *     alt property exists\n *       getPackage-->>Caller: Return property value\n *     else property doesn't exist\n *       getPackage-->>Caller: Throw Error\n *     end\n *   else no property specified\n *     getPackage-->>Caller: Return entire package object\n *   end\n * @memberOf module:utils\n */\nexport function getPackage(\n  p: string = process.cwd(),\n  property?: string\n): object | string {\n  let pkg: any;\n  try {\n    pkg = JSON.parse(readFile(path.join(p, `package.json`)));\n  } catch (error: unknown) {\n    throw new Error(`Failed to retrieve package information\" ${error}`);\n  }\n\n  if (property) {\n    if (!(property in pkg))\n      throw new Error(`Property \"${property}\" not found in package.json`);\n    return pkg[property] as string;\n  }\n  return pkg;\n}\n\nexport function setPackageAttribute(\n  attr: string,\n  value: string,\n  p: string = process.cwd()\n): void {\n  const pkg = getPackage(p) as Record<string, any>;\n  pkg[attr] = value;\n  writeFile(path.join(p, `package.json`), JSON.stringify(pkg, null, 2));\n}\n\n/**\n * @description Retrieves the version from package.json.\n * @summary A convenience function that calls getPackage to retrieve the \"version\" property from package.json.\n * @param {string} [p=process.cwd()] - The directory path where the package.json file is located.\n * @return {string} The version string from package.json.\n * @function getPackageVersion\n * @memberOf module:fs-utils\n */\nexport function getPackageVersion(p = process.cwd()): string {\n  return getPackage(p, \"version\") as string;\n}\n\n/**\n * @description Retrieves all dependencies from the project.\n * @summary Executes 'npm ls --json' command to get a detailed list of all dependencies (production, development, and peer) and their versions.\n * @param {string} [path=process.cwd()] - The directory path of the project.\n * @return {Promise<{prod: Array<{name: string, version: string}>, dev: Array<{name: string, version: string}>, peer: Array<{name: string, version: string}>}>} An object containing arrays of production, development, and peer dependencies.\n * @function getDependencies\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant getDependencies\n *   participant runCommand\n *   participant JSON\n *   Caller->>getDependencies: Call with optional path\n *   getDependencies->>runCommand: Execute 'npm ls --json'\n *   runCommand-->>getDependencies: Return command output\n *   getDependencies->>JSON: Parse command output\n *   JSON-->>getDependencies: Return parsed object\n *   getDependencies->>getDependencies: Process dependencies\n *   getDependencies-->>Caller: Return processed dependencies\n * @memberOf module:fs-utils\n */\nexport async function getDependencies(\n  path: string = process.cwd()\n): Promise<DependencyMap> {\n  let pkg: any;\n\n  try {\n    pkg = JSON.parse(await runCommand(`npm ls --json`, { cwd: path }).promise);\n  } catch (e: unknown) {\n    throw new Error(`Failed to retrieve dependencies: ${e}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  const mapper = (entry: [string, unknown], index: number) => ({\n    name: entry[0],\n    version: (entry[1] as any).version,\n  });\n\n  return {\n    prod: Object.entries(pkg.dependencies || {}).map(mapper),\n    dev: Object.entries(pkg.devDependencies || {}).map(mapper),\n    peer: Object.entries(pkg.peerDependencies || {}).map(mapper),\n  };\n}\n\nexport async function updateDependencies() {\n  const log = logger.for(updateDependencies);\n  log.info(\"checking for updates...\");\n  await runCommand(\"npx npm-check-updates -u\").promise;\n  log.info(\"updating...\");\n  await runCommand(\"npx npm run do-install\").promise;\n}\n\nexport async function installIfNotAvailable(\n  deps: string[] | string,\n  dependencies?: SimpleDependencyMap\n) {\n  if (!dependencies) {\n    const d: DependencyMap = await getDependencies();\n    dependencies = {\n      prod: d.prod?.map((p) => p.name) || [],\n      dev: d.dev?.map((d) => d.name) || [],\n      peer: d.peer?.map((p) => p.name) || [],\n    };\n  }\n  const { prod, dev, peer } = dependencies;\n  const installed = Array.from(\n    new Set([...(prod || []), ...(dev || []), ...(peer || [])])\n  );\n  deps = typeof deps === \"string\" ? [deps] : deps;\n  const toInstall = deps.filter((d) => !installed.includes(d));\n\n  if (toInstall.length) await installDependencies({ dev: toInstall });\n  dependencies.dev = dependencies.dev || [];\n  dependencies.dev.push(...toInstall);\n  return dependencies;\n}\n\nexport async function pushToGit() {\n  const log = logger.for(pushToGit);\n  const gitUser = await runCommand(\"git config user.name\").promise;\n  const gitEmail = await runCommand(\"git config user.email\").promise;\n  log.verbose(`cached git id: ${gitUser}/${gitEmail}. changing to automation`);\n  await runCommand('git config user.email \"automation@decaf.ts\"').promise;\n  await runCommand('git config user.name \"decaf\"').promise;\n  log.info(\"Pushing changes to git...\");\n  await runCommand(\"git add .\").promise;\n  await runCommand(`git commit -m \"refs #1 - after repo setup\"`).promise;\n  await runCommand(\"git push\").promise;\n  await runCommand(`git config user.email \"${gitEmail}\"`).promise;\n  await runCommand(`git config user.name \"${gitUser}\"`).promise;\n  log.verbose(`reverted to git id: ${gitUser}/${gitEmail}`);\n}\n\nexport async function installDependencies(dependencies: {\n  prod?: string[];\n  dev?: string[];\n  peer?: string[];\n}) {\n  const log = logger.for(installDependencies);\n  const prod = dependencies.prod || [];\n  const dev = dependencies.dev || [];\n  const peer = dependencies.peer || [];\n  if (prod.length) {\n    log.info(`Installing dependencies ${prod.join(\", \")}...`);\n    await runCommand(`npm install ${prod.join(\" \")}`, { cwd: process.cwd() })\n      .promise;\n  }\n  if (dev.length) {\n    log.info(`Installing devDependencies ${dev.join(\", \")}...`);\n    await runCommand(`npm install --save-dev ${dev.join(\" \")}`, {\n      cwd: process.cwd(),\n    }).promise;\n  }\n  if (peer.length) {\n    log.info(`Installing peerDependencies ${peer.join(\", \")}...`);\n    await runCommand(`npm install --save-peer ${peer.join(\" \")}`, {\n      cwd: process.cwd(),\n    }).promise;\n  }\n}\n\nexport async function normalizeImport<T>(\n  importPromise: Promise<T>\n): Promise<T> {\n  // CommonJS's `module.exports` is wrapped as `default` in ESModule.\n  return importPromise.then((m: any) => (m.default || m) as T);\n}\n","import { VerbosityLogger } from \"./types\";\nimport slogans from \"../assets/slogans.json\";\nimport { style } from \"styled-string-builder\";\n\n/**\n * @description Array of ANSI color codes for banner styling.\n * @summary Defines a set of ANSI color codes used to style the banner text.\n */\nconst colors = [\n  \"\\x1b[38;5;215m\", // soft orange\n  \"\\x1b[38;5;209m\", // coral\n  \"\\x1b[38;5;205m\", // pink\n  \"\\x1b[38;5;210m\", // peachy\n  \"\\x1b[38;5;217m\", // salmon\n  \"\\x1b[38;5;216m\", // light coral\n  \"\\x1b[38;5;224m\", // light peach\n  \"\\x1b[38;5;230m\", // soft cream\n  \"\\x1b[38;5;230m\", // soft cream\n];\n\n/**\n * @description Prints a styled banner to the console.\n * @summary Generates and prints a colorful ASCII art banner with a random slogan.\n * @param {VerbosityLogger} [logger] - Optional logger for verbose output.\n * @function printBanner\n * @mermaid\n * sequenceDiagram\n *   participant printBanner\n *   participant getSlogan\n *   participant padEnd\n *   participant console\n *   printBanner->>getSlogan: Call getSlogan()\n *   getSlogan-->>printBanner: Return random slogan\n *   printBanner->>printBanner: Create banner ASCII art\n *   printBanner->>printBanner: Split banner into lines\n *   printBanner->>printBanner: Calculate max line length\n *   printBanner->>padEnd: Call padEnd with slogan\n *   padEnd-->>printBanner: Return padded slogan line\n *   loop For each banner line\n *     printBanner->>style: Call style(line)\n *     style-->>printBanner: Return styled line\n *     printBanner->>console: Log styled line\n *   end\n */\nexport function printBanner(logger?: VerbosityLogger) {\n  const message = getSlogan();\n  const banner: string | string[] =\n    `#                 ░▒▓███████▓▒░  ░▒▓████████▓▒░  ░▒▓██████▓▒░   ░▒▓██████▓▒░  ░▒▓████████▓▒░       ░▒▓████████▓▒░  ░▒▓███████▓▒░ \n#      ( (        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓█▓▒░        \n#       ) )       ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓█▓▒░        \n#    [=======]    ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓██████▓▒░   ░▒▓█▓▒░        ░▒▓████████▓▒░ ░▒▓██████▓▒░            ░▒▓█▓▒░      ░▒▓██████▓▒░  \n#     \\`-----´     ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░            ░▒▓█▓▒░ \n#                 ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░            ░▒▓█▓▒░ \n#                 ░▒▓███████▓▒░  ░▒▓████████▓▒░  ░▒▓██████▓▒░  ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓███████▓▒░  \n#`.split(\"\\n\");\n  const maxLength = banner.reduce((max, line) => Math.max(max, line.length), 0);\n  banner.push(`#  ${message.padStart(maxLength - 3)}`);\n  banner.forEach((line, index) => {\n    (logger ? logger.info.bind(logger) : console.log.bind(console))(\n      style(line || \"\").raw(colors[index]).text\n    );\n  });\n}\n\n/**\n * @description Retrieves a slogan from the predefined list.\n * @summary Fetches a random slogan or a specific one by index from the slogans list.\n * @param {number} [i] - Optional index to retrieve a specific slogan.\n * @return {string} The selected slogan.\n * @function getSlogan\n * @mermaid\n * sequenceDiagram\n *   participant getSlogan\n *   participant Math.random\n *   participant slogans\n *   alt i is undefined\n *     getSlogan->>Math.random: Generate random index\n *     Math.random-->>getSlogan: Return random index\n *   else i is defined\n *     Note over getSlogan: Use provided index\n *   end\n *   getSlogan->>slogans: Access slogan at index\n *   slogans-->>getSlogan: Return slogan\n *   alt Error occurs\n *     getSlogan->>getSlogan: Throw error\n *   end\n *   getSlogan-->>Caller: Return slogan\n */\nexport function getSlogan(i?: number): string {\n  try {\n    i =\n      typeof i === \"undefined\" ? Math.floor(Math.random() * slogans.length) : i;\n    return slogans[i].Slogan;\n  } catch (error: unknown) {\n    throw new Error(`Failed to retrieve slogans: ${error}`);\n  }\n}\n","/**\n * @class ObjectAccumulator\n * @template T - The type of the accumulated object, extends object\n * @description A class that accumulates objects and provides type-safe access to their properties.\n * It allows for dynamic addition of properties while maintaining type information.\n * @summary Accumulates objects and maintains type information for accumulated properties\n * @memberOf utils\n */\nexport class ObjectAccumulator<T extends object> {\n  /**\n   * @private\n   * @description The size of the accumulated object\n   * @type {number}\n   */\n  private __size!: number;\n\n  constructor() {\n    Object.defineProperty(this, \"__size\", {\n      value: 0,\n      writable: true,\n      configurable: false,\n      enumerable: false,\n    });\n  }\n\n  /**\n   * @protected\n   * @description Expands the accumulator with properties from a new object\n   * @summary Adds new properties to the accumulator\n   * @template V - The type of the object being expanded\n   * @param {V} value - The object to expand with\n   * @returns {void}\n   */\n  protected expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => v,\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @description Accumulates a new object into the accumulator\n   * @summary Adds properties from a new object to the accumulator, maintaining type information\n   * @template V - The type of the object being accumulated\n   * @param {V} value - The object to accumulate\n   * @returns A new ObjectAccumulator instance with updated type information\n   * @mermaid\n   * sequenceDiagram\n   *   participant A as Accumulator\n   *   participant O as Object\n   *   A->>O: Get entries\n   *   loop For each entry\n   *     A->>A: Define property\n   *   end\n   *   A->>A: Update size\n   *   A->>A: Return updated accumulator\n   */\n  accumulate<V extends object>(value: V): T & V & ObjectAccumulator<T & V> {\n    this.expand(value);\n    this.__size = this.__size + Object.keys(value).length;\n    return this as unknown as T & V & ObjectAccumulator<T & V>;\n  }\n\n  /**\n   * @description Retrieves a value from the accumulator by its key\n   * @summary Gets a value from the accumulated object using a type-safe key\n   * @template K - The key type, must be a key of this\n   * @param {K} key - The key of the value to retrieve\n   * @returns {any | undefined} The value associated with the key, or undefined if not found\n   */\n  get<K extends keyof this>(key: K): this[K] | undefined {\n    return this[key];\n  }\n\n  /**\n   * @description Checks if a key exists in the accumulator\n   * @summary Determines whether the accumulator contains a specific key\n   * @param {string} key - The key to check for existence\n   * @returns {boolean} True if the key exists, false otherwise\n   */\n  has(key: string): boolean {\n    return !!this[key as keyof this];\n  }\n\n  /**\n   * @description Removes a key-value pair from the accumulator\n   * @summary Deletes a property from the accumulated object\n   * @param {string} key - The key of the property to remove\n   * @returns {} The accumulator instance with the specified property removed\n   */\n  remove(\n    key: keyof this | string\n  ):\n    | (Omit<this, typeof key> & ObjectAccumulator<Omit<this, typeof key>>)\n    | this {\n    if (!(key in this)) return this;\n\n    delete this[key as keyof this];\n    this.__size--;\n    return this as unknown as Omit<this, typeof key> &\n      ObjectAccumulator<Omit<this, typeof key>>;\n  }\n\n  /**\n   * @description Retrieves all keys from the accumulator\n   * @summary Gets an array of all accumulated property keys\n   * @returns {string[]} An array of keys as strings\n   */\n  keys(): string[] {\n    return Object.keys(this);\n  }\n\n  /**\n   * @description Retrieves all values from the accumulator\n   * @summary Gets an array of all accumulated property values\n   * @returns An array of values\n   */\n  values(): T[keyof T][] {\n    return Object.values(this);\n  }\n\n  /**\n   * @description Gets the number of key-value pairs in the accumulator\n   * @summary Returns the count of accumulated properties\n   * @returns {number} The number of key-value pairs\n   */\n  size(): number {\n    return this.__size;\n  }\n\n  /**\n   * @description Clears all accumulated key-value pairs\n   * @summary Removes all properties from the accumulator and returns a new empty instance\n   * @returns {ObjectAccumulator<never>} A new empty ObjectAccumulator instance\n   */\n  clear(): ObjectAccumulator<never> {\n    return new ObjectAccumulator();\n  }\n\n  /**\n   * @description Executes a callback for each key-value pair in the accumulator\n   * @summary Iterates over all accumulated properties, calling a function for each\n   * @param {function(any, string, number): void} callback - The function to execute for each entry\n   * @returns {void}\n   */\n  forEach(\n    callback: (value: this[keyof this], key: keyof this, i: number) => void\n  ): void {\n    Object.entries(this).forEach(([key, value], i) =>\n      callback(value, key as keyof this, i)\n    );\n  }\n\n  /**\n   * @description Creates a new array with the results of calling a provided function on every element in the accumulator\n   * @summary Maps each accumulated property to a new value using a callback function\n   * @template R - The type of the mapped values\n   * @param {function(any, string,number): R} callback - Function that produces an element of the new array\n   * @returns {R[]} A new array with each element being the result of the callback function\n   */\n  map<R>(\n    callback: (value: this[keyof this], key: keyof this, i: number) => R\n  ): R[] {\n    return Object.entries(this).map(([key, value], i) =>\n      callback(value, key as keyof this, i)\n    );\n  }\n}\n","/**\n * @function isBrowser\n * @description Determines if the current environment is a browser by checking the prototype chain of the global object.\n * @summary Checks if the code is running in a browser environment.\n * @returns {boolean} True if the environment is a browser, false otherwise.\n */\nexport function isBrowser(): boolean {\n  return (\n    Object.getPrototypeOf(Object.getPrototypeOf(globalThis)) !==\n    Object.prototype\n  );\n}\n","import { toENVFormat } from \"./text\";\nimport { ObjectAccumulator } from \"./accumulator\";\nimport { EnvironmentFactory } from \"./types\";\nimport { isBrowser } from \"./web\";\n\n/**\n * @class Environment\n * @extends {ObjectAccumulator<T>}\n * @template T\n * @description A class representing an environment with accumulation capabilities.\n * @summary Manages environment-related data and provides methods for accumulation and key retrieval.\n * @param {T} [initialData] - The initial data to populate the environment with.\n */\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n  }\n\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env = (globalThis as typeof globalThis & { ENV: Record<string, any> })[\n        \"ENV\"\n      ];\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return env[k];\n  }\n\n  protected expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          return typeof fromEnv === \"undefined\" ? v : fromEnv;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one instance of the Environment class exists.\n   * @template E\n   * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.\n   * @return {E} The singleton instance of the Environment class.\n   */\n  protected static instance<E extends Environment<any>>(...args: unknown[]): E {\n    Environment._instance = !Environment._instance\n      ? Environment.factory(...args)\n      : Environment._instance;\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties to the environment from the provided object.\n   * @template V\n   * @param {V} value - The object to accumulate into the environment.\n   * @return {V} The updated environment instance.\n   */\n  static accumulate<V extends object>(\n    value: V\n  ): typeof Environment._instance &\n    V &\n    ObjectAccumulator<typeof Environment._instance & V> {\n    const instance = Environment.instance();\n    return instance.accumulate(value);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n}\n","import { ParseArgsResult } from \"../input/types\";\nimport { LoggingConfig, VerbosityLogger } from \"../output/types\";\nimport { CommandOptions } from \"./types\";\nimport { Logging } from \"../output/logging\";\nimport { DefaultLoggingConfig, LogLevel } from \"../utils/constants\";\nimport { UserInput } from \"../input/input\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"./constants\";\nimport { getDependencies, getPackageVersion } from \"../utils/fs\";\nimport { printBanner } from \"../output/common\";\nimport { Environment } from \"../utils/environment\";\n\n/**\n * @class Command\n * @abstract\n * @template I - The type of input options for the command.\n * @template R - The return type of the command execution.\n * @memberOf utils/cli\n * @description Abstract base class for command implementation.\n * @summary Provides a structure for creating command-line interface commands with input handling, logging, and execution flow.\n *\n * @param {string} name - The name of the command.\n * @param {CommandOptions<I>} [inputs] - The input options for the command.\n * @param {string[]} [requirements] - The list of required dependencies for the command.\n */\nexport abstract class Command<I, R> {\n  /**\n   * @static\n   * @description Static logger for the Command class.\n   * @type {VerbosityLogger}\n   */\n  static log: VerbosityLogger;\n\n  /**\n   * @protected\n   * @description Instance logger for the command.\n   * @type {VerbosityLogger}\n   */\n  protected log: VerbosityLogger;\n\n  protected constructor(\n    protected name: string,\n    protected inputs: CommandOptions<I> = {} as unknown as CommandOptions<I>,\n    protected requirements: string[] = []\n  ) {\n    if (!Command.log) {\n      Object.defineProperty(Command, \"log\", {\n        writable: false,\n        value: Logging.for(Command.name),\n      });\n      this.log = Command.log;\n    }\n    this.log = Command.log.for(this.name);\n    this.inputs = Object.assign({}, DefaultCommandOptions, inputs);\n  }\n\n  /**\n   * @protected\n   * @async\n   * @description Checks if all required dependencies are present.\n   * @summary Retrieves the list of dependencies and compares it against the required dependencies for the command.\n   * @returns {Promise<void>} A promise that resolves when the check is complete.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Command\n   *   participant getDependencies\n   *   participant Set\n   *   Command->>getDependencies: Call\n   *   getDependencies-->>Command: Return {prod, dev, peer}\n   *   Command->>Set: Create Set from prod, dev, peer\n   *   Set-->>Command: Return unique dependencies\n   *   Command->>Command: Compare against requirements\n   *   alt Missing dependencies\n   *     Command->>Command: Add to missing list\n   *   end\n   *   Note over Command: If missing.length > 0, handle missing dependencies\n   */\n  protected async checkRequirements(): Promise<void> {\n    const { prod, dev, peer } = await getDependencies();\n    const missing = [];\n    const fullList = Array.from(\n      new Set([...prod, ...dev, ...peer]).values()\n    ).map((d) => d.name);\n    for (const dep of this.requirements)\n      if (!fullList.includes(dep)) missing.push(dep);\n\n    if (!missing.length) return;\n  }\n\n  /**\n   * @protected\n   * @description Provides help information for the command.\n   * @summary This method should be overridden in derived classes to provide specific help information.\n   * @param {ParseArgsResult} args - The parsed command-line arguments.\n   * @returns {void}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected help(args: ParseArgsResult): void {\n    return this.log.info(\n      `This is help. I'm no use because I should have been overridden.`\n    );\n  }\n\n  /**\n   * @protected\n   * @abstract\n   * @description Runs the command with the provided arguments.\n   * @summary This method should be implemented in derived classes to define the command's behavior.\n   * @param {ParseArgsResult} answers - The parsed command-line arguments.\n   * @returns {Promise<R | string | void>} A promise that resolves with the command's result.\n   */\n  protected abstract run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof I]: unknown }\n  ): Promise<R | string | void>;\n\n  /**\n   * @async\n   * @description Executes the command.\n   * @summary This method handles the overall execution flow of the command, including parsing arguments,\n   * setting up logging, checking for version or help requests, and running the command.\n   * @returns {Promise<R | string | void>} A promise that resolves with the command's result.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Command\n   *   participant UserInput\n   *   participant Logging\n   *   participant getPackageVersion\n   *   participant printBanner\n   *   Command->>UserInput: parseArgs(inputs)\n   *   UserInput-->>Command: Return ParseArgsResult\n   *   Command->>Command: Process options\n   *   Command->>Logging: setConfig(options)\n   *   alt version requested\n   *     Command->>getPackageVersion: Call\n   *     getPackageVersion-->>Command: Return version\n   *   else help requested\n   *     Command->>Command: help(args)\n   *   else banner requested\n   *     Command->>printBanner: Call\n   *   end\n   *   Command->>Command: run(args)\n   *   alt error occurs\n   *     Command->>Command: Log error\n   *   end\n   *   Command-->>Command: Return result\n   */\n  async execute(): Promise<R | string | void> {\n    const args: ParseArgsResult = UserInput.parseArgs(this.inputs);\n    const env = Environment.accumulate(DefaultLoggingConfig)\n      .accumulate(DefaultCommandValues)\n      .accumulate(args.values);\n    const { timestamp, verbose, version, help, logLevel, logStyle, banner } =\n      env;\n\n    this.log.setConfig({\n      ...env,\n      timestamp: !!timestamp,\n      level: logLevel as LogLevel,\n      style: !!logStyle,\n      verbose: (verbose as number) || 0,\n    });\n\n    if (version) {\n      return getPackageVersion();\n    }\n\n    if (help) {\n      return this.help(args);\n    }\n\n    if (banner)\n      printBanner(\n        this.log.for(printBanner, {\n          timestamp: false,\n          style: false,\n          context: false,\n          logLevel: false,\n        })\n      );\n\n    let result;\n    try {\n      result = await this.run(env);\n    } catch (e: unknown) {\n      this.log.error(`Error while running provided cli function: ${e}`);\n      throw e;\n    }\n\n    return result as R;\n  }\n}\n","import https from \"https\";\nimport { Logging } from \"../output/logging\";\n\n/**\n * @description A simple HTTP client for downloading files.\n * @summary This class provides functionality to download files from HTTPS URLs.\n * It uses Node.js built-in https module to make requests.\n *\n * @class\n */\nexport class HttpClient {\n  protected static log = Logging.for(HttpClient);\n  /**\n   * @description Downloads a file from a given URL.\n   * @summary This method sends a GET request to the specified URL and returns the response body as a string.\n   * It handles different scenarios such as non-200 status codes and network errors.\n   *\n   * @param url - The URL of the file to download.\n   * @return A promise that resolves with the file content as a string.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant HttpClient\n   *   participant HTTPS\n   *   participant Server\n   *   Client->>HttpClient: downloadFile(url)\n   *   HttpClient->>HTTPS: get(url)\n   *   HTTPS->>Server: GET request\n   *   Server-->>HTTPS: Response\n   *   HTTPS-->>HttpClient: Response object\n   *   alt Status code is 200\n   *     loop For each data chunk\n   *       HTTPS->>HttpClient: 'data' event\n   *       HttpClient->>HttpClient: Accumulate data\n   *     end\n   *     HTTPS->>HttpClient: 'end' event\n   *     HttpClient-->>Client: Resolve with data\n   *   else Status code is not 200\n   *     HttpClient-->>Client: Reject with error\n   *   end\n   */\n  static async downloadFile(url: string): Promise<string> {\n    return new Promise<string>((resolve, reject) => {\n      function request(url: string) {\n        url = encodeURI(url);\n        https.get(url, (res) => {\n          if (res.statusCode === 301 || res.statusCode === 307)\n            return request(res.headers.location as string);\n\n          if (res.statusCode !== 200) {\n            HttpClient.log.error(\n              `Failed to fetch ${url} (status: ${res.statusCode})`\n            );\n            return reject(new Error(`Failed to fetch ${url}`));\n          }\n          let data = \"\";\n          res.on(\"data\", (chunk) => {\n            data += chunk;\n          });\n          res.on(\"error\", (error) => {\n            reject(error);\n          });\n\n          res.on(\"end\", () => {\n            resolve(data);\n          });\n        });\n      }\n      request(url);\n    });\n  }\n}\n","import { LoggingConfig } from \"../../output\";\nimport { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"../constants\";\nimport {\n  copyFile,\n  deletePath,\n  getAllFiles,\n  getPackage,\n  patchFile,\n  readFile,\n  renameFile,\n  runCommand,\n  writeFile,\n} from \"../../utils\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { rollup, InputOptions, OutputOptions, RollupBuild } from \"rollup\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport commonjs from \"@rollup/plugin-commonjs\";\nimport { nodeResolve } from \"@rollup/plugin-node-resolve\";\nimport json from \"@rollup/plugin-json\";\n\nconst VERSION_STRING = \"##VERSION##\";\n\nenum Modes {\n  CJS = \"commonjs\",\n  ESM = \"es2022\",\n}\n\nconst Commands = [\"update-scripts\", \"tag-release\", \"build-scripts\"];\n\nconst options = {\n  prod: {\n    type: \"boolean\",\n    default: false,\n  },\n  dev: {\n    type: \"boolean\",\n    default: false,\n  },\n  docs: {\n    type: \"boolean\",\n    default: false,\n  },\n  commands: {\n    type: \"boolean\",\n    default: false,\n  },\n  banner: {\n    type: \"boolean\",\n    default: false,\n  },\n};\n\nexport class BuildScripts extends Command<\n  CommandOptions<typeof options>,\n  void\n> {\n  private replacements: Record<string, string> = {};\n  private readonly pkgVersion: string;\n  private readonly pkgName: string;\n\n  constructor() {\n    super(\n      \"BuildScripts\",\n      Object.assign({}, DefaultCommandOptions, options) as CommandOptions<\n        typeof options\n      >\n    );\n    const pkg = getPackage() as { name: string; version: string };\n    const { name, version } = pkg;\n    this.pkgName = name.includes(\"@\") ? name.split(\"/\")[1] : name;\n    this.pkgVersion = version;\n    this.replacements[VERSION_STRING] = this.pkgVersion;\n  }\n\n  patchCjsImports(file: string) {\n    const regexp = /(require\\([\"'])(\\..*?)([\"']\\)[;,])/g;\n    let data = readFile(file);\n    data = data.replace(regexp, (match, ...groups: string[]) => {\n      const renamedFile = groups[1] + \".cjs\";\n      const dirname = path.dirname(file).replace(\"lib\", \"src\");\n      const fileName = groups[1] + \".ts\";\n      const sourceFilePath = path.join(dirname, fileName);\n\n      let result;\n      if (!fs.existsSync(sourceFilePath)) {\n        result = groups[0] + groups[1] + \"/index.cjs\" + groups[2];\n      } else {\n        result = groups[0] + renamedFile + groups[2];\n      }\n\n      return result;\n    });\n    writeFile(file, data);\n  }\n\n  patchFiles(p: string) {\n    const log = this.log.for(this.patchFiles);\n    const { name, version } = getPackage() as any;\n    log.info(`Patching ${name} ${version} module in ${p}...`);\n    const stat = fs.statSync(p);\n    if (stat.isDirectory())\n      fs.readdirSync(p, { withFileTypes: true, recursive: true })\n        .filter((p) => p.isFile())\n        .forEach((file) =>\n          patchFile(path.join(file.parentPath, file.name), this.replacements)\n        );\n    log.verbose(`Module ${name} ${version} patched in ${p}...`);\n  }\n\n  private async build(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.build);\n    log.info(\n      `Building ${this.pkgName} ${this.pkgVersion} module (${mode}) in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n\n    await runCommand(\n      `npx tsc --module ${bundle ? \"amd\" : mode}${isDev ? \" --inlineSourceMap\" : \" --sourceMap false\"} --outDir ${bundle ? \"dist\" : `lib${mode === Modes.ESM ? \"/esm\" : \"\"}`}${bundle ? ` --isolatedModules false --outFile ${this.pkgName}` : \"\"}`\n    ).promise;\n    log.verbose(\n      `Module ${this.pkgName} ${this.pkgVersion} (${mode}) built in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    if (mode === Modes.CJS && !bundle) {\n      const files = getAllFiles(\n        \"lib\",\n        (file) => file.endsWith(\".js\") && !file.includes(\"/esm/\")\n      );\n\n      for (const file of files) {\n        log.verbose(`Patching ${file}'s cjs imports...`);\n        const f = file.replace(\".js\", \".cjs\");\n        await renameFile(file, f);\n        this.patchCjsImports(f);\n      }\n    }\n  }\n\n  copyAssets(mode: Modes) {\n    const log = this.log.for(this.copyAssets);\n    let hasAssets = false;\n    try {\n      hasAssets = fs.statSync(\"./src/assets\").isDirectory();\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return log.verbose(`No assets found in ./src/assets to copy`);\n    }\n    if (hasAssets)\n      copyFile(\n        \"./src/assets\",\n        `./${mode === Modes.CJS ? \"lib\" : \"dist\"}/assets`\n      );\n  }\n\n  async buildCommands() {\n    for (const cmd of Commands) {\n      await this.bundle(Modes.CJS, true, true, `src/bin/${cmd}.ts`, cmd);\n      let data = readFile(`bin/${cmd}.cjs`);\n      data = \"#!/usr/bin/env node\\n\" + data;\n      writeFile(`bin/${cmd}.cjs`, data);\n    }\n  }\n\n  async bundle(\n    mode: Modes,\n    isDev: boolean,\n    isLib: boolean,\n    entryFile: string = \"src/index.ts\",\n    nameOverride: string = this.pkgName,\n    externals?: string[],\n    include: string[] = [\"prompts\", \"styled-string-builder\"]\n  ) {\n    const isEsm = mode === Modes.ESM;\n    const pkgName = this.pkgName;\n\n    const ext = Array.from(\n      new Set([\n        ...[\n          \"fs\",\n          \"path\",\n          \"process\",\n          \"rollup\",\n          \"@rollup/plugin-typescript\",\n          \"@rollup/plugin-json\",\n          \"@rollup/plugin-commonjs\",\n          \"@rollup/plugin-node-resolve\",\n          \"child_process\",\n          \"util\",\n          \"https\",\n        ],\n        ...(externals || []),\n      ])\n    );\n\n    const plugins = [\n      typescript({\n        compilerOptions: {\n          module: \"esnext\",\n          declaration: false,\n          outDir: isLib ? \"bin\" : \"dist\",\n        },\n        include: [\"src/**/*.ts\"],\n        exclude: [\"node_modules\", \"**/*.spec.ts\"],\n        tsconfig: \"./tsconfig.json\",\n      }),\n      json(),\n    ];\n\n    if (isLib) {\n      plugins.push(\n        commonjs({\n          include: [],\n          exclude: externals,\n        }),\n        nodeResolve({\n          resolveOnly: include,\n        })\n      );\n    }\n\n    const input: InputOptions = {\n      input: entryFile,\n      plugins: plugins,\n      external: ext,\n    };\n\n    const outputs: OutputOptions[] = [\n      {\n        file: `${isLib ? \"bin/\" : \"dist/\"}${nameOverride ? nameOverride : `.bundle.${!isDev ? \"min\" : \"\"}`}${isEsm ? \".esm\" : \"\"}.cjs`,\n        format: isLib ? \"cjs\" : isEsm ? \"esm\" : \"umd\",\n        name: pkgName,\n        esModule: isEsm,\n        sourcemap: isDev ? \"inline\" : false,\n        globals: {},\n        exports: \"auto\",\n      },\n    ];\n\n    try {\n      const bundle = await rollup(input);\n      console.log(bundle.watchFiles);\n      async function generateOutputs(bundle: RollupBuild) {\n        for (const outputOptions of outputs) {\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n          const { output } = await bundle.write(outputOptions);\n        }\n      }\n\n      await generateOutputs(bundle);\n    } catch (e: unknown) {\n      throw new Error(`Failed to bundle: ${e}`);\n    }\n  }\n\n  private async buildByEnv(isDev: boolean) {\n    try {\n      deletePath(\"lib\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    try {\n      deletePath(\"dist\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    fs.mkdirSync(\"lib\");\n    fs.mkdirSync(\"dist\");\n    await this.build(isDev, Modes.CJS);\n    await this.build(isDev, Modes.ESM);\n    await this.bundle(Modes.CJS, true, false);\n    await this.bundle(Modes.ESM, true, false);\n    this.patchFiles(\"lib\");\n    this.patchFiles(\"dist\");\n    this.copyAssets(Modes.CJS);\n    this.copyAssets(Modes.ESM);\n  }\n\n  async buildDev() {\n    return this.buildByEnv(true);\n  }\n\n  async buildProd() {\n    return this.buildByEnv(false);\n  }\n\n  async buildDocs() {\n    await runCommand(`npm install better-docs taffydb`).promise;\n    await runCommand(`npx markdown-include ./workdocs/readme-md.json`).promise;\n    await runCommand(\n      `npx jsdoc -c ./workdocs/jsdocs.json -t ./node_modules/better-docs`\n    ).promise;\n    await runCommand(`npm remove better-docs taffydb`).promise;\n    [\n      {\n        src: \"workdocs/assets\",\n        dest: \"./docs/workdocs/assets\",\n      },\n      {\n        src: \"workdocs/reports/coverage\",\n        dest: \"./docs/workdocs/reports/coverage\",\n      },\n      {\n        src: \"workdocs/reports/html\",\n        dest: \"./docs/workdocs/reports/html\",\n      },\n      {\n        src: \"workdocs/resources\",\n        dest: \"./docs/workdocs/resources\",\n      },\n      {\n        src: \"LICENSE.md\",\n        dest: \"./docs/LICENSE.md\",\n      },\n    ].forEach((f) => {\n      const { src, dest } = f;\n      copyFile(src, dest);\n    });\n  }\n\n  protected async run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<string | void | R> {\n    const { dev, prod, docs, commands } = answers;\n\n    if (commands) {\n      await this.buildCommands();\n    }\n\n    if (dev) {\n      return await this.buildDev();\n    }\n    if (prod) {\n      return await this.buildProd();\n    }\n    if (docs) {\n      return await this.buildDocs();\n    }\n  }\n}\n","import { runCommand } from \"../../utils/utils\";\nimport { NoCIFLag, SemVersion, SemVersionRegex } from \"../../utils/constants\";\nimport { UserInput } from \"../../input/input\";\nimport { Command } from \"../command\";\nimport { LoggingConfig } from \"../../output\";\nimport { DefaultCommandValues } from \"../index\";\n\nconst options = {\n  ci: {\n    type: \"boolean\",\n    default: true,\n  },\n  message: {\n    type: \"string\",\n    short: \"m\",\n  },\n  tag: {\n    type: \"string\",\n    short: \"t\",\n    default: undefined,\n  },\n};\n\n/**\n * @class ReleaseScript\n * @extends {Command}\n * @cavegory scripts\n * @description A command-line script for managing releases and version updates.\n * @summary This script automates the process of creating and pushing new releases. It handles version updates,\n * commit messages, and optionally publishes to NPM. The script supports semantic versioning and can work in both CI and non-CI environments.\n *\n * @param {Object} options - Configuration options for the script\n * @param {boolean} options.ci - Whether the script is running in a CI environment (default: true)\n * @param {string} options.message - The release message (short: 'm')\n * @param {string} options.tag - The version tag to use (short: 't', default: undefined)\n */\nexport class ReleaseScript extends Command<typeof options, void> {\n  constructor() {\n    super(\"ReleaseScript\", options);\n  }\n\n  /**\n   * @description Prepares the version for the release.\n   * @summary This method validates the provided tag or prompts the user for a new one if not provided or invalid.\n   * It also displays the latest git tags for reference.\n   * @param {string} tag - The version tag to prepare\n   * @returns {Promise<string>} The prepared version tag\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant T as TestVersion\n   *   participant U as UserInput\n   *   participant G as Git\n   *   R->>T: testVersion(tag)\n   *   alt tag is valid\n   *     T-->>R: return tag\n   *   else tag is invalid or not provided\n   *     R->>G: List latest git tags\n   *     R->>U: Prompt for new tag\n   *     U-->>R: return new tag\n   *   end\n   */\n  async prepareVersion(tag?: string): Promise<string> {\n    const log = this.log.for(this.prepareVersion);\n    tag = this.testVersion((tag as string) || \"\");\n    if (!tag) {\n      log.verbose(\"No release message provided. Prompting for one:\");\n      log.info(`Listing latest git tags:`);\n      await runCommand(\"git tag --sort=-taggerdate | head -n 5\").promise;\n      return await UserInput.insistForText(\n        \"tag\",\n        \"Enter the new tag number (accepts v*.*.*[-...])\",\n        (val) =>\n          !!val.toString().match(/^v[0-9]+\\.[0-9]+.[0-9]+(-[0-9a-zA-Z-]+)?$/)\n      );\n    }\n    return tag;\n  }\n\n  /**\n   * @description Tests if the provided version is valid.\n   * @summary This method checks if the version is a valid semantic version or a predefined update type (PATCH, MINOR, MAJOR).\n   * @param {string} version - The version to test\n   * @returns {string | undefined} The validated version or undefined if invalid\n   */\n  testVersion(version: string): string | undefined {\n    const log = this.log.for(this.testVersion);\n    version = version.trim().toLowerCase();\n    switch (version) {\n      case SemVersion.PATCH:\n      case SemVersion.MINOR:\n      case SemVersion.MAJOR:\n        log.verbose(`Using provided SemVer update: ${version}`, 1);\n        return version;\n      default:\n        log.verbose(\n          `Testing provided version for SemVer compatibility: ${version}`,\n          1\n        );\n        if (!new RegExp(SemVersionRegex).test(version)) {\n          log.debug(`Invalid version number: ${version}`);\n          return undefined;\n        }\n        log.verbose(`version approved: ${version}`, 1);\n        return version;\n    }\n  }\n\n  /**\n   * @description Prepares the release message.\n   * @summary This method either returns the provided message or prompts the user for a new one if not provided.\n   * @param {string} [message] - The release message\n   * @returns {Promise<string>} The prepared release message\n   */\n  async prepareMessage(message?: string) {\n    const log = this.log.for(this.prepareMessage);\n    if (!message) {\n      log.verbose(\"No release message provided. Prompting for one\");\n      return await UserInput.insistForText(\n        \"message\",\n        \"What should be the release message/ticket?\",\n        (val) => !!val && val.toString().length > 5\n      );\n    }\n    return message;\n  }\n\n  /**\n   * @description Runs the release script.\n   * @summary This method orchestrates the entire release process, including version preparation, message creation,\n   * git operations, and npm publishing (if not in CI environment).\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant V as PrepareVersion\n   *   participant M as PrepareMessage\n   *   participant N as NPM\n   *   participant G as Git\n   *   participant U as UserInput\n   *   R->>V: prepareVersion(tag)\n   *   R->>M: prepareMessage(message)\n   *   R->>N: Run prepare-release script\n   *   R->>G: Check git status\n   *   alt changes exist\n   *     R->>U: Ask for confirmation\n   *     U-->>R: Confirm\n   *     R->>G: Add and commit changes\n   *   end\n   *   R->>N: Update npm version\n   *   R->>G: Push changes and tags\n   *   alt not CI environment\n   *     R->>N: Publish to npm\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<void> {\n    let result: any;\n    const { ci } = args;\n    let { tag, message } = args;\n    tag = await this.prepareVersion(tag as string);\n    message = await this.prepareMessage(message as string);\n    result = await runCommand(`npm run prepare-release -- ${tag} ${message}`, {\n      cwd: process.cwd(),\n    }).promise;\n    result = await runCommand(\"git status --porcelain\").promise;\n    await result;\n    if (\n      result.logs.length &&\n      (await UserInput.askConfirmation(\n        \"git-changes\",\n        \"Do you want to push the changes to the remote repository?\",\n        true\n      ))\n    ) {\n      await runCommand(\"git add .\").promise;\n      await runCommand(\n        `git commit -m \"${tag} - ${message} - after release preparation${ci ? \"\" : NoCIFLag}\"`\n      ).promise;\n    }\n    await runCommand(\n      `npm version \"${tag}\" -m \"${message}${ci ? \"\" : NoCIFLag}\"`\n    ).promise;\n    await runCommand(\"git push --follow-tags\").promise;\n    if (!ci) {\n      await runCommand(\"NPM_TOKEN=$(cat .npmtoken) npm publish --access public\")\n        .promise;\n    }\n  }\n}\n","import path from \"path\";\nimport { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport {\n  getPackage,\n  HttpClient,\n  patchFile,\n  patchString,\n  runCommand,\n  setPackageAttribute,\n  SetupScriptKey,\n  Tokens,\n  writeFile,\n} from \"../../utils\";\nimport { LoggingConfig } from \"../../output\";\nimport { DefaultCommandValues } from \"../index\";\nimport { UserInput } from \"../../input\";\nimport fs from \"fs\";\n\nconst baseUrl =\n  \"https://raw.githubusercontent.com/decaf-ts/ts-workspace/master\";\n\nconst options = {\n  templates: [\n    \".github/ISSUE_TEMPLATE/bug_report.md\",\n    \".github/ISSUE_TEMPLATE/feature_request.md\",\n    \".github/FUNDING.yml\",\n  ],\n  workflows: [\n    \".github/workflows/codeql-analysis.yml\",\n    \".github/workflows/jest-coverage.yaml\",\n    \".github/workflows/nodejs-build-prod.yaml\",\n    \".github/workflows/pages.yaml\",\n    \".github/workflows/publish-on-release.yaml\",\n    \".github/workflows/release-on-tag.yaml\",\n    \".github/workflows/snyk-analysis.yaml\",\n  ],\n  ide: [\n    \".idea/runConfigurations/All Tests.run.xml\",\n    \".idea/runConfigurations/build.run.xml\",\n    \".idea/runConfigurations/build_prod.run.xml\",\n    \".idea/runConfigurations/coverage.run.xml\",\n    \".idea/runConfigurations/docs.run.xml\",\n    \".idea/runConfigurations/drawings.run.xml\",\n    \".idea/runConfigurations/flash-forward.run.xml\",\n    \".idea/runConfigurations/Integration_Tests.run.xml\",\n    \".idea/runConfigurations/Bundling_Tests.run.xml\",\n    \".idea/runConfigurations/lint-fix.run.xml\",\n    \".idea/runConfigurations/release.run.xml\",\n    \".idea/runConfigurations/test_circular.run.xml\",\n    \".idea/runConfigurations/uml.run.xml\",\n    \".idea/runConfigurations/Unit Tests.run.xml\",\n    \".idea/runConfigurations/update-scripts.run.xml\",\n  ],\n  docs: [\n    \"workdocs/tutorials/Contributing.md\",\n    \"workdocs/tutorials/Documentation.md\",\n    \"workdocs/tutorials/For Developers.md\",\n    \"workdocs/2-Badges.md\",\n    \"workdocs/jsdocs.json\",\n    \"workdocs/readme-md.json\",\n  ],\n  styles: [\".prettierrc\", \"eslint.config.js\"],\n  scripts: [\n    \"bin/update-scripts.cjs\",\n    \"bin/tag-release.cjs\",\n    \"bin/build-scripts.cjs\",\n  ],\n  tests: [\"jest.config.ts\", \"workdocs/reports/jest.coverage.config.ts\"],\n  typescript: [\"tsconfig.json\"],\n  docker: [\"Dockerfile\"],\n  automation: [\n    \"workdocs/confluence/Continuous Integration-Deployment/GitHub.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Jira.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Teams.md\",\n  ],\n};\n\nconst argzz = {\n  // init attributes\n  boot: {\n    type: \"boolean\",\n  },\n  org: {\n    type: \"string\",\n    short: \"o\",\n  },\n  name: {\n    type: \"string\",\n    short: \"n\",\n    default: undefined,\n  },\n  author: {\n    type: \"string\",\n    short: \"a\",\n    default: undefined,\n  },\n  // update attributes\n  all: {\n    type: \"boolean\",\n  },\n  license: {\n    type: \"string\",\n    message: \"Pick the license\",\n  },\n  scripts: {\n    type: \"boolean\",\n  },\n  styles: {\n    type: \"boolean\",\n  },\n  docs: {\n    type: \"boolean\",\n  },\n  ide: {\n    type: \"boolean\",\n  },\n  workflows: {\n    type: \"boolean\",\n  },\n  templates: {\n    type: \"boolean\",\n  },\n  typescript: {\n    type: \"boolean\",\n  },\n  docker: {\n    type: \"boolean\",\n  },\n  pkg: {\n    type: \"boolean\",\n  },\n  dependencies: {\n    type: \"boolean\",\n  },\n  tests: {\n    type: \"boolean\",\n  },\n  automation: {\n    type: \"boolean\",\n  },\n};\n\n/**\n * @class TemplateSync\n * @extends {Command}\n * @category scripts\n * @description A command-line tool for synchronizing project templates and configurations.\n * @summary This class provides functionality to download and update various project files and configurations from a remote repository.\n * It supports updating licenses, IDE configurations, scripts, styles, documentation, workflows, and templates.\n *\n * @param {CommandOptions} args - The command options for TemplateSync\n */\nexport class TemplateSync extends Command<CommandOptions<typeof argzz>, void> {\n  private replacements: Record<string, string | number> = {};\n\n  constructor() {\n    super(\"TemplateSync\", argzz);\n  }\n\n  private loadValuesFromPackage() {\n    const p = process.cwd();\n    const author = getPackage(p, \"author\") as string;\n    const scopedName = getPackage(p, \"name\");\n    let name: string = scopedName as string;\n    let org: string | undefined;\n    if (name.startsWith(\"@\")) {\n      const split = name.split(\"/\");\n      name = split[1];\n      org = split[0].replace(\"@\", \"\");\n    }\n    [\"Tiago Venceslau\", \"TiagoVenceslau\", \"${author}\"].forEach(\n      (el) => (this.replacements[el] = author)\n    );\n    [\"TS-Workspace\", \"ts-workspace\", \"${name}\"].forEach(\n      (el) => (this.replacements[el] = name)\n    );\n    [\"decaf-ts\", \"${org}\"].forEach(\n      (el) => (this.replacements[el] = (org as string) || '\"\"')\n    );\n    this.replacements[\"${org_or_owner}\"] = org || name;\n  }\n\n  /**\n   * @description Downloads files for a specific option category.\n   * @summary This method downloads all files associated with a given option key from the remote repository.\n   * @param {string} key - The key representing the option category to download\n   * @returns {Promise<void>}\n   * @throws {Error} If the specified option key is not found\n   */\n  async downloadOption(key: keyof typeof options): Promise<void> {\n    if (!(key in options)) {\n      throw new Error(`Option \"${key}\" not found in options`);\n    }\n    const files = options[key as keyof typeof options];\n\n    for (const file of files) {\n      this.log.info(`Downloading ${file}`);\n\n      let data = await HttpClient.downloadFile(`${baseUrl}/${file}`);\n      data = patchString(data, this.replacements);\n      writeFile(path.join(process.cwd(), file), data);\n    }\n  }\n\n  /**\n   * @description Downloads and sets up the specified license.\n   * @summary This method downloads the chosen license file, saves it to the project, and updates the package.json license field.\n   * @param {\"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"} license - The license to download and set up\n   * @returns {Promise<void>}\n   */\n  async getLicense(license: \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\") {\n    this.log.info(`Downloading ${license} license`);\n    const url = `${baseUrl}/workdocs/licenses/${license}.md`;\n    let data = await HttpClient.downloadFile(url);\n    data = patchString(data, this.replacements);\n    writeFile(path.join(process.cwd(), \"LICENSE.md\"), data);\n    setPackageAttribute(\"license\", license);\n  }\n\n  /**\n   * @description Downloads IDE configuration files.\n   * @returns {Promise<void>}\n   */\n  async getIde() {\n    fs.mkdirSync(path.join(process.cwd(), \".idea\", \"runConfigurations\"), {\n      recursive: true,\n    });\n    await this.downloadOption(\"ide\");\n  }\n\n  /**\n   * @description Update npm scripts\n   * @returns {Promise<void>}\n   */\n  async getScripts() {\n    await this.downloadOption(\"scripts\");\n    this.log.info(\"please re-run the command\");\n    process.exit(0);\n  }\n\n  /**\n   * @description Downloads style configuration files.\n   * @returns {Promise<void>}\n   */\n  getStyles = () => this.downloadOption(\"styles\");\n\n  /**\n   * @description Downloads template files.\n   * @returns {Promise<void>}\n   */\n  getTemplates = () => this.downloadOption(\"templates\");\n\n  /**\n   * @description Downloads workflow configuration files.\n   * @returns {Promise<void>}\n   */\n  getWorkflows = () => this.downloadOption(\"workflows\");\n\n  /**\n   * @description Downloads documentation files.\n   * @returns {Promise<void>}\n   */\n  getDocs = () => this.downloadOption(\"docs\");\n\n  /**\n   * @description Downloads typescript config files.\n   * @returns {Promise<void>}\n   */\n  getTypescript = () => this.downloadOption(\"typescript\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getAutomation = () => this.downloadOption(\"automation\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getTests = () => this.downloadOption(\"tests\");\n\n  /**\n   * @description Downloads docker image files.\n   * @returns {Promise<void>}\n   */\n  getDocker = () => this.downloadOption(\"docker\");\n\n  async initPackage(pkgName: string, author: string, license: string) {\n    try {\n      const pkg = getPackage() as Record<string, unknown>;\n      delete pkg[SetupScriptKey];\n      pkg.name = pkgName;\n      pkg.version = \"0.0.1\";\n      pkg.author = author;\n      pkg.license = license;\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json: ${e}`);\n    }\n  }\n\n  async updatePackageScrips() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { scripts } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in scripts) {\n          const replaced = patchString(scripts[key], this.replacements);\n          if (replaced !== scripts[key]) {\n            pkg.scripts[key] = replaced;\n          }\n        }\n      });\n\n      pkg[\"exports\"][\"require\"] = originalPkg[\"exports\"][\"require\"];\n      pkg[\"exports\"][\"import\"] = originalPkg[\"exports\"][\"import\"];\n      pkg[\"types\"] = originalPkg[\"types\"];\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json scripts: ${e}`);\n    }\n  }\n\n  async createTokenFiles() {\n    const log = this.log.for(this.createTokenFiles);\n    const gitToken = await UserInput.insistForText(\n      \"token\",\n      \"please input your github token\",\n      (res: string) => {\n        return !!res.match(/^ghp_[0-9a-zA-Z]{36}$/g);\n      }\n    );\n    Object.values(Tokens).forEach((token) => {\n      try {\n        let status;\n        try {\n          status = fs.existsSync(token);\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        } catch (e: unknown) {\n          log.info(`Token file ${token} not found. Creating a new one...`);\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n          return;\n        }\n        if (!status) {\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n        }\n      } catch (e: unknown) {\n        throw new Error(`Error creating token file ${token}: ${e}`);\n      }\n    });\n  }\n\n  async getOrg(): Promise<string> {\n    const org = await UserInput.askText(\n      \"Organization\",\n      \"Enter the organization name (will be used to scope your npm project. leave blank to create a unscoped project):\"\n    );\n    const confirmation = await UserInput.askConfirmation(\n      \"Confirm organization\",\n      \"Is this organization correct?\",\n      true\n    );\n    if (!confirmation) return this.getOrg();\n\n    return org;\n  }\n\n  async auditFix() {\n    return await runCommand(\"npm audit fix --force\").promise;\n  }\n\n  patchFiles() {\n    const files = [\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"src\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile())\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"workdocs\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile() && entry.name.endsWith(\".md\"))\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      path.join(process.cwd(), \".gitlab-ci.yml\"),\n      path.join(process.cwd(), \"workdocs\", \"jsdocs.json\"),\n    ];\n\n    for (const file of files) {\n      patchFile(file as string, this.replacements);\n    }\n  }\n\n  async updateDependencies() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { devDependencies } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in devDependencies) {\n          const replaced = devDependencies[key];\n          if (replaced !== devDependencies[key]) {\n            (pkg as any)[\"devDependencies\"] =\n              (pkg as any)[\"devDependencies\"] || {};\n            (pkg as any)[\"devDependencies\"][key] = replaced;\n          }\n        }\n      });\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n      await runCommand(\"npm install\").promise;\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json dependencies: ${e}`);\n    }\n  }\n\n  /**\n   * @description Runs the template synchronization process.\n   * @summary This method orchestrates the downloading of various project components based on the provided arguments.\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant T as TemplateSync\n   *   participant L as getLicense\n   *   participant I as getIde\n   *   participant S as getScripts\n   *   participant St as getStyles\n   *   participant D as getDocs\n   *   participant W as getWorkflows\n   *   participant Te as getTemplates\n   *   T->>T: Parse arguments\n   *   alt all flag is true\n   *     T->>T: Set all component flags to true\n   *   end\n   *   alt license is specified\n   *     T->>L: getLicense(license)\n   *   end\n   *   alt ide flag is true\n   *     T->>I: getIde()\n   *   end\n   *   alt scripts flag is true\n   *     T->>S: getScripts()\n   *   end\n   *   alt styles flag is true\n   *     T->>St: getStyles()\n   *   end\n   *   alt docs flag is true\n   *     T->>D: getDocs()\n   *   end\n   *   alt workflows flag is true\n   *     T->>W: getWorkflows()\n   *   end\n   *   alt templates flag is true\n   *     T->>Te: getTemplates()\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof argzz]: unknown }\n  ) {\n    let { license } = args;\n    const { boot } = args;\n    let {\n      all,\n      scripts,\n      styles,\n      docs,\n      ide,\n      workflows,\n      templates,\n      docker,\n      typescript,\n      dependencies,\n      tests,\n      automation,\n      pkg,\n    } = args;\n    if (\n      scripts ||\n      styles ||\n      docs ||\n      ide ||\n      workflows ||\n      templates ||\n      docker ||\n      typescript ||\n      automation ||\n      dependencies ||\n      tests ||\n      pkg\n    )\n      all = false;\n\n    if (boot) {\n      const org = await this.getOrg();\n      const name = await UserInput.insistForText(\n        \"Project name\",\n        \"Enter the project name:\",\n        (res: string) => res.length > 1\n      );\n      const author = await UserInput.insistForText(\n        \"Author\",\n        \"Enter the author name:\",\n        (res: string) => res.length > 1\n      );\n      const pkgName = org ? `@${org}/${name}` : name;\n\n      await this.initPackage(pkgName, author, license as string);\n      await this.createTokenFiles();\n      await this.auditFix();\n      this.patchFiles();\n    }\n\n    if (all) {\n      scripts = false;\n      styles = true;\n      docs = true;\n      ide = true;\n      workflows = true;\n      templates = true;\n      docker = true;\n      typescript = true;\n      pkg = true;\n      dependencies = true;\n      tests = true;\n      automation = false;\n    }\n\n    if (typeof scripts === \"undefined\")\n      scripts = await UserInput.askConfirmation(\n        \"scripts\",\n        \"Do you want to get scripts?\",\n        true\n      );\n\n    if (scripts) await this.getScripts();\n\n    this.loadValuesFromPackage();\n    if (!all && typeof license === \"undefined\") {\n      const confirmation = await UserInput.askConfirmation(\n        \"license\",\n        \"Do you want to set a license?\",\n        true\n      );\n      if (confirmation)\n        license = await UserInput.insistForText(\n          \"license\",\n          \"Enter the desired License (MIT|GPL|Apache|LGPL|AGPL):\",\n          (val) => !!val && !!val.match(/^(MIT|GPL|Apache|LGPL|AGPL)$/g)\n        );\n    }\n    if (typeof license !== \"undefined\")\n      await this.getLicense(\n        license as \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"\n      );\n\n    if (typeof ide === \"undefined\")\n      ide = await UserInput.askConfirmation(\n        \"ide\",\n        \"Do you want to get ide configs?\",\n        true\n      );\n\n    if (ide) await this.getIde();\n\n    if (typeof typescript === \"undefined\")\n      typescript = await UserInput.askConfirmation(\n        \"typescript\",\n        \"Do you want to get typescript configs?\",\n        true\n      );\n    if (typescript) await this.getTypescript();\n\n    if (typeof docker === \"undefined\")\n      docker = await UserInput.askConfirmation(\n        \"docker\",\n        \"Do you want to get docker configs?\",\n        true\n      );\n\n    if (docker) await this.getDocker();\n    if (typeof automation === \"undefined\")\n      automation = await UserInput.askConfirmation(\n        \"automation\",\n        \"Do you want to get automation configs?\",\n        true\n      );\n    if (automation) await this.getAutomation();\n\n    if (typeof styles === \"undefined\")\n      styles = await UserInput.askConfirmation(\n        \"styles\",\n        \"Do you want to get styles?\",\n        true\n      );\n    if (styles) await this.getStyles();\n\n    if (typeof docs === \"undefined\")\n      docs = await UserInput.askConfirmation(\n        \"docs\",\n        \"Do you want to get docs?\",\n        true\n      );\n    if (docs) await this.getDocs();\n    if (typeof workflows === \"undefined\")\n      workflows = await UserInput.askConfirmation(\n        \"workflows\",\n        \"Do you want to get workflows?\",\n        true\n      );\n    if (workflows) await this.getWorkflows();\n    if (typeof templates === \"undefined\")\n      templates = await UserInput.askConfirmation(\n        \"templates\",\n        \"Do you want to get templates?\",\n        true\n      );\n    if (templates) await this.getTemplates();\n    if (typeof pkg === \"undefined\")\n      pkg = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your package.json scripts?\",\n        true\n      );\n    if (pkg) await this.updatePackageScrips();\n\n    if (typeof tests === \"undefined\")\n      tests = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your test configs?\",\n        true\n      );\n    if (tests) await this.getTests();\n\n    if (typeof dependencies === \"undefined\")\n      dependencies = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update dev dependencies?\",\n        true\n      );\n    if (dependencies) await this.updateDependencies();\n  }\n}\n","import { StandardOutputWriter } from \"./StandardOutputWriter\";\nimport { PromiseExecutor } from \"../utils/types\";\n\n/**\n * @description A specialized output writer that uses regular expressions to process output.\n * @summary This class extends StandardOutputWriter to provide regex-based output processing.\n * It allows for pattern matching in the output stream and can trigger specific actions\n * based on matched patterns.\n *\n * @template T - The type of the resolved value, defaulting to string.\n *\n * @param lock - A PromiseExecutor to control the asynchronous flow.\n * @param regexp - A string or RegExp to match against the output.\n * @param flags - Optional flags for the RegExp constructor.\n *\n * @class\n */\nexport class RegexpOutputWriter extends StandardOutputWriter<string> {\n  /**\n   * @description The regular expression used for matching output.\n   * @summary This readonly property stores the compiled RegExp used for pattern matching.\n   */\n  protected readonly regexp: RegExp;\n\n  /**\n   * @description Initializes a new instance of RegexpOutputWriter.\n   * @summary Constructs the RegexpOutputWriter with a lock mechanism and a regular expression.\n   *\n   * @param cmd\n   * @param lock - A PromiseExecutor to control the asynchronous flow.\n   * @param regexp - A string or RegExp to match against the output.\n   * @param flags - Optional flags for the RegExp constructor, defaults to \"g\".\n   */\n  constructor(\n    cmd: string,\n    lock: PromiseExecutor<string, Error>,\n    regexp: string | RegExp,\n    flags = \"g\"\n  ) {\n    super(cmd, lock);\n    try {\n      this.regexp =\n        typeof regexp === \"string\" ? new RegExp(regexp, flags) : regexp;\n    } catch (e: unknown) {\n      throw new Error(`Invalid regular expression: ${e}`);\n    }\n  }\n\n  /**\n   * @description Tests the input data against the stored regular expression.\n   * @summary Executes the regular expression on the input data and returns the match result.\n   *\n   * @param data - The string to test against the regular expression.\n   * @return The result of the regular expression execution, or undefined if an error occurs.\n   */\n  private test(data: string) {\n    this.regexp.lastIndex = 0;\n    let match;\n    try {\n      match = this.regexp.exec(data);\n    } catch (e: unknown) {\n      return console.debug(`Failed to parse chunk: ${data}\\nError: ${e} `);\n    }\n    return match;\n  }\n\n  /**\n   * @description Tests the data and resolves the promise if a match is found.\n   * @summary Executes the test method and resolves the promise with the first match group if successful.\n   *\n   * @param data - The string to test against the regular expression.\n   */\n  protected testAndResolve(data: string) {\n    const match = this.test(data);\n    if (match) this.resolve(match[0]);\n  }\n\n  /**\n   * @description Tests the data and rejects the promise if a match is found.\n   * @summary Executes the test method and rejects the promise with the first match group if successful.\n   *\n   * @param data - The string to test against the regular expression.\n   */\n  protected testAndReject(data: string) {\n    const match = this.test(data);\n    if (match) this.reject(match[0]);\n  }\n\n  /**\n   * @description Processes incoming data chunks.\n   * @summary Calls the parent class data method and then tests the data for a match to potentially resolve the promise.\n   *\n   * @param chunk - The data chunk to process.\n   */\n  data(chunk: any) {\n    super.data(chunk);\n    this.testAndResolve(String(chunk));\n  }\n\n  /**\n   * @description Processes incoming error chunks.\n   * @summary Calls the parent class error method and then tests the data for a match to potentially reject the promise.\n   *\n   * @param chunk - The error chunk to process.\n   */\n  error(chunk: any) {\n    super.error(chunk);\n    this.testAndReject(String(chunk));\n  }\n}\n","export * from \"./cli\";\nexport * from \"./input\";\nexport * from \"./output\";\nexport * from \"./utils\";\nexport * from \"./writers\";\n\n/**\n * @module @decaf-ts/utils\n * @description\n * This module serves a light version of Decaf CLI tool, providing a comprehensive set of utilities\n * and functionalities for command-line interface operations. It encompasses several key components:\n *\n * 1. Input Handling: Manages user input and command-line arguments processing.\n * 2. Utility Functions: Offers a collection of helper functions and constants for various operations.\n * 3. Type Definitions: Defines custom types and interfaces used throughout the module.\n * 4. Output Management: Provides different output writing strategies for flexible console output handling.\n *\n * The module is designed to facilitate the creation of robust CLI applications by offering:\n * - Standardized input parsing and validation\n * - Consistent output formatting and handling\n * - Reusable utility functions for common CLI tasks\n * - Extensible architecture for adding new commands and features\n *\n * It supports various output modes, including standard console output and regular expression-based output,\n * allowing for versatile data presentation and processing. The modular structure enables easy maintenance\n * and extension of the CLI functionality.\n *\n * This module is particularly useful for developers building complex command-line tools that require\n * structured input handling, flexible output formatting, and a rich set of utility functions.\n */\n\n/**\n * @description Represents the current version of the module.\n * @summary This constant stores the version number of the @asdasdasd/utils module.\n * The actual version number is replaced during the build process,\n * with the placeholder \"##VERSION##\" being substituted with the current version.\n *\n * @const VERSION\n * @memberOf module:@decaf-ts/utils\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["options"],"mappings":"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"}
3830
+ export { AbortCode, BuildScripts, Command, DefaultCommandOptions, DefaultCommandValues, Encoding, Environment, HttpClient, NoCIFLag, RegexpOutputWriter, ReleaseScript, SemVersion, SemVersionRegex, SetupScriptKey, StandardOutputWriter, TemplateSync, Tokens, UserInput, VERSION, chainAbortController, copyFile, deletePath, escapeRegExp, getAllFiles, getDependencies, getPackage, getPackageVersion, getSlogan, installDependencies, installIfNotAvailable, lockify, normalizeImport, padEnd, patchFile, patchPlaceholders, patchString, printBanner, pushToGit, readFile, renameFile, runCommand, setPackageAttribute, spawnCommand, toCamelCase, toENVFormat, toKebabCase, toPascalCase, toSnakeCase, updateDependencies, writeFile };
3831
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"utils.esm.cjs","sources":["../src/input/input.ts","../src/cli/constants.ts","../src/utils/text.ts","../src/utils/constants.ts","../src/writers/StandardOutputWriter.ts","../src/utils/utils.ts","../src/utils/fs.ts","../src/output/common.ts","../src/utils/web.ts","../src/utils/environment.ts","../src/cli/command.ts","../src/utils/http.ts","../src/cli/commands/build-scripts.ts","../src/cli/commands/tag-release.ts","../src/cli/commands/update-scripts.ts","../src/writers/RegexpOutputWriter.ts","../src/index.ts"],"sourcesContent":["import {\n  Answers,\n  Choice,\n  Falsy,\n  InitialReturnValue,\n  PrevCaller,\n  PromptObject,\n  PromptType,\n  ValueOrFunc,\n} from \"prompts\";\nimport prompts from \"prompts\";\nimport { parseArgs, ParseArgsConfig } from \"util\";\nimport { Writable, Readable } from \"stream\";\nimport { Kleur, ParseArgsOptionsConfig, ParseArgsResult } from \"./types\";\nimport { Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Represents a user input prompt with various configuration options.\n * @summary This class provides a flexible interface for creating and managing user input prompts.\n * It implements the PromptObject interface from the 'prompts' library and offers methods to set\n * various properties of the prompt. The class also includes static methods for common input scenarios\n * and argument parsing.\n *\n * @template R - The type of the prompt name, extending string.\n *\n * @param name - The name of the prompt, used as the key in the returned answers object.\n *\n * @class\n */\nexport class UserInput<R extends string = string> implements PromptObject<R> {\n  private static readonly logger = Logging.for(UserInput);\n  /**\n   * @description The type of the prompt.\n   * @summary Determines the input method (e.g., text, number, confirm).\n   */\n  type: PromptType | Falsy | PrevCaller<R, PromptType | Falsy> = \"text\";\n\n  /**\n   * @description The name of the prompt.\n   * @summary Used as the key in the returned answers object.\n   */\n  name: ValueOrFunc<R>;\n\n  /**\n   * @description The message displayed to the user.\n   * @summary The question or instruction presented to the user.\n   */\n  message?: ValueOrFunc<string> | undefined;\n\n  /**\n   * @description The initial value of the prompt.\n   * @summary The default value presented to the user.\n   */\n  initial?:\n    | InitialReturnValue\n    | PrevCaller<R, InitialReturnValue | Promise<InitialReturnValue>>\n    | undefined;\n\n  /**\n   * @description The style of the prompt.\n   * @summary Determines the visual style of the prompt.\n   */\n  style?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The format function for the input.\n   * @summary A function to format the user's input before it's returned.\n   */\n  format?: PrevCaller<R, void> | undefined;\n\n  /**\n   * @description The validation function for the input.\n   * @summary A function to validate the user's input.\n   */\n  validate?:\n    | PrevCaller<R, boolean | string | Promise<boolean | string>>\n    | undefined;\n\n  /**\n   * @description The onState callback function.\n   * @summary A function called when the state of the prompt changes.\n   */\n  onState?: PrevCaller<R, void> | undefined;\n\n  onRender?: ((kleur: Kleur) => void) | undefined;\n\n  /**\n   * @description The minimum value for number inputs.\n   * @summary The lowest number the user can input.\n   */\n  min?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The maximum value for number inputs.\n   * @summary The highest number the user can input.\n   */\n  max?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description Whether to allow float values for number inputs.\n   * @summary If true, allows decimal numbers.\n   */\n  float?: boolean | PrevCaller<R, boolean | Falsy> | undefined;\n\n  /**\n   * @description The number of decimal places to round to for float inputs.\n   * @summary Determines the precision of float inputs.\n   */\n  round?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description Instructions for the user.\n   * @summary Additional guidance provided to the user.\n   */\n  instructions?: string | boolean | undefined;\n\n  /**\n   * @description The increment value for number inputs.\n   * @summary The step size when increasing or decreasing the number.\n   */\n  increment?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The separator for list inputs.\n   * @summary The character used to separate list items.\n   */\n  separator?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The active option style for select inputs.\n   * @summary The style applied to the currently selected option.\n   */\n  active?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The inactive option style for select inputs.\n   * @summary The style applied to non-selected options.\n   */\n  inactive?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  choices?: Choice[] | PrevCaller<R, Choice[] | Falsy> | undefined;\n\n  /**\n   * @description The hint text for the prompt.\n   * @summary Additional information displayed to the user.\n   */\n  hint?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The warning text for the prompt.\n   * @summary A warning message displayed to the user.\n   */\n  warn?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  suggest?: ((input: any, choices: Choice[]) => Promise<any>) | undefined;\n\n  /**\n   * @description The limit for list inputs.\n   * @summary The maximum number of items that can be selected.\n   */\n  limit?: number | PrevCaller<R, number | Falsy> | undefined;\n\n  /**\n   * @description The mask for password inputs.\n   * @summary The character used to hide the user's input.\n   */\n  mask?: string | PrevCaller<R, string | Falsy> | undefined;\n\n  /**\n   * @description The stdout stream for the prompt.\n   * @summary The output stream used by the prompt.\n   */\n  stdout?: Writable | undefined;\n\n  /**\n   * @description The stdin stream for the prompt.\n   * @summary The input stream used by the prompt.\n   */\n  stdin?: Readable | undefined;\n\n  /**\n   * @description Creates a new UserInput instance.\n   * @summary Initializes a new UserInput object with the given name.\n   *\n   * @param name - The name of the prompt.\n   */\n  constructor(name: ValueOrFunc<R>) {\n    this.name = name;\n  }\n\n  /**\n   * @description Sets the type of the prompt.\n   * @summary Configures the input method for the prompt.\n   *\n   * @param type - The type of the prompt.\n   * @returns This UserInput instance for method chaining.\n   */\n  setType(type: PromptType | Falsy | PrevCaller<R, PromptType | Falsy>): this {\n    UserInput.logger.verbose(`Setting type to: ${type}`);\n    this.type = type;\n    return this;\n  }\n\n  /**\n   * @description Sets the message of the prompt.\n   * @summary Configures the question or instruction presented to the user.\n   *\n   * @param value - The message to be displayed.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMessage(value: ValueOrFunc<string> | undefined): this {\n    UserInput.logger.verbose(`Setting message to: ${value}`);\n    this.message = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the initial value of the prompt.\n   * @summary Configures the default value presented to the user.\n   *\n   * @param value - The initial value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInitial(\n    value:\n      | InitialReturnValue\n      | PrevCaller<R, InitialReturnValue | Promise<InitialReturnValue>>\n      | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting initial value to: ${value}`);\n    this.initial = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the style of the prompt.\n   * @summary Configures the visual style of the prompt.\n   *\n   * @param value - The style to be applied.\n   * @returns This UserInput instance for method chaining.\n   */\n  setStyle(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting style to: ${value}`);\n    this.style = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the format function of the prompt.\n   * @summary Configures a function to format the user's input before it's returned.\n   *\n   * @param value - The format function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setFormat(value: PrevCaller<R, void> | undefined): this {\n    UserInput.logger.verbose(`Setting format function`);\n    this.format = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the validation function of the prompt.\n   * @summary Configures a function to validate the user's input.\n   *\n   * @param value - The validation function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setValidate(\n    value:\n      | PrevCaller<R, boolean | string | Promise<boolean | string>>\n      | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting validate function`);\n    this.validate = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the onState callback of the prompt.\n   * @summary Configures a function to be called when the state of the prompt changes.\n   *\n   * @param value - The onState callback function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setOnState(value: PrevCaller<R, void> | undefined): this {\n    UserInput.logger.verbose(`Setting onState callback`);\n    this.onState = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the onRender callback of the prompt.\n   * @summary Configures a function to be called when the prompt is rendered.\n   *\n   * @param value - The onRender callback function.\n   * @returns This UserInput instance for method chaining.\n   */\n  setOnRender(value: ((kleur: Kleur) => void) | undefined): this {\n    UserInput.logger.verbose(`Setting onRender callback`);\n    this.onRender = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the minimum value for number inputs.\n   * @summary Configures the lowest number the user can input.\n   *\n   * @param value - The minimum value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMin(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting min value to: ${value}`);\n    this.min = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the maximum value for number inputs.\n   * @summary Configures the highest number the user can input.\n   *\n   * @param value - The maximum value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setMax(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting max value to: ${value}`);\n    this.max = value;\n    return this;\n  }\n\n  /**\n   * @description Sets whether to allow float values for number inputs.\n   * @summary Configures whether decimal numbers are allowed.\n   *\n   * @param value - Whether to allow float values.\n   * @returns This UserInput instance for method chaining.\n   */\n  setFloat(value: boolean | PrevCaller<R, boolean | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting float to: ${value}`);\n    this.float = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the number of decimal places to round to for float inputs.\n   * @summary Configures the precision of float inputs.\n   *\n   * @param value - The number of decimal places.\n   * @returns This UserInput instance for method chaining.\n   */\n  setRound(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting round to: ${value}`);\n    this.round = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the instructions for the user.\n   * @summary Configures additional guidance provided to the user.\n   *\n   * @param value - The instructions.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInstructions(value: string | boolean | undefined): this {\n    UserInput.logger.verbose(`Setting instructions to: ${value}`);\n    this.instructions = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the increment value for number inputs.\n   * @summary Configures the step size when increasing or decreasing the number.\n   *\n   * @param value - The increment value.\n   * @returns This UserInput instance for method chaining.\n   */\n  setIncrement(\n    value: number | PrevCaller<R, number | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting increment to: ${value}`);\n    this.increment = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the separator for list inputs.\n   * @summary Configures the character used to separate list items.\n   *\n   * @param value - The separator character.\n   * @returns This UserInput instance for method chaining.\n   */\n  setSeparator(\n    value: string | PrevCaller<R, string | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting separator to: ${value}`);\n    this.separator = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the active option style for select inputs.\n   * @summary Configures the style applied to the currently selected option.\n   *\n   * @param value - The active option style.\n   * @returns This UserInput instance for method chaining.\n   */\n  setActive(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting active style to: ${value}`);\n    this.active = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the inactive option style for select inputs.\n   * @summary Configures the style applied to non-selected options.\n   *\n   * @param value - The inactive option style.\n   * @returns This UserInput instance for method chaining.\n   */\n  setInactive(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting inactive style to: ${value}`);\n    this.inactive = value;\n    return this;\n  }\n\n  setChoices(\n    value: Choice[] | PrevCaller<R, Choice[] | Falsy> | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting choices: ${JSON.stringify(value)}`);\n    this.choices = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the hint text for the prompt.\n   * @summary Configures additional information displayed to the user.\n   *\n   * @param value - The hint text.\n   * @returns This UserInput instance for method chaining.\n   */\n  setHint(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting hint to: ${value}`);\n    this.hint = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the warning text for the prompt.\n   * @summary Configures a warning message displayed to the user.\n   *\n   * @param value - The warning text.\n   * @returns This UserInput instance for method chaining.\n   */\n  setWarn(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting warn to: ${value}`);\n    this.warn = value;\n    return this;\n  }\n\n  setSuggest(\n    value: ((input: any, choices: Choice[]) => Promise<any>) | undefined\n  ): this {\n    UserInput.logger.verbose(`Setting suggest function`);\n    this.suggest = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the limit for list inputs.\n   * @summary Configures the maximum number of items that can be selected in list-type prompts.\n   * @template R - The type of the prompt name, extending string.\n   * @param value - The maximum number of items that can be selected, or a function to determine this value.\n   * @return This UserInput instance for method chaining.\n   */\n  setLimit(value: number | PrevCaller<R, number | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting limit to: ${value}`);\n    this.limit = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the mask for password inputs.\n   * @summary Configures the character used to hide the user's input in password-type prompts.\n   * @template R - The type of the prompt name, extending string.\n   * @param value - The character used to mask the input, or a function to determine this value.\n   * @return This UserInput instance for method chaining.\n   */\n  setMask(value: string | PrevCaller<R, string | Falsy> | undefined): this {\n    UserInput.logger.verbose(`Setting mask to: ${value}`);\n    this.mask = value;\n    return this;\n  }\n\n  /**\n   * @description Sets the stdout stream for the prompt.\n   * @summary Configures the output stream used by the prompt for displaying messages and results.\n   * @param value - The Writable stream to be used as stdout.\n   * @return This UserInput instance for method chaining.\n   */\n  setStdout(value: Writable | undefined): this {\n    UserInput.logger.verbose(`Setting stdout stream`);\n    this.stdout = value;\n    return this;\n  }\n  /**\n   * @description Sets the stdin stream for the prompt.\n   * @summary Configures the input stream used by the prompt for receiving user input.\n   * @param value - The Readable stream to be used as stdin.\n   * @return This UserInput instance for method chaining.\n   */\n  setStdin(value: Readable | undefined): this {\n    this.stdin = value;\n    return this;\n  }\n\n  /**\n   * @description Asks the user for input based on the current UserInput configuration.\n   * @summary Prompts the user and returns their response as a single value.\n   * @template R - The type of the prompt name, extending string.\n   * @return A Promise that resolves to the user's answer.\n   */\n  async ask() {\n    return (await UserInput.ask(this))[this.name as keyof Answers<R>];\n  }\n\n  /**\n   * @description Asks the user one or more questions based on the provided UserInput configurations.\n   * @summary Prompts the user with one or more questions and returns their answers as an object.\n   * @template R - The type of the prompt name, extending string.\n   * @param question - A single UserInput instance or an array of UserInput instances.\n   * @return A Promise that resolves to an object containing the user's answers.\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant A as ask method\n   *   participant P as prompts library\n   *   A->>P: Call prompts with question(s)\n   *   P->>U: Display prompt(s)\n   *   U->>P: Provide input\n   *   P->>A: Return answers\n   *   A->>A: Process answers\n   *   A-->>Caller: Return processed answers\n   */\n  static async ask<R extends string = string>(\n    question: UserInput<R> | UserInput<R>[]\n  ) {\n    const log = UserInput.logger.for(this.ask);\n    if (!Array.isArray(question)) {\n      question = [question];\n    }\n    let answers: Answers<R>;\n    try {\n      log.verbose(\n        `Asking questions: ${question.map((q) => q.name).join(\", \")}`\n      );\n      answers = await prompts(question);\n      log.verbose(`Received answers: ${JSON.stringify(answers, null, 2)}`);\n    } catch (error: unknown) {\n      throw new Error(`Error while getting input: ${error}`);\n    }\n    return answers;\n  }\n\n  /**\n   * @description Asks the user for a number input.\n   * @summary Prompts the user to enter a number, with optional minimum, maximum, and initial values.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param min - The minimum allowed value (optional).\n   * @param max - The maximum allowed value (optional).\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to the number entered by the user.\n   */\n  static async askNumber(\n    name: string,\n    question: string,\n    min?: number,\n    max?: number,\n    initial?: number\n  ): Promise<number> {\n    const log = UserInput.logger.for(this.askNumber);\n    log.verbose(\n      `Asking number input: undefined, question: ${question}, min: ${min}, max: ${max}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"number\");\n\n    if (typeof min === \"number\") userInput.setMin(min);\n\n    if (typeof max === \"number\") userInput.setMax(max);\n\n    if (typeof initial === \"number\") userInput.setInitial(initial);\n\n    return (await this.ask(userInput))[name];\n  }\n\n  /**\n   * @description Asks the user for a text input.\n   * @summary Prompts the user to enter text, with optional masking and initial value.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param mask - The character used to mask the input (optional, for password-like inputs).\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to the text entered by the user.\n   */\n  static async askText(\n    name: string,\n    question: string,\n    mask: string | undefined = undefined,\n    initial?: string\n  ): Promise<string> {\n    const log = UserInput.logger.for(this.askText);\n    log.verbose(\n      `Asking text input: undefined, question: ${question}, mask: ${mask}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name).setMessage(question);\n\n    if (mask) userInput.setMask(mask);\n    if (typeof initial === \"string\") userInput.setInitial(initial);\n    return (await this.ask(userInput))[name];\n  }\n\n  /**\n   * @description Asks the user for a confirmation (yes/no).\n   * @summary Prompts the user with a yes/no question and returns a boolean result.\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param initial - The initial value presented to the user (optional).\n   * @return A Promise that resolves to a boolean representing the user's answer.\n   */\n  static async askConfirmation(\n    name: string,\n    question: string,\n    initial?: boolean\n  ): Promise<boolean> {\n    const log = UserInput.logger.for(this.askConfirmation);\n    log.verbose(\n      `Asking confirmation input: undefined, question: ${question}, initial: ${initial}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"confirm\");\n\n    if (typeof initial !== \"undefined\") userInput.setInitial(initial);\n    return (await this.ask(userInput))[name];\n  }\n  /**\n   * @description Repeatedly asks for input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid input from the user, allowing for a specified number of attempts.\n   *\n   * @template R - The type of the expected result.\n   * @param input - The UserInput instance to use for prompting.\n   * @param test - A function to validate the user's input.\n   * @param limit - The maximum number of attempts allowed (default is 1).\n   * @param defaultConfirmation\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant U as User\n   *   participant I as insist method\n   *   participant A as ask method\n   *   participant T as test function\n   *   participant C as askConfirmation method\n   *   loop Until valid input or limit reached\n   *     I->>A: Call ask with input\n   *     A->>U: Prompt user\n   *     U->>A: Provide input\n   *     A->>I: Return result\n   *     I->>T: Test result\n   *     alt Test passes\n   *       I->>C: Ask for confirmation\n   *       C->>U: Confirm input\n   *       U->>C: Provide confirmation\n   *       C->>I: Return confirmation\n   *       alt Confirmed\n   *         I-->>Caller: Return valid result\n   *       else Not confirmed\n   *         I->>I: Continue loop\n   *       end\n   *     else Test fails\n   *       I->>I: Continue loop\n   *     end\n   *   end\n   *   I-->>Caller: Return undefined if limit reached\n   */\n  static async insist<R>(\n    input: UserInput,\n    test: (res: string | number) => boolean,\n    defaultConfirmation: boolean,\n    limit = 1\n  ): Promise<R | undefined> {\n    const log = UserInput.logger.for(this.insist);\n    log.verbose(\n      `Insisting on input: ${input.name}, test: ${test.toString()}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    let result: string | number | undefined = undefined;\n    let count = 0;\n    let confirmation: boolean;\n    try {\n      do {\n        result = (await UserInput.ask(input))[\n          input.name as keyof Answers<string>\n        ] as string;\n        if (!test(result)) {\n          result = undefined;\n          continue;\n        }\n        confirmation = await UserInput.askConfirmation(\n          `${input.name}-confirm`,\n          `Is the ${input.type} correct?`,\n          defaultConfirmation\n        );\n        if (!confirmation) result = undefined;\n      } while (typeof result === \"undefined\" && limit > 1 && count++ < limit);\n    } catch (e: unknown) {\n      log.error(`Error while insisting: ${e}`);\n      throw e;\n    }\n\n    if (typeof result === \"undefined\") log.info(\"no selection...\");\n    return result as R | undefined;\n  }\n  /**\n   * @description Repeatedly asks for text input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid text input from the user, allowing for a specified number of attempts.\n   *\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param test - A function to validate the user's input.\n   * @param mask - The character used to mask the input (optional, for password-like inputs).\n   * @param initial - The initial value presented to the user (optional).\n   * @param defaultConfirmation\n   * @param limit - The maximum number of attempts allowed (default is -1, meaning unlimited).\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   */\n  static async insistForText(\n    name: string,\n    question: string,\n    test: (res: string) => boolean,\n    mask: string | undefined = undefined,\n    initial?: string,\n    defaultConfirmation = false,\n    limit = -1\n  ): Promise<string> {\n    const log = UserInput.logger.for(this.insistForText);\n    log.verbose(\n      `Insisting for text input: undefined, question: ${question}, test: ${test.toString()}, mask: ${mask}, initial: ${initial}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    const userInput = new UserInput(name).setMessage(question);\n\n    if (mask) userInput.setMask(mask);\n    if (typeof initial === \"string\") userInput.setInitial(initial);\n    return (await this.insist(\n      userInput,\n      test as (res: string | number) => boolean,\n      defaultConfirmation,\n      limit\n    )) as string;\n  }\n  /**\n   * @description Repeatedly asks for number input until a valid response is given or the limit is reached.\n   * @summary This method insists on getting a valid number input from the user, allowing for a specified number of attempts.\n   *\n   * @param name - The name of the prompt, used as the key in the returned answers object.\n   * @param question - The message displayed to the user.\n   * @param test - A function to validate the user's input.\n   * @param min - The minimum allowed value (optional).\n   * @param max - The maximum allowed value (optional).\n   * @param initial - The initial value presented to the user (optional).\n   * @param defaultConfirmation\n   * @param limit - The maximum number of attempts allowed (default is -1, meaning unlimited).\n   * @return A Promise that resolves to the valid input or undefined if the limit is reached.\n   */\n  static async insistForNumber(\n    name: string,\n    question: string,\n    test: (res: number) => boolean,\n    min?: number,\n    max?: number,\n    initial?: number,\n    defaultConfirmation = false,\n    limit = -1\n  ): Promise<number> {\n    const log = UserInput.logger.for(this.insistForNumber);\n    log.verbose(\n      `Insisting for number input: undefined, question: ${question}, test: ${test.toString()}, min: ${min}, max: ${max}, initial: ${initial}, defaultConfirmation: ${defaultConfirmation}, limit: ${limit}`\n    );\n    const userInput = new UserInput(name)\n      .setMessage(question)\n      .setType(\"number\");\n\n    if (typeof min === \"number\") userInput.setMin(min);\n\n    if (typeof max === \"number\") userInput.setMax(max);\n\n    if (typeof initial === \"number\") userInput.setInitial(initial);\n    return (await this.insist(\n      userInput,\n      test as (res: string | number) => boolean,\n      defaultConfirmation,\n      limit\n    )) as number;\n  }\n\n  /**\n   * @description Parses command-line arguments based on the provided options.\n   * @summary Uses Node.js's util.parseArgs to parse command-line arguments and return the result.\n   * @param options - Configuration options for parsing arguments.\n   * @return An object containing the parsed arguments.\n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Caller\n   *   participant P as parseArgs method\n   *   participant U as util.parseArgs\n   *   C->>P: Call with options\n   *   P->>P: Prepare args object\n   *   P->>U: Call parseArgs with prepared args\n   *   U->>P: Return parsed result\n   *   P-->>C: Return ParseArgsResult\n   */\n  static parseArgs(options: ParseArgsOptionsConfig): ParseArgsResult {\n    const log = UserInput.logger.for(this.parseArgs);\n    const args: ParseArgsConfig = {\n      args: process.argv.slice(2),\n      options: options,\n    };\n    log.debug(`Parsing arguments: ${JSON.stringify(args, null, 2)}`);\n    try {\n      return parseArgs(args);\n    } catch (error: unknown) {\n      log.debug(\n        `Error while parsing arguments:\\n${JSON.stringify(args, null, 2)}\\n | options\\n${JSON.stringify(options, null, 2)}\\n | ${error}`\n      );\n      throw new Error(`Error while parsing arguments: ${error}`);\n    }\n  }\n}\n","/**\n * @description Default command options for CLI commands.\n * @summary Defines the structure and default values for common command-line options used across various CLI commands.\n * @const DefaultCommandOptions\n * @typedef {Object} DefaultCommandOptions\n * @property {Object} verbose - Verbosity level option.\n * @property {string} verbose.type - The type of the verbose option (number).\n * @property {string} verbose.short - The short flag for the verbose option (V).\n * @property {number} verbose.default - The default value for verbosity (0).\n * @property {Object} version - Version display option.\n * @property {string} version.type - The type of the version option (boolean).\n * @property {string} version.short - The short flag for the version option (v).\n * @property {undefined} version.default - The default value for version display (undefined).\n * @property {Object} help - Help display option.\n * @property {string} help.type - The type of the help option (boolean).\n * @property {string} help.short - The short flag for the help option (h).\n * @property {boolean} help.default - The default value for help display (false).\n * @property {Object} logLevel - Log level option.\n * @property {string} logLevel.type - The type of the logLevel option (string).\n * @property {string} logLevel.default - The default value for log level (\"info\").\n * @property {Object} logStyle - Log styling option.\n * @property {string} logStyle.type - The type of the logStyle option (boolean).\n * @property {boolean} logStyle.default - The default value for log styling (true).\n * @property {Object} timestamp - Timestamp display option.\n * @property {string} timestamp.type - The type of the timestamp option (boolean).\n * @property {boolean} timestamp.default - The default value for timestamp display (true).\n * @property {Object} banner - Banner display option.\n * @property {string} banner.type - The type of the banner option (boolean).\n * @property {boolean} banner.default - The default value for banner display (false).\n */\nexport const DefaultCommandOptions = {\n  verbose: {\n    type: \"boolean\",\n    short: \"V\",\n    default: undefined,\n  },\n  version: {\n    type: \"boolean\",\n    short: \"v\",\n    default: undefined,\n  },\n  help: {\n    type: \"boolean\",\n    short: \"h\",\n    default: false,\n  },\n  logLevel: {\n    type: \"string\",\n    default: \"info\",\n  },\n  logStyle: {\n    type: \"boolean\",\n    default: true,\n  },\n  timestamp: {\n    type: \"boolean\",\n    default: true,\n  },\n  banner: {\n    type: \"boolean\",\n    default: true,\n  },\n};\n\n/**\n * @description Default command values derived from DefaultCommandOptions.\n * @summary Creates an object with the default values of all options defined in DefaultCommandOptions.\n * @const DefaultCommandValues\n * @typedef {Object} DefaultCommandValues\n * @property {unknown} [key: string] - The default value for each option in DefaultCommandOptions.\n */\nexport const DefaultCommandValues: {\n  [k in keyof typeof DefaultCommandOptions]: unknown;\n} = Object.keys(DefaultCommandOptions).reduce(\n  (acc: Record<keyof typeof DefaultCommandOptions, unknown>, key: string) => {\n    acc[key as keyof typeof DefaultCommandOptions] =\n      DefaultCommandOptions[key as keyof typeof DefaultCommandOptions].default;\n    return acc;\n  },\n  {} as Record<keyof typeof DefaultCommandValues, unknown>\n);\n","/**\n * @description Pads the end of a string with a specified character.\n * @summary Extends the input string to a specified length by adding a padding character to the end.\n * If the input string is already longer than the specified length, it is returned unchanged.\n *\n * @param {string} str - The input string to be padded.\n * @param {number} length - The desired total length of the resulting string.\n * @param {string} [char=\" \"] - The character to use for padding. Defaults to a space.\n * @return {string} The padded string.\n * @throws {Error} If the padding character is not exactly one character long.\n *\n * @function padEnd\n *\n * @memberOf module:TextUtils\n */\nexport function padEnd(\n  str: string,\n  length: number,\n  char: string = \" \"\n): string {\n  if (char.length !== 1)\n    throw new Error(\"Invalid character length for padding. must be one!\");\n  return str.padEnd(length, char);\n}\n\n/**\n * @description Replaces placeholders in a string with provided values.\n * @summary Interpolates a string by replacing placeholders of the form ${variableName}\n * with corresponding values from the provided object. If a placeholder doesn't have\n * a corresponding value, it is left unchanged in the string.\n *\n * @param {string} input - The input string containing placeholders to be replaced.\n * @param {Record<string, number | string>} values - An object containing key-value pairs for replacement.\n * @return {string} The interpolated string with placeholders replaced by their corresponding values.\n *\n * @function patchPlaceholders\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchString\n *   participant String.replace\n *   Caller->>patchString: Call with input and values\n *   patchString->>String.replace: Call with regex and replacement function\n *   String.replace->>patchString: Return replaced string\n *   patchString-->>Caller: Return patched string\n *\n * @memberOf module:TextUtils\n */\nexport function patchPlaceholders(\n  input: string,\n  values: Record<string, number | string>\n): string {\n  return input.replace(\n    /\\$\\{([a-zA-Z0-9_]+)\\}/g,\n    (match, variable) => (values[variable as string] as string) || match\n  );\n}\n\nexport function patchString(\n  input: string,\n  values: Record<string, number | string>,\n  flags: string = \"g\"\n): string {\n  Object.entries(values).forEach(([key, val]) => {\n    const regexp = new RegExp(escapeRegExp(key), flags);\n    input = input.replace(regexp, val as string);\n  });\n  return input;\n}\n\n/**\n * @description Converts a string to camelCase.\n * @summary Transforms the input string into camelCase format, where words are joined without spaces\n * and each word after the first starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to camelCase.\n *\n * @function toCamelCase\n *\n * @memberOf module:TextUtils\n */\nexport function toCamelCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word, index) =>\n      index === 0 ? word.toLowerCase() : word.toUpperCase()\n    )\n    .replace(/\\s+/g, \"\");\n}\n\n/**\n * @description Converts a string to ENVIRONMENT_VARIABLE format.\n * @summary Transforms the input string into uppercase with words separated by underscores,\n * typically used for environment variable names.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to ENVIRONMENT_VARIABLE format.\n *\n * @function toENVFormat\n *\n * @memberOf module:TextUtils\n */\nexport function toENVFormat(text: string): string {\n  return toSnakeCase(text).toUpperCase();\n}\n\n/**\n * @description Converts a string to snake_case.\n * @summary Transforms the input string into lowercase with words separated by underscores.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to snake_case.\n *\n * @function toSnakeCase\n *\n * @memberOf module:TextUtils\n */\nexport function toSnakeCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1_$2\")\n    .replace(/[\\s-]+/g, \"_\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to kebab-case.\n * @summary Transforms the input string into lowercase with words separated by hyphens.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to kebab-case.\n *\n * @function toKebabCase\n *\n * @memberOf module:TextUtils\n */\nexport function toKebabCase(text: string): string {\n  return text\n    .replace(/([a-z])([A-Z])/g, \"$1-$2\")\n    .replace(/[\\s_]+/g, \"-\")\n    .toLowerCase();\n}\n\n/**\n * @description Converts a string to PascalCase.\n * @summary Transforms the input string into PascalCase format, where words are joined without spaces\n * and each word starts with a capital letter.\n *\n * @param {string} text - The input string to be converted.\n * @return {string} The input string converted to PascalCase.\n *\n * @function toPascalCase\n *\n * @memberOf module:TextUtils\n */\nexport function toPascalCase(text: string): string {\n  return text\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word) => word.toUpperCase())\n    .replace(/\\s+/g, \"\");\n}\n\nexport function escapeRegExp(string: string) {\n  return string.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\"); // $& means the whole matched string\n}\n","/**\n * @description Default encoding for text operations.\n * @summary The standard UTF-8 encoding used for text processing.\n * @const {string} Encoding\n * @memberOf @decaf-ts/utils\n */\nexport const Encoding = \"utf-8\";\n\n/**\n * @description Regular expression for semantic versioning.\n * @summary A regex pattern to match and parse semantic version strings.\n * @const {RegExp} SemVersionRegex\n * @memberOf @decaf-ts/utils\n */\nexport const SemVersionRegex =\n  /^(\\d+)\\.(\\d+)\\.(\\d+)(?:-([0-9A-Za-z-]+(?:\\.[0-9A-Za-z])))/g;\n\n/**\n * @description Enum for semantic version components.\n * @summary Defines the three levels of semantic versioning: PATCH, MINOR, and MAJOR.\n * @enum {string}\n * @memberOf @decaf-ts/utils\n */\nexport enum SemVersion {\n  /** Patch version for backwards-compatible bug fixes. */\n  PATCH = \"patch\",\n  /** Minor version for backwards-compatible new features. */\n  MINOR = \"minor\",\n  /** Major version for changes that break backwards compatibility. */\n  MAJOR = \"major\",\n}\n\n/**\n * @description Flag to indicate non-CI environment.\n * @summary Used to specify that a command should run outside of a Continuous Integration environment.\n * @const {string} NoCIFLag\n * @memberOf @decaf-ts/utils\n */\nexport const NoCIFLag = \"-no-ci\";\n\n/**\n * @description Key for the setup script in package.json.\n * @summary Identifies the script that runs after package installation.\n * @const {string} SetupScriptKey\n * @memberOf @decaf-ts/utils\n */\nexport const SetupScriptKey = \"postinstall\";\n\n/**\n * @description Enum for various authentication tokens.\n * @summary Defines the file names for storing different types of authentication tokens.\n * @enum {string}\n * @memberOf @decaf-ts/utils\n */\nexport enum Tokens {\n  /** Git authentication token file name. */\n  GIT = \".token\",\n  /** NPM authentication token file name. */\n  NPM = \".npmtoken\",\n  /** Docker authentication token file name. */\n  DOCKER = \".dockertoken\",\n  /** Confluence authentication token file name. */\n  CONFLUENCE = \".confluence-token\",\n}\n\nexport const AbortCode = \"Aborted\";\n","import { Encoding } from \"../utils/constants\";\nimport { OutputWriter } from \"./OutputWriter\";\nimport { PromiseExecutor } from \"../utils/types\";\nimport { OutputType } from \"./types\";\nimport { style } from \"styled-string-builder\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description A standard output writer for handling command execution output.\n * @summary This class implements the OutputWriter interface and provides methods for\n * handling various types of output from command execution, including standard output,\n * error output, and exit codes. It also includes utility methods for parsing commands\n * and resolving or rejecting promises based on execution results.\n *\n * @template R - The type of the resolved value, defaulting to number.\n *\n * @param lock - A PromiseExecutor to control the asynchronous flow.\n * @param args - Additional arguments (unused in the current implementation).\n *\n * @class\n */\nexport class StandardOutputWriter<R = string> implements OutputWriter {\n  protected logger: Logger;\n\n  /**\n   * @description Initializes a new instance of StandardOutputWriter.\n   * @summary Constructs the StandardOutputWriter with a lock mechanism and optional arguments.\n   *\n   * @param cmd\n   * @param lock - A PromiseExecutor to control the asynchronous flow.\n   * @param args - Additional arguments (currently unused).\n   */\n  constructor(\n    protected cmd: string,\n    protected lock: PromiseExecutor<R>,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    ...args: unknown[]\n  ) {\n    this.logger = Logging.for(this.cmd);\n  }\n\n  /**\n   * @description Logs output to the console.\n   * @summary Formats and logs the given data with a timestamp and type indicator.\n   *\n   * @param type - The type of output (stdout or stderr).\n   * @param data - The data to be logged.\n   */\n  protected log(type: OutputType, data: string | Buffer) {\n    data = Buffer.isBuffer(data) ? data.toString(Encoding) : data;\n    const log = type === \"stderr\" ? style(data).red.text : data;\n    this.logger.info(log);\n  }\n\n  /**\n   * @description Handles standard output data.\n   * @summary Logs the given chunk as standard output.\n   *\n   * @param chunk - The data chunk to be logged.\n   */\n  data(chunk: any) {\n    this.log(\"stdout\", String(chunk));\n  }\n\n  /**\n   * @description Handles error output data.\n   * @summary Logs the given chunk as error output.\n   *\n   * @param chunk - The error data chunk to be logged.\n   */\n  error(chunk: any) {\n    this.log(\"stderr\", String(chunk));\n  }\n\n  /**\n   * @description Handles error objects.\n   * @summary Logs the error message from the given Error object.\n   *\n   * @param err - The Error object to be logged.\n   */\n  errors(err: Error) {\n    this.log(\"stderr\", `Error executing command exited : ${err}`);\n  }\n\n  /**\n   * @description Handles the exit of a command.\n   * @summary Logs the exit code and resolves or rejects the promise based on the code.\n   *\n   * @param code - The exit code of the command.\n   * @param logs\n   */\n  exit(code: number | string, logs: string[]) {\n    this.log(\n      \"stdout\",\n      `command exited code : ${code === 0 ? style(code.toString()).green.text : style(code === null ? \"null\" : code.toString()).red.text}`\n    );\n    if (code === 0) {\n      this.resolve(logs.map((l) => l.trim()).join(\"\\n\") as R);\n    } else {\n      this.reject(new Error(logs.length ? logs.join(\"\\n\") : code.toString()));\n    }\n  }\n\n  /**\n   * @description Parses a command string or array into components.\n   * @summary Converts the command into a consistent format and stores it, then returns it split into command and arguments.\n   *\n   * @param command - The command as a string or array of strings.\n   * @return A tuple containing the command and its arguments as separate elements.\n   */\n  parseCommand(command: string | string[]): [string, string[]] {\n    command = typeof command === \"string\" ? command.split(\" \") : command;\n    this.cmd = command.join(\" \");\n    return [command[0], command.slice(1)];\n  }\n\n  /**\n   * @description Resolves the promise with a success message.\n   * @summary Logs a success message and resolves the promise with the given reason.\n   *\n   * @param reason - The reason for resolving the promise.\n   */\n  protected resolve(reason: R) {\n    this.log(\n      \"stdout\",\n      `${this.cmd} executed successfully: ${style(reason ? \"ran to completion\" : (reason as string)).green}`\n    );\n    this.lock.resolve(reason);\n  }\n\n  /**\n   * @description Rejects the promise with an error message.\n   * @summary Logs an error message and rejects the promise with the given reason.\n   *\n   * @param reason - The reason for rejecting the promise, either a number (exit code) or a string.\n   */\n  protected reject(reason: number | string | Error) {\n    if (!(reason instanceof Error)) {\n      reason = new Error(\n        typeof reason === \"number\" ? `Exit code ${reason}` : reason\n      );\n    }\n    this.log(\n      \"stderr\",\n      `${this.cmd} failed to execute: ${style(reason.message).red}`\n    );\n    this.lock.reject(reason);\n  }\n}\n","import {\n  ChildProcessWithoutNullStreams,\n  spawn,\n  SpawnOptionsWithoutStdio,\n} from \"child_process\";\nimport { StandardOutputWriter } from \"../writers/StandardOutputWriter\";\nimport { CommandResult } from \"./types\";\nimport { OutputWriterConstructor } from \"../writers/types\";\nimport { AbortCode } from \"./constants\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description Creates a locked version of a function.\n * @summary This higher-order function takes a function and returns a new function that ensures\n * sequential execution of the original function, even when called multiple times concurrently.\n * It uses a Promise-based locking mechanism to queue function calls.\n *\n * @template R - The return type of the input function.\n *\n * @param f - The function to be locked. It can take any number of parameters and return a value of type R.\n * @return A new function with the same signature as the input function, but with sequential execution guaranteed.\n *\n * @function lockify\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant LockedFunction\n *   participant OriginalFunction\n *   Caller->>LockedFunction: Call with params\n *   LockedFunction->>LockedFunction: Check current lock\n *   alt Lock is resolved\n *     LockedFunction->>OriginalFunction: Execute with params\n *     OriginalFunction-->>LockedFunction: Return result\n *     LockedFunction-->>Caller: Return result\n *   else Lock is pending\n *     LockedFunction->>LockedFunction: Queue execution\n *     LockedFunction-->>Caller: Return promise\n *     Note over LockedFunction: Wait for previous execution\n *     LockedFunction->>OriginalFunction: Execute with params\n *     OriginalFunction-->>LockedFunction: Return result\n *     LockedFunction-->>Caller: Resolve promise with result\n *   end\n *   LockedFunction->>LockedFunction: Update lock\n *\n * @memberOf @decaf-ts/utils\n */\nexport function lockify<R>(f: (...params: unknown[]) => R) {\n  let lock: Promise<R | void> = Promise.resolve();\n  return (...params: unknown[]) => {\n    const result = lock.then(() => f(...params));\n    lock = result.catch(() => {});\n    return result;\n  };\n}\n\nexport function chainAbortController(\n  controller: AbortController,\n  ...signals: AbortSignal[]\n): AbortController;\nexport function chainAbortController(\n  ...signals: AbortSignal[]\n): AbortController;\nexport function chainAbortController(\n  argument0: AbortController | AbortSignal,\n  ...remainder: AbortSignal[]\n): AbortController {\n  let signals: AbortSignal[];\n  let controller: AbortController;\n\n  // normalize args\n  if (argument0 instanceof AbortSignal) {\n    controller = new AbortController();\n    signals = [argument0, ...remainder];\n  } else {\n    controller = argument0;\n    signals = remainder;\n  }\n\n  // if the controller is already aborted, exit early\n  if (controller.signal.aborted) {\n    return controller;\n  }\n\n  const handler = () => controller.abort();\n\n  for (const signal of signals) {\n    // check before adding! (and assume there is no possible way that the signal could\n    // abort between the `if` check and adding the event listener)\n    if (signal.aborted) {\n      controller.abort();\n      break;\n    }\n    signal.addEventListener(\"abort\", handler, {\n      once: true,\n      signal: controller.signal,\n    });\n  }\n\n  return controller;\n}\n\nexport function spawnCommand<R = string>(\n  output: StandardOutputWriter<R>,\n  command: string,\n  opts: SpawnOptionsWithoutStdio,\n  abort: AbortController,\n  logger: Logger\n): ChildProcessWithoutNullStreams {\n  function spawnInner(command: string, controller: AbortController) {\n    const [cmd, argz] = output.parseCommand(command);\n    logger.info(`Running command: ${cmd}`);\n    logger.debug(`with args: ${argz.join(\" \")}`);\n    const childProcess = spawn(cmd, argz, {\n      ...opts,\n      cwd: opts.cwd || process.cwd(),\n      env: Object.assign({}, process.env, opts.env, { PATH: process.env.PATH }),\n      shell: opts.shell || false,\n      signal: controller.signal,\n    });\n    logger.verbose(`pid : ${childProcess.pid}`);\n    return childProcess;\n  }\n\n  const m = command.match(/[<>$#]/g);\n  if (m)\n    throw new Error(\n      `Invalid command: ${command}. contains invalid characters: ${m}`\n    );\n  if (command.includes(\" | \")) {\n    const cmds = command.split(\" | \");\n    const spawns = [];\n    const controllers = new Array(cmds.length);\n    controllers[0] = abort;\n    for (let i = 0; i < cmds.length; i++) {\n      if (i !== 0)\n        controllers[i] = chainAbortController(controllers[i - 1].signal);\n      spawns.push(spawnInner(cmds[i], controllers[i]));\n      if (i === 0) continue;\n      spawns[i - 1].stdout.pipe(spawns[i].stdin);\n    }\n    return spawns[cmds.length - 1];\n  }\n\n  return spawnInner(command, abort);\n}\n\n/**\n * @description Executes a command asynchronously with customizable output handling.\n * @summary This function runs a shell command as a child process, providing fine-grained\n * control over its execution and output handling. It supports custom output writers,\n * allows for command abortion, and captures both stdout and stderr.\n *\n * @template R - The type of the resolved value from the command execution.\n *\n * @param command - The command to run, either as a string or an array of strings.\n * @param opts - Spawn options for the child process. Defaults to an empty object.\n * @param outputConstructor - Constructor for the output writer. Defaults to StandardOutputWriter.\n * @param args - Additional arguments to pass to the output constructor.\n * @return {CommandResult} A promise that resolves to the command result of type R.\n *\n * @function runCommand\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant runCommand\n *   participant OutputWriter\n *   participant ChildProcess\n *   Caller->>runCommand: Call with command and options\n *   runCommand->>OutputWriter: Create new instance\n *   runCommand->>OutputWriter: Parse command\n *   runCommand->>ChildProcess: Spawn process\n *   ChildProcess-->>runCommand: Return process object\n *   runCommand->>ChildProcess: Set up event listeners\n *   loop For each stdout data\n *     ChildProcess->>runCommand: Emit stdout data\n *     runCommand->>OutputWriter: Handle stdout data\n *   end\n *   loop For each stderr data\n *     ChildProcess->>runCommand: Emit stderr data\n *     runCommand->>OutputWriter: Handle stderr data\n *   end\n *   ChildProcess->>runCommand: Emit error (if any)\n *   runCommand->>OutputWriter: Handle error\n *   ChildProcess->>runCommand: Emit exit\n *   runCommand->>OutputWriter: Handle exit\n *   OutputWriter-->>runCommand: Resolve or reject promise\n *   runCommand-->>Caller: Return CommandResult\n *\n * @memberOf @decaf-ts/utils\n */\nexport function runCommand<R = string>(\n  command: string,\n  opts: SpawnOptionsWithoutStdio = {},\n  outputConstructor: OutputWriterConstructor<\n    R,\n    StandardOutputWriter<R>,\n    Error\n  > = StandardOutputWriter<R>,\n  ...args: unknown[]\n): CommandResult<R> {\n  const logger = Logging.for(runCommand);\n  const abort = new AbortController();\n\n  const result: Omit<CommandResult, \"promise\" | \"pipe\"> = {\n    abort: abort,\n    command: command,\n    logs: [],\n    errs: [],\n  };\n\n  const lock = new Promise<R>((resolve, reject) => {\n    let output;\n    try {\n      output = new outputConstructor(\n        command,\n        {\n          resolve,\n          reject,\n        },\n        ...args\n      );\n\n      result.cmd = spawnCommand<R>(output, command, opts, abort, logger);\n    } catch (e: unknown) {\n      return reject(new Error(`Error running command ${command}: ${e}`));\n    }\n\n    result.cmd.stdout.setEncoding(\"utf8\");\n\n    result.cmd.stdout.on(\"data\", (chunk: any) => {\n      chunk = chunk.toString();\n      result.logs.push(chunk);\n      output.data(chunk);\n    });\n\n    result.cmd.stderr.on(\"data\", (data: any) => {\n      data = data.toString();\n      result.errs.push(data);\n      output.error(data);\n    });\n\n    result.cmd.once(\"error\", (err: Error) => {\n      output.exit(err.message, result.errs);\n    });\n\n    result.cmd.once(\"exit\", (code: number = 0) => {\n      if (abort.signal.aborted && code === null) code = AbortCode as any;\n      output.exit(code, code === 0 ? result.logs : result.errs);\n    });\n  });\n\n  Object.assign(result, {\n    promise: lock,\n    pipe: async <E>(cb: (r: R) => E) => {\n      const l = logger.for(\"pipe\");\n      try {\n        l.verbose(`Executing pipe function ${command}...`);\n        const result: R = await lock;\n        l.verbose(`Piping output to ${cb.name}: ${result}`);\n        return cb(result);\n      } catch (e: unknown) {\n        l.error(`Error piping command output: ${e}`);\n        throw e;\n      }\n    },\n  });\n\n  return result as CommandResult<R>;\n}\n","import fs from \"fs\";\nimport path from \"path\";\nimport { patchString } from \"./text\";\nimport { runCommand } from \"./utils\";\nimport { DependencyMap, SimpleDependencyMap } from \"./types\";\nimport { Logging } from \"@decaf-ts/logging\";\n\nconst logger = Logging.for(\"fs\");\n\n/**\n * @description Patches a file with given values.\n * @summary Reads a file, applies patches using TextUtils, and writes the result back to the file.\n *\n * @param {string} path - The path to the file to be patched.\n * @param {Record<string, number | string>} values - The values to patch into the file.\n * @return {void}\n *\n * @function patchFile\n *\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant patchFile\n *   participant fs\n *   participant readFile\n *   participant TextUtils\n *   participant writeFile\n *   Caller->>patchFile: Call with path and values\n *   patchFile->>fs: Check if file exists\n *   patchFile->>readFile: Read file content\n *   readFile->>fs: Read file\n *   fs-->>readFile: Return file content\n *   readFile-->>patchFile: Return file content\n *   patchFile->>TextUtils: Patch string\n *   TextUtils-->>patchFile: Return patched content\n *   patchFile->>writeFile: Write patched content\n *   writeFile->>fs: Write to file\n *   fs-->>writeFile: File written\n *   writeFile-->>patchFile: File written\n *   patchFile-->>Caller: Patching complete\n *\n * @memberOf module:fs-utils\n */\nexport function patchFile(\n  path: string,\n  values: Record<string, number | string>\n) {\n  const log = logger.for(patchFile);\n  if (!fs.existsSync(path))\n    throw new Error(`File not found at path \"${path}\".`);\n  let content = readFile(path);\n\n  try {\n    log.verbose(`Patching file \"${path}\"...`);\n    log.debug(`with value: ${JSON.stringify(values)}`);\n    content = patchString(content, values);\n  } catch (error: unknown) {\n    throw new Error(`Error patching file: ${error}`);\n  }\n  writeFile(path, content);\n}\n\n/**\n * @description Reads a file and returns its content.\n * @summary Reads the content of a file at the specified path and returns it as a string.\n *\n * @param {string} path - The path to the file to be read.\n * @return {string} The content of the file.\n *\n * @function readFile\n *\n * @memberOf module:utils\n */\nexport function readFile(path: string): string {\n  const log = logger.for(readFile);\n  try {\n    log.verbose(`Reading file \"${path}\"...`);\n    return fs.readFileSync(path, \"utf8\");\n  } catch (error: unknown) {\n    log.verbose(`Error reading file \"${path}\": ${error}`);\n    throw new Error(`Error reading file \"${path}\": ${error}`);\n  }\n}\n\n/**\n * @description Writes data to a file.\n * @summary Writes the provided data to a file at the specified path.\n *\n * @param {string} path - The path to the file to be written.\n * @param {string | Buffer} data - The data to be written to the file.\n * @return {void}\n *\n * @function writeFile\n *\n * @memberOf module:utils\n */\nexport function writeFile(path: string, data: string | Buffer): void {\n  const log = logger.for(writeFile);\n  try {\n    log.verbose(`Writing file \"${path} with ${data.length} bytes...`);\n    fs.writeFileSync(path, data, \"utf8\");\n  } catch (error: unknown) {\n    log.verbose(`Error writing file \"${path}\": ${error}`);\n    throw new Error(`Error writing file \"${path}\": ${error}`);\n  }\n}\n\n/**\n * @description Retrieves all files recursively from a directory.\n * @summary Traverses through directories and subdirectories to collect all file paths.\n *\n * @param {string} p - The path to start searching from.\n * @param filter\n * @return {string[]} Array of file paths.\n *\n * @function getAllFiles\n *\n * @memberOf module:fs-utils\n */\nexport function getAllFiles(\n  p: string,\n  filter?: (f: string, i?: number) => boolean\n): string[] {\n  const log = logger.for(getAllFiles);\n  const files: string[] = [];\n\n  try {\n    log.verbose(`Retrieving all files from \"${p}\"...`);\n    const entries = fs.readdirSync(p);\n\n    entries.forEach((entry) => {\n      const fullPath = path.join(p, entry);\n      const stat = fs.statSync(fullPath);\n\n      if (stat.isFile()) {\n        files.push(fullPath);\n      } else if (stat.isDirectory()) {\n        files.push(...getAllFiles(fullPath));\n      }\n    });\n    if (!filter) return files;\n    return files.filter(filter);\n  } catch (error: unknown) {\n    log.verbose(`Error retrieving files from \"${p}\": ${error}`);\n    throw new Error(`Error retrieving files from \"${p}\": ${error}`);\n  }\n}\n\nexport async function renameFile(source: string, dest: string) {\n  const log = logger.for(renameFile);\n  let descriptorSource, descriptorDest;\n\n  try {\n    descriptorSource = fs.statSync(source);\n  } catch (error: unknown) {\n    log.verbose(`Source path \"${source}\" does not exist: ${error}`);\n    throw new Error(`Source path \"${source}\" does not exist: ${error}`);\n  }\n\n  try {\n    descriptorDest = fs.statSync(dest);\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (e: unknown) {\n    // do nothing. its ok\n  }\n  if (descriptorDest) {\n    log.verbose(`Destination path \"${dest}\" already exists`);\n    throw new Error(`Destination path \"${dest}\" already exists`);\n  }\n\n  try {\n    log.verbose(\n      `Renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}...`\n    );\n    fs.renameSync(source, dest);\n    log.verbose(`Successfully renamed to \"${dest}\"`);\n  } catch (error: unknown) {\n    log.verbose(\n      `Error renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}\": ${error}`\n    );\n    throw new Error(\n      `Error renaming ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}\": ${error}`\n    );\n  }\n}\n\nexport function copyFile(source: string, dest: string) {\n  const log = logger.for(copyFile);\n  let descriptorSource, descriptorDest;\n  try {\n    descriptorSource = fs.statSync(source);\n  } catch (error: unknown) {\n    log.verbose(`Source path \"${source}\" does not exist: ${error}`);\n    throw new Error(`Source path \"${source}\" does not exist: ${error}`);\n  }\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    descriptorDest = fs.statSync(dest);\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  } catch (error: unknown) {\n    if (descriptorSource.isDirectory()) {\n      log.verbose(`Dest path \"${dest}\" does not exist. creating`);\n      fs.mkdirSync(dest, { recursive: true });\n    }\n  }\n\n  try {\n    log.verbose(\n      `Copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}...`\n    );\n    fs.cpSync(source, dest, { recursive: true });\n  } catch (error: unknown) {\n    log.verbose(\n      `Error copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}: ${error}`\n    );\n    throw new Error(\n      `Error copying ${descriptorSource.isFile() ? \"file\" : \"directory\"} \"${source}\" to \"${dest}: ${error}`\n    );\n  }\n}\n\nexport function deletePath(p: string) {\n  const log = logger.for(deletePath);\n  try {\n    const descriptor = fs.statSync(p);\n    if (descriptor.isFile()) {\n      log.verbose(`Deleting file \"${p}...`);\n      fs.rmSync(p, { recursive: true, force: true });\n    } else if (descriptor.isDirectory())\n      fs.rmSync(p, { recursive: true, force: true });\n  } catch (error: unknown) {\n    log.verbose(`Error Deleting \"${p}\": ${error}`);\n    throw new Error(`Error Deleting \"${p}\": ${error}`);\n  }\n}\n\n/**\n * @description Retrieves package information from package.json.\n * @summary Loads and parses the package.json file from a specified directory or the current working directory. Can return the entire package object or a specific property.\n * @param {string} [p=process.cwd()] - The directory path where the package.json file is located.\n * @param {string} [property] - Optional. The specific property to retrieve from package.json.\n * @return {object | string} The parsed contents of package.json or the value of the specified property.\n * @function getPackage\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant getPackage\n *   participant readFile\n *   participant JSON\n *   Caller->>getPackage: Call with path and optional property\n *   getPackage->>readFile: Read package.json\n *   readFile-->>getPackage: Return file content\n *   getPackage->>JSON: Parse file content\n *   JSON-->>getPackage: Return parsed object\n *   alt property specified\n *     getPackage->>getPackage: Check if property exists\n *     alt property exists\n *       getPackage-->>Caller: Return property value\n *     else property doesn't exist\n *       getPackage-->>Caller: Throw Error\n *     end\n *   else no property specified\n *     getPackage-->>Caller: Return entire package object\n *   end\n * @memberOf module:utils\n */\nexport function getPackage(\n  p: string = process.cwd(),\n  property?: string\n): object | string {\n  let pkg: any;\n  try {\n    pkg = JSON.parse(readFile(path.join(p, `package.json`)));\n  } catch (error: unknown) {\n    throw new Error(`Failed to retrieve package information\" ${error}`);\n  }\n\n  if (property) {\n    if (!(property in pkg))\n      throw new Error(`Property \"${property}\" not found in package.json`);\n    return pkg[property] as string;\n  }\n  return pkg;\n}\n\nexport function setPackageAttribute(\n  attr: string,\n  value: string,\n  p: string = process.cwd()\n): void {\n  const pkg = getPackage(p) as Record<string, any>;\n  pkg[attr] = value;\n  writeFile(path.join(p, `package.json`), JSON.stringify(pkg, null, 2));\n}\n\n/**\n * @description Retrieves the version from package.json.\n * @summary A convenience function that calls getPackage to retrieve the \"version\" property from package.json.\n * @param {string} [p=process.cwd()] - The directory path where the package.json file is located.\n * @return {string} The version string from package.json.\n * @function getPackageVersion\n * @memberOf module:fs-utils\n */\nexport function getPackageVersion(p = process.cwd()): string {\n  return getPackage(p, \"version\") as string;\n}\n\n/**\n * @description Retrieves all dependencies from the project.\n * @summary Executes 'npm ls --json' command to get a detailed list of all dependencies (production, development, and peer) and their versions.\n * @param {string} [path=process.cwd()] - The directory path of the project.\n * @return {Promise<{prod: Array<{name: string, version: string}>, dev: Array<{name: string, version: string}>, peer: Array<{name: string, version: string}>}>} An object containing arrays of production, development, and peer dependencies.\n * @function getDependencies\n * @mermaid\n * sequenceDiagram\n *   participant Caller\n *   participant getDependencies\n *   participant runCommand\n *   participant JSON\n *   Caller->>getDependencies: Call with optional path\n *   getDependencies->>runCommand: Execute 'npm ls --json'\n *   runCommand-->>getDependencies: Return command output\n *   getDependencies->>JSON: Parse command output\n *   JSON-->>getDependencies: Return parsed object\n *   getDependencies->>getDependencies: Process dependencies\n *   getDependencies-->>Caller: Return processed dependencies\n * @memberOf module:fs-utils\n */\nexport async function getDependencies(\n  path: string = process.cwd()\n): Promise<DependencyMap> {\n  let pkg: any;\n\n  try {\n    pkg = JSON.parse(await runCommand(`npm ls --json`, { cwd: path }).promise);\n  } catch (e: unknown) {\n    throw new Error(`Failed to retrieve dependencies: ${e}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  const mapper = (entry: [string, unknown], index: number) => ({\n    name: entry[0],\n    version: (entry[1] as any).version,\n  });\n\n  return {\n    prod: Object.entries(pkg.dependencies || {}).map(mapper),\n    dev: Object.entries(pkg.devDependencies || {}).map(mapper),\n    peer: Object.entries(pkg.peerDependencies || {}).map(mapper),\n  };\n}\n\nexport async function updateDependencies() {\n  const log = logger.for(updateDependencies);\n  log.info(\"checking for updates...\");\n  await runCommand(\"npx npm-check-updates -u\").promise;\n  log.info(\"updating...\");\n  await runCommand(\"npx npm run do-install\").promise;\n}\n\nexport async function installIfNotAvailable(\n  deps: string[] | string,\n  dependencies?: SimpleDependencyMap\n) {\n  if (!dependencies) {\n    const d: DependencyMap = await getDependencies();\n    dependencies = {\n      prod: d.prod?.map((p) => p.name) || [],\n      dev: d.dev?.map((d) => d.name) || [],\n      peer: d.peer?.map((p) => p.name) || [],\n    };\n  }\n  const { prod, dev, peer } = dependencies;\n  const installed = Array.from(\n    new Set([...(prod || []), ...(dev || []), ...(peer || [])])\n  );\n  deps = typeof deps === \"string\" ? [deps] : deps;\n  const toInstall = deps.filter((d) => !installed.includes(d));\n\n  if (toInstall.length) await installDependencies({ dev: toInstall });\n  dependencies.dev = dependencies.dev || [];\n  dependencies.dev.push(...toInstall);\n  return dependencies;\n}\n\nexport async function pushToGit() {\n  const log = logger.for(pushToGit);\n  const gitUser = await runCommand(\"git config user.name\").promise;\n  const gitEmail = await runCommand(\"git config user.email\").promise;\n  log.verbose(`cached git id: ${gitUser}/${gitEmail}. changing to automation`);\n  await runCommand('git config user.email \"automation@decaf.ts\"').promise;\n  await runCommand('git config user.name \"decaf\"').promise;\n  log.info(\"Pushing changes to git...\");\n  await runCommand(\"git add .\").promise;\n  await runCommand(`git commit -m \"refs #1 - after repo setup\"`).promise;\n  await runCommand(\"git push\").promise;\n  await runCommand(`git config user.email \"${gitEmail}\"`).promise;\n  await runCommand(`git config user.name \"${gitUser}\"`).promise;\n  log.verbose(`reverted to git id: ${gitUser}/${gitEmail}`);\n}\n\nexport async function installDependencies(dependencies: {\n  prod?: string[];\n  dev?: string[];\n  peer?: string[];\n}) {\n  const log = logger.for(installDependencies);\n  const prod = dependencies.prod || [];\n  const dev = dependencies.dev || [];\n  const peer = dependencies.peer || [];\n  if (prod.length) {\n    log.info(`Installing dependencies ${prod.join(\", \")}...`);\n    await runCommand(`npm install ${prod.join(\" \")}`, { cwd: process.cwd() })\n      .promise;\n  }\n  if (dev.length) {\n    log.info(`Installing devDependencies ${dev.join(\", \")}...`);\n    await runCommand(`npm install --save-dev ${dev.join(\" \")}`, {\n      cwd: process.cwd(),\n    }).promise;\n  }\n  if (peer.length) {\n    log.info(`Installing peerDependencies ${peer.join(\", \")}...`);\n    await runCommand(`npm install --save-peer ${peer.join(\" \")}`, {\n      cwd: process.cwd(),\n    }).promise;\n  }\n}\n\nexport async function normalizeImport<T>(\n  importPromise: Promise<T>\n): Promise<T> {\n  // CommonJS's `module.exports` is wrapped as `default` in ESModule.\n  return importPromise.then((m: any) => (m.default || m) as T);\n}\n","import slogans from \"../assets/slogans.json\";\nimport { style } from \"styled-string-builder\";\nimport { Logger } from \"@decaf-ts/logging\";\n\n/**\n * @description Array of ANSI color codes for banner styling.\n * @summary Defines a set of ANSI color codes used to style the banner text.\n */\nconst colors = [\n  \"\\x1b[38;5;215m\", // soft orange\n  \"\\x1b[38;5;209m\", // coral\n  \"\\x1b[38;5;205m\", // pink\n  \"\\x1b[38;5;210m\", // peachy\n  \"\\x1b[38;5;217m\", // salmon\n  \"\\x1b[38;5;216m\", // light coral\n  \"\\x1b[38;5;224m\", // light peach\n  \"\\x1b[38;5;230m\", // soft cream\n  \"\\x1b[38;5;230m\", // soft cream\n];\n\n/**\n * @description Prints a styled banner to the console.\n * @summary Generates and prints a colorful ASCII art banner with a random slogan.\n * @param {Logger} [logger] - Optional logger for verbose output.\n * @function printBanner\n * @mermaid\n * sequenceDiagram\n *   participant printBanner\n *   participant getSlogan\n *   participant padEnd\n *   participant console\n *   printBanner->>getSlogan: Call getSlogan()\n *   getSlogan-->>printBanner: Return random slogan\n *   printBanner->>printBanner: Create banner ASCII art\n *   printBanner->>printBanner: Split banner into lines\n *   printBanner->>printBanner: Calculate max line length\n *   printBanner->>padEnd: Call padEnd with slogan\n *   padEnd-->>printBanner: Return padded slogan line\n *   loop For each banner line\n *     printBanner->>style: Call style(line)\n *     style-->>printBanner: Return styled line\n *     printBanner->>console: Log styled line\n *   end\n */\nexport function printBanner(logger?: Logger) {\n  const message = getSlogan();\n  const banner: string | string[] =\n    `#                 ░▒▓███████▓▒░  ░▒▓████████▓▒░  ░▒▓██████▓▒░   ░▒▓██████▓▒░  ░▒▓████████▓▒░       ░▒▓████████▓▒░  ░▒▓███████▓▒░ \n#      ( (        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓█▓▒░        \n#       ) )       ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓█▓▒░        \n#    [=======]    ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓██████▓▒░   ░▒▓█▓▒░        ░▒▓████████▓▒░ ░▒▓██████▓▒░            ░▒▓█▓▒░      ░▒▓██████▓▒░  \n#     \\`-----´     ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░            ░▒▓█▓▒░ \n#                 ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░        ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░            ░▒▓█▓▒░ \n#                 ░▒▓███████▓▒░  ░▒▓████████▓▒░  ░▒▓██████▓▒░  ░▒▓█▓▒░░▒▓█▓▒░ ░▒▓█▓▒░                 ░▒▓█▓▒░     ░▒▓███████▓▒░  \n#`.split(\"\\n\");\n  const maxLength = banner.reduce((max, line) => Math.max(max, line.length), 0);\n  banner.push(`#  ${message.padStart(maxLength - 3)}`);\n  banner.forEach((line, index) => {\n    (logger ? logger.info.bind(logger) : console.log.bind(console))(\n      style(line || \"\").raw(colors[index]).text\n    );\n  });\n}\n\n/**\n * @description Retrieves a slogan from the predefined list.\n * @summary Fetches a random slogan or a specific one by index from the slogans list.\n * @param {number} [i] - Optional index to retrieve a specific slogan.\n * @return {string} The selected slogan.\n * @function getSlogan\n * @mermaid\n * sequenceDiagram\n *   participant getSlogan\n *   participant Math.random\n *   participant slogans\n *   alt i is undefined\n *     getSlogan->>Math.random: Generate random index\n *     Math.random-->>getSlogan: Return random index\n *   else i is defined\n *     Note over getSlogan: Use provided index\n *   end\n *   getSlogan->>slogans: Access slogan at index\n *   slogans-->>getSlogan: Return slogan\n *   alt Error occurs\n *     getSlogan->>getSlogan: Throw error\n *   end\n *   getSlogan-->>Caller: Return slogan\n */\nexport function getSlogan(i?: number): string {\n  try {\n    i =\n      typeof i === \"undefined\" ? Math.floor(Math.random() * slogans.length) : i;\n    return slogans[i].Slogan;\n  } catch (error: unknown) {\n    throw new Error(`Failed to retrieve slogans: ${error}`);\n  }\n}\n","/**\n * @function isBrowser\n * @description Determines if the current environment is a browser by checking the prototype chain of the global object.\n * @summary Checks if the code is running in a browser environment.\n * @returns {boolean} True if the environment is a browser, false otherwise.\n */\nexport function isBrowser(): boolean {\n  return (\n    Object.getPrototypeOf(Object.getPrototypeOf(globalThis)) !==\n    Object.prototype\n  );\n}\n","import { toENVFormat } from \"./text\";\nimport { EnvironmentFactory } from \"./types\";\nimport { isBrowser } from \"./web\";\nimport { ObjectAccumulator } from \"typed-object-accumulator\";\n\n/**\n * @class Environment\n * @extends {ObjectAccumulator<T>}\n * @template T\n * @description A class representing an environment with accumulation capabilities.\n * @summary Manages environment-related data and provides methods for accumulation and key retrieval.\n * @param {T} [initialData] - The initial data to populate the environment with.\n */\nexport class Environment<T extends object> extends ObjectAccumulator<T> {\n  /**\n   * @static\n   * @protected\n   * @description A factory function for creating Environment instances.\n   * @summary Defines how new instances of the Environment class should be created.\n   * @return {Environment<any>} A new instance of the Environment class.\n   */\n  protected static factory: EnvironmentFactory<any, any> =\n    (): Environment<any> => new Environment();\n\n  /**\n   * @static\n   * @private\n   * @description The singleton instance of the Environment class.\n   * @type {Environment<any>}\n   */\n  private static _instance: Environment<any>;\n\n  protected constructor() {\n    super();\n  }\n\n  protected fromEnv(k: string) {\n    let env: Record<string, unknown>;\n    if (isBrowser()) {\n      env = (globalThis as typeof globalThis & { ENV: Record<string, any> })[\n        \"ENV\"\n      ];\n    } else {\n      env = globalThis.process.env;\n      k = toENVFormat(k);\n    }\n    return env[k];\n  }\n\n  protected expand<V extends object>(value: V): void {\n    Object.entries(value).forEach(([k, v]) => {\n      Object.defineProperty(this, k, {\n        get: () => {\n          const fromEnv = this.fromEnv(k);\n          return typeof fromEnv === \"undefined\" ? v : fromEnv;\n        },\n        set: (val: V[keyof V]) => {\n          v = val;\n        },\n        configurable: true,\n        enumerable: true,\n      });\n    });\n  }\n\n  /**\n   * @protected\n   * @static\n   * @description Retrieves or creates the singleton instance of the Environment class.\n   * @summary Ensures only one instance of the Environment class exists.\n   * @template E\n   * @param {...unknown[]} args - Arguments to pass to the factory function if a new instance is created.\n   * @return {E} The singleton instance of the Environment class.\n   */\n  protected static instance<E extends Environment<any>>(...args: unknown[]): E {\n    Environment._instance = !Environment._instance\n      ? Environment.factory(...args)\n      : Environment._instance;\n    return Environment._instance as E;\n  }\n\n  /**\n   * @static\n   * @description Accumulates the given value into the environment.\n   * @summary Adds new properties to the environment from the provided object.\n   * @template V\n   * @param {V} value - The object to accumulate into the environment.\n   * @return {V} The updated environment instance.\n   */\n  static accumulate<V extends object>(\n    value: V\n  ): typeof Environment._instance &\n    V &\n    ObjectAccumulator<typeof Environment._instance & V> {\n    const instance = Environment.instance();\n    return instance.accumulate(value);\n  }\n\n  /**\n   * @static\n   * @description Retrieves the keys of the environment, optionally converting them to ENV format.\n   * @summary Gets all keys in the environment, with an option to format them for environment variables.\n   * @param {boolean} [toEnv=true] - Whether to convert the keys to ENV format.\n   * @return {string[]} An array of keys from the environment.\n   */\n  static keys(toEnv: boolean = true): string[] {\n    return Environment.instance()\n      .keys()\n      .map((k) => (toEnv ? toENVFormat(k) : k));\n  }\n}\n","import { ParseArgsResult } from \"../input/types\";\nimport { CommandOptions } from \"./types\";\nimport { UserInput } from \"../input/input\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"./constants\";\nimport { getDependencies, getPackageVersion } from \"../utils/fs\";\nimport { printBanner } from \"../output/common\";\nimport { Environment } from \"../utils/environment\";\nimport {\n  DefaultLoggingConfig,\n  Logger,\n  Logging,\n  LoggingConfig,\n  LogLevel,\n} from \"@decaf-ts/logging\";\n\n/**\n * @class Command\n * @abstract\n * @template I - The type of input options for the command.\n * @template R - The return type of the command execution.\n * @memberOf utils/cli\n * @description Abstract base class for command implementation.\n * @summary Provides a structure for creating command-line interface commands with input handling, logging, and execution flow.\n *\n * @param {string} name - The name of the command.\n * @param {CommandOptions<I>} [inputs] - The input options for the command.\n * @param {string[]} [requirements] - The list of required dependencies for the command.\n */\nexport abstract class Command<I, R> {\n  /**\n   * @static\n   * @description Static logger for the Command class.\n   * @type {Logger}\n   */\n  static log: Logger;\n\n  /**\n   * @protected\n   * @description Instance logger for the command.\n   * @type {Logger}\n   */\n  protected log: Logger;\n\n  protected constructor(\n    protected name: string,\n    protected inputs: CommandOptions<I> = {} as unknown as CommandOptions<I>,\n    protected requirements: string[] = []\n  ) {\n    if (!Command.log) {\n      Object.defineProperty(Command, \"log\", {\n        writable: false,\n        value: Logging.for(Command.name),\n      });\n      this.log = Command.log;\n    }\n    this.log = Command.log.for(this.name);\n    this.inputs = Object.assign(\n      {},\n      DefaultCommandOptions,\n      inputs\n    ) as CommandOptions<I>;\n  }\n\n  /**\n   * @protected\n   * @async\n   * @description Checks if all required dependencies are present.\n   * @summary Retrieves the list of dependencies and compares it against the required dependencies for the command.\n   * @returns {Promise<void>} A promise that resolves when the check is complete.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Command\n   *   participant getDependencies\n   *   participant Set\n   *   Command->>getDependencies: Call\n   *   getDependencies-->>Command: Return {prod, dev, peer}\n   *   Command->>Set: Create Set from prod, dev, peer\n   *   Set-->>Command: Return unique dependencies\n   *   Command->>Command: Compare against requirements\n   *   alt Missing dependencies\n   *     Command->>Command: Add to missing list\n   *   end\n   *   Note over Command: If missing.length > 0, handle missing dependencies\n   */\n  protected async checkRequirements(): Promise<void> {\n    const { prod, dev, peer } = await getDependencies();\n    const missing = [];\n    const fullList = Array.from(\n      new Set([...prod, ...dev, ...peer]).values()\n    ).map((d) => d.name);\n    for (const dep of this.requirements)\n      if (!fullList.includes(dep)) missing.push(dep);\n\n    if (!missing.length) return;\n  }\n\n  /**\n   * @protected\n   * @description Provides help information for the command.\n   * @summary This method should be overridden in derived classes to provide specific help information.\n   * @param {ParseArgsResult} args - The parsed command-line arguments.\n   * @returns {void}\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected help(args: ParseArgsResult): void {\n    return this.log.info(\n      `This is help. I'm no use because I should have been overridden.`\n    );\n  }\n\n  /**\n   * @protected\n   * @abstract\n   * @description Runs the command with the provided arguments.\n   * @summary This method should be implemented in derived classes to define the command's behavior.\n   * @param {ParseArgsResult} answers - The parsed command-line arguments.\n   * @returns {Promise<R | string | void>} A promise that resolves with the command's result.\n   */\n  protected abstract run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof I]: unknown }\n  ): Promise<R | string | void>;\n\n  /**\n   * @async\n   * @description Executes the command.\n   * @summary This method handles the overall execution flow of the command, including parsing arguments,\n   * setting up logging, checking for version or help requests, and running the command.\n   * @returns {Promise<R | string | void>} A promise that resolves with the command's result.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Command\n   *   participant UserInput\n   *   participant Logging\n   *   participant getPackageVersion\n   *   participant printBanner\n   *   Command->>UserInput: parseArgs(inputs)\n   *   UserInput-->>Command: Return ParseArgsResult\n   *   Command->>Command: Process options\n   *   Command->>Logging: setConfig(options)\n   *   alt version requested\n   *     Command->>getPackageVersion: Call\n   *     getPackageVersion-->>Command: Return version\n   *   else help requested\n   *     Command->>Command: help(args)\n   *   else banner requested\n   *     Command->>printBanner: Call\n   *   end\n   *   Command->>Command: run(args)\n   *   alt error occurs\n   *     Command->>Command: Log error\n   *   end\n   *   Command-->>Command: Return result\n   */\n  async execute(): Promise<R | string | void> {\n    const args: ParseArgsResult = UserInput.parseArgs(this.inputs);\n    const env = Environment.accumulate(DefaultLoggingConfig)\n      .accumulate(DefaultCommandValues)\n      .accumulate(args.values);\n    const { timestamp, verbose, version, help, logLevel, logStyle, banner } =\n      env;\n\n    this.log.setConfig({\n      ...env,\n      timestamp: !!timestamp,\n      level: logLevel as LogLevel,\n      style: !!logStyle,\n      verbose: (verbose as number) || 0,\n    });\n\n    if (version) {\n      return getPackageVersion();\n    }\n\n    if (help) {\n      return this.help(args);\n    }\n\n    if (banner)\n      printBanner(\n        this.log.for(printBanner, {\n          timestamp: false,\n          style: false,\n          context: false,\n          logLevel: false,\n        })\n      );\n\n    let result;\n    try {\n      result = await this.run(env);\n    } catch (e: unknown) {\n      this.log.error(`Error while running provided cli function: ${e}`);\n      throw e;\n    }\n\n    return result as R;\n  }\n}\n","import https from \"https\";\nimport { Logging } from \"@decaf-ts/logging\";\n\n/**\n * @description A simple HTTP client for downloading files.\n * @summary This class provides functionality to download files from HTTPS URLs.\n * It uses Node.js built-in https module to make requests.\n *\n * @class\n */\nexport class HttpClient {\n  protected static log = Logging.for(HttpClient);\n  /**\n   * @description Downloads a file from a given URL.\n   * @summary This method sends a GET request to the specified URL and returns the response body as a string.\n   * It handles different scenarios such as non-200 status codes and network errors.\n   *\n   * @param url - The URL of the file to download.\n   * @return A promise that resolves with the file content as a string.\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant HttpClient\n   *   participant HTTPS\n   *   participant Server\n   *   Client->>HttpClient: downloadFile(url)\n   *   HttpClient->>HTTPS: get(url)\n   *   HTTPS->>Server: GET request\n   *   Server-->>HTTPS: Response\n   *   HTTPS-->>HttpClient: Response object\n   *   alt Status code is 200\n   *     loop For each data chunk\n   *       HTTPS->>HttpClient: 'data' event\n   *       HttpClient->>HttpClient: Accumulate data\n   *     end\n   *     HTTPS->>HttpClient: 'end' event\n   *     HttpClient-->>Client: Resolve with data\n   *   else Status code is not 200\n   *     HttpClient-->>Client: Reject with error\n   *   end\n   */\n  static async downloadFile(url: string): Promise<string> {\n    return new Promise<string>((resolve, reject) => {\n      function request(url: string) {\n        url = encodeURI(url);\n        https.get(url, (res) => {\n          if (res.statusCode === 301 || res.statusCode === 307)\n            return request(res.headers.location as string);\n\n          if (res.statusCode !== 200) {\n            HttpClient.log.error(\n              `Failed to fetch ${url} (status: ${res.statusCode})`\n            );\n            return reject(new Error(`Failed to fetch ${url}`));\n          }\n          let data = \"\";\n          res.on(\"data\", (chunk) => {\n            data += chunk;\n          });\n          res.on(\"error\", (error) => {\n            reject(error);\n          });\n\n          res.on(\"end\", () => {\n            resolve(data);\n          });\n        });\n      }\n      request(url);\n    });\n  }\n}\n","import { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport { DefaultCommandOptions, DefaultCommandValues } from \"../constants\";\nimport {\n  copyFile,\n  deletePath,\n  getAllFiles,\n  getPackage,\n  patchFile,\n  readFile,\n  renameFile,\n  runCommand,\n  writeFile,\n} from \"../../utils\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { rollup, InputOptions, OutputOptions, RollupBuild } from \"rollup\";\nimport typescript from \"@rollup/plugin-typescript\";\nimport commonjs from \"@rollup/plugin-commonjs\";\nimport { nodeResolve } from \"@rollup/plugin-node-resolve\";\nimport json from \"@rollup/plugin-json\";\nimport { LoggingConfig } from \"@decaf-ts/logging\";\n\nconst VERSION_STRING = \"##VERSION##\";\n\nenum Modes {\n  CJS = \"commonjs\",\n  ESM = \"es2022\",\n}\n\nconst Commands = [\"update-scripts\", \"tag-release\", \"build-scripts\"];\n\nconst options = {\n  prod: {\n    type: \"boolean\",\n    default: false,\n  },\n  dev: {\n    type: \"boolean\",\n    default: false,\n  },\n  docs: {\n    type: \"boolean\",\n    default: false,\n  },\n  commands: {\n    type: \"boolean\",\n    default: false,\n  },\n  banner: {\n    type: \"boolean\",\n    default: false,\n  },\n};\n\nexport class BuildScripts extends Command<\n  CommandOptions<typeof options>,\n  void\n> {\n  private replacements: Record<string, string> = {};\n  private readonly pkgVersion: string;\n  private readonly pkgName: string;\n\n  constructor() {\n    super(\n      \"BuildScripts\",\n      Object.assign({}, DefaultCommandOptions, options) as CommandOptions<\n        typeof options\n      >\n    );\n    const pkg = getPackage() as { name: string; version: string };\n    const { name, version } = pkg;\n    this.pkgName = name.includes(\"@\") ? name.split(\"/\")[1] : name;\n    this.pkgVersion = version;\n    this.replacements[VERSION_STRING] = this.pkgVersion;\n  }\n\n  patchCjsImports(file: string) {\n    const regexp = /(require\\([\"'])(\\..*?)([\"']\\)[;,])/g;\n    let data = readFile(file);\n    data = data.replace(regexp, (match, ...groups: string[]) => {\n      const renamedFile = groups[1] + \".cjs\";\n      const dirname = path.dirname(file).replace(\"lib\", \"src\");\n      const fileName = groups[1] + \".ts\";\n      const sourceFilePath = path.join(dirname, fileName);\n\n      let result;\n      if (!fs.existsSync(sourceFilePath)) {\n        result = groups[0] + groups[1] + \"/index.cjs\" + groups[2];\n      } else {\n        result = groups[0] + renamedFile + groups[2];\n      }\n\n      return result;\n    });\n    writeFile(file, data);\n  }\n\n  patchFiles(p: string) {\n    const log = this.log.for(this.patchFiles);\n    const { name, version } = getPackage() as any;\n    log.info(`Patching ${name} ${version} module in ${p}...`);\n    const stat = fs.statSync(p);\n    if (stat.isDirectory())\n      fs.readdirSync(p, { withFileTypes: true, recursive: true })\n        .filter((p) => p.isFile())\n        .forEach((file) =>\n          patchFile(path.join(file.parentPath, file.name), this.replacements)\n        );\n    log.verbose(`Module ${name} ${version} patched in ${p}...`);\n  }\n\n  private async build(isDev: boolean, mode: Modes, bundle = false) {\n    const log = this.log.for(this.build);\n    log.info(\n      `Building ${this.pkgName} ${this.pkgVersion} module (${mode}) in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n\n    await runCommand(\n      `npx tsc --module ${bundle ? \"amd\" : mode}${isDev ? \" --inlineSourceMap\" : \" --sourceMap false\"} --outDir ${bundle ? \"dist\" : `lib${mode === Modes.ESM ? \"/esm\" : \"\"}`}${bundle ? ` --isolatedModules false --outFile ${this.pkgName}` : \"\"}`\n    ).promise;\n    log.verbose(\n      `Module ${this.pkgName} ${this.pkgVersion} (${mode}) built in ${isDev ? \"dev\" : \"prod\"} mode...`\n    );\n    if (mode === Modes.CJS && !bundle) {\n      const files = getAllFiles(\n        \"lib\",\n        (file) => file.endsWith(\".js\") && !file.includes(\"/esm/\")\n      );\n\n      for (const file of files) {\n        log.verbose(`Patching ${file}'s cjs imports...`);\n        const f = file.replace(\".js\", \".cjs\");\n        await renameFile(file, f);\n        this.patchCjsImports(f);\n      }\n    }\n  }\n\n  copyAssets(mode: Modes) {\n    const log = this.log.for(this.copyAssets);\n    let hasAssets = false;\n    try {\n      hasAssets = fs.statSync(\"./src/assets\").isDirectory();\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      return log.verbose(`No assets found in ./src/assets to copy`);\n    }\n    if (hasAssets)\n      copyFile(\n        \"./src/assets\",\n        `./${mode === Modes.CJS ? \"lib\" : \"dist\"}/assets`\n      );\n  }\n\n  async buildCommands() {\n    for (const cmd of Commands) {\n      await this.bundle(Modes.CJS, true, true, `src/bin/${cmd}.ts`, cmd);\n      let data = readFile(`bin/${cmd}.cjs`);\n      data = \"#!/usr/bin/env node\\n\" + data;\n      writeFile(`bin/${cmd}.cjs`, data);\n    }\n  }\n\n  async bundle(\n    mode: Modes,\n    isDev: boolean,\n    isLib: boolean,\n    entryFile: string = \"src/index.ts\",\n    nameOverride: string = this.pkgName,\n    externals?: string[],\n    include: string[] = [\n      \"prompts\",\n      \"styled-string-builder\",\n      \"typed-object-accumulator\",\n      \"@decaf-ts/logging\",\n    ]\n  ) {\n    const isEsm = mode === Modes.ESM;\n    const pkgName = this.pkgName;\n\n    const ext = Array.from(\n      new Set([\n        ...[\n          \"fs\",\n          \"path\",\n          \"process\",\n          \"rollup\",\n          \"@rollup/plugin-typescript\",\n          \"@rollup/plugin-json\",\n          \"@rollup/plugin-commonjs\",\n          \"@rollup/plugin-node-resolve\",\n          \"child_process\",\n          \"util\",\n          \"https\",\n          \"tslib\",\n        ],\n        ...(externals || []),\n      ])\n    );\n\n    const plugins = [\n      typescript({\n        compilerOptions: {\n          module: \"esnext\",\n          declaration: false,\n          outDir: isLib ? \"bin\" : \"dist\",\n        },\n        include: [\"src/**/*.ts\"],\n        exclude: [\"node_modules\", \"**/*.spec.ts\"],\n        tsconfig: \"./tsconfig.json\",\n      }),\n      json(),\n    ];\n\n    if (isLib) {\n      plugins.push(\n        commonjs({\n          include: [],\n          exclude: externals,\n        }),\n        nodeResolve({\n          resolveOnly: include,\n        })\n      );\n    }\n\n    const input: InputOptions = {\n      input: entryFile,\n      plugins: plugins,\n      external: ext,\n    };\n\n    const outputs: OutputOptions[] = [\n      {\n        file: `${isLib ? \"bin/\" : \"dist/\"}${nameOverride ? nameOverride : `.bundle.${!isDev ? \"min\" : \"\"}`}${isEsm ? \".esm\" : \"\"}.cjs`,\n        format: isLib ? \"cjs\" : isEsm ? \"esm\" : \"umd\",\n        name: pkgName,\n        esModule: isEsm,\n        sourcemap: isDev ? \"inline\" : false,\n        globals: {},\n        exports: \"auto\",\n      },\n    ];\n\n    try {\n      const bundle = await rollup(input);\n      console.log(bundle.watchFiles);\n      async function generateOutputs(bundle: RollupBuild) {\n        for (const outputOptions of outputs) {\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n          const { output } = await bundle.write(outputOptions);\n        }\n      }\n\n      await generateOutputs(bundle);\n    } catch (e: unknown) {\n      throw new Error(`Failed to bundle: ${e}`);\n    }\n  }\n\n  private async buildByEnv(isDev: boolean) {\n    try {\n      deletePath(\"lib\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    try {\n      deletePath(\"dist\");\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: unknown) {\n      // do nothing\n    }\n    fs.mkdirSync(\"lib\");\n    fs.mkdirSync(\"dist\");\n    await this.build(isDev, Modes.CJS);\n    await this.build(isDev, Modes.ESM);\n    await this.bundle(Modes.CJS, true, false);\n    await this.bundle(Modes.ESM, true, false);\n    this.patchFiles(\"lib\");\n    this.patchFiles(\"dist\");\n    this.copyAssets(Modes.CJS);\n    this.copyAssets(Modes.ESM);\n  }\n\n  async buildDev() {\n    return this.buildByEnv(true);\n  }\n\n  async buildProd() {\n    return this.buildByEnv(false);\n  }\n\n  async buildDocs() {\n    await runCommand(`npm install better-docs taffydb`).promise;\n    await runCommand(`npx markdown-include ./workdocs/readme-md.json`).promise;\n    await runCommand(\n      `npx jsdoc -c ./workdocs/jsdocs.json -t ./node_modules/better-docs`\n    ).promise;\n    await runCommand(`npm remove better-docs taffydb`).promise;\n    [\n      {\n        src: \"workdocs/assets\",\n        dest: \"./docs/workdocs/assets\",\n      },\n      {\n        src: \"workdocs/reports/coverage\",\n        dest: \"./docs/workdocs/reports/coverage\",\n      },\n      {\n        src: \"workdocs/reports/html\",\n        dest: \"./docs/workdocs/reports/html\",\n      },\n      {\n        src: \"workdocs/resources\",\n        dest: \"./docs/workdocs/resources\",\n      },\n      {\n        src: \"LICENSE.md\",\n        dest: \"./docs/LICENSE.md\",\n      },\n    ].forEach((f) => {\n      const { src, dest } = f;\n      copyFile(src, dest);\n    });\n  }\n\n  protected async run<R>(\n    answers: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<string | void | R> {\n    const { dev, prod, docs, commands } = answers;\n\n    if (commands) {\n      await this.buildCommands();\n    }\n\n    if (dev) {\n      return await this.buildDev();\n    }\n    if (prod) {\n      return await this.buildProd();\n    }\n    if (docs) {\n      return await this.buildDocs();\n    }\n  }\n}\n","import { runCommand } from \"../../utils/utils\";\nimport { NoCIFLag, SemVersion, SemVersionRegex } from \"../../utils/constants\";\nimport { UserInput } from \"../../input/input\";\nimport { Command } from \"../command\";\nimport { DefaultCommandValues } from \"../index\";\nimport { LoggingConfig } from \"@decaf-ts/logging\";\n\nconst options = {\n  ci: {\n    type: \"boolean\",\n    default: true,\n  },\n  message: {\n    type: \"string\",\n    short: \"m\",\n  },\n  tag: {\n    type: \"string\",\n    short: \"t\",\n    default: undefined,\n  },\n};\n\n/**\n * @class ReleaseScript\n * @extends {Command}\n * @cavegory scripts\n * @description A command-line script for managing releases and version updates.\n * @summary This script automates the process of creating and pushing new releases. It handles version updates,\n * commit messages, and optionally publishes to NPM. The script supports semantic versioning and can work in both CI and non-CI environments.\n *\n * @param {Object} options - Configuration options for the script\n * @param {boolean} options.ci - Whether the script is running in a CI environment (default: true)\n * @param {string} options.message - The release message (short: 'm')\n * @param {string} options.tag - The version tag to use (short: 't', default: undefined)\n */\nexport class ReleaseScript extends Command<typeof options, void> {\n  constructor() {\n    super(\"ReleaseScript\", options);\n  }\n\n  /**\n   * @description Prepares the version for the release.\n   * @summary This method validates the provided tag or prompts the user for a new one if not provided or invalid.\n   * It also displays the latest git tags for reference.\n   * @param {string} tag - The version tag to prepare\n   * @returns {Promise<string>} The prepared version tag\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant T as TestVersion\n   *   participant U as UserInput\n   *   participant G as Git\n   *   R->>T: testVersion(tag)\n   *   alt tag is valid\n   *     T-->>R: return tag\n   *   else tag is invalid or not provided\n   *     R->>G: List latest git tags\n   *     R->>U: Prompt for new tag\n   *     U-->>R: return new tag\n   *   end\n   */\n  async prepareVersion(tag?: string): Promise<string> {\n    const log = this.log.for(this.prepareVersion);\n    tag = this.testVersion((tag as string) || \"\");\n    if (!tag) {\n      log.verbose(\"No release message provided. Prompting for one:\");\n      log.info(`Listing latest git tags:`);\n      await runCommand(\"git tag --sort=-taggerdate | head -n 5\").promise;\n      return await UserInput.insistForText(\n        \"tag\",\n        \"Enter the new tag number (accepts v*.*.*[-...])\",\n        (val) =>\n          !!val.toString().match(/^v[0-9]+\\.[0-9]+.[0-9]+(-[0-9a-zA-Z-]+)?$/)\n      );\n    }\n    return tag;\n  }\n\n  /**\n   * @description Tests if the provided version is valid.\n   * @summary This method checks if the version is a valid semantic version or a predefined update type (PATCH, MINOR, MAJOR).\n   * @param {string} version - The version to test\n   * @returns {string | undefined} The validated version or undefined if invalid\n   */\n  testVersion(version: string): string | undefined {\n    const log = this.log.for(this.testVersion);\n    version = version.trim().toLowerCase();\n    switch (version) {\n      case SemVersion.PATCH:\n      case SemVersion.MINOR:\n      case SemVersion.MAJOR:\n        log.verbose(`Using provided SemVer update: ${version}`, 1);\n        return version;\n      default:\n        log.verbose(\n          `Testing provided version for SemVer compatibility: ${version}`,\n          1\n        );\n        if (!new RegExp(SemVersionRegex).test(version)) {\n          log.debug(`Invalid version number: ${version}`);\n          return undefined;\n        }\n        log.verbose(`version approved: ${version}`, 1);\n        return version;\n    }\n  }\n\n  /**\n   * @description Prepares the release message.\n   * @summary This method either returns the provided message or prompts the user for a new one if not provided.\n   * @param {string} [message] - The release message\n   * @returns {Promise<string>} The prepared release message\n   */\n  async prepareMessage(message?: string) {\n    const log = this.log.for(this.prepareMessage);\n    if (!message) {\n      log.verbose(\"No release message provided. Prompting for one\");\n      return await UserInput.insistForText(\n        \"message\",\n        \"What should be the release message/ticket?\",\n        (val) => !!val && val.toString().length > 5\n      );\n    }\n    return message;\n  }\n\n  /**\n   * @description Runs the release script.\n   * @summary This method orchestrates the entire release process, including version preparation, message creation,\n   * git operations, and npm publishing (if not in CI environment).\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant V as PrepareVersion\n   *   participant M as PrepareMessage\n   *   participant N as NPM\n   *   participant G as Git\n   *   participant U as UserInput\n   *   R->>V: prepareVersion(tag)\n   *   R->>M: prepareMessage(message)\n   *   R->>N: Run prepare-release script\n   *   R->>G: Check git status\n   *   alt changes exist\n   *     R->>U: Ask for confirmation\n   *     U-->>R: Confirm\n   *     R->>G: Add and commit changes\n   *   end\n   *   R->>N: Update npm version\n   *   R->>G: Push changes and tags\n   *   alt not CI environment\n   *     R->>N: Publish to npm\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<void> {\n    let result: any;\n    const { ci } = args;\n    let { tag, message } = args;\n    tag = await this.prepareVersion(tag as string);\n    message = await this.prepareMessage(message as string);\n    result = await runCommand(`npm run prepare-release -- ${tag} ${message}`, {\n      cwd: process.cwd(),\n    }).promise;\n    result = await runCommand(\"git status --porcelain\").promise;\n    await result;\n    if (\n      result.logs.length &&\n      (await UserInput.askConfirmation(\n        \"git-changes\",\n        \"Do you want to push the changes to the remote repository?\",\n        true\n      ))\n    ) {\n      await runCommand(\"git add .\").promise;\n      await runCommand(\n        `git commit -m \"${tag} - ${message} - after release preparation${ci ? \"\" : NoCIFLag}\"`\n      ).promise;\n    }\n    await runCommand(\n      `npm version \"${tag}\" -m \"${message}${ci ? \"\" : NoCIFLag}\"`\n    ).promise;\n    await runCommand(\"git push --follow-tags\").promise;\n    if (!ci) {\n      await runCommand(\"NPM_TOKEN=$(cat .npmtoken) npm publish --access public\")\n        .promise;\n    }\n  }\n}\n","import path from \"path\";\nimport { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport {\n  getPackage,\n  HttpClient,\n  patchFile,\n  patchString,\n  runCommand,\n  setPackageAttribute,\n  SetupScriptKey,\n  Tokens,\n  writeFile,\n} from \"../../utils\";\nimport { DefaultCommandValues } from \"../index\";\nimport { UserInput } from \"../../input\";\nimport fs from \"fs\";\nimport { LoggingConfig } from \"@decaf-ts/logging\";\n\nconst baseUrl =\n  \"https://raw.githubusercontent.com/decaf-ts/ts-workspace/master\";\n\nconst options = {\n  templates: [\n    \".github/ISSUE_TEMPLATE/bug_report.md\",\n    \".github/ISSUE_TEMPLATE/feature_request.md\",\n    \".github/FUNDING.yml\",\n  ],\n  workflows: [\n    \".github/workflows/codeql-analysis.yml\",\n    \".github/workflows/jest-coverage.yaml\",\n    \".github/workflows/nodejs-build-prod.yaml\",\n    \".github/workflows/pages.yaml\",\n    \".github/workflows/publish-on-release.yaml\",\n    \".github/workflows/release-on-tag.yaml\",\n    \".github/workflows/snyk-analysis.yaml\",\n  ],\n  ide: [\n    \".idea/runConfigurations/All Tests.run.xml\",\n    \".idea/runConfigurations/build.run.xml\",\n    \".idea/runConfigurations/build_prod.run.xml\",\n    \".idea/runConfigurations/coverage.run.xml\",\n    \".idea/runConfigurations/docs.run.xml\",\n    \".idea/runConfigurations/drawings.run.xml\",\n    \".idea/runConfigurations/flash-forward.run.xml\",\n    \".idea/runConfigurations/Integration_Tests.run.xml\",\n    \".idea/runConfigurations/Bundling_Tests.run.xml\",\n    \".idea/runConfigurations/lint-fix.run.xml\",\n    \".idea/runConfigurations/release.run.xml\",\n    \".idea/runConfigurations/test_circular.run.xml\",\n    \".idea/runConfigurations/uml.run.xml\",\n    \".idea/runConfigurations/Unit Tests.run.xml\",\n    \".idea/runConfigurations/update-scripts.run.xml\",\n  ],\n  docs: [\n    \"workdocs/tutorials/Contributing.md\",\n    \"workdocs/tutorials/Documentation.md\",\n    \"workdocs/tutorials/For Developers.md\",\n    \"workdocs/2-Badges.md\",\n    \"workdocs/jsdocs.json\",\n    \"workdocs/readme-md.json\",\n  ],\n  styles: [\".prettierrc\", \"eslint.config.js\"],\n  scripts: [\n    \"bin/update-scripts.cjs\",\n    \"bin/tag-release.cjs\",\n    \"bin/build-scripts.cjs\",\n  ],\n  tests: [\"jest.config.ts\", \"workdocs/reports/jest.coverage.config.ts\"],\n  typescript: [\"tsconfig.json\"],\n  docker: [\"Dockerfile\"],\n  automation: [\n    \"workdocs/confluence/Continuous Integration-Deployment/GitHub.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Jira.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Teams.md\",\n  ],\n};\n\nconst argzz = {\n  // init attributes\n  boot: {\n    type: \"boolean\",\n  },\n  org: {\n    type: \"string\",\n    short: \"o\",\n  },\n  name: {\n    type: \"string\",\n    short: \"n\",\n    default: undefined,\n  },\n  author: {\n    type: \"string\",\n    short: \"a\",\n    default: undefined,\n  },\n  // update attributes\n  all: {\n    type: \"boolean\",\n  },\n  license: {\n    type: \"string\",\n    message: \"Pick the license\",\n  },\n  scripts: {\n    type: \"boolean\",\n  },\n  styles: {\n    type: \"boolean\",\n  },\n  docs: {\n    type: \"boolean\",\n  },\n  ide: {\n    type: \"boolean\",\n  },\n  workflows: {\n    type: \"boolean\",\n  },\n  templates: {\n    type: \"boolean\",\n  },\n  typescript: {\n    type: \"boolean\",\n  },\n  docker: {\n    type: \"boolean\",\n  },\n  pkg: {\n    type: \"boolean\",\n  },\n  dependencies: {\n    type: \"boolean\",\n  },\n  tests: {\n    type: \"boolean\",\n  },\n  automation: {\n    type: \"boolean\",\n  },\n};\n\n/**\n * @class TemplateSync\n * @extends {Command}\n * @category scripts\n * @description A command-line tool for synchronizing project templates and configurations.\n * @summary This class provides functionality to download and update various project files and configurations from a remote repository.\n * It supports updating licenses, IDE configurations, scripts, styles, documentation, workflows, and templates.\n *\n * @param {CommandOptions} args - The command options for TemplateSync\n */\nexport class TemplateSync extends Command<CommandOptions<typeof argzz>, void> {\n  private replacements: Record<string, string | number> = {};\n\n  constructor() {\n    super(\"TemplateSync\", argzz);\n  }\n\n  private loadValuesFromPackage() {\n    const p = process.cwd();\n    const author = getPackage(p, \"author\") as string;\n    const scopedName = getPackage(p, \"name\");\n    let name: string = scopedName as string;\n    let org: string | undefined;\n    if (name.startsWith(\"@\")) {\n      const split = name.split(\"/\");\n      name = split[1];\n      org = split[0].replace(\"@\", \"\");\n    }\n    [\"Tiago Venceslau\", \"TiagoVenceslau\", \"${author}\"].forEach(\n      (el) => (this.replacements[el] = author)\n    );\n    [\"TS-Workspace\", \"ts-workspace\", \"${name}\"].forEach(\n      (el) => (this.replacements[el] = name)\n    );\n    [\"decaf-ts\", \"${org}\"].forEach(\n      (el) => (this.replacements[el] = (org as string) || '\"\"')\n    );\n    this.replacements[\"${org_or_owner}\"] = org || name;\n  }\n\n  /**\n   * @description Downloads files for a specific option category.\n   * @summary This method downloads all files associated with a given option key from the remote repository.\n   * @param {string} key - The key representing the option category to download\n   * @returns {Promise<void>}\n   * @throws {Error} If the specified option key is not found\n   */\n  async downloadOption(key: keyof typeof options): Promise<void> {\n    if (!(key in options)) {\n      throw new Error(`Option \"${key}\" not found in options`);\n    }\n    const files = options[key as keyof typeof options];\n\n    for (const file of files) {\n      this.log.info(`Downloading ${file}`);\n\n      let data = await HttpClient.downloadFile(`${baseUrl}/${file}`);\n      data = patchString(data, this.replacements);\n      writeFile(path.join(process.cwd(), file), data);\n    }\n  }\n\n  /**\n   * @description Downloads and sets up the specified license.\n   * @summary This method downloads the chosen license file, saves it to the project, and updates the package.json license field.\n   * @param {\"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"} license - The license to download and set up\n   * @returns {Promise<void>}\n   */\n  async getLicense(license: \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\") {\n    this.log.info(`Downloading ${license} license`);\n    const url = `${baseUrl}/workdocs/licenses/${license}.md`;\n    let data = await HttpClient.downloadFile(url);\n    data = patchString(data, this.replacements);\n    writeFile(path.join(process.cwd(), \"LICENSE.md\"), data);\n    setPackageAttribute(\"license\", license);\n  }\n\n  /**\n   * @description Downloads IDE configuration files.\n   * @returns {Promise<void>}\n   */\n  async getIde() {\n    fs.mkdirSync(path.join(process.cwd(), \".idea\", \"runConfigurations\"), {\n      recursive: true,\n    });\n    await this.downloadOption(\"ide\");\n  }\n\n  /**\n   * @description Update npm scripts\n   * @returns {Promise<void>}\n   */\n  async getScripts() {\n    await this.downloadOption(\"scripts\");\n    this.log.info(\"please re-run the command\");\n    process.exit(0);\n  }\n\n  /**\n   * @description Downloads style configuration files.\n   * @returns {Promise<void>}\n   */\n  getStyles = () => this.downloadOption(\"styles\");\n\n  /**\n   * @description Downloads template files.\n   * @returns {Promise<void>}\n   */\n  getTemplates = () => this.downloadOption(\"templates\");\n\n  /**\n   * @description Downloads workflow configuration files.\n   * @returns {Promise<void>}\n   */\n  getWorkflows = () => this.downloadOption(\"workflows\");\n\n  /**\n   * @description Downloads documentation files.\n   * @returns {Promise<void>}\n   */\n  getDocs = () => this.downloadOption(\"docs\");\n\n  /**\n   * @description Downloads typescript config files.\n   * @returns {Promise<void>}\n   */\n  getTypescript = () => this.downloadOption(\"typescript\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getAutomation = () => this.downloadOption(\"automation\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getTests = () => this.downloadOption(\"tests\");\n\n  /**\n   * @description Downloads docker image files.\n   * @returns {Promise<void>}\n   */\n  getDocker = () => this.downloadOption(\"docker\");\n\n  async initPackage(pkgName: string, author: string, license: string) {\n    try {\n      const pkg = getPackage() as Record<string, unknown>;\n      delete pkg[SetupScriptKey];\n      pkg.name = pkgName;\n      pkg.version = \"0.0.1\";\n      pkg.author = author;\n      pkg.license = license;\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json: ${e}`);\n    }\n  }\n\n  async updatePackageScrips() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { scripts } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in scripts) {\n          const replaced = patchString(scripts[key], this.replacements);\n          if (replaced !== scripts[key]) {\n            pkg.scripts[key] = replaced;\n          }\n        }\n      });\n\n      pkg[\"exports\"][\"require\"] = originalPkg[\"exports\"][\"require\"];\n      pkg[\"exports\"][\"import\"] = originalPkg[\"exports\"][\"import\"];\n      pkg[\"types\"] = originalPkg[\"types\"];\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json scripts: ${e}`);\n    }\n  }\n\n  async createTokenFiles() {\n    const log = this.log.for(this.createTokenFiles);\n    const gitToken = await UserInput.insistForText(\n      \"token\",\n      \"please input your github token\",\n      (res: string) => {\n        return !!res.match(/^ghp_[0-9a-zA-Z]{36}$/g);\n      }\n    );\n    Object.values(Tokens).forEach((token) => {\n      try {\n        let status;\n        try {\n          status = fs.existsSync(token);\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        } catch (e: unknown) {\n          log.info(`Token file ${token} not found. Creating a new one...`);\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n          return;\n        }\n        if (!status) {\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n        }\n      } catch (e: unknown) {\n        throw new Error(`Error creating token file ${token}: ${e}`);\n      }\n    });\n  }\n\n  async getOrg(): Promise<string> {\n    const org = await UserInput.askText(\n      \"Organization\",\n      \"Enter the organization name (will be used to scope your npm project. leave blank to create a unscoped project):\"\n    );\n    const confirmation = await UserInput.askConfirmation(\n      \"Confirm organization\",\n      \"Is this organization correct?\",\n      true\n    );\n    if (!confirmation) return this.getOrg();\n\n    return org;\n  }\n\n  async auditFix() {\n    return await runCommand(\"npm audit fix --force\").promise;\n  }\n\n  patchFiles() {\n    const files = [\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"src\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile())\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"workdocs\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile() && entry.name.endsWith(\".md\"))\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      path.join(process.cwd(), \".gitlab-ci.yml\"),\n      path.join(process.cwd(), \"workdocs\", \"jsdocs.json\"),\n    ];\n\n    for (const file of files) {\n      patchFile(file as string, this.replacements);\n    }\n  }\n\n  async updateDependencies() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { devDependencies } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in devDependencies) {\n          const replaced = devDependencies[key];\n          if (replaced !== devDependencies[key]) {\n            (pkg as any)[\"devDependencies\"] =\n              (pkg as any)[\"devDependencies\"] || {};\n            (pkg as any)[\"devDependencies\"][key] = replaced;\n          }\n        }\n      });\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n      await runCommand(\"npm install\").promise;\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json dependencies: ${e}`);\n    }\n  }\n\n  /**\n   * @description Runs the template synchronization process.\n   * @summary This method orchestrates the downloading of various project components based on the provided arguments.\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant T as TemplateSync\n   *   participant L as getLicense\n   *   participant I as getIde\n   *   participant S as getScripts\n   *   participant St as getStyles\n   *   participant D as getDocs\n   *   participant W as getWorkflows\n   *   participant Te as getTemplates\n   *   T->>T: Parse arguments\n   *   alt all flag is true\n   *     T->>T: Set all component flags to true\n   *   end\n   *   alt license is specified\n   *     T->>L: getLicense(license)\n   *   end\n   *   alt ide flag is true\n   *     T->>I: getIde()\n   *   end\n   *   alt scripts flag is true\n   *     T->>S: getScripts()\n   *   end\n   *   alt styles flag is true\n   *     T->>St: getStyles()\n   *   end\n   *   alt docs flag is true\n   *     T->>D: getDocs()\n   *   end\n   *   alt workflows flag is true\n   *     T->>W: getWorkflows()\n   *   end\n   *   alt templates flag is true\n   *     T->>Te: getTemplates()\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof argzz]: unknown }\n  ) {\n    let { license } = args;\n    const { boot } = args;\n    let {\n      all,\n      scripts,\n      styles,\n      docs,\n      ide,\n      workflows,\n      templates,\n      docker,\n      typescript,\n      dependencies,\n      tests,\n      automation,\n      pkg,\n    } = args;\n    if (\n      scripts ||\n      styles ||\n      docs ||\n      ide ||\n      workflows ||\n      templates ||\n      docker ||\n      typescript ||\n      automation ||\n      dependencies ||\n      tests ||\n      pkg\n    )\n      all = false;\n\n    if (boot) {\n      const org = await this.getOrg();\n      const name = await UserInput.insistForText(\n        \"Project name\",\n        \"Enter the project name:\",\n        (res: string) => res.length > 1\n      );\n      const author = await UserInput.insistForText(\n        \"Author\",\n        \"Enter the author name:\",\n        (res: string) => res.length > 1\n      );\n      const pkgName = org ? `@${org}/${name}` : name;\n\n      await this.initPackage(pkgName, author, license as string);\n      await this.createTokenFiles();\n      await this.auditFix();\n      this.patchFiles();\n    }\n\n    if (all) {\n      scripts = false;\n      styles = true;\n      docs = true;\n      ide = true;\n      workflows = true;\n      templates = true;\n      docker = true;\n      typescript = true;\n      pkg = true;\n      dependencies = true;\n      tests = true;\n      automation = false;\n    }\n\n    if (typeof scripts === \"undefined\")\n      scripts = await UserInput.askConfirmation(\n        \"scripts\",\n        \"Do you want to get scripts?\",\n        true\n      );\n\n    if (scripts) await this.getScripts();\n\n    this.loadValuesFromPackage();\n    if (!all && typeof license === \"undefined\") {\n      const confirmation = await UserInput.askConfirmation(\n        \"license\",\n        \"Do you want to set a license?\",\n        true\n      );\n      if (confirmation)\n        license = await UserInput.insistForText(\n          \"license\",\n          \"Enter the desired License (MIT|GPL|Apache|LGPL|AGPL):\",\n          (val) => !!val && !!val.match(/^(MIT|GPL|Apache|LGPL|AGPL)$/g)\n        );\n    }\n    if (typeof license !== \"undefined\")\n      await this.getLicense(\n        license as \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"\n      );\n\n    if (typeof ide === \"undefined\")\n      ide = await UserInput.askConfirmation(\n        \"ide\",\n        \"Do you want to get ide configs?\",\n        true\n      );\n\n    if (ide) await this.getIde();\n\n    if (typeof typescript === \"undefined\")\n      typescript = await UserInput.askConfirmation(\n        \"typescript\",\n        \"Do you want to get typescript configs?\",\n        true\n      );\n    if (typescript) await this.getTypescript();\n\n    if (typeof docker === \"undefined\")\n      docker = await UserInput.askConfirmation(\n        \"docker\",\n        \"Do you want to get docker configs?\",\n        true\n      );\n\n    if (docker) await this.getDocker();\n    if (typeof automation === \"undefined\")\n      automation = await UserInput.askConfirmation(\n        \"automation\",\n        \"Do you want to get automation configs?\",\n        true\n      );\n    if (automation) await this.getAutomation();\n\n    if (typeof styles === \"undefined\")\n      styles = await UserInput.askConfirmation(\n        \"styles\",\n        \"Do you want to get styles?\",\n        true\n      );\n    if (styles) await this.getStyles();\n\n    if (typeof docs === \"undefined\")\n      docs = await UserInput.askConfirmation(\n        \"docs\",\n        \"Do you want to get docs?\",\n        true\n      );\n    if (docs) await this.getDocs();\n    if (typeof workflows === \"undefined\")\n      workflows = await UserInput.askConfirmation(\n        \"workflows\",\n        \"Do you want to get workflows?\",\n        true\n      );\n    if (workflows) await this.getWorkflows();\n    if (typeof templates === \"undefined\")\n      templates = await UserInput.askConfirmation(\n        \"templates\",\n        \"Do you want to get templates?\",\n        true\n      );\n    if (templates) await this.getTemplates();\n    if (typeof pkg === \"undefined\")\n      pkg = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your package.json scripts?\",\n        true\n      );\n    if (pkg) await this.updatePackageScrips();\n\n    if (typeof tests === \"undefined\")\n      tests = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your test configs?\",\n        true\n      );\n    if (tests) await this.getTests();\n\n    if (typeof dependencies === \"undefined\")\n      dependencies = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update dev dependencies?\",\n        true\n      );\n    if (dependencies) await this.updateDependencies();\n  }\n}\n","import { StandardOutputWriter } from \"./StandardOutputWriter\";\nimport { PromiseExecutor } from \"../utils/types\";\n\n/**\n * @description A specialized output writer that uses regular expressions to process output.\n * @summary This class extends StandardOutputWriter to provide regex-based output processing.\n * It allows for pattern matching in the output stream and can trigger specific actions\n * based on matched patterns.\n *\n * @template T - The type of the resolved value, defaulting to string.\n *\n * @param lock - A PromiseExecutor to control the asynchronous flow.\n * @param regexp - A string or RegExp to match against the output.\n * @param flags - Optional flags for the RegExp constructor.\n *\n * @class\n */\nexport class RegexpOutputWriter extends StandardOutputWriter<string> {\n  /**\n   * @description The regular expression used for matching output.\n   * @summary This readonly property stores the compiled RegExp used for pattern matching.\n   */\n  protected readonly regexp: RegExp;\n\n  /**\n   * @description Initializes a new instance of RegexpOutputWriter.\n   * @summary Constructs the RegexpOutputWriter with a lock mechanism and a regular expression.\n   *\n   * @param cmd\n   * @param lock - A PromiseExecutor to control the asynchronous flow.\n   * @param regexp - A string or RegExp to match against the output.\n   * @param flags - Optional flags for the RegExp constructor, defaults to \"g\".\n   */\n  constructor(\n    cmd: string,\n    lock: PromiseExecutor<string, Error>,\n    regexp: string | RegExp,\n    flags = \"g\"\n  ) {\n    super(cmd, lock);\n    try {\n      this.regexp =\n        typeof regexp === \"string\" ? new RegExp(regexp, flags) : regexp;\n    } catch (e: unknown) {\n      throw new Error(`Invalid regular expression: ${e}`);\n    }\n  }\n\n  /**\n   * @description Tests the input data against the stored regular expression.\n   * @summary Executes the regular expression on the input data and returns the match result.\n   *\n   * @param data - The string to test against the regular expression.\n   * @return The result of the regular expression execution, or undefined if an error occurs.\n   */\n  private test(data: string) {\n    this.regexp.lastIndex = 0;\n    let match;\n    try {\n      match = this.regexp.exec(data);\n    } catch (e: unknown) {\n      return console.debug(`Failed to parse chunk: ${data}\\nError: ${e} `);\n    }\n    return match;\n  }\n\n  /**\n   * @description Tests the data and resolves the promise if a match is found.\n   * @summary Executes the test method and resolves the promise with the first match group if successful.\n   *\n   * @param data - The string to test against the regular expression.\n   */\n  protected testAndResolve(data: string) {\n    const match = this.test(data);\n    if (match) this.resolve(match[0]);\n  }\n\n  /**\n   * @description Tests the data and rejects the promise if a match is found.\n   * @summary Executes the test method and rejects the promise with the first match group if successful.\n   *\n   * @param data - The string to test against the regular expression.\n   */\n  protected testAndReject(data: string) {\n    const match = this.test(data);\n    if (match) this.reject(match[0]);\n  }\n\n  /**\n   * @description Processes incoming data chunks.\n   * @summary Calls the parent class data method and then tests the data for a match to potentially resolve the promise.\n   *\n   * @param chunk - The data chunk to process.\n   */\n  data(chunk: any) {\n    super.data(chunk);\n    this.testAndResolve(String(chunk));\n  }\n\n  /**\n   * @description Processes incoming error chunks.\n   * @summary Calls the parent class error method and then tests the data for a match to potentially reject the promise.\n   *\n   * @param chunk - The error chunk to process.\n   */\n  error(chunk: any) {\n    super.error(chunk);\n    this.testAndReject(String(chunk));\n  }\n}\n","export * from \"./cli\";\nexport * from \"./input\";\nexport * from \"./output\";\nexport * from \"./utils\";\nexport * from \"./writers\";\n\n/**\n * @module @decaf-ts/utils\n * @description\n * This module serves a light version of Decaf CLI tool, providing a comprehensive set of utilities\n * and functionalities for command-line interface operations. It encompasses several key components:\n *\n * 1. Input Handling: Manages user input and command-line arguments processing.\n * 2. Utility Functions: Offers a collection of helper functions and constants for various operations.\n * 3. Type Definitions: Defines custom types and interfaces used throughout the module.\n * 4. Output Management: Provides different output writing strategies for flexible console output handling.\n *\n * The module is designed to facilitate the creation of robust CLI applications by offering:\n * - Standardized input parsing and validation\n * - Consistent output formatting and handling\n * - Reusable utility functions for common CLI tasks\n * - Extensible architecture for adding new commands and features\n *\n * It supports various output modes, including standard console output and regular expression-based output,\n * allowing for versatile data presentation and processing. The modular structure enables easy maintenance\n * and extension of the CLI functionality.\n *\n * This module is particularly useful for developers building complex command-line tools that require\n * structured input handling, flexible output formatting, and a rich set of utility functions.\n */\n\n/**\n * @description Represents the current version of the module.\n * @summary This constant stores the version number of the @asdasdasd/utils module.\n * The actual version number is replaced during the build process,\n * with the placeholder \"##VERSION##\" being substituted with the current version.\n *\n * @const VERSION\n * @memberOf module:@decaf-ts/utils\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["options"],"mappings":"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"}