neex 0.2.8 → 0.2.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 (47) hide show
  1. package/bun.lock +118 -544
  2. package/dist/cli.d.ts +1 -0
  3. package/dist/cli.js +199 -0
  4. package/dist/cli.js.map +1 -0
  5. package/dist/commands/build.d.ts +3 -0
  6. package/dist/commands/build.js +41 -0
  7. package/dist/commands/build.js.map +1 -0
  8. package/dist/commands/cache.d.ts +3 -0
  9. package/dist/commands/cache.js +34 -0
  10. package/dist/commands/cache.js.map +1 -0
  11. package/dist/commands/dev.d.ts +3 -0
  12. package/dist/commands/dev.js +51 -0
  13. package/dist/commands/dev.js.map +1 -0
  14. package/dist/commands/process.d.ts +2 -0
  15. package/dist/commands/process.js +216 -0
  16. package/dist/commands/process.js.map +1 -0
  17. package/dist/commands/run.d.ts +2 -0
  18. package/dist/commands/run.js +81 -0
  19. package/dist/commands/run.js.map +1 -0
  20. package/dist/commands/start.d.ts +3 -0
  21. package/dist/commands/start.js +45 -0
  22. package/dist/commands/start.js.map +1 -0
  23. package/dist/dev-manager.d.ts +34 -0
  24. package/dist/dev-manager.js +172 -0
  25. package/dist/dev-manager.js.map +1 -0
  26. package/dist/index.d.ts +38 -0
  27. package/dist/index.js +69 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/logger.d.ts +31 -0
  30. package/dist/logger.js +238 -0
  31. package/dist/logger.js.map +1 -0
  32. package/dist/process-manager.d.ts +51 -0
  33. package/dist/process-manager.js +258 -0
  34. package/dist/process-manager.js.map +1 -0
  35. package/dist/project-manager.d.ts +50 -0
  36. package/dist/project-manager.js +241 -0
  37. package/dist/project-manager.js.map +1 -0
  38. package/dist/runner.d.ts +16 -0
  39. package/dist/runner.js +331 -0
  40. package/dist/runner.js.map +1 -0
  41. package/dist/types.d.ts +37 -0
  42. package/dist/types.js +3 -0
  43. package/dist/types.js.map +1 -0
  44. package/dist/typescript-runner.d.ts +12 -0
  45. package/dist/typescript-runner.js +161 -0
  46. package/dist/typescript-runner.js.map +1 -0
  47. package/package.json +5 -2
@@ -0,0 +1,81 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.registerRunCommands = registerRunCommands;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ const figures_1 = __importDefault(require("figures"));
9
+ const index_js_1 = require("../index.js");
10
+ function registerRunCommands(program) {
11
+ // Sequential execution command
12
+ program
13
+ .command('sequential <commands...>')
14
+ .alias('s')
15
+ .description('Run commands sequentially')
16
+ .option('-c, --no-color', 'Disable colored output')
17
+ .option('-t, --no-timing', 'Hide timing information')
18
+ .option('-p, --no-prefix', 'Hide command prefix')
19
+ .option('-s, --stop-on-error', 'Stop on first error')
20
+ .option('-o, --no-output', 'Hide command output')
21
+ .option('-m, --minimal', 'Use minimal output format')
22
+ .action(async (commands, options) => {
23
+ try {
24
+ await (0, index_js_1.run)(commands, {
25
+ parallel: false,
26
+ color: options.color,
27
+ showTiming: options.timing,
28
+ prefix: options.prefix,
29
+ stopOnError: options.stopOnError,
30
+ printOutput: options.output,
31
+ minimalOutput: options.minimal
32
+ });
33
+ }
34
+ catch (error) {
35
+ if (error instanceof Error) {
36
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Error: ${error.message}`));
37
+ }
38
+ else {
39
+ console.error(chalk_1.default.red(`${figures_1.default.cross} An unknown error occurred`));
40
+ }
41
+ process.exit(1);
42
+ }
43
+ });
44
+ // Parallel execution command
45
+ program
46
+ .command('parallel <commands...>', { isDefault: true })
47
+ .alias('p')
48
+ .description('Run commands in parallel (default) or sequentially with -q. Alias: p')
49
+ .option('-c, --no-color', 'Disable colored output')
50
+ .option('-t, --no-timing', 'Hide timing information')
51
+ .option('-p, --no-prefix', 'Hide command prefix')
52
+ .option('-s, --stop-on-error', 'Stop on first error')
53
+ .option('-o, --no-output', 'Hide command output')
54
+ .option('-m, --minimal', 'Use minimal output format')
55
+ .option('-x, --max-parallel <number>', 'Maximum number of parallel processes', parseInt)
56
+ .option('-q, --sequential', 'Run commands sequentially instead of in parallel')
57
+ .action(async (commands, options) => {
58
+ try {
59
+ await (0, index_js_1.run)(commands, {
60
+ parallel: !options.sequential,
61
+ maxParallel: options.maxParallel,
62
+ color: options.color,
63
+ showTiming: options.timing,
64
+ prefix: options.prefix,
65
+ stopOnError: options.stopOnError,
66
+ printOutput: options.output,
67
+ minimalOutput: options.minimal
68
+ });
69
+ }
70
+ catch (error) {
71
+ if (error instanceof Error) {
72
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Error: ${error.message}`));
73
+ }
74
+ else {
75
+ console.error(chalk_1.default.red(`${figures_1.default.cross} An unknown error occurred`));
76
+ }
77
+ process.exit(1);
78
+ }
79
+ });
80
+ }
81
+ //# sourceMappingURL=run.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ import { ProjectManager } from '../project-manager.js';
3
+ export declare function registerStartCommand(program: Command, projectManager: ProjectManager): void;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.registerStartCommand = registerStartCommand;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ const figures_1 = __importDefault(require("figures"));
9
+ function registerStartCommand(program, projectManager) {
10
+ program
11
+ .command('start')
12
+ .description('Start the built application in production mode with health monitoring')
13
+ .option('-p, --port <number>', 'Port to run the server on', '3000')
14
+ .option('-o, --outDir <dir>', 'Output directory', 'dist')
15
+ .option('-e, --entry <file>', 'Entry file name', 'server.js')
16
+ .option('-i, --inspect', 'Enable Node.js inspector')
17
+ .option('-c, --cluster', 'Run in cluster mode')
18
+ .option('-w, --workers <number>', 'Number of worker processes', '0')
19
+ .option('--max-memory <size>', 'Maximum memory per process (e.g., 1024M)')
20
+ .option('--health-check', 'Enable health check endpoint')
21
+ .action(async (options) => {
22
+ try {
23
+ await projectManager.start({
24
+ port: options.port,
25
+ outDir: options.outDir,
26
+ entry: options.entry,
27
+ inspect: options.inspect,
28
+ cluster: options.cluster,
29
+ workers: options.workers,
30
+ maxMemory: options.maxMemory,
31
+ healthCheck: options.healthCheck
32
+ });
33
+ }
34
+ catch (error) {
35
+ if (error instanceof Error) {
36
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Error: ${error.message}`));
37
+ }
38
+ else {
39
+ console.error(chalk_1.default.red(`${figures_1.default.cross} An unknown error occurred`));
40
+ }
41
+ process.exit(1);
42
+ }
43
+ });
44
+ }
45
+ //# sourceMappingURL=start.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"start.js","sourceRoot":"","sources":["../../src/commands/start.ts"],"names":[],"mappings":";;;;;AAKA,oDAiCC;AArCD,kDAA0B;AAC1B,sDAA8B;AAG9B,SAAgB,oBAAoB,CAAC,OAAgB,EAAE,cAA8B;IACjF,OAAO;SACF,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,uEAAuE,CAAC;SACpF,MAAM,CAAC,qBAAqB,EAAE,2BAA2B,EAAE,MAAM,CAAC;SAClE,MAAM,CAAC,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,CAAC;SACxD,MAAM,CAAC,oBAAoB,EAAE,iBAAiB,EAAE,WAAW,CAAC;SAC5D,MAAM,CAAC,eAAe,EAAE,0BAA0B,CAAC;SACnD,MAAM,CAAC,eAAe,EAAE,qBAAqB,CAAC;SAC9C,MAAM,CAAC,wBAAwB,EAAE,4BAA4B,EAAE,GAAG,CAAC;SACnE,MAAM,CAAC,qBAAqB,EAAE,0CAA0C,CAAC;SACzE,MAAM,CAAC,gBAAgB,EAAE,8BAA8B,CAAC;SACxD,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACtB,IAAI,CAAC;YACD,MAAM,cAAc,CAAC,KAAK,CAAC;gBACvB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,OAAO,CAAC,SAAS;gBAC5B,WAAW,EAAE,OAAO,CAAC,WAAW;aACnC,CAAC,CAAC;QACP,CAAC;QAAC,OAAO,KAAc,EAAE,CAAC;YACtB,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;gBACzB,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,GAAG,iBAAO,CAAC,KAAK,WAAW,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YACzE,CAAC;iBAAM,CAAC;gBACJ,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,GAAG,iBAAO,CAAC,KAAK,4BAA4B,CAAC,CAAC,CAAC;YAC3E,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;IACL,CAAC,CAAC,CAAC;AACX,CAAC"}
@@ -0,0 +1,34 @@
1
+ import { EventEmitter } from 'events';
2
+ interface DevOptions {
3
+ entry: string;
4
+ outdir?: string;
5
+ watch?: boolean;
6
+ port?: number;
7
+ env?: Record<string, string>;
8
+ sourcemap?: boolean;
9
+ minify?: boolean;
10
+ target?: string[];
11
+ format?: 'cjs' | 'esm' | 'iife';
12
+ }
13
+ interface BuildResult {
14
+ success: boolean;
15
+ outputPath?: string;
16
+ error?: Error;
17
+ }
18
+ declare class DevManager extends EventEmitter {
19
+ private watcher;
20
+ private process;
21
+ private isRestarting;
22
+ private restartTimer;
23
+ private defaultOutDir;
24
+ private defaultPort;
25
+ constructor();
26
+ build(options: DevOptions): Promise<BuildResult>;
27
+ private startProcess;
28
+ private setupWatcher;
29
+ dev(options: DevOptions): Promise<void>;
30
+ start(options: DevOptions): Promise<void>;
31
+ stop(): void;
32
+ }
33
+ export declare const devManager: DevManager;
34
+ export {};
@@ -0,0 +1,172 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.devManager = void 0;
7
+ const esbuild_1 = require("esbuild");
8
+ const chokidar_1 = require("chokidar");
9
+ const child_process_1 = require("child_process");
10
+ const path_1 = require("path");
11
+ const fs_1 = require("fs");
12
+ const chalk_1 = __importDefault(require("chalk"));
13
+ const figures_1 = __importDefault(require("figures"));
14
+ const events_1 = require("events");
15
+ class DevManager extends events_1.EventEmitter {
16
+ constructor() {
17
+ super();
18
+ this.watcher = null;
19
+ this.process = null;
20
+ this.isRestarting = false;
21
+ this.restartTimer = null;
22
+ this.defaultOutDir = 'dist';
23
+ this.defaultPort = 3000;
24
+ }
25
+ async build(options) {
26
+ const outdir = options.outdir || this.defaultOutDir;
27
+ const outfile = (0, path_1.resolve)(outdir, `${(0, path_1.basename)(options.entry, '.ts')}.js`);
28
+ try {
29
+ if (!(0, fs_1.existsSync)(outdir)) {
30
+ (0, fs_1.mkdirSync)(outdir, { recursive: true });
31
+ }
32
+ const buildOptions = {
33
+ entryPoints: [options.entry],
34
+ outfile,
35
+ bundle: true,
36
+ platform: 'node',
37
+ target: options.target || ['node18'],
38
+ format: options.format || 'cjs',
39
+ sourcemap: options.sourcemap ?? true,
40
+ minify: options.minify ?? false,
41
+ define: {
42
+ 'process.env.NODE_ENV': '"development"',
43
+ ...Object.entries(options.env || {}).reduce((acc, [key, value]) => ({
44
+ ...acc,
45
+ [`process.env.${key}`]: JSON.stringify(value)
46
+ }), {})
47
+ }
48
+ };
49
+ await (0, esbuild_1.build)(buildOptions);
50
+ return { success: true, outputPath: outfile };
51
+ }
52
+ catch (error) {
53
+ return { success: false, error: error };
54
+ }
55
+ }
56
+ startProcess(outputPath, options) {
57
+ if (this.process) {
58
+ this.process.kill();
59
+ }
60
+ this.process = (0, child_process_1.spawn)('node', [outputPath], {
61
+ stdio: 'inherit',
62
+ env: {
63
+ ...process.env,
64
+ PORT: options.port?.toString() || this.defaultPort.toString(),
65
+ NODE_ENV: 'development',
66
+ ...options.env
67
+ }
68
+ });
69
+ this.process.on('error', (err) => {
70
+ this.emit('error', err);
71
+ });
72
+ this.process.on('exit', (code) => {
73
+ if (code !== 0 && !this.isRestarting) {
74
+ this.emit('error', new Error(`Process exited with code ${code}`));
75
+ }
76
+ });
77
+ }
78
+ setupWatcher(options) {
79
+ if (this.watcher) {
80
+ this.watcher.close();
81
+ }
82
+ const watchPaths = [
83
+ options.entry,
84
+ (0, path_1.dirname)(options.entry)
85
+ ];
86
+ this.watcher = (0, chokidar_1.watch)(watchPaths, {
87
+ ignored: /(^|[\/\\])\../,
88
+ persistent: true
89
+ });
90
+ this.watcher.on('change', async (path) => {
91
+ console.log(chalk_1.default.blue(`${figures_1.default.info} File changed: ${path}`));
92
+ if (this.restartTimer) {
93
+ clearTimeout(this.restartTimer);
94
+ }
95
+ this.isRestarting = true;
96
+ this.restartTimer = setTimeout(async () => {
97
+ try {
98
+ const result = await this.build(options);
99
+ if (result.success && result.outputPath) {
100
+ this.startProcess(result.outputPath, options);
101
+ console.log(chalk_1.default.green(`${figures_1.default.tick} Restarted successfully`));
102
+ }
103
+ else {
104
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Build failed: ${result.error?.message}`));
105
+ }
106
+ }
107
+ catch (error) {
108
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Error during restart: ${error}`));
109
+ }
110
+ finally {
111
+ this.isRestarting = false;
112
+ }
113
+ }, 1000);
114
+ });
115
+ }
116
+ async dev(options) {
117
+ try {
118
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Starting development server...`));
119
+ const result = await this.build(options);
120
+ if (!result.success || !result.outputPath) {
121
+ throw new Error(`Build failed: ${result.error?.message}`);
122
+ }
123
+ this.startProcess(result.outputPath, options);
124
+ if (options.watch) {
125
+ this.setupWatcher(options);
126
+ }
127
+ this.emit('start', { outputPath: result.outputPath });
128
+ }
129
+ catch (error) {
130
+ this.emit('error', error);
131
+ throw error;
132
+ }
133
+ }
134
+ async start(options) {
135
+ try {
136
+ const result = await this.build(options);
137
+ if (!result.success || !result.outputPath) {
138
+ throw new Error(`Build failed: ${result.error?.message}`);
139
+ }
140
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Starting production server...`));
141
+ this.startProcess(result.outputPath, {
142
+ ...options,
143
+ env: {
144
+ ...options.env,
145
+ NODE_ENV: 'production'
146
+ }
147
+ });
148
+ this.emit('start', { outputPath: result.outputPath });
149
+ }
150
+ catch (error) {
151
+ this.emit('error', error);
152
+ throw error;
153
+ }
154
+ }
155
+ stop() {
156
+ if (this.process) {
157
+ this.process.kill();
158
+ this.process = null;
159
+ }
160
+ if (this.watcher) {
161
+ this.watcher.close();
162
+ this.watcher = null;
163
+ }
164
+ if (this.restartTimer) {
165
+ clearTimeout(this.restartTimer);
166
+ this.restartTimer = null;
167
+ }
168
+ this.emit('stop');
169
+ }
170
+ }
171
+ exports.devManager = new DevManager();
172
+ //# sourceMappingURL=dev-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dev-manager.js","sourceRoot":"","sources":["../src/dev-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,38 @@
1
+ import { RunOptions, RunResult } from './types';
2
+ export { RunOptions, RunResult };
3
+ export interface neexOptions {
4
+ parallel?: boolean;
5
+ maxParallel?: number;
6
+ printOutput?: boolean;
7
+ color?: boolean;
8
+ showTiming?: boolean;
9
+ prefix?: boolean;
10
+ stopOnError?: boolean;
11
+ minimalOutput?: boolean;
12
+ groupOutput?: boolean;
13
+ isServerMode?: boolean;
14
+ registerCleanup?: (cleanupFn: () => void) => void;
15
+ }
16
+ /**
17
+ * Run one or more commands in parallel or sequentially
18
+ */
19
+ export declare function run(commands: string | string[], options?: neexOptions): Promise<RunResult[]>;
20
+ /**
21
+ * Run multiple commands in parallel
22
+ */
23
+ export declare function runParallel(commands: string | string[], options?: Omit<neexOptions, 'parallel'>): Promise<RunResult[]>;
24
+ /**
25
+ * Run multiple commands sequentially
26
+ */
27
+ export declare function runSequential(commands: string | string[], options?: Omit<neexOptions, 'parallel'>): Promise<RunResult[]>;
28
+ /**
29
+ * Run multiple servers with optimized output
30
+ */
31
+ export declare function runServers(commands: string | string[], options?: Omit<neexOptions, 'parallel' | 'isServerMode'>): Promise<RunResult[]>;
32
+ declare const _default: {
33
+ run: typeof run;
34
+ runParallel: typeof runParallel;
35
+ runSequential: typeof runSequential;
36
+ runServers: typeof runServers;
37
+ };
38
+ export default _default;
package/dist/index.js ADDED
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.run = run;
7
+ exports.runParallel = runParallel;
8
+ exports.runSequential = runSequential;
9
+ exports.runServers = runServers;
10
+ // src/index.ts - Updated version
11
+ const runner_1 = require("./runner");
12
+ const logger_1 = __importDefault(require("./logger"));
13
+ /**
14
+ * Run one or more commands in parallel or sequentially
15
+ */
16
+ async function run(commands, options) {
17
+ const cmdArray = Array.isArray(commands) ? commands : [commands];
18
+ const runOptions = {
19
+ parallel: options?.parallel ?? false,
20
+ maxParallel: options?.maxParallel,
21
+ printOutput: options?.printOutput ?? true,
22
+ color: options?.color ?? true,
23
+ showTiming: options?.showTiming ?? true,
24
+ prefix: options?.prefix ?? true,
25
+ stopOnError: options?.stopOnError ?? false,
26
+ minimalOutput: options?.minimalOutput ?? false,
27
+ groupOutput: options?.groupOutput ?? false,
28
+ isServerMode: options?.isServerMode ?? false
29
+ };
30
+ const runner = new runner_1.Runner(runOptions);
31
+ if (options?.registerCleanup) {
32
+ options.registerCleanup(() => runner.cleanup());
33
+ }
34
+ const results = await runner.run(cmdArray);
35
+ if (runOptions.printOutput && cmdArray.length > 1) {
36
+ logger_1.default.printSummary(results);
37
+ }
38
+ return results;
39
+ }
40
+ /**
41
+ * Run multiple commands in parallel
42
+ */
43
+ async function runParallel(commands, options) {
44
+ return run(commands, { ...options, parallel: true });
45
+ }
46
+ /**
47
+ * Run multiple commands sequentially
48
+ */
49
+ async function runSequential(commands, options) {
50
+ return run(commands, { ...options, parallel: false });
51
+ }
52
+ /**
53
+ * Run multiple servers with optimized output
54
+ */
55
+ async function runServers(commands, options) {
56
+ return run(commands, {
57
+ ...options,
58
+ parallel: true,
59
+ isServerMode: true,
60
+ printOutput: true
61
+ });
62
+ }
63
+ exports.default = {
64
+ run,
65
+ runParallel,
66
+ runSequential,
67
+ runServers
68
+ };
69
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAwBA,kBA6BC;AAKD,kCAEC;AAKD,sCAEC;AAKD,gCAOC;AA/ED,iCAAiC;AACjC,qCAAkC;AAElC,sDAA8B;AAkB9B;;GAEG;AACI,KAAK,UAAU,GAAG,CAAC,QAA2B,EAAE,OAAqB;IACxE,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAEjE,MAAM,UAAU,GAAe;QAC3B,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,KAAK;QACpC,WAAW,EAAE,OAAO,EAAE,WAAW;QACjC,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,IAAI;QACzC,KAAK,EAAE,OAAO,EAAE,KAAK,IAAI,IAAI;QAC7B,UAAU,EAAE,OAAO,EAAE,UAAU,IAAI,IAAI;QACvC,MAAM,EAAE,OAAO,EAAE,MAAM,IAAI,IAAI;QAC/B,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,KAAK;QAC1C,aAAa,EAAE,OAAO,EAAE,aAAa,IAAI,KAAK;QAC9C,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,KAAK;QAC1C,YAAY,EAAE,OAAO,EAAE,YAAY,IAAI,KAAK;KAC/C,CAAC;IAEF,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,UAAU,CAAC,CAAC;IAEtC,IAAI,OAAO,EAAE,eAAe,EAAE,CAAC;QAC3B,OAAO,CAAC,eAAe,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IAE3C,IAAI,UAAU,CAAC,WAAW,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAChD,gBAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,OAAO,OAAO,CAAC;AACnB,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,WAAW,CAAC,QAA2B,EAAE,OAAuC;IAClG,OAAO,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;AACzD,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,aAAa,CAAC,QAA2B,EAAE,OAAuC;IACpG,OAAO,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AAC1D,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,UAAU,CAAC,QAA2B,EAAE,OAAwD;IAClH,OAAO,GAAG,CAAC,QAAQ,EAAE;QACjB,GAAG,OAAO;QACV,QAAQ,EAAE,IAAI;QACd,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,IAAI;KACpB,CAAC,CAAC;AACP,CAAC;AAED,kBAAe;IACX,GAAG;IACH,WAAW;IACX,aAAa;IACb,UAAU;CACb,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { CommandOutput, RunResult } from './types';
2
+ declare class Logger {
3
+ private static instance;
4
+ private prefixLength;
5
+ private outputBuffer;
6
+ private commandColors;
7
+ private startTimes;
8
+ private spinnerFrames;
9
+ private spinnerIndex;
10
+ private spinnerIntervals;
11
+ private isSpinnerActive;
12
+ private constructor();
13
+ static getInstance(): Logger;
14
+ private getSpinnerFrame;
15
+ private showBanner;
16
+ setCommands(commands: string[]): void;
17
+ private generateColor;
18
+ formatPrefix(command: string): string;
19
+ bufferOutput(output: CommandOutput): void;
20
+ printBuffer(command: string): void;
21
+ printLine(message: string, level?: 'info' | 'error' | 'warn'): void;
22
+ printStart(command: string): void;
23
+ startSpinner(command: string): void;
24
+ stopSpinner(command: string): void;
25
+ stopAllSpinners(): void;
26
+ printSuccess(result: RunResult): void;
27
+ printError(result: RunResult): void;
28
+ printSummary(results: RunResult[]): void;
29
+ }
30
+ declare const _default: Logger;
31
+ export default _default;