neex 0.2.7 → 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 (50) hide show
  1. package/README.md +3 -1
  2. package/bun.lock +118 -518
  3. package/dist/cli.d.ts +1 -0
  4. package/dist/cli.js +199 -0
  5. package/dist/cli.js.map +1 -0
  6. package/dist/commands/build.d.ts +3 -0
  7. package/dist/commands/build.js +41 -0
  8. package/dist/commands/build.js.map +1 -0
  9. package/dist/commands/cache.d.ts +3 -0
  10. package/dist/commands/cache.js +34 -0
  11. package/dist/commands/cache.js.map +1 -0
  12. package/dist/commands/dev.d.ts +3 -0
  13. package/dist/commands/dev.js +51 -0
  14. package/dist/commands/dev.js.map +1 -0
  15. package/dist/commands/process.d.ts +2 -0
  16. package/dist/commands/process.js +216 -0
  17. package/dist/commands/process.js.map +1 -0
  18. package/dist/commands/run.d.ts +2 -0
  19. package/dist/commands/run.js +81 -0
  20. package/dist/commands/run.js.map +1 -0
  21. package/dist/commands/start.d.ts +3 -0
  22. package/dist/commands/start.js +45 -0
  23. package/dist/commands/start.js.map +1 -0
  24. package/dist/dev-manager.d.ts +34 -0
  25. package/dist/dev-manager.js +172 -0
  26. package/dist/dev-manager.js.map +1 -0
  27. package/dist/index.d.ts +38 -0
  28. package/dist/index.js +69 -0
  29. package/dist/index.js.map +1 -0
  30. package/dist/logger.d.ts +31 -0
  31. package/dist/logger.js +238 -0
  32. package/dist/logger.js.map +1 -0
  33. package/dist/process-manager.d.ts +51 -0
  34. package/dist/process-manager.js +258 -0
  35. package/dist/process-manager.js.map +1 -0
  36. package/dist/project-manager.d.ts +50 -0
  37. package/dist/project-manager.js +241 -0
  38. package/dist/project-manager.js.map +1 -0
  39. package/dist/runner.d.ts +16 -0
  40. package/dist/runner.js +331 -0
  41. package/dist/runner.js.map +1 -0
  42. package/dist/src/cli.js +186 -157
  43. package/dist/src/process-manager.js +110 -60
  44. package/dist/types.d.ts +37 -0
  45. package/dist/types.js +3 -0
  46. package/dist/types.js.map +1 -0
  47. package/dist/typescript-runner.d.ts +12 -0
  48. package/dist/typescript-runner.js +161 -0
  49. package/dist/typescript-runner.js.map +1 -0
  50. package/package.json +7 -2
@@ -0,0 +1,241 @@
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.ProjectManager = void 0;
7
+ const child_process_1 = require("child_process");
8
+ const path_1 = require("path");
9
+ const fs_1 = require("fs");
10
+ const chalk_1 = __importDefault(require("chalk"));
11
+ const figures_1 = __importDefault(require("figures"));
12
+ const chokidar_1 = require("chokidar");
13
+ const typescript_runner_1 = require("./typescript-runner");
14
+ const child_process_2 = require("child_process");
15
+ class ProjectManager {
16
+ constructor() {
17
+ this.server = null;
18
+ this.watcher = null;
19
+ this.tsRunner = new typescript_runner_1.FastTypeScriptRunner();
20
+ }
21
+ async startDev(options) {
22
+ try {
23
+ const entryPath = (0, path_1.resolve)(process.cwd(), options.entry);
24
+ if (!(0, fs_1.existsSync)(entryPath)) {
25
+ throw new Error(`Entry file ${options.entry} not found`);
26
+ }
27
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Starting development server with ${this.tsRunner['compiler']} compiler...`));
28
+ await this.startServer(entryPath, options);
29
+ this.setupFileWatcher(options);
30
+ this.setupCleanup();
31
+ }
32
+ catch (error) {
33
+ this.handleError(error);
34
+ }
35
+ }
36
+ async build(options) {
37
+ try {
38
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Building project...`));
39
+ const startTime = Date.now();
40
+ const compiler = options.compiler === 'auto' ? this.tsRunner['compiler'] : options.compiler;
41
+ const buildCommand = this.getBuildCommand(compiler, options);
42
+ const build = (0, child_process_1.spawn)('sh', ['-c', buildCommand], {
43
+ stdio: 'inherit'
44
+ });
45
+ build.on('close', (code) => {
46
+ if (code === 0) {
47
+ const buildTime = Date.now() - startTime;
48
+ console.log(chalk_1.default.green(`${figures_1.default.tick} Build completed successfully in ${buildTime}ms`));
49
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Output: ${options.outDir}`));
50
+ }
51
+ else {
52
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Build failed with code ${code}`));
53
+ process.exit(code ?? 1);
54
+ }
55
+ });
56
+ }
57
+ catch (error) {
58
+ this.handleError(error);
59
+ }
60
+ }
61
+ async start(options) {
62
+ try {
63
+ const outDir = options.outDir;
64
+ const entryFile = options.entry;
65
+ const entryPath = (0, path_1.resolve)(process.cwd(), outDir, entryFile);
66
+ if (!(0, fs_1.existsSync)(entryPath)) {
67
+ console.log(chalk_1.default.yellow(`${figures_1.default.warning} Build not found. Building project first...`));
68
+ await this.build({ outDir: 'dist', minify: false, sourcemap: false, watch: false, compiler: 'auto', target: 'ES2022' });
69
+ }
70
+ this.startProductionServer(entryPath, options);
71
+ }
72
+ catch (error) {
73
+ this.handleError(error);
74
+ }
75
+ }
76
+ async startServer(entryPath, options) {
77
+ if (this.server) {
78
+ this.server.kill('SIGTERM');
79
+ await new Promise(resolve => setTimeout(resolve, 100));
80
+ }
81
+ try {
82
+ const startTime = Date.now();
83
+ const compiledPath = await this.tsRunner.compile(entryPath);
84
+ const compileTime = Date.now() - startTime;
85
+ console.log(chalk_1.default.green(`${figures_1.default.tick} Compiled in ${compileTime}ms`));
86
+ const nodeArgs = [];
87
+ if (options.inspect)
88
+ nodeArgs.push('--inspect');
89
+ if (options.inspectBrk)
90
+ nodeArgs.push('--inspect-brk');
91
+ this.server = (0, child_process_1.spawn)('node', [...nodeArgs, compiledPath], {
92
+ stdio: 'inherit',
93
+ env: {
94
+ ...process.env,
95
+ PORT: options.port,
96
+ NODE_ENV: 'development',
97
+ TS_NODE_DEV: 'true'
98
+ }
99
+ });
100
+ this.server.on('error', (err) => {
101
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Server error: ${err.message}`));
102
+ });
103
+ this.server.on('exit', (code, signal) => {
104
+ if (code !== 0 && signal !== 'SIGTERM') {
105
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Server crashed with code ${code}`));
106
+ }
107
+ });
108
+ console.log(chalk_1.default.green(`${figures_1.default.tick} Server started on port ${options.port}`));
109
+ }
110
+ catch (error) {
111
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Compilation error: ${error}`));
112
+ }
113
+ }
114
+ setupFileWatcher(options) {
115
+ this.watcher = (0, chokidar_1.watch)(options.watch, {
116
+ ignored: [
117
+ ...options.ignore,
118
+ /(^|[\/\\])\../,
119
+ '**/*.map',
120
+ '**/*.d.ts',
121
+ '**/node_modules/**'
122
+ ],
123
+ persistent: true,
124
+ ignoreInitial: true,
125
+ awaitWriteFinish: {
126
+ stabilityThreshold: 200,
127
+ pollInterval: 50
128
+ }
129
+ });
130
+ let restartTimer = null;
131
+ let isRestarting = false;
132
+ const handleFileChange = (path, event) => {
133
+ const ext = path.split('.').pop()?.toLowerCase();
134
+ if (!options.ext.includes(ext)) {
135
+ return;
136
+ }
137
+ if (restartTimer) {
138
+ clearTimeout(restartTimer);
139
+ }
140
+ isRestarting = true;
141
+ restartTimer = setTimeout(() => {
142
+ if (options.clear) {
143
+ process.stdout.write('\x1Bc');
144
+ }
145
+ console.log(chalk_1.default.yellow(`${figures_1.default.info} ${event}: ${path}`));
146
+ console.log(chalk_1.default.yellow(`${figures_1.default.info} Restarting server...`));
147
+ this.startServer((0, path_1.resolve)(process.cwd(), options.entry), options).then(() => {
148
+ isRestarting = false;
149
+ });
150
+ }, parseInt(options.delay));
151
+ };
152
+ this.watcher
153
+ .on('change', (path) => handleFileChange(path, 'Changed'))
154
+ .on('add', (path) => handleFileChange(path, 'Added'))
155
+ .on('unlink', (path) => handleFileChange(path, 'Removed'));
156
+ }
157
+ setupCleanup() {
158
+ const handleSignal = (signal) => {
159
+ console.log(`\n${chalk_1.default.yellow(`${figures_1.default.warning} Received ${signal}. Cleaning up...`)}`);
160
+ if (this.server) {
161
+ this.server.kill('SIGTERM');
162
+ }
163
+ if (this.watcher) {
164
+ this.watcher.close();
165
+ }
166
+ setTimeout(() => process.exit(0), 500);
167
+ };
168
+ process.on('SIGINT', () => handleSignal('SIGINT'));
169
+ process.on('SIGTERM', () => handleSignal('SIGTERM'));
170
+ process.on('SIGQUIT', () => handleSignal('SIGQUIT'));
171
+ }
172
+ getBuildCommand(compiler, options) {
173
+ switch (compiler) {
174
+ case 'swc':
175
+ return `npx swc src -d ${options.outDir} --config-file .swcrc`;
176
+ case 'esbuild':
177
+ return `npx esbuild src/**/*.ts --outdir=${options.outDir} --platform=node --target=node18 --format=cjs${options.sourcemap ? ' --sourcemap' : ''}${options.minify ? ' --minify' : ''}`;
178
+ default:
179
+ return `npx tsc --outDir ${options.outDir}${options.sourcemap ? ' --sourceMap' : ''}`;
180
+ }
181
+ }
182
+ startProductionServer(entryPath, options) {
183
+ console.log(chalk_1.default.blue(`${figures_1.default.info} Starting production server...`));
184
+ const nodeArgs = [];
185
+ if (options.inspect)
186
+ nodeArgs.push('--inspect');
187
+ if (options.maxMemory)
188
+ nodeArgs.push(`--max-old-space-size=${options.maxMemory.replace('M', '')}`);
189
+ let serverCommand = 'node';
190
+ let serverArgs = [...nodeArgs, entryPath];
191
+ if (options.cluster) {
192
+ serverCommand = 'npx';
193
+ serverArgs = ['pm2', 'start', entryPath, '--name', 'neex-app', '--instances', options.workers || 'max'];
194
+ }
195
+ this.server = (0, child_process_1.spawn)(serverCommand, serverArgs, {
196
+ stdio: 'inherit',
197
+ env: {
198
+ ...process.env,
199
+ PORT: options.port,
200
+ NODE_ENV: 'production'
201
+ }
202
+ });
203
+ this.server.on('error', (err) => {
204
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Server error: ${err.message}`));
205
+ process.exit(1);
206
+ });
207
+ console.log(chalk_1.default.green(`${figures_1.default.tick} Production server started on port ${options.port}`));
208
+ }
209
+ handleError(error) {
210
+ if (error instanceof Error) {
211
+ console.error(chalk_1.default.red(`${figures_1.default.cross} Error: ${error.message}`));
212
+ }
213
+ else {
214
+ console.error(chalk_1.default.red(`${figures_1.default.cross} An unknown error occurred`));
215
+ }
216
+ process.exit(1);
217
+ }
218
+ clearCache() {
219
+ this.tsRunner.clearCache();
220
+ }
221
+ getCacheStats() {
222
+ const cacheDir = (0, path_1.join)(process.cwd(), '.neex', 'cache');
223
+ if (!(0, fs_1.existsSync)(cacheDir)) {
224
+ return {
225
+ size: '0B',
226
+ files: 0,
227
+ lastUpdated: 'Never'
228
+ };
229
+ }
230
+ const size = (0, child_process_2.execSync)(`du -sh ${cacheDir}`, { encoding: 'utf8' }).trim().split('\t')[0];
231
+ const files = (0, child_process_2.execSync)(`find ${cacheDir} -type f | wc -l`, { encoding: 'utf8' }).trim();
232
+ const lastUpdated = (0, child_process_2.execSync)(`stat -f "%Sm" ${cacheDir}`, { encoding: 'utf8' }).trim();
233
+ return {
234
+ size,
235
+ files: parseInt(files),
236
+ lastUpdated
237
+ };
238
+ }
239
+ }
240
+ exports.ProjectManager = ProjectManager;
241
+ //# sourceMappingURL=project-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"project-manager.js","sourceRoot":"","sources":["../src/project-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { RunOptions, RunResult } from './types';
2
+ export declare class Runner {
3
+ private options;
4
+ private activeProcesses;
5
+ private serverInfo;
6
+ private portRegex;
7
+ private urlRegex;
8
+ constructor(options: RunOptions);
9
+ private resolveScriptAndCwd;
10
+ detectServerInfo(command: string, data: string): void;
11
+ runCommand(originalCommand: string): Promise<RunResult>;
12
+ runSequential(commands: string[]): Promise<RunResult[]>;
13
+ runParallel(commands: string[]): Promise<RunResult[]>;
14
+ run(commands: string[]): Promise<RunResult[]>;
15
+ cleanup(signal?: NodeJS.Signals): void;
16
+ }
package/dist/runner.js ADDED
@@ -0,0 +1,331 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.Runner = void 0;
40
+ // src/runner.ts - Updated version
41
+ const child_process_1 = require("child_process");
42
+ const fsPromises = __importStar(require("fs/promises"));
43
+ const path = __importStar(require("path"));
44
+ const chalk_1 = __importDefault(require("chalk"));
45
+ const logger_1 = __importDefault(require("./logger"));
46
+ const p_map_1 = __importDefault(require("p-map"));
47
+ const npm_run_path_1 = __importDefault(require("npm-run-path"));
48
+ class Runner {
49
+ constructor(options) {
50
+ this.activeProcesses = new Map();
51
+ this.serverInfo = new Map();
52
+ this.portRegex = /listening on (?:port |http:\/\/localhost:|https:\/\/localhost:)(\d+)/i;
53
+ this.urlRegex = /(https?:\/\/localhost:[0-9]+(?:\/[^\s]*)?)/i;
54
+ this.options = options;
55
+ this.activeProcesses = new Map();
56
+ }
57
+ async resolveScriptAndCwd(scriptNameOrCommand, baseDir) {
58
+ try {
59
+ const packageJsonPath = path.join(baseDir, 'package.json');
60
+ const packageJsonContent = await fsPromises.readFile(packageJsonPath, 'utf-8');
61
+ const packageJson = JSON.parse(packageJsonContent);
62
+ if (packageJson.scripts && packageJson.scripts[scriptNameOrCommand]) {
63
+ const scriptValue = packageJson.scripts[scriptNameOrCommand];
64
+ const cdMatch = scriptValue.match(/^cd\s+([^&]+)\s+&&\s+(.*)$/);
65
+ if (cdMatch) {
66
+ const dir = cdMatch[1];
67
+ const commandToExecute = cdMatch[2];
68
+ const targetCwd = path.resolve(baseDir, dir);
69
+ return { executableCommand: commandToExecute, executionCwd: targetCwd };
70
+ }
71
+ else {
72
+ // It's a script from package.json, but no 'cd ... && ...' pattern
73
+ return { executableCommand: scriptValue, executionCwd: baseDir };
74
+ }
75
+ }
76
+ }
77
+ catch (error) {
78
+ // Errors like package.json not found, or script not in package.json
79
+ // Will treat as direct command
80
+ }
81
+ return { executableCommand: scriptNameOrCommand, executionCwd: undefined };
82
+ }
83
+ detectServerInfo(command, data) {
84
+ if (!this.options.isServerMode)
85
+ return;
86
+ // Get or create server info
87
+ let serverInfo = this.serverInfo.get(command);
88
+ if (!serverInfo) {
89
+ serverInfo = {
90
+ name: command,
91
+ status: 'starting'
92
+ };
93
+ this.serverInfo.set(command, serverInfo);
94
+ }
95
+ // Try to detect port from output
96
+ const portMatch = data.match(this.portRegex);
97
+ if (portMatch && portMatch[1]) {
98
+ serverInfo.port = parseInt(portMatch[1], 10);
99
+ serverInfo.status = 'running';
100
+ // Only log if we just discovered the port
101
+ if (!serverInfo.url) {
102
+ logger_1.default.printLine(`Server ${command} running on port ${serverInfo.port}`, 'info');
103
+ }
104
+ }
105
+ // Try to detect full URL from output
106
+ const urlMatch = data.match(this.urlRegex);
107
+ if (urlMatch && urlMatch[1]) {
108
+ serverInfo.url = urlMatch[1];
109
+ serverInfo.status = 'running';
110
+ // Log the full URL once we detect it
111
+ logger_1.default.printLine(`Server ${command} available at ${chalk_1.default.cyan(serverInfo.url)}`, 'info');
112
+ }
113
+ // Update server info
114
+ this.serverInfo.set(command, serverInfo);
115
+ }
116
+ async runCommand(originalCommand) {
117
+ const { executableCommand: command, executionCwd: cwd } = await this.resolveScriptAndCwd(originalCommand, process.cwd());
118
+ const startTime = new Date();
119
+ const result = {
120
+ command: originalCommand,
121
+ success: false,
122
+ code: null,
123
+ startTime,
124
+ endTime: null,
125
+ output: []
126
+ };
127
+ if (this.options.printOutput) {
128
+ logger_1.default.printStart(originalCommand);
129
+ }
130
+ return new Promise((resolve) => {
131
+ const [cmd, ...args] = command.split(' ');
132
+ const env = {
133
+ ...process.env,
134
+ ...npm_run_path_1.default.env(),
135
+ FORCE_COLOR: this.options.color ? '1' : '0'
136
+ };
137
+ const proc = (0, child_process_1.spawn)(cmd, args, {
138
+ stdio: ['ignore', 'pipe', 'pipe'],
139
+ shell: true,
140
+ env,
141
+ detached: true,
142
+ cwd
143
+ });
144
+ this.activeProcesses.set(originalCommand, proc);
145
+ if (this.options.isServerMode) {
146
+ this.serverInfo.set(originalCommand, {
147
+ name: originalCommand,
148
+ status: 'starting',
149
+ pid: proc.pid,
150
+ startTime: new Date()
151
+ });
152
+ }
153
+ // Capture and display output
154
+ if (this.options.printOutput) {
155
+ proc.stdout.on('data', (data) => {
156
+ const output = {
157
+ command: originalCommand,
158
+ type: 'stdout',
159
+ data: data.toString(),
160
+ timestamp: new Date()
161
+ };
162
+ if (this.options.isServerMode) {
163
+ this.detectServerInfo(originalCommand, data.toString());
164
+ }
165
+ // Store output for logging
166
+ if (result.output)
167
+ result.output.push(output);
168
+ logger_1.default.bufferOutput(output);
169
+ // Print immediately unless we're in group mode
170
+ if (!this.options.groupOutput) {
171
+ logger_1.default.printBuffer(originalCommand);
172
+ }
173
+ });
174
+ proc.stderr.on('data', (data) => {
175
+ const output = {
176
+ command: originalCommand,
177
+ type: 'stderr',
178
+ data: data.toString(),
179
+ timestamp: new Date()
180
+ };
181
+ // Store output for logging
182
+ if (result.output)
183
+ result.output.push(output);
184
+ logger_1.default.bufferOutput(output);
185
+ // Print immediately unless we're in group mode
186
+ if (!this.options.groupOutput) {
187
+ logger_1.default.printBuffer(originalCommand);
188
+ }
189
+ });
190
+ }
191
+ proc.on('close', (code) => {
192
+ const endTime = new Date();
193
+ const duration = endTime.getTime() - startTime.getTime();
194
+ result.endTime = endTime;
195
+ result.duration = duration;
196
+ result.code = code;
197
+ result.success = code === 0;
198
+ this.activeProcesses.delete(originalCommand);
199
+ if (this.options.isServerMode) {
200
+ const serverInfo = this.serverInfo.get(originalCommand);
201
+ if (serverInfo) {
202
+ serverInfo.status = code === 0 ? 'stopped' : 'error';
203
+ this.serverInfo.set(originalCommand, serverInfo);
204
+ }
205
+ // If this is server mode and a server failed, print prominent error
206
+ if (code !== 0) {
207
+ logger_1.default.printLine(`Server ${originalCommand} crashed with code ${code}`, 'error');
208
+ }
209
+ }
210
+ // Print grouped output at the end if enabled
211
+ if (this.options.groupOutput && result.output && result.output.length > 0) {
212
+ logger_1.default.printBuffer(originalCommand);
213
+ }
214
+ if (this.options.printOutput) {
215
+ if (result.success) {
216
+ logger_1.default.printSuccess(result);
217
+ }
218
+ else {
219
+ logger_1.default.printError(result);
220
+ }
221
+ }
222
+ resolve(result);
223
+ });
224
+ proc.on('error', (error) => {
225
+ const endTime = new Date();
226
+ const duration = endTime.getTime() - startTime.getTime();
227
+ result.endTime = endTime;
228
+ result.duration = duration;
229
+ result.error = error;
230
+ result.success = false;
231
+ this.activeProcesses.delete(originalCommand);
232
+ if (this.options.isServerMode) {
233
+ const serverInfo = this.serverInfo.get(originalCommand);
234
+ if (serverInfo) {
235
+ serverInfo.status = 'error';
236
+ this.serverInfo.set(originalCommand, serverInfo);
237
+ }
238
+ }
239
+ if (this.options.printOutput) {
240
+ logger_1.default.printError(result);
241
+ }
242
+ resolve(result);
243
+ });
244
+ });
245
+ }
246
+ async runSequential(commands) {
247
+ const results = [];
248
+ for (const cmd of commands) {
249
+ const result = await this.runCommand(cmd);
250
+ results.push(result);
251
+ // Stop on error if enabled
252
+ if (!result.success && this.options.stopOnError) {
253
+ break;
254
+ }
255
+ }
256
+ return results;
257
+ }
258
+ async runParallel(commands) {
259
+ const concurrency = this.options.maxParallel || commands.length;
260
+ const mapper = async (cmd) => {
261
+ return this.runCommand(cmd);
262
+ };
263
+ try {
264
+ return await (0, p_map_1.default)(commands, mapper, {
265
+ concurrency,
266
+ stopOnError: this.options.stopOnError
267
+ });
268
+ }
269
+ catch (error) {
270
+ // If pMap stops due to stopOnError
271
+ if (this.options.isServerMode) {
272
+ logger_1.default.printLine('One or more servers failed to start. Stopping all servers.', 'error');
273
+ }
274
+ return [];
275
+ }
276
+ }
277
+ async run(commands) {
278
+ if (commands.length === 0) {
279
+ return [];
280
+ }
281
+ // Set up logger with commands
282
+ logger_1.default.setCommands(commands);
283
+ // Run in parallel or sequential mode
284
+ if (this.options.parallel) {
285
+ if (this.options.isServerMode) {
286
+ logger_1.default.printLine('Starting servers in parallel mode', 'info');
287
+ }
288
+ return this.runParallel(commands);
289
+ }
290
+ else {
291
+ if (this.options.isServerMode) {
292
+ logger_1.default.printLine('Starting servers in sequential mode', 'info');
293
+ }
294
+ return this.runSequential(commands);
295
+ }
296
+ }
297
+ cleanup(signal = 'SIGTERM') {
298
+ logger_1.default.printLine('Cleaning up child processes...', 'warn');
299
+ this.activeProcesses.forEach((proc, command) => {
300
+ if (proc.pid && !proc.killed) {
301
+ try {
302
+ // Kill process group
303
+ process.kill(-proc.pid, signal);
304
+ logger_1.default.printLine(`Sent ${signal} to process group ${proc.pid} (${command})`, 'info');
305
+ }
306
+ catch (e) {
307
+ // Fallback if killing group failed
308
+ try {
309
+ proc.kill(signal);
310
+ logger_1.default.printLine(`Sent ${signal} to process ${proc.pid} (${command})`, 'info');
311
+ }
312
+ catch (errInner) {
313
+ logger_1.default.printLine(`Failed to kill process ${proc.pid} (${command}): ${errInner.message}`, 'error');
314
+ }
315
+ }
316
+ }
317
+ });
318
+ this.activeProcesses.clear();
319
+ // Print server status summary if in server mode
320
+ if (this.options.isServerMode && this.serverInfo.size > 0) {
321
+ logger_1.default.printLine('Server shutdown summary:', 'info');
322
+ this.serverInfo.forEach((info, command) => {
323
+ const statusColor = info.status === 'running' ? chalk_1.default.green :
324
+ info.status === 'error' ? chalk_1.default.red : chalk_1.default.yellow;
325
+ logger_1.default.printLine(` ${command}: ${statusColor(info.status)}`, 'info');
326
+ });
327
+ }
328
+ }
329
+ }
330
+ exports.Runner = Runner;
331
+ //# sourceMappingURL=runner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runner.js","sourceRoot":"","sources":["../src/runner.ts"],"names":[],"mappings":"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"}