@decaf-ts/cli 0.3.7 → 0.3.9

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 (45) hide show
  1. package/README.md +23 -3
  2. package/dist/cli.cjs +2 -326
  3. package/dist/cli.cjs.map +1 -0
  4. package/dist/cli.js +2 -0
  5. package/dist/cli.js.map +1 -0
  6. package/lib/CliWrapper.cjs +107 -2
  7. package/lib/CliWrapper.d.ts +3 -0
  8. package/lib/CliWrapper.js.map +1 -0
  9. package/lib/bin/cli.cjs +1 -1
  10. package/lib/bin/cli.js.map +1 -0
  11. package/lib/constants.cjs +1 -1
  12. package/lib/constants.js.map +1 -0
  13. package/lib/demo/cli-module.cjs +1 -1
  14. package/lib/demo/cli-module.js.map +1 -0
  15. package/lib/esm/CliWrapper.d.ts +3 -0
  16. package/lib/esm/CliWrapper.js +107 -2
  17. package/lib/esm/CliWrapper.js.map +1 -0
  18. package/lib/esm/bin/cli.js +1 -1
  19. package/lib/esm/bin/cli.js.map +1 -0
  20. package/lib/esm/constants.js +1 -1
  21. package/lib/esm/constants.js.map +1 -0
  22. package/lib/esm/demo/cli-module.js +1 -1
  23. package/lib/esm/demo/cli-module.js.map +1 -0
  24. package/lib/esm/index.d.ts +0 -7
  25. package/lib/esm/index.js +1 -8
  26. package/lib/esm/index.js.map +1 -0
  27. package/lib/esm/types.js +1 -1
  28. package/lib/esm/types.js.map +1 -0
  29. package/lib/esm/utils.js +1 -1
  30. package/lib/esm/utils.js.map +1 -0
  31. package/lib/esm/version.d.ts +14 -0
  32. package/lib/esm/version.js +17 -0
  33. package/lib/esm/version.js.map +1 -0
  34. package/lib/index.cjs +1 -9
  35. package/lib/index.d.ts +0 -7
  36. package/lib/index.js.map +1 -0
  37. package/lib/types.cjs +1 -1
  38. package/lib/types.js.map +1 -0
  39. package/lib/utils.cjs +1 -1
  40. package/lib/utils.js.map +1 -0
  41. package/lib/version.cjs +20 -0
  42. package/lib/version.d.ts +14 -0
  43. package/lib/version.js.map +1 -0
  44. package/package.json +17 -23
  45. package/dist/cli.esm.cjs +0 -321
package/README.md CHANGED
@@ -1,10 +1,9 @@
1
- ![Banner](./workdocs/assets/Banner.png)
1
+ ![Banner](./workdocs/assets/decaf-logo.svg)
2
2
 
3
3
  ## Decaf-ts CLI
4
4
 
5
5
  A modular command-line interface framework for Decaf-ts that dynamically discovers and loads CLI modules from different packages. The CLI provides a unified entry point (`decaf`) for executing commands from various Decaf modules, making it easy to extend with new functionality without modifying the core CLI code.
6
6
 
7
-
8
7
  ![Licence](https://img.shields.io/github/license/decaf-ts/cli.svg?style=plastic)
9
8
  ![GitHub language count](https://img.shields.io/github/languages/count/decaf-ts/cli?style=plastic)
10
9
  ![GitHub top language](https://img.shields.io/github/languages/top/decaf-ts/cli?style=plastic)
@@ -34,6 +33,9 @@ A modular command-line interface framework for Decaf-ts that dynamically discove
34
33
 
35
34
  Documentation available [here](https://decaf-ts.github.io/cli/)
36
35
 
36
+ Minimal size: 1.6 KB kb gzipped
37
+
38
+
37
39
  ### Description
38
40
 
39
41
  The Decaf-ts CLI is a powerful and extensible command-line interface framework designed to provide a unified entry point for all Decaf-ts modules. It enables developers to create modular CLI commands that can be discovered and executed through a single command-line tool.
@@ -200,6 +202,24 @@ npx decaf demo command "hello world"
200
202
  ```
201
203
 
202
204
 
205
+ ## Coding Principles
206
+
207
+ - group similar functionality in folders (analog to namespaces but without any namespace declaration)
208
+ - one class per file;
209
+ - one interface per file (unless interface is just used as a type);
210
+ - group types as other interfaces in a types.ts file per folder;
211
+ - group constants or enums in a constants.ts file per folder;
212
+ - group decorators in a decorators.ts file per folder;
213
+ - always import from the specific file, never from a folder or index file (exceptions for dependencies on other packages);
214
+ - prefer the usage of established design patters where applicable:
215
+ - Singleton (can be an anti-pattern. use with care);
216
+ - factory;
217
+ - observer;
218
+ - strategy;
219
+ - builder;
220
+ - etc;
221
+
222
+
203
223
  ### Related
204
224
 
205
225
  [![decaf-ts](https://github-readme-stats.vercel.app/api/pin/?username=decaf-ts&repo=decaf-ts)](https://github.com/decaf-ts/decaf-ts)
@@ -244,4 +264,4 @@ So if you can, if this project in any way. either by learning something or simpl
244
264
 
245
265
  This project is released under the [MIT License](./LICENSE.md).
246
266
 
247
- By developers, for developers...
267
+ By developers, for developers...
package/dist/cli.cjs CHANGED
@@ -1,326 +1,2 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('commander'), require('fs'), require('path')) :
3
- typeof define === 'function' && define.amd ? define(['exports', 'commander', 'fs', 'path'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.cli = {}, global.commander, global.fs, global.path));
5
- })(this, (function (exports, commander, fs, path) { 'use strict';
6
-
7
- /**
8
- * @description The filename that identifies Decaf CLI modules
9
- * @summary The standard filename for CLI module files where each library must export a single CliModule function
10
- *
11
- * @const CLI_FILE_NAME
12
- * @memberOf module:CLI
13
- */
14
- const CLI_FILE_NAME = "cli-module";
15
-
16
- /**
17
- * @description Utility class for CLI operations
18
- * @summary A static utility class that provides methods for loading modules, retrieving package information, and initializing CLI commands
19
- *
20
- * @example
21
- * // Initialize a Command object with package information
22
- * const command = new Command();
23
- * CLIUtils.initialize(command, './path/to/package');
24
- *
25
- * // Load a CLI module from a file
26
- * const module = await CLIUtils.loadFromFile('./path/to/cli-module.js');
27
- *
28
- * @class CLIUtils
29
- */
30
- class CLIUtils {
31
- /**
32
- * @description Dynamically imports a module file
33
- * @summary Loads a JavaScript file and returns it as a CliModule, handling both ESM and CommonJS formats
34
- *
35
- * @param {string} path The file path to the module to load
36
- * @return {Promise<CliModule>} A promise that resolves to the loaded CliModule
37
- */
38
- static async loadFromFile(path) {
39
- try {
40
- return CLIUtils.normalizeImport(import(path));
41
- }
42
- catch (e) {
43
- throw new Error(`Failed to load from ${path}: ${e instanceof Error ? e.message : e}`);
44
- }
45
- }
46
- /**
47
- * @description Normalizes module imports to handle both ESM and CommonJS formats
48
- * @summary Properly imports JavaScript files regardless of their module format by handling the ESM wrapper for CommonJS modules
49
- *
50
- * @template T The type of the imported module
51
- * @param {Promise<T>} importPromise The promise returned by the dynamic import
52
- * @return {Promise<T>} A promise that resolves to the normalized module
53
- * @private
54
- */
55
- static async normalizeImport(importPromise) {
56
- // CommonJS's `module.exports` is wrapped as `default` in ESModule.
57
- return importPromise.then((m) => (m.default || m));
58
- }
59
- /**
60
- * @description Initializes a Command object with package information
61
- * @summary Sets up a Commander Command object with the package name, description, and version from the package.json file
62
- *
63
- * @param {Command} command The Command object to initialize
64
- * @param {string} [basePath] The base path where the package.json file is located, defaults to the current working directory
65
- * @return {void}
66
- */
67
- static initialize(command, basePath) {
68
- const name = CLIUtils.packageName(basePath);
69
- command
70
- .name(name)
71
- .description(`Runs ${name} related commands`)
72
- .version(CLIUtils.packageVersion(basePath));
73
- }
74
- /**
75
- * @description Retrieves and parses the package.json file
76
- * @summary Reads the package.json file from the specified path and parses it into a JavaScript object
77
- *
78
- * @param {string} basePath The base path where the package.json file is located
79
- * @return {Record<string, unknown>} The parsed package.json content as an object
80
- * @private
81
- */
82
- static getPackage(basePath) {
83
- try {
84
- return JSON.parse(fs.readFileSync(path.join(basePath, "package.json"), "utf8"));
85
- }
86
- catch (e) {
87
- throw new Error(`Unable to read version from ${basePath}: ${e}`);
88
- }
89
- }
90
- /**
91
- * @description Returns the version from package.json
92
- * @summary Retrieves the version field from the package.json file at the specified path
93
- *
94
- * @param {string} basePath The base path where the package.json file is located
95
- * @return {string} The package version string
96
- */
97
- static packageVersion(basePath) {
98
- return CLIUtils.getPackage(basePath)["version"];
99
- }
100
- /**
101
- * @description Returns the name from package.json
102
- * @summary Retrieves the name field from the package.json file at the specified path and extracts the package name without the scope
103
- *
104
- * @param {string} basePath The base path where the package.json file is located
105
- * @return {string} The package name without the scope (e.g., "cli" from "@decaf-ts/cli")
106
- */
107
- static packageName(basePath) {
108
- const name = CLIUtils.getPackage(basePath)["name"].split("/");
109
- return name[name.length - 1];
110
- }
111
- }
112
-
113
- /**
114
- * @description Utility class to handle CLI functionality from all Decaf modules
115
- * @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.
116
- * It crawls the filesystem to find CLI modules, loads them, and registers their commands.
117
- *
118
- * @param {string} [basePath] The base path to look for modules in. Defaults to `./`
119
- * @param {number} [crawlLevels] Number of folder levels to crawl to find modules from the basePath. Defaults to 4
120
- *
121
- * @example
122
- * // Create a new CLI wrapper and run it with custom options
123
- * const cli = new CliWrapper('./src', 2);
124
- * cli.run(process.argv).then(() => {
125
- * console.log('CLI commands executed successfully');
126
- * });
127
- *
128
- * @class CliWrapper
129
- */
130
- class CliWrapper {
131
- constructor(basePath = "./", crawlLevels = 4) {
132
- this.basePath = basePath;
133
- this.crawlLevels = crawlLevels;
134
- this.modules = {};
135
- this.rootPath = path.resolve(__dirname, "..");
136
- }
137
- /**
138
- * @description Retrieves and initializes the Commander Command object
139
- * @summary Lazy-loads the Command object, initializing it with the package name, description, and version
140
- * @return {Command} The initialized Command object
141
- * @private
142
- */
143
- get command() {
144
- if (!this._command) {
145
- this._command = new commander.Command();
146
- CLIUtils.initialize(this._command, this.rootPath);
147
- }
148
- return this._command;
149
- }
150
- /**
151
- * @description Loads and registers a module from a file
152
- * @summary Dynamically imports a CLI module from the specified file path, initializes it, and registers it in the modules collection
153
- *
154
- * @param {string} filePath Path to the module file to load
155
- * @param {string} rootPath Repository root path to find the package.json
156
- * @return {Promise<string>} A promise that resolves to the module name
157
- *
158
- * @private
159
- * @mermaid
160
- * sequenceDiagram
161
- * participant CliWrapper
162
- * participant CLIUtils
163
- * participant Module
164
- *
165
- * CliWrapper->>CLIUtils: loadFromFile(filePath)
166
- * CLIUtils-->>CliWrapper: module
167
- * CliWrapper->>CliWrapper: Get module name
168
- * CliWrapper->>Command: new Command()
169
- * Command-->>CliWrapper: cmd
170
- * CliWrapper->>CLIUtils: initialize(cmd, path.dirname(rootPath))
171
- * CliWrapper->>Module: module()
172
- * Note over CliWrapper,Module: Handle Promise if needed
173
- * Module-->>CliWrapper: Command instance
174
- * CliWrapper->>CliWrapper: Store in modules[name]
175
- * CliWrapper-->>CliWrapper: Return name
176
- */
177
- async load(filePath, rootPath) {
178
- let name;
179
- try {
180
- const module = await CLIUtils.loadFromFile(filePath);
181
- name = module.name;
182
- const cmd = new commander.Command();
183
- CLIUtils.initialize(cmd, rootPath);
184
- let m = module();
185
- if (m instanceof Promise)
186
- m = await m;
187
- this.modules[name] = m;
188
- }
189
- catch (e) {
190
- throw new Error(`failed to load module ${name || "unnamed"} under ${filePath}: ${e instanceof Error ? e.message : e}`);
191
- }
192
- return name;
193
- }
194
- /**
195
- * @description Finds and loads all CLI modules in the basePath
196
- * @summary Uses the crawl method to find all CLI modules in the specified base path,
197
- * then loads and registers each module as a subcommand
198
- *
199
- * @return {Promise<void>} A promise that resolves when all modules are loaded
200
- *
201
- * @private
202
- * @mermaid
203
- * sequenceDiagram
204
- * participant CliWrapper
205
- * participant Filesystem
206
- * participant Module
207
- *
208
- * CliWrapper->>Filesystem: Join basePath with cwd
209
- * CliWrapper->>CliWrapper: crawl(basePath, crawlLevels)
210
- * CliWrapper-->>CliWrapper: modules[]
211
- * loop For each module
212
- * alt Not @decaf-ts/cli
213
- * CliWrapper->>CliWrapper: load(module, cwd)
214
- * CliWrapper-->>CliWrapper: name
215
- * CliWrapper->>CliWrapper: Check if command exists
216
- * alt Command doesn't exist
217
- * CliWrapper->>Command: command(name).addCommand(modules[name])
218
- * end
219
- * end
220
- * end
221
- * CliWrapper->>Console: Log loaded modules
222
- */
223
- async boot() {
224
- const basePath = path.resolve(this.rootPath, this.basePath);
225
- const modules = this.crawl(basePath, this.crawlLevels);
226
- for (const module of modules) {
227
- if (module.includes("@decaf-ts/cli")) {
228
- continue;
229
- }
230
- let name;
231
- try {
232
- name = await this.load(module, this.rootPath);
233
- }
234
- catch (e) {
235
- console.error(e);
236
- continue;
237
- }
238
- if (!this.command.commands.find((c) => c["_name"] === name))
239
- try {
240
- this.command.command(name).addCommand(this.modules[name]);
241
- }
242
- catch (e) {
243
- console.error(e);
244
- }
245
- }
246
- console.log(`loaded modules:\n${Object.keys(this.modules)
247
- .map((k) => `- ${k}`)
248
- .join("\n")}`);
249
- }
250
- /**
251
- * @description Recursively searches for CLI module files in the directory structure
252
- * @summary Crawls the basePath up to the specified number of folder levels to find files named according to CLI_FILE_NAME
253
- *
254
- * @param {string} basePath The absolute base path to start searching in
255
- * @param {number} [levels=2] The maximum number of directory levels to crawl
256
- * @return {string[]} An array of file paths to CLI modules
257
- *
258
- * @private
259
- */
260
- crawl(basePath, levels = 2) {
261
- if (levels <= 0)
262
- return [];
263
- return fs.readdirSync(basePath).reduce((accum, file) => {
264
- file = path.join(basePath, file);
265
- if (fs.statSync(file).isDirectory()) {
266
- accum.push(...this.crawl(file, levels - 1));
267
- }
268
- else if (file.match(new RegExp(`${CLI_FILE_NAME}.[cm]?js$`, "gm"))) {
269
- accum.push(file);
270
- }
271
- return accum;
272
- }, []);
273
- }
274
- /**
275
- * @description Executes the CLI with the provided arguments
276
- * @summary Boots the CLI by loading all modules, then parses and executes the command specified in the arguments
277
- *
278
- * @param {string[]} [args=process.argv] Command line arguments to parse and execute
279
- * @return {Promise<void>} A promise that resolves when the command execution is complete
280
- *
281
- * @mermaid
282
- * sequenceDiagram
283
- * participant Client
284
- * participant CliWrapper
285
- * participant Command
286
- *
287
- * Client->>CliWrapper: run(args)
288
- * CliWrapper->>CliWrapper: boot()
289
- * Note over CliWrapper: Loads all modules
290
- * CliWrapper->>Command: parseAsync(args)
291
- * Command-->>CliWrapper: result
292
- * CliWrapper-->>Client: result
293
- */
294
- async run(args = process.argv) {
295
- await this.boot();
296
- return this.command.parseAsync(args);
297
- }
298
- }
299
-
300
- /**
301
- * @description Decaf-ts' CLI module
302
- * @summary This file will crawl the current working directory for files called {@link CLI_FILE_NAME}
303
- * within the @decaf-ts namespace and load them as subcommands. It serves as the main entry point
304
- * for the CLI functionality, exporting the CliWrapper class and VERSION constant.
305
- *
306
- * @example
307
- * run module command - $ npx decaf <module name> <module command> ...<module command options>
308
- * get module help - $ npx decaf help <module name>;
309
- * list imported modules - $ npx decaf list;
310
- * get cli help - $ npx decaf help;
311
- *
312
- * @module CLI
313
- */
314
- /**
315
- * @description Stores the current package version
316
- * @summary A constant that holds the version string of the package, which is replaced during build
317
- * @const VERSION
318
- * @memberOf module:CLI
319
- */
320
- const VERSION = "0.3.6";
321
-
322
- exports.CliWrapper = CliWrapper;
323
- exports.VERSION = VERSION;
324
-
325
- }));
326
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"cli.cjs","sources":["../src/constants.ts","../src/utils.ts","../src/CliWrapper.ts","../src/index.ts"],"sourcesContent":["// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport { CliModule } from \"./types\";\n\n/**\n * @description The filename that identifies Decaf CLI modules\n * @summary The standard filename for CLI module files where each library must export a single CliModule function\n *\n * @const CLI_FILE_NAME\n * @memberOf module:CLI\n */\nexport const CLI_FILE_NAME = \"cli-module\";\n","import path from \"path\";\nimport fs from \"fs\";\nimport { Command } from \"commander\";\nimport { CliModule } from \"./types\";\n\n/**\n * @description Utility class for CLI operations\n * @summary A static utility class that provides methods for loading modules, retrieving package information, and initializing CLI commands\n * \n * @example\n * // Initialize a Command object with package information\n * const command = new Command();\n * CLIUtils.initialize(command, './path/to/package');\n * \n * // Load a CLI module from a file\n * const module = await CLIUtils.loadFromFile('./path/to/cli-module.js');\n * \n * @class CLIUtils\n */\nexport class CLIUtils {\n  /**\n   * @description Dynamically imports a module file\n   * @summary Loads a JavaScript file and returns it as a CliModule, handling both ESM and CommonJS formats\n   * \n   * @param {string} path The file path to the module to load\n   * @return {Promise<CliModule>} A promise that resolves to the loaded CliModule\n   */\n  static async loadFromFile(path: string): Promise<CliModule> {\n    try {\n      return CLIUtils.normalizeImport(import(path));\n    } catch (e: unknown) {\n      throw new Error(\n        `Failed to load from ${path}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n  }\n\n  /**\n   * @description Normalizes module imports to handle both ESM and CommonJS formats\n   * @summary Properly imports JavaScript files regardless of their module format by handling the ESM wrapper for CommonJS modules\n   *\n   * @template T The type of the imported module\n   * @param {Promise<T>} importPromise The promise returned by the dynamic import\n   * @return {Promise<T>} A promise that resolves to the normalized module\n   * @private\n   */\n  static async normalizeImport<T>(importPromise: Promise<T>): Promise<T> {\n    // CommonJS's `module.exports` is wrapped as `default` in ESModule.\n    return importPromise.then(\n      (m: unknown) => ((m as { default: T }).default || m) as T\n    );\n  }\n\n  /**\n   * @description Initializes a Command object with package information\n   * @summary Sets up a Commander Command object with the package name, description, and version from the package.json file\n   *\n   * @param {Command} command The Command object to initialize\n   * @param {string} [basePath] The base path where the package.json file is located, defaults to the current working directory\n   * @return {void}\n   */\n  static initialize(command: Command, basePath: string) {\n    const name = CLIUtils.packageName(basePath);\n    command\n      .name(name)\n      .description(`Runs ${name} related commands`)\n      .version(CLIUtils.packageVersion(basePath));\n  }\n\n  /**\n   * @description Retrieves and parses the package.json file\n   * @summary Reads the package.json file from the specified path and parses it into a JavaScript object\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {Record<string, unknown>} The parsed package.json content as an object\n   * @private\n   */\n  private static getPackage(basePath: string): Record<string, unknown> {\n    try {\n      return JSON.parse(\n        fs.readFileSync(path.join(basePath, \"package.json\"), \"utf8\")\n      );\n    } catch (e: unknown) {\n      throw new Error(`Unable to read version from ${basePath}: ${e}`);\n    }\n  }\n\n  /**\n   * @description Returns the version from package.json\n   * @summary Retrieves the version field from the package.json file at the specified path\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package version string\n   */\n  static packageVersion(basePath: string): string {\n    return CLIUtils.getPackage(basePath)[\"version\"] as string;\n  }\n\n  /**\n   * @description Returns the name from package.json\n   * @summary Retrieves the name field from the package.json file at the specified path and extracts the package name without the scope\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package name without the scope (e.g., \"cli\" from \"@decaf-ts/cli\")\n   */\n  static packageName(basePath: string): string {\n    const name = (CLIUtils.getPackage(basePath)[\"name\"] as string).split(\"/\");\n    return name[name.length - 1];\n  }\n}\n","import { Command } from \"commander\";\nimport fs from \"fs\";\nimport path from \"path\";\nimport { CLI_FILE_NAME } from \"./constants\";\nimport { CLIUtils } from \"./utils\";\n\n/**\n * @description Utility class to handle CLI functionality from all Decaf modules\n * @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.\n * It crawls the filesystem to find CLI modules, loads them, and registers their commands.\n * \n * @param {string} [basePath] The base path to look for modules in. Defaults to `./`\n * @param {number} [crawlLevels] Number of folder levels to crawl to find modules from the basePath. Defaults to 4\n * \n * @example\n * // Create a new CLI wrapper and run it with custom options\n * const cli = new CliWrapper('./src', 2);\n * cli.run(process.argv).then(() => {\n *   console.log('CLI commands executed successfully');\n * });\n * \n * @class CliWrapper\n */\nexport class CliWrapper {\n  private _command?: Command;\n  private modules: Record<string, Command> = {};\n  private readonly rootPath: string;\n\n  constructor(\n    private basePath: string = \"./\",\n    private crawlLevels = 4\n  ) {\n    this.rootPath = path.resolve(__dirname, \"..\");\n  }\n\n  /**\n   * @description Retrieves and initializes the Commander Command object\n   * @summary Lazy-loads the Command object, initializing it with the package name, description, and version\n   * @return {Command} The initialized Command object\n   * @private\n   */\n  private get command() {\n    if (!this._command) {\n      this._command = new Command();\n      CLIUtils.initialize(this._command, this.rootPath);\n    }\n    return this._command;\n  }\n\n  /**\n   * @description Loads and registers a module from a file\n   * @summary Dynamically imports a CLI module from the specified file path, initializes it, and registers it in the modules collection\n   *\n   * @param {string} filePath Path to the module file to load\n   * @param {string} rootPath Repository root path to find the package.json\n   * @return {Promise<string>} A promise that resolves to the module name\n   *\n   * @private\n   * @mermaid\n   * sequenceDiagram\n   *   participant CliWrapper\n   *   participant CLIUtils\n   *   participant Module\n   *   \n   *   CliWrapper->>CLIUtils: loadFromFile(filePath)\n   *   CLIUtils-->>CliWrapper: module\n   *   CliWrapper->>CliWrapper: Get module name\n   *   CliWrapper->>Command: new Command()\n   *   Command-->>CliWrapper: cmd\n   *   CliWrapper->>CLIUtils: initialize(cmd, path.dirname(rootPath))\n   *   CliWrapper->>Module: module()\n   *   Note over CliWrapper,Module: Handle Promise if needed\n   *   Module-->>CliWrapper: Command instance\n   *   CliWrapper->>CliWrapper: Store in modules[name]\n   *   CliWrapper-->>CliWrapper: Return name\n   */\n  private async load(filePath: string, rootPath: string): Promise<string> {\n    let name;\n    try {\n      const module = await CLIUtils.loadFromFile(filePath);\n      name = module.name;\n      const cmd = new Command();\n      CLIUtils.initialize(cmd, rootPath);\n      let m = module();\n      if (m instanceof Promise) m = await m;\n      this.modules[name] = m;\n    } catch (e: unknown) {\n      throw new Error(\n        `failed to load module ${name || \"unnamed\"} under ${filePath}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n    return name;\n  }\n\n  /**\n   * @description Finds and loads all CLI modules in the basePath\n   * @summary Uses the crawl method to find all CLI modules in the specified base path, \n   * then loads and registers each module as a subcommand\n   * \n   * @return {Promise<void>} A promise that resolves when all modules are loaded\n   * \n   * @private\n   * @mermaid\n   * sequenceDiagram\n   *   participant CliWrapper\n   *   participant Filesystem\n   *   participant Module\n   *   \n   *   CliWrapper->>Filesystem: Join basePath with cwd\n   *   CliWrapper->>CliWrapper: crawl(basePath, crawlLevels)\n   *   CliWrapper-->>CliWrapper: modules[]\n   *   loop For each module\n   *     alt Not @decaf-ts/cli\n   *       CliWrapper->>CliWrapper: load(module, cwd)\n   *       CliWrapper-->>CliWrapper: name\n   *       CliWrapper->>CliWrapper: Check if command exists\n   *       alt Command doesn't exist\n   *         CliWrapper->>Command: command(name).addCommand(modules[name])\n   *       end\n   *     end\n   *   end\n   *   CliWrapper->>Console: Log loaded modules\n   */\n  private async boot() {\n    const basePath = path.resolve(this.rootPath, this.basePath);\n    const modules = this.crawl(basePath, this.crawlLevels);\n    for (const module of modules) {\n      if (module.includes(\"@decaf-ts/cli\")) {\n        continue;\n      }\n      let name: string;\n      try {\n        name = await this.load(module, this.rootPath);\n      } catch (e: unknown) {\n        console.error(e);\n        continue;\n      }\n\n      if (\n        !this.command.commands.find(\n          (c) => (c as unknown as Record<string, string>)[\"_name\"] === name\n        )\n      )\n        try {\n          this.command.command(name).addCommand(this.modules[name]);\n        } catch (e: unknown) {\n          console.error(e);\n        }\n    }\n    console.log(\n      `loaded modules:\\n${Object.keys(this.modules)\n        .map((k) => `- ${k}`)\n        .join(\"\\n\")}`\n    );\n  }\n\n  /**\n   * @description Recursively searches for CLI module files in the directory structure\n   * @summary Crawls the basePath up to the specified number of folder levels to find files named according to CLI_FILE_NAME\n   * \n   * @param {string} basePath The absolute base path to start searching in\n   * @param {number} [levels=2] The maximum number of directory levels to crawl\n   * @return {string[]} An array of file paths to CLI modules\n   * \n   * @private\n   */\n  private crawl(basePath: string, levels: number = 2) {\n    if (levels <= 0) return [];\n    return fs.readdirSync(basePath).reduce((accum: string[], file) => {\n      file = path.join(basePath, file);\n      if (fs.statSync(file).isDirectory()) {\n        accum.push(...this.crawl(file, levels - 1));\n      } else if (file.match(new RegExp(`${CLI_FILE_NAME}.[cm]?js$`, \"gm\"))) {\n        accum.push(file);\n      }\n      return accum;\n    }, []);\n  }\n\n  /**\n   * @description Executes the CLI with the provided arguments\n   * @summary Boots the CLI by loading all modules, then parses and executes the command specified in the arguments\n   *\n   * @param {string[]} [args=process.argv] Command line arguments to parse and execute\n   * @return {Promise<void>} A promise that resolves when the command execution is complete\n   * \n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant CliWrapper\n   *   participant Command\n   *   \n   *   Client->>CliWrapper: run(args)\n   *   CliWrapper->>CliWrapper: boot()\n   *   Note over CliWrapper: Loads all modules\n   *   CliWrapper->>Command: parseAsync(args)\n   *   Command-->>CliWrapper: result\n   *   CliWrapper-->>Client: result\n   */\n  async run(args: string[] = process.argv) {\n    await this.boot();\n    return this.command.parseAsync(args);\n  }\n}\n","export * from \"./CliWrapper\";\n\n/**\n * @description Decaf-ts' CLI module\n * @summary This file will crawl the current working directory for files called {@link CLI_FILE_NAME}\n * within the @decaf-ts namespace and load them as subcommands. It serves as the main entry point\n * for the CLI functionality, exporting the CliWrapper class and VERSION constant.\n *\n * @example\n * run module command     - $ npx decaf <module name> <module command> ...<module command options>\n * get module help        - $ npx decaf help <module name>;\n * list imported modules  - $ npx decaf list;\n * get cli help           - $ npx decaf help;\n *\n * @module CLI\n */\n\n/**\n * @description Stores the current package version\n * @summary A constant that holds the version string of the package, which is replaced during build\n * @const VERSION\n * @memberOf module:CLI\n */\nexport const VERSION = \"##VERSION##\";\n"],"names":["Command"],"mappings":"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"}
1
+ var t,e;t=this,e=function(t,e,a,n,r,o){"use strict";function s(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var i=s(a),c=s(n);class d{static async loadFromFile(t){try{return d.normalizeImport(import(t))}catch(e){throw Error(`Failed to load from ${t}: ${e instanceof Error?e.message:e}`)}}static async normalizeImport(t){return t.then(t=>t.default||t)}static initialize(t,e){const a=d.packageName(e);t.name(a).description(`Runs ${a} related commands`).version(d.packageVersion(e))}static getPackage(t){try{return JSON.parse(i.default.readFileSync(c.default.join(t,"package.json"),"utf8"))}catch(e){throw Error(`Unable to read version from ${t}: ${e}`)}}static packageVersion(t){return d.getPackage(t).version}static packageName(t){const e=d.getPackage(t).name.split("/");return e[e.length-1]}}const l=["\x1b[38;5;215m","\x1b[38;5;209m","\x1b[38;5;205m","\x1b[38;5;210m","\x1b[38;5;217m","\x1b[38;5;216m","\x1b[38;5;224m","\x1b[38;5;230m","\x1b[38;5;230m"];t.CliWrapper=class{constructor(t="./",e=4){this.basePath=t,this.crawlLevels=e,this.modules={},this.rootPath=c.default.resolve(__dirname,"..")}get command(){return this._command||(this._command=new e.Command,d.initialize(this._command,this.rootPath)),this._command}async load(t,a){let n;try{const r=await d.loadFromFile(t);n=r.name;const o=new e.Command;d.initialize(o,a);let s=r();s instanceof Promise&&(s=await s),this.modules[n]=s}catch(e){throw Error(`failed to load module ${n||"unnamed"} under ${t}: ${e instanceof Error?e.message:e}`)}return n}async boot(){const t=c.default.resolve(this.rootPath,this.basePath),e=this.crawl(t,this.crawlLevels);for(const t of e){if(t.includes("@decaf-ts/cli"))continue;let e;try{e=await this.load(t,this.rootPath)}catch(t){continue}if(!this.command.commands.find(t=>t._name===e))try{this.command.command(e).addCommand(this.modules[e])}catch(t){}}}crawl(t,e=2){return e>0?i.default.readdirSync(t).reduce((a,n)=>(n=c.default.join(t,n),i.default.statSync(n).isDirectory()?a.push(...this.crawl(n,e-1)):n.match(RegExp("cli-module\\.[cm]js$","gm"))&&a.push(n),a),[]):[]}getSlogan(){let t,e=__dirname;try{for(;e&&e!==c.default.parse(e).root;){const a=c.default.join(e,"node_modules");if(i.default.existsSync(a)&&i.default.statSync(a).isDirectory()){t=a;break}const n=c.default.dirname(e);if(n===e)break;e=n}}catch{}const a=[];if(t){const e=c.default.join(t,"@decaf-ts");try{if(i.default.existsSync(e)&&i.default.statSync(e).isDirectory()){const t=i.default.readdirSync(e);for(const n of t){const t=c.default.join(e,n);try{const e=c.default.join(t,"workdocs","assets","slogans.json");if(i.default.existsSync(e)&&i.default.statSync(e).isFile()){const t=i.default.readFileSync(e,"utf-8"),n=JSON.parse(t);if(Array.isArray(n))for(const t of n)"string"==typeof t&&t.trim().length>0&&a.push(t.trim())}}catch{}}}}catch{}}return 0===a.length?"Decaf: strongly brewed TypeScript.":a[Math.floor(Math.random()*a.length)]}printBanner(t=r.Logging.get()){let e;try{e=this.getSlogan()}catch{e="Decaf: strongly brewed TypeScript."}const a="# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# ( ( \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# ) ) \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# [=======] \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# `-----\xb4 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n#".split("\n"),n=a.reduce((t,e)=>Math.max(t,e.length),0);a.push("# "+e.padStart(n-3)),a.forEach((e,a)=>{const n=l[a%l.length]||"",r=t?t.info.bind(t):(()=>{}).bind();try{r(o.style(e||"").raw(n).text)}catch{r((e||"")+"")}})}async run(t=process.argv){return await this.boot(),this.printBanner(),this.command.parseAsync(t)}}},"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("commander"),require("fs"),require("path"),require("@decaf-ts/logging"),require("styled-string-builder")):"function"==typeof define&&define.amd?define(["exports","commander","fs","path","@decaf-ts/logging","styled-string-builder"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).cli={},t.commander,t.fs,t.path,t.decafTsLogging,t.styledStringBuilder);
2
+ //# sourceMappingURL=cli.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.cjs","sources":["../src/utils.ts","../src/CliWrapper.ts"],"sourcesContent":[null,null],"names":["CLIUtils","loadFromFile","path","normalizeImport","import","e","Error","message","importPromise","then","m","default","initialize","command","basePath","name","packageName","description","version","packageVersion","getPackage","JSON","parse","fs","readFileSync","join","split","length","colors","constructor","crawlLevels","this","modules","rootPath","resolve","__dirname","_command","Command","load","filePath","module","cmd","Promise","boot","crawl","includes","commands","find","c","addCommand","levels","readdirSync","reduce","accum","file","statSync","isDirectory","push","match","RegExp","getSlogan","nodeModulesDir","current","root","candidate","existsSync","parent","dirname","slogans","scopeDir","pkgs","pkg","depPath","slogansPath","isFile","raw","parsed","Array","isArray","s","trim","Math","floor","random","printBanner","logger","Logging","get","banner","maxLength","max","line","padStart","forEach","index","color","logFn","info","bind","console","style","text","String","run","args","process","argv","parseAsync"],"mappings":"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"}
package/dist/cli.js ADDED
@@ -0,0 +1,2 @@
1
+ import{Command as t}from"commander";import r from"fs";import a from"path";import{Logging as e}from"@decaf-ts/logging";import{style as n}from"styled-string-builder";class o{static async loadFromFile(t){try{return o.normalizeImport(import(t))}catch(r){throw Error(`Failed to load from ${t}: ${r instanceof Error?r.message:r}`)}}static async normalizeImport(t){return t.then(t=>t.default||t)}static initialize(t,r){const a=o.packageName(r);t.name(a).description(`Runs ${a} related commands`).version(o.packageVersion(r))}static getPackage(t){try{return JSON.parse(r.readFileSync(a.join(t,"package.json"),"utf8"))}catch(r){throw Error(`Unable to read version from ${t}: ${r}`)}}static packageVersion(t){return o.getPackage(t).version}static packageName(t){const r=o.getPackage(t).name.split("/");return r[r.length-1]}}const s=["\x1b[38;5;215m","\x1b[38;5;209m","\x1b[38;5;205m","\x1b[38;5;210m","\x1b[38;5;217m","\x1b[38;5;216m","\x1b[38;5;224m","\x1b[38;5;230m","\x1b[38;5;230m"];class i{constructor(t="./",r=4){this.basePath=t,this.crawlLevels=r,this.modules={},this.rootPath=a.resolve(__dirname,"..")}get command(){return this._command||(this._command=new t,o.initialize(this._command,this.rootPath)),this._command}async load(r,a){let e;try{const n=await o.loadFromFile(r);e=n.name;const s=new t;o.initialize(s,a);let i=n();i instanceof Promise&&(i=await i),this.modules[e]=i}catch(t){throw Error(`failed to load module ${e||"unnamed"} under ${r}: ${t instanceof Error?t.message:t}`)}return e}async boot(){const t=a.resolve(this.rootPath,this.basePath),r=this.crawl(t,this.crawlLevels);for(const t of r){if(t.includes("@decaf-ts/cli"))continue;let r;try{r=await this.load(t,this.rootPath)}catch(t){continue}if(!this.command.commands.find(t=>t._name===r))try{this.command.command(r).addCommand(this.modules[r])}catch(t){}}}crawl(t,e=2){return e>0?r.readdirSync(t).reduce((n,o)=>(o=a.join(t,o),r.statSync(o).isDirectory()?n.push(...this.crawl(o,e-1)):o.match(RegExp("cli-module\\.[cm]js$","gm"))&&n.push(o),n),[]):[]}getSlogan(){let t,e=__dirname;try{for(;e&&e!==a.parse(e).root;){const n=a.join(e,"node_modules");if(r.existsSync(n)&&r.statSync(n).isDirectory()){t=n;break}const o=a.dirname(e);if(o===e)break;e=o}}catch{}const n=[];if(t){const e=a.join(t,"@decaf-ts");try{if(r.existsSync(e)&&r.statSync(e).isDirectory()){const t=r.readdirSync(e);for(const o of t){const t=a.join(e,o);try{const e=a.join(t,"workdocs","assets","slogans.json");if(r.existsSync(e)&&r.statSync(e).isFile()){const t=r.readFileSync(e,"utf-8"),a=JSON.parse(t);if(Array.isArray(a))for(const t of a)"string"==typeof t&&t.trim().length>0&&n.push(t.trim())}}catch{}}}}catch{}}return 0===n.length?"Decaf: strongly brewed TypeScript.":n[Math.floor(Math.random()*n.length)]}printBanner(t=e.get()){let r;try{r=this.getSlogan()}catch{r="Decaf: strongly brewed TypeScript."}const a="# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# ( ( \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# ) ) \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# [=======] \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# `-----\xb4 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n#".split("\n"),o=a.reduce((t,r)=>Math.max(t,r.length),0);a.push("# "+r.padStart(o-3)),a.forEach((r,a)=>{const e=s[a%s.length]||"",o=t?t.info.bind(t):(()=>{}).bind();try{o(n(r||"").raw(e).text)}catch{o((r||"")+"")}})}async run(t=process.argv){return await this.boot(),this.printBanner(),this.command.parseAsync(t)}}export{i as CliWrapper};
2
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sources":["../src/utils.ts","../src/CliWrapper.ts"],"sourcesContent":[null,null],"names":["CLIUtils","loadFromFile","path","normalizeImport","import","e","Error","message","importPromise","then","m","default","initialize","command","basePath","name","packageName","description","version","packageVersion","getPackage","JSON","parse","fs","readFileSync","join","split","length","colors","CliWrapper","constructor","crawlLevels","this","modules","rootPath","resolve","__dirname","_command","Command","load","filePath","module","cmd","Promise","boot","crawl","includes","commands","find","c","addCommand","levels","readdirSync","reduce","accum","file","statSync","isDirectory","push","match","RegExp","getSlogan","nodeModulesDir","current","root","candidate","existsSync","parent","dirname","slogans","scopeDir","pkgs","pkg","depPath","slogansPath","isFile","raw","parsed","Array","isArray","s","trim","Math","floor","random","printBanner","logger","Logging","get","banner","maxLength","max","line","padStart","forEach","index","color","logFn","info","bind","console","style","text","String","run","args","process","argv","parseAsync"],"mappings":"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"}