teen_process 2.0.2 → 2.0.4
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.
- package/build/index.js +38 -0
- package/build/lib/exec.d.ts +108 -0
- package/build/lib/exec.d.ts.map +1 -0
- package/build/lib/exec.js +189 -166
- package/build/lib/exec.js.map +1 -0
- package/build/lib/helpers.d.ts +13 -0
- package/build/lib/helpers.d.ts.map +1 -0
- package/build/lib/helpers.js +39 -29
- package/build/lib/helpers.js.map +1 -0
- package/build/lib/index.d.ts +8 -0
- package/build/lib/index.d.ts.map +1 -0
- package/build/lib/index.js +33 -27
- package/build/lib/index.js.map +1 -0
- package/build/lib/subprocess.d.ts +66 -0
- package/build/lib/subprocess.d.ts.map +1 -0
- package/build/lib/subprocess.js +268 -263
- package/build/lib/subprocess.js.map +1 -0
- package/index.js +1 -1
- package/lib/exec.js +3 -4
- package/lib/helpers.js +21 -15
- package/lib/index.js +3 -2
- package/lib/subprocess.js +2 -2
- package/package.json +31 -33
package/build/lib/subprocess.js
CHANGED
|
@@ -1,285 +1,290 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
var _shellQuote = require("shell-quote");
|
|
19
|
-
|
|
20
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
21
|
-
|
|
22
|
-
var _helpers = require("./helpers");
|
|
23
|
-
|
|
24
|
-
const {
|
|
25
|
-
EventEmitter
|
|
26
|
-
} = _events.default;
|
|
2
|
+
/* eslint-disable promise/prefer-await-to-callbacks */
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.SubProcess = void 0;
|
|
8
|
+
const child_process_1 = require("child_process");
|
|
9
|
+
const events_1 = __importDefault(require("events"));
|
|
10
|
+
const { EventEmitter } = events_1.default;
|
|
11
|
+
const bluebird_1 = __importDefault(require("bluebird"));
|
|
12
|
+
const shell_quote_1 = require("shell-quote");
|
|
13
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
14
|
+
const helpers_1 = require("./helpers");
|
|
15
|
+
// This is needed to avoid memory leaks
|
|
16
|
+
// when the process output is too long and contains
|
|
17
|
+
// no line breaks
|
|
27
18
|
const MAX_LINE_PORTION_LENGTH = 0xFFFF;
|
|
28
|
-
|
|
29
19
|
function cutSuffix(str, suffixLength) {
|
|
30
|
-
|
|
20
|
+
return str.length > suffixLength
|
|
21
|
+
// https://bugs.chromium.org/p/v8/issues/detail?id=2869
|
|
22
|
+
? ` ${str.substr(str.length - suffixLength)}`.substr(1)
|
|
23
|
+
: str;
|
|
31
24
|
}
|
|
32
|
-
|
|
33
25
|
class SubProcess extends EventEmitter {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
stderr: ''
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
get isRunning() {
|
|
60
|
-
return !!this.proc;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
emitLines(stream, lines) {
|
|
64
|
-
for (let line of lines) {
|
|
65
|
-
this.emit('stream-line', `[${stream.toUpperCase()}] ${line}`);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
async start(startDetector = null, timeoutMs = null, detach = false) {
|
|
70
|
-
let startDelay = 10;
|
|
71
|
-
|
|
72
|
-
const genericStartDetector = function genericStartDetector(stdout, stderr) {
|
|
73
|
-
return stdout || stderr;
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
if (startDetector === null) {
|
|
77
|
-
startDetector = genericStartDetector;
|
|
26
|
+
/**
|
|
27
|
+
* @param {string} cmd
|
|
28
|
+
* @param {string[]} [args]
|
|
29
|
+
* @param {any} [opts]
|
|
30
|
+
*/
|
|
31
|
+
constructor(cmd, args = [], opts = {}) {
|
|
32
|
+
super();
|
|
33
|
+
if (!cmd)
|
|
34
|
+
throw new Error('Command is required'); // eslint-disable-line curly
|
|
35
|
+
if (!lodash_1.default.isString(cmd))
|
|
36
|
+
throw new Error('Command must be a string'); // eslint-disable-line curly
|
|
37
|
+
if (!lodash_1.default.isArray(args))
|
|
38
|
+
throw new Error('Args must be an array'); // eslint-disable-line curly
|
|
39
|
+
this.cmd = cmd;
|
|
40
|
+
this.args = args;
|
|
41
|
+
this.proc = null;
|
|
42
|
+
this.opts = opts;
|
|
43
|
+
this.expectingExit = false;
|
|
44
|
+
// get a quoted representation of the command for error strings
|
|
45
|
+
this.rep = (0, shell_quote_1.quote)([cmd, ...args]);
|
|
46
|
+
this.lastLinePortion = { stdout: '', stderr: '' };
|
|
78
47
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
startDetector = null;
|
|
48
|
+
get isRunning() {
|
|
49
|
+
// presence of `proc` means we have connected and started
|
|
50
|
+
return !!this.proc;
|
|
83
51
|
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
if (!this.opts.detached) {
|
|
94
|
-
throw new Error(`Unable to detach process that is not started with 'detached' option`);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
detach = true;
|
|
98
|
-
timeoutMs = null;
|
|
52
|
+
/**
|
|
53
|
+
*
|
|
54
|
+
* @param {string} stream
|
|
55
|
+
* @param {Iterable<string>} lines
|
|
56
|
+
*/
|
|
57
|
+
emitLines(stream, lines) {
|
|
58
|
+
for (let line of lines) {
|
|
59
|
+
this.emit('stream-line', `[${stream.toUpperCase()}] ${line}`);
|
|
60
|
+
}
|
|
99
61
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
try {
|
|
124
|
-
if (_lodash.default.isFunction(startDetector) && startDetector(stdout, stderr)) {
|
|
62
|
+
// spawn the subprocess and return control whenever we deem that it has fully
|
|
63
|
+
// "started"
|
|
64
|
+
/**
|
|
65
|
+
*
|
|
66
|
+
* @param {StartDetector|number?} startDetector
|
|
67
|
+
* @param {number?} timeoutMs
|
|
68
|
+
* @param {boolean} detach
|
|
69
|
+
* @returns {Promise<void>}
|
|
70
|
+
*/
|
|
71
|
+
async start(startDetector = null, timeoutMs = null, detach = false) {
|
|
72
|
+
let startDelay = 10;
|
|
73
|
+
const genericStartDetector = /** @type {StartDetector} */ (function genericStartDetector(stdout, stderr) {
|
|
74
|
+
return stdout || stderr;
|
|
75
|
+
});
|
|
76
|
+
// the default start detector simply returns true when we get any output
|
|
77
|
+
if (startDetector === null) {
|
|
78
|
+
startDetector = genericStartDetector;
|
|
79
|
+
}
|
|
80
|
+
// if the user passes a number, then we simply delay a certain amount of
|
|
81
|
+
// time before returning control, rather than waiting for a condition
|
|
82
|
+
if (lodash_1.default.isNumber(startDetector)) {
|
|
83
|
+
startDelay = startDetector;
|
|
125
84
|
startDetector = null;
|
|
126
|
-
resolve();
|
|
127
|
-
}
|
|
128
|
-
} catch (e) {
|
|
129
|
-
reject(e);
|
|
130
85
|
}
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
if (!streamData) continue;
|
|
136
|
-
const lines = streamData.split('\n').map(x => ` ${x}`.substr(1));
|
|
137
|
-
|
|
138
|
-
if (lines.length > 1) {
|
|
139
|
-
lines[0] = this.lastLinePortion[streamName] + lines[0];
|
|
140
|
-
this.lastLinePortion[streamName] = cutSuffix(_lodash.default.last(lines), MAX_LINE_PORTION_LENGTH);
|
|
141
|
-
const resultLines = lines.slice(0, -1);
|
|
142
|
-
this.emit(`lines-${streamName}`, resultLines);
|
|
143
|
-
this.emitLines(streamName, resultLines);
|
|
144
|
-
} else {
|
|
145
|
-
const currentPortion = cutSuffix(lines[0], MAX_LINE_PORTION_LENGTH);
|
|
146
|
-
|
|
147
|
-
if (this.lastLinePortion[streamName].length + currentPortion.length > MAX_LINE_PORTION_LENGTH) {
|
|
148
|
-
this.lastLinePortion[streamName] = currentPortion;
|
|
149
|
-
} else {
|
|
150
|
-
this.lastLinePortion[streamName] += currentPortion;
|
|
86
|
+
// if the user passes in a boolean as one of the arguments, use it for `detach`
|
|
87
|
+
if (lodash_1.default.isBoolean(startDetector) && startDetector) {
|
|
88
|
+
if (!this.opts.detached) {
|
|
89
|
+
throw new Error(`Unable to detach process that is not started with 'detached' option`);
|
|
151
90
|
}
|
|
152
|
-
|
|
91
|
+
detach = true;
|
|
92
|
+
startDetector = genericStartDetector;
|
|
153
93
|
}
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
(_this$proc2 = this.proc) === null || _this$proc2 === void 0 ? void 0 : _this$proc2.kill('SIGINT');
|
|
161
|
-
|
|
162
|
-
if (err.code === 'ENOENT') {
|
|
163
|
-
var _this$opts;
|
|
164
|
-
|
|
165
|
-
err = (0, _helpers.formatEnoent)(err, this.cmd, (_this$opts = this.opts) === null || _this$opts === void 0 ? void 0 : _this$opts.cwd);
|
|
94
|
+
else if (lodash_1.default.isBoolean(timeoutMs) && timeoutMs) {
|
|
95
|
+
if (!this.opts.detached) {
|
|
96
|
+
throw new Error(`Unable to detach process that is not started with 'detached' option`);
|
|
97
|
+
}
|
|
98
|
+
detach = true;
|
|
99
|
+
timeoutMs = null;
|
|
166
100
|
}
|
|
167
|
-
|
|
168
|
-
reject
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
101
|
+
// return a promise so we can wrap the async behavior
|
|
102
|
+
return await new bluebird_1.default((resolve, reject) => {
|
|
103
|
+
// actually spawn the subproc
|
|
104
|
+
this.proc = (0, child_process_1.spawn)(this.cmd, this.args, this.opts);
|
|
105
|
+
if (this.proc.stdout) {
|
|
106
|
+
this.proc.stdout.setEncoding(this.opts.encoding || 'utf8');
|
|
107
|
+
}
|
|
108
|
+
if (this.proc.stderr) {
|
|
109
|
+
this.proc.stderr.setEncoding(this.opts.encoding || 'utf8');
|
|
110
|
+
}
|
|
111
|
+
this.lastLinePortion = { stdout: '', stderr: '' };
|
|
112
|
+
// this function handles output that we collect from the subproc
|
|
113
|
+
/**
|
|
114
|
+
*
|
|
115
|
+
* @param { {stdout: string, stderr: string} } streams
|
|
116
|
+
*/
|
|
117
|
+
const handleOutput = (streams) => {
|
|
118
|
+
const { stdout, stderr } = streams;
|
|
119
|
+
// if we have a startDetector, run it on the output so we can resolve/
|
|
120
|
+
// reject and move on from start
|
|
121
|
+
try {
|
|
122
|
+
if (lodash_1.default.isFunction(startDetector) && startDetector(stdout, stderr)) {
|
|
123
|
+
startDetector = null;
|
|
124
|
+
resolve();
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
catch (e) {
|
|
128
|
+
reject(e);
|
|
129
|
+
}
|
|
130
|
+
// emit the actual output for whomever's listening
|
|
131
|
+
this.emit('output', stdout, stderr);
|
|
132
|
+
// we also want to emit lines, but it's more complex since output
|
|
133
|
+
// comes in chunks and a line could come in two different chunks, so
|
|
134
|
+
// we have logic to handle that case (using this.lastLinePortion to
|
|
135
|
+
// remember a line that started but did not finish in the last chunk)
|
|
136
|
+
for (const [streamName, streamData] of /** @type {[['stdout', string], ['stderr', string]]} */ (lodash_1.default.toPairs(streams))) {
|
|
137
|
+
if (!streamData)
|
|
138
|
+
continue; // eslint-disable-line curly
|
|
139
|
+
const lines = streamData.split('\n')
|
|
140
|
+
// https://bugs.chromium.org/p/v8/issues/detail?id=2869
|
|
141
|
+
.map((x) => ` ${x}`.substr(1));
|
|
142
|
+
if (lines.length > 1) {
|
|
143
|
+
lines[0] = this.lastLinePortion[streamName] + lines[0];
|
|
144
|
+
this.lastLinePortion[streamName] = cutSuffix(lodash_1.default.last(lines), MAX_LINE_PORTION_LENGTH);
|
|
145
|
+
const resultLines = lines.slice(0, -1);
|
|
146
|
+
this.emit(`lines-${streamName}`, resultLines);
|
|
147
|
+
this.emitLines(streamName, resultLines);
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
const currentPortion = cutSuffix(lines[0], MAX_LINE_PORTION_LENGTH);
|
|
151
|
+
if (this.lastLinePortion[streamName].length + currentPortion.length > MAX_LINE_PORTION_LENGTH) {
|
|
152
|
+
this.lastLinePortion[streamName] = currentPortion;
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
this.lastLinePortion[streamName] += currentPortion;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
// if we get an error spawning the proc, reject and clean up the proc
|
|
161
|
+
this.proc.on('error', /** @param {NodeJS.ErrnoException} err */ async (err) => {
|
|
162
|
+
this.proc?.removeAllListeners('exit');
|
|
163
|
+
this.proc?.kill('SIGINT');
|
|
164
|
+
if (err.code === 'ENOENT') {
|
|
165
|
+
err = await (0, helpers_1.formatEnoent)(err, this.cmd, this.opts?.cwd);
|
|
166
|
+
}
|
|
167
|
+
reject(err);
|
|
168
|
+
this.proc?.unref();
|
|
169
|
+
this.proc = null;
|
|
170
|
+
});
|
|
171
|
+
if (this.proc.stdout) {
|
|
172
|
+
this.proc.stdout.on('data', (chunk) => handleOutput({ stdout: chunk.toString(), stderr: '' }));
|
|
173
|
+
}
|
|
174
|
+
if (this.proc.stderr) {
|
|
175
|
+
this.proc.stderr.on('data', (chunk) => handleOutput({ stdout: '', stderr: chunk.toString() }));
|
|
176
|
+
}
|
|
177
|
+
// when the proc exits, we might still have a buffer of lines we were
|
|
178
|
+
// waiting on more chunks to complete. Go ahead and emit those, then
|
|
179
|
+
// re-emit the exit so a listener can handle the possibly-unexpected exit
|
|
180
|
+
this.proc.on('exit', (code, signal) => {
|
|
181
|
+
this.handleLastLines();
|
|
182
|
+
this.emit('exit', code, signal);
|
|
183
|
+
// in addition to the bare exit event, also emit one of three other
|
|
184
|
+
// events that contain more helpful information:
|
|
185
|
+
// 'stop': we stopped this
|
|
186
|
+
// 'die': the process ended out of our control with a non-zero exit
|
|
187
|
+
// 'end': the process ended out of our control with a zero exit
|
|
188
|
+
let event = this.expectingExit ? 'stop' : 'die';
|
|
189
|
+
if (!this.expectingExit && code === 0) {
|
|
190
|
+
event = 'end';
|
|
191
|
+
}
|
|
192
|
+
this.emit(event, code, signal);
|
|
193
|
+
// finally clean up the proc and make sure to reset our exit
|
|
194
|
+
// expectations
|
|
195
|
+
this.proc = null;
|
|
196
|
+
this.expectingExit = false;
|
|
197
|
+
});
|
|
198
|
+
// if the user hasn't given us a startDetector, instead just resolve
|
|
199
|
+
// when startDelay ms have passed
|
|
200
|
+
if (!startDetector) {
|
|
201
|
+
setTimeout(() => { resolve(); }, startDelay);
|
|
202
|
+
}
|
|
203
|
+
// if the user has given us a timeout, start the clock for rejecting
|
|
204
|
+
// the promise if we take too long to start
|
|
205
|
+
if (lodash_1.default.isNumber(timeoutMs)) {
|
|
206
|
+
setTimeout(() => {
|
|
207
|
+
reject(new Error(`The process did not start within ${timeoutMs}ms ` +
|
|
208
|
+
`(cmd: '${this.rep}')`));
|
|
209
|
+
}, timeoutMs);
|
|
210
|
+
}
|
|
211
|
+
}).finally(() => {
|
|
212
|
+
if (detach && this.proc) {
|
|
213
|
+
this.proc.unref();
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
handleLastLines() {
|
|
218
|
+
for (let stream of ['stdout', 'stderr']) {
|
|
219
|
+
if (this.lastLinePortion[stream]) {
|
|
220
|
+
const lastLines = [this.lastLinePortion[stream]];
|
|
221
|
+
this.emit(`lines-${stream}`, lastLines);
|
|
222
|
+
this.emitLines(stream, lastLines);
|
|
223
|
+
this.lastLinePortion[stream] = '';
|
|
224
|
+
}
|
|
194
225
|
}
|
|
195
|
-
|
|
196
|
-
this.emit(event, code, signal);
|
|
197
|
-
this.proc = null;
|
|
198
|
-
this.expectingExit = false;
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
if (!startDetector) {
|
|
202
|
-
setTimeout(() => {
|
|
203
|
-
resolve();
|
|
204
|
-
}, startDelay);
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
if (_lodash.default.isNumber(timeoutMs)) {
|
|
208
|
-
setTimeout(() => {
|
|
209
|
-
reject(new Error(`The process did not start within ${timeoutMs}ms ` + `(cmd: '${this.rep}')`));
|
|
210
|
-
}, timeoutMs);
|
|
211
|
-
}
|
|
212
|
-
}).finally(() => {
|
|
213
|
-
if (detach && this.proc) {
|
|
214
|
-
this.proc.unref();
|
|
215
|
-
}
|
|
216
|
-
});
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
handleLastLines() {
|
|
220
|
-
for (let stream of ['stdout', 'stderr']) {
|
|
221
|
-
if (this.lastLinePortion[stream]) {
|
|
222
|
-
const lastLines = [this.lastLinePortion[stream]];
|
|
223
|
-
this.emit(`lines-${stream}`, lastLines);
|
|
224
|
-
this.emitLines(stream, lastLines);
|
|
225
|
-
this.lastLinePortion[stream] = '';
|
|
226
|
-
}
|
|
227
226
|
}
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
227
|
+
/**
|
|
228
|
+
*
|
|
229
|
+
* @param {NodeJS.Signals} signal
|
|
230
|
+
* @param {number} timeout
|
|
231
|
+
* @returns {Promise<void>}
|
|
232
|
+
*/
|
|
233
|
+
async stop(signal = 'SIGTERM', timeout = 10000) {
|
|
234
|
+
if (!this.isRunning) {
|
|
235
|
+
throw new Error(`Can't stop process; it's not currently running (cmd: '${this.rep}')`);
|
|
236
|
+
}
|
|
237
|
+
// make sure to emit any data in our lines buffer whenever we're done with
|
|
238
|
+
// the proc
|
|
239
|
+
this.handleLastLines();
|
|
240
|
+
return await new bluebird_1.default((resolve, reject) => {
|
|
241
|
+
this.proc?.on('close', resolve);
|
|
242
|
+
this.expectingExit = true;
|
|
243
|
+
this.proc?.kill(signal);
|
|
244
|
+
// this timeout needs unref() or node will wait for the timeout to fire before
|
|
245
|
+
// exiting the process.
|
|
246
|
+
setTimeout(() => {
|
|
247
|
+
reject(new Error(`Process didn't end after ${timeout}ms (cmd: '${this.rep}')`));
|
|
248
|
+
}, timeout).unref();
|
|
249
|
+
});
|
|
233
250
|
}
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
async join(allowedExitCodes = [0]) {
|
|
249
|
-
if (!this.isRunning) {
|
|
250
|
-
throw new Error(`Cannot join process; it is not currently running (cmd: '${this.rep}')`);
|
|
251
|
+
async join(allowedExitCodes = [0]) {
|
|
252
|
+
if (!this.isRunning) {
|
|
253
|
+
throw new Error(`Cannot join process; it is not currently running (cmd: '${this.rep}')`);
|
|
254
|
+
}
|
|
255
|
+
return await new bluebird_1.default((resolve, reject) => {
|
|
256
|
+
this.proc?.on('exit', (code) => {
|
|
257
|
+
if (code !== null && allowedExitCodes.indexOf(code) === -1) {
|
|
258
|
+
reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));
|
|
259
|
+
}
|
|
260
|
+
else {
|
|
261
|
+
resolve(code);
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
});
|
|
251
265
|
}
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
}
|
|
260
|
-
|
|
266
|
+
/*
|
|
267
|
+
* This will only work if the process is created with the `detached` option
|
|
268
|
+
*/
|
|
269
|
+
detachProcess() {
|
|
270
|
+
if (!this.opts.detached) {
|
|
271
|
+
// this means that there is a misconfiguration in the calling code
|
|
272
|
+
throw new Error(`Unable to detach process that is not started with 'detached' option`);
|
|
273
|
+
}
|
|
274
|
+
if (this.proc) {
|
|
275
|
+
this.proc.unref();
|
|
261
276
|
}
|
|
262
|
-
});
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
detachProcess() {
|
|
267
|
-
if (!this.opts.detached) {
|
|
268
|
-
throw new Error(`Unable to detach process that is not started with 'detached' option`);
|
|
269
277
|
}
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
this.proc.unref();
|
|
278
|
+
get pid() {
|
|
279
|
+
return this.proc ? this.proc.pid : null;
|
|
273
280
|
}
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
get pid() {
|
|
277
|
-
return this.proc ? this.proc.pid : null;
|
|
278
|
-
}
|
|
279
|
-
|
|
280
281
|
}
|
|
281
|
-
|
|
282
282
|
exports.SubProcess = SubProcess;
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJFdmVudEVtaXR0ZXIiLCJldmVudHMiLCJNQVhfTElORV9QT1JUSU9OX0xFTkdUSCIsImN1dFN1ZmZpeCIsInN0ciIsInN1ZmZpeExlbmd0aCIsImxlbmd0aCIsInN1YnN0ciIsIlN1YlByb2Nlc3MiLCJsYXN0TGluZVBvcnRpb24iLCJwcm9jIiwiYXJncyIsImNtZCIsIm9wdHMiLCJleHBlY3RpbmdFeGl0IiwicmVwIiwiY29uc3RydWN0b3IiLCJFcnJvciIsIl8iLCJpc1N0cmluZyIsImlzQXJyYXkiLCJxdW90ZSIsInN0ZG91dCIsInN0ZGVyciIsImlzUnVubmluZyIsImVtaXRMaW5lcyIsInN0cmVhbSIsImxpbmVzIiwibGluZSIsImVtaXQiLCJ0b1VwcGVyQ2FzZSIsInN0YXJ0Iiwic3RhcnREZXRlY3RvciIsInRpbWVvdXRNcyIsImRldGFjaCIsInN0YXJ0RGVsYXkiLCJnZW5lcmljU3RhcnREZXRlY3RvciIsImlzTnVtYmVyIiwiaXNCb29sZWFuIiwiZGV0YWNoZWQiLCJCIiwicmVzb2x2ZSIsInJlamVjdCIsInNwYXduIiwic2V0RW5jb2RpbmciLCJlbmNvZGluZyIsImhhbmRsZU91dHB1dCIsInN0cmVhbXMiLCJpc0Z1bmN0aW9uIiwiZSIsInN0cmVhbU5hbWUiLCJzdHJlYW1EYXRhIiwidG9QYWlycyIsInNwbGl0IiwibWFwIiwieCIsImxhc3QiLCJyZXN1bHRMaW5lcyIsInNsaWNlIiwiY3VycmVudFBvcnRpb24iLCJvbiIsImVyciIsInJlbW92ZUFsbExpc3RlbmVycyIsImtpbGwiLCJjb2RlIiwiZm9ybWF0RW5vZW50IiwiY3dkIiwidW5yZWYiLCJjaHVuayIsInRvU3RyaW5nIiwic2lnbmFsIiwiaGFuZGxlTGFzdExpbmVzIiwiZXZlbnQiLCJzZXRUaW1lb3V0IiwiZmluYWxseSIsImxhc3RMaW5lcyIsInN0b3AiLCJ0aW1lb3V0Iiwiam9pbiIsImFsbG93ZWRFeGl0Q29kZXMiLCJpbmRleE9mIiwiZGV0YWNoUHJvY2VzcyIsInBpZCJdLCJzb3VyY2VzIjpbIi4uLy4uL2xpYi9zdWJwcm9jZXNzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHByb21pc2UvcHJlZmVyLWF3YWl0LXRvLWNhbGxiYWNrcyAqL1xuXG5pbXBvcnQgeyBzcGF3biB9IGZyb20gJ2NoaWxkX3Byb2Nlc3MnO1xuaW1wb3J0IGV2ZW50cyBmcm9tICdldmVudHMnO1xuY29uc3QgeyBFdmVudEVtaXR0ZXIgfSA9IGV2ZW50cztcbmltcG9ydCBCIGZyb20gJ2JsdWViaXJkJztcbmltcG9ydCB7IHF1b3RlIH0gZnJvbSAnc2hlbGwtcXVvdGUnO1xuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IGZvcm1hdEVub2VudCB9IGZyb20gJy4vaGVscGVycyc7XG5cblxuLy8gVGhpcyBpcyBuZWVkZWQgdG8gYXZvaWQgbWVtb3J5IGxlYWtzXG4vLyB3aGVuIHRoZSBwcm9jZXNzIG91dHB1dCBpcyB0b28gbG9uZyBhbmQgY29udGFpbnNcbi8vIG5vIGxpbmUgYnJlYWtzXG5jb25zdCBNQVhfTElORV9QT1JUSU9OX0xFTkdUSCA9IDB4RkZGRjtcblxuZnVuY3Rpb24gY3V0U3VmZml4IChzdHIsIHN1ZmZpeExlbmd0aCkge1xuICByZXR1cm4gc3RyLmxlbmd0aCA+IHN1ZmZpeExlbmd0aFxuICAgIC8vIGh0dHBzOi8vYnVncy5jaHJvbWl1bS5vcmcvcC92OC9pc3N1ZXMvZGV0YWlsP2lkPTI4NjlcbiAgICA/IGAgJHtzdHIuc3Vic3RyKHN0ci5sZW5ndGggLSBzdWZmaXhMZW5ndGgpfWAuc3Vic3RyKDEpXG4gICAgOiBzdHI7XG59XG5cblxuY2xhc3MgU3ViUHJvY2VzcyBleHRlbmRzIEV2ZW50RW1pdHRlciB7XG5cbiAgLyoqXG4gICAqIEB0eXBlIHsge3N0ZG91dDogc3RyaW5nLCBzdGRlcnI6IHN0cmluZ30gfVxuICAgKi9cbiAgbGFzdExpbmVQb3J0aW9uO1xuXG4gIC8qKiBAdHlwZSB7aW1wb3J0KCdjaGlsZF9wcm9jZXNzJykuQ2hpbGRQcm9jZXNzP30gKi9cbiAgcHJvYztcblxuICAvKiogQHR5cGUge3N0cmluZ1tdfSAqL1xuICBhcmdzO1xuXG4gIC8qKlxuICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgKi9cbiAgY21kO1xuXG4gIC8qKlxuICAgKiBAdHlwZSB7YW55fVxuICAqL1xuICBvcHRzO1xuXG4gIC8qKlxuICAgKiBAdHlwZSB7Ym9vbGVhbn1cbiAgICovXG4gIGV4cGVjdGluZ0V4aXQ7XG5cbiAgLyoqXG4gICAqIEB0eXBlIHtzdHJpbmd9XG4gICAqL1xuICByZXA7XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBjbWRcbiAgICogQHBhcmFtIHtzdHJpbmdbXX0gW2FyZ3NdXG4gICAqIEBwYXJhbSB7YW55fSBbb3B0c11cbiAgICovXG4gIGNvbnN0cnVjdG9yIChjbWQsIGFyZ3MgPSBbXSwgb3B0cyA9IHt9KSB7XG4gICAgc3VwZXIoKTtcbiAgICBpZiAoIWNtZCkgdGhyb3cgbmV3IEVycm9yKCdDb21tYW5kIGlzIHJlcXVpcmVkJyk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgY3VybHlcbiAgICBpZiAoIV8uaXNTdHJpbmcoY21kKSkgdGhyb3cgbmV3IEVycm9yKCdDb21tYW5kIG11c3QgYmUgYSBzdHJpbmcnKTsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBjdXJseVxuICAgIGlmICghXy5pc0FycmF5KGFyZ3MpKSB0aHJvdyBuZXcgRXJyb3IoJ0FyZ3MgbXVzdCBiZSBhbiBhcnJheScpOyAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIGN1cmx5XG5cbiAgICB0aGlzLmNtZCA9IGNtZDtcbiAgICB0aGlzLmFyZ3MgPSBhcmdzO1xuICAgIHRoaXMucHJvYyA9IG51bGw7XG4gICAgdGhpcy5vcHRzID0gb3B0cztcbiAgICB0aGlzLmV4cGVjdGluZ0V4aXQgPSBmYWxzZTtcblxuICAgIC8vIGdldCBhIHF1b3RlZCByZXByZXNlbnRhdGlvbiBvZiB0aGUgY29tbWFuZCBmb3IgZXJyb3Igc3RyaW5nc1xuICAgIHRoaXMucmVwID0gcXVvdGUoW2NtZCwgLi4uYXJnc10pO1xuXG4gICAgdGhpcy5sYXN0TGluZVBvcnRpb24gPSB7c3Rkb3V0OiAnJywgc3RkZXJyOiAnJ307XG4gIH1cblxuICBnZXQgaXNSdW5uaW5nICgpIHtcbiAgICAvLyBwcmVzZW5jZSBvZiBgcHJvY2AgbWVhbnMgd2UgaGF2ZSBjb25uZWN0ZWQgYW5kIHN0YXJ0ZWRcbiAgICByZXR1cm4gISF0aGlzLnByb2M7XG4gIH1cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHN0cmVhbVxuICAgKiBAcGFyYW0ge0l0ZXJhYmxlPHN0cmluZz59IGxpbmVzXG4gICAqL1xuICBlbWl0TGluZXMgKHN0cmVhbSwgbGluZXMpIHtcbiAgICBmb3IgKGxldCBsaW5lIG9mIGxpbmVzKSB7XG4gICAgICB0aGlzLmVtaXQoJ3N0cmVhbS1saW5lJywgYFske3N0cmVhbS50b1VwcGVyQ2FzZSgpfV0gJHtsaW5lfWApO1xuICAgIH1cbiAgfVxuXG4gIC8vIHNwYXduIHRoZSBzdWJwcm9jZXNzIGFuZCByZXR1cm4gY29udHJvbCB3aGVuZXZlciB3ZSBkZWVtIHRoYXQgaXQgaGFzIGZ1bGx5XG4gIC8vIFwic3RhcnRlZFwiXG4gIC8qKlxuICAgKlxuICAgKiBAcGFyYW0ge1N0YXJ0RGV0ZWN0b3J8bnVtYmVyP30gc3RhcnREZXRlY3RvclxuICAgKiBAcGFyYW0ge251bWJlcj99IHRpbWVvdXRNc1xuICAgKiBAcGFyYW0ge2Jvb2xlYW59IGRldGFjaFxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTx2b2lkPn1cbiAgICovXG4gIGFzeW5jIHN0YXJ0IChzdGFydERldGVjdG9yID0gbnVsbCwgdGltZW91dE1zID0gbnVsbCwgZGV0YWNoID0gZmFsc2UpIHtcbiAgICBsZXQgc3RhcnREZWxheSA9IDEwO1xuXG4gICAgY29uc3QgZ2VuZXJpY1N0YXJ0RGV0ZWN0b3IgPSAvKiogQHR5cGUge1N0YXJ0RGV0ZWN0b3J9ICovKGZ1bmN0aW9uIGdlbmVyaWNTdGFydERldGVjdG9yIChzdGRvdXQsIHN0ZGVycikge1xuICAgICAgcmV0dXJuIHN0ZG91dCB8fCBzdGRlcnI7XG4gICAgfSk7XG5cbiAgICAvLyB0aGUgZGVmYXVsdCBzdGFydCBkZXRlY3RvciBzaW1wbHkgcmV0dXJucyB0cnVlIHdoZW4gd2UgZ2V0IGFueSBvdXRwdXRcbiAgICBpZiAoc3RhcnREZXRlY3RvciA9PT0gbnVsbCkge1xuICAgICAgc3RhcnREZXRlY3RvciA9IGdlbmVyaWNTdGFydERldGVjdG9yO1xuICAgIH1cblxuICAgIC8vIGlmIHRoZSB1c2VyIHBhc3NlcyBhIG51bWJlciwgdGhlbiB3ZSBzaW1wbHkgZGVsYXkgYSBjZXJ0YWluIGFtb3VudCBvZlxuICAgIC8vIHRpbWUgYmVmb3JlIHJldHVybmluZyBjb250cm9sLCByYXRoZXIgdGhhbiB3YWl0aW5nIGZvciBhIGNvbmRpdGlvblxuICAgIGlmIChfLmlzTnVtYmVyKHN0YXJ0RGV0ZWN0b3IpKSB7XG4gICAgICBzdGFydERlbGF5ID0gc3RhcnREZXRlY3RvcjtcbiAgICAgIHN0YXJ0RGV0ZWN0b3IgPSBudWxsO1xuICAgIH1cblxuICAgIC8vIGlmIHRoZSB1c2VyIHBhc3NlcyBpbiBhIGJvb2xlYW4gYXMgb25lIG9mIHRoZSBhcmd1bWVudHMsIHVzZSBpdCBmb3IgYGRldGFjaGBcbiAgICBpZiAoXy5pc0Jvb2xlYW4oc3RhcnREZXRlY3RvcikgJiYgc3RhcnREZXRlY3Rvcikge1xuICAgICAgaWYgKCF0aGlzLm9wdHMuZGV0YWNoZWQpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmFibGUgdG8gZGV0YWNoIHByb2Nlc3MgdGhhdCBpcyBub3Qgc3RhcnRlZCB3aXRoICdkZXRhY2hlZCcgb3B0aW9uYCk7XG4gICAgICB9XG4gICAgICBkZXRhY2ggPSB0cnVlO1xuICAgICAgc3RhcnREZXRlY3RvciA9IGdlbmVyaWNTdGFydERldGVjdG9yO1xuICAgIH0gZWxzZSBpZiAoXy5pc0Jvb2xlYW4odGltZW91dE1zKSAmJiB0aW1lb3V0TXMpIHtcbiAgICAgIGlmICghdGhpcy5vcHRzLmRldGFjaGVkKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgVW5hYmxlIHRvIGRldGFjaCBwcm9jZXNzIHRoYXQgaXMgbm90IHN0YXJ0ZWQgd2l0aCAnZGV0YWNoZWQnIG9wdGlvbmApO1xuICAgICAgfVxuICAgICAgZGV0YWNoID0gdHJ1ZTtcbiAgICAgIHRpbWVvdXRNcyA9IG51bGw7XG4gICAgfVxuXG4gICAgLy8gcmV0dXJuIGEgcHJvbWlzZSBzbyB3ZSBjYW4gd3JhcCB0aGUgYXN5bmMgYmVoYXZpb3JcbiAgICByZXR1cm4gYXdhaXQgbmV3IEIoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgLy8gYWN0dWFsbHkgc3Bhd24gdGhlIHN1YnByb2NcbiAgICAgIHRoaXMucHJvYyA9IHNwYXduKHRoaXMuY21kLCB0aGlzLmFyZ3MsIHRoaXMub3B0cyk7XG5cbiAgICAgIGlmICh0aGlzLnByb2Muc3Rkb3V0KSB7XG4gICAgICAgIHRoaXMucHJvYy5zdGRvdXQuc2V0RW5jb2RpbmcodGhpcy5vcHRzLmVuY29kaW5nIHx8ICd1dGY4Jyk7XG4gICAgICB9XG4gICAgICBpZiAodGhpcy5wcm9jLnN0ZGVycikge1xuICAgICAgICB0aGlzLnByb2Muc3RkZXJyLnNldEVuY29kaW5nKHRoaXMub3B0cy5lbmNvZGluZyB8fCAndXRmOCcpO1xuICAgICAgfVxuICAgICAgdGhpcy5sYXN0TGluZVBvcnRpb24gPSB7c3Rkb3V0OiAnJywgc3RkZXJyOiAnJ307XG5cbiAgICAgIC8vIHRoaXMgZnVuY3Rpb24gaGFuZGxlcyBvdXRwdXQgdGhhdCB3ZSBjb2xsZWN0IGZyb20gdGhlIHN1YnByb2NcbiAgICAgIC8qKlxuICAgICAgICpcbiAgICAgICAqIEBwYXJhbSB7IHtzdGRvdXQ6IHN0cmluZywgc3RkZXJyOiBzdHJpbmd9IH0gc3RyZWFtc1xuICAgICAgICovXG4gICAgICBjb25zdCBoYW5kbGVPdXRwdXQgPSAoc3RyZWFtcykgPT4ge1xuICAgICAgICBjb25zdCB7c3Rkb3V0LCBzdGRlcnJ9ID0gc3RyZWFtcztcbiAgICAgICAgLy8gaWYgd2UgaGF2ZSBhIHN0YXJ0RGV0ZWN0b3IsIHJ1biBpdCBvbiB0aGUgb3V0cHV0IHNvIHdlIGNhbiByZXNvbHZlL1xuICAgICAgICAvLyByZWplY3QgYW5kIG1vdmUgb24gZnJvbSBzdGFydFxuICAgICAgICB0cnkge1xuICAgICAgICAgIGlmIChfLmlzRnVuY3Rpb24oc3RhcnREZXRlY3RvcikgJiYgc3RhcnREZXRlY3RvcihzdGRvdXQsIHN0ZGVycikpIHtcbiAgICAgICAgICAgIHN0YXJ0RGV0ZWN0b3IgPSBudWxsO1xuICAgICAgICAgICAgcmVzb2x2ZSgpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIGVtaXQgdGhlIGFjdHVhbCBvdXRwdXQgZm9yIHdob21ldmVyJ3MgbGlzdGVuaW5nXG4gICAgICAgIHRoaXMuZW1pdCgnb3V0cHV0Jywgc3Rkb3V0LCBzdGRlcnIpO1xuXG4gICAgICAgIC8vIHdlIGFsc28gd2FudCB0byBlbWl0IGxpbmVzLCBidXQgaXQncyBtb3JlIGNvbXBsZXggc2luY2Ugb3V0cHV0XG4gICAgICAgIC8vIGNvbWVzIGluIGNodW5rcyBhbmQgYSBsaW5lIGNvdWxkIGNvbWUgaW4gdHdvIGRpZmZlcmVudCBjaHVua3MsIHNvXG4gICAgICAgIC8vIHdlIGhhdmUgbG9naWMgdG8gaGFuZGxlIHRoYXQgY2FzZSAodXNpbmcgdGhpcy5sYXN0TGluZVBvcnRpb24gdG9cbiAgICAgICAgLy8gcmVtZW1iZXIgYSBsaW5lIHRoYXQgc3RhcnRlZCBidXQgZGlkIG5vdCBmaW5pc2ggaW4gdGhlIGxhc3QgY2h1bmspXG4gICAgICAgIGZvciAoY29uc3QgW3N0cmVhbU5hbWUsIHN0cmVhbURhdGFdIG9mIC8qKiBAdHlwZSB7W1snc3Rkb3V0Jywgc3RyaW5nXSwgWydzdGRlcnInLCBzdHJpbmddXX0gKi8oXy50b1BhaXJzKHN0cmVhbXMpKSkge1xuICAgICAgICAgIGlmICghc3RyZWFtRGF0YSkgY29udGludWU7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgY3VybHlcbiAgICAgICAgICBjb25zdCBsaW5lcyA9IHN0cmVhbURhdGEuc3BsaXQoJ1xcbicpXG4gICAgICAgICAgICAvLyBodHRwczovL2J1Z3MuY2hyb21pdW0ub3JnL3AvdjgvaXNzdWVzL2RldGFpbD9pZD0yODY5XG4gICAgICAgICAgICAubWFwKCh4KSA9PiBgICR7eH1gLnN1YnN0cigxKSk7XG4gICAgICAgICAgaWYgKGxpbmVzLmxlbmd0aCA+IDEpIHtcbiAgICAgICAgICAgIGxpbmVzWzBdID0gdGhpcy5sYXN0TGluZVBvcnRpb25bc3RyZWFtTmFtZV0gKyBsaW5lc1swXTtcbiAgICAgICAgICAgIHRoaXMubGFzdExpbmVQb3J0aW9uW3N0cmVhbU5hbWVdID0gY3V0U3VmZml4KF8ubGFzdChsaW5lcyksIE1BWF9MSU5FX1BPUlRJT05fTEVOR1RIKTtcbiAgICAgICAgICAgIGNvbnN0IHJlc3VsdExpbmVzID0gbGluZXMuc2xpY2UoMCwgLTEpO1xuICAgICAgICAgICAgdGhpcy5lbWl0KGBsaW5lcy0ke3N0cmVhbU5hbWV9YCwgcmVzdWx0TGluZXMpO1xuICAgICAgICAgICAgdGhpcy5lbWl0TGluZXMoc3RyZWFtTmFtZSwgcmVzdWx0TGluZXMpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb25zdCBjdXJyZW50UG9ydGlvbiA9IGN1dFN1ZmZpeChsaW5lc1swXSwgTUFYX0xJTkVfUE9SVElPTl9MRU5HVEgpO1xuICAgICAgICAgICAgaWYgKHRoaXMubGFzdExpbmVQb3J0aW9uW3N0cmVhbU5hbWVdLmxlbmd0aCArIGN1cnJlbnRQb3J0aW9uLmxlbmd0aCA+IE1BWF9MSU5FX1BPUlRJT05fTEVOR1RIKSB7XG4gICAgICAgICAgICAgIHRoaXMubGFzdExpbmVQb3J0aW9uW3N0cmVhbU5hbWVdID0gY3VycmVudFBvcnRpb247XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICB0aGlzLmxhc3RMaW5lUG9ydGlvbltzdHJlYW1OYW1lXSArPSBjdXJyZW50UG9ydGlvbjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH07XG5cbiAgICAgIC8vIGlmIHdlIGdldCBhbiBlcnJvciBzcGF3bmluZyB0aGUgcHJvYywgcmVqZWN0IGFuZCBjbGVhbiB1cCB0aGUgcHJvY1xuICAgICAgdGhpcy5wcm9jLm9uKCdlcnJvcicsIC8qKiBAcGFyYW0ge05vZGVKUy5FcnJub0V4Y2VwdGlvbn0gZXJyICovIChlcnIpID0+IHtcbiAgICAgICAgdGhpcy5wcm9jPy5yZW1vdmVBbGxMaXN0ZW5lcnMoJ2V4aXQnKTtcbiAgICAgICAgdGhpcy5wcm9jPy5raWxsKCdTSUdJTlQnKTtcblxuICAgICAgICBpZiAoZXJyLmNvZGUgPT09ICdFTk9FTlQnKSB7XG4gICAgICAgICAgZXJyID0gZm9ybWF0RW5vZW50KGVyciwgdGhpcy5jbWQsIHRoaXMub3B0cz8uY3dkKTtcbiAgICAgICAgfVxuICAgICAgICByZWplY3QoZXJyKTtcblxuICAgICAgICB0aGlzLnByb2M/LnVucmVmKCk7XG4gICAgICAgIHRoaXMucHJvYyA9IG51bGw7XG4gICAgICB9KTtcblxuICAgICAgaWYgKHRoaXMucHJvYy5zdGRvdXQpIHtcbiAgICAgICAgdGhpcy5wcm9jLnN0ZG91dC5vbignZGF0YScsIChjaHVuaykgPT4gaGFuZGxlT3V0cHV0KHtzdGRvdXQ6IGNodW5rLnRvU3RyaW5nKCksIHN0ZGVycjogJyd9KSk7XG4gICAgICB9XG5cbiAgICAgIGlmICh0aGlzLnByb2Muc3RkZXJyKSB7XG4gICAgICAgIHRoaXMucHJvYy5zdGRlcnIub24oJ2RhdGEnLCAoY2h1bmspID0+IGhhbmRsZU91dHB1dCh7c3Rkb3V0OiAnJywgc3RkZXJyOiBjaHVuay50b1N0cmluZygpfSkpO1xuICAgICAgfVxuXG4gICAgICAvLyB3aGVuIHRoZSBwcm9jIGV4aXRzLCB3ZSBtaWdodCBzdGlsbCBoYXZlIGEgYnVmZmVyIG9mIGxpbmVzIHdlIHdlcmVcbiAgICAgIC8vIHdhaXRpbmcgb24gbW9yZSBjaHVua3MgdG8gY29tcGxldGUuIEdvIGFoZWFkIGFuZCBlbWl0IHRob3NlLCB0aGVuXG4gICAgICAvLyByZS1lbWl0IHRoZSBleGl0IHNvIGEgbGlzdGVuZXIgY2FuIGhhbmRsZSB0aGUgcG9zc2libHktdW5leHBlY3RlZCBleGl0XG4gICAgICB0aGlzLnByb2Mub24oJ2V4aXQnLCAoY29kZSwgc2lnbmFsKSA9PiB7XG4gICAgICAgIHRoaXMuaGFuZGxlTGFzdExpbmVzKCk7XG5cbiAgICAgICAgdGhpcy5lbWl0KCdleGl0JywgY29kZSwgc2lnbmFsKTtcblxuICAgICAgICAvLyBpbiBhZGRpdGlvbiB0byB0aGUgYmFyZSBleGl0IGV2ZW50LCBhbHNvIGVtaXQgb25lIG9mIHRocmVlIG90aGVyXG4gICAgICAgIC8vIGV2ZW50cyB0aGF0IGNvbnRhaW4gbW9yZSBoZWxwZnVsIGluZm9ybWF0aW9uOlxuICAgICAgICAvLyAnc3RvcCc6IHdlIHN0b3BwZWQgdGhpc1xuICAgICAgICAvLyAnZGllJzogdGhlIHByb2Nlc3MgZW5kZWQgb3V0IG9mIG91ciBjb250cm9sIHdpdGggYSBub24temVybyBleGl0XG4gICAgICAgIC8vICdlbmQnOiB0aGUgcHJvY2VzcyBlbmRlZCBvdXQgb2Ygb3VyIGNvbnRyb2wgd2l0aCBhIHplcm8gZXhpdFxuICAgICAgICBsZXQgZXZlbnQgPSB0aGlzLmV4cGVjdGluZ0V4aXQgPyAnc3RvcCcgOiAnZGllJztcbiAgICAgICAgaWYgKCF0aGlzLmV4cGVjdGluZ0V4aXQgJiYgY29kZSA9PT0gMCkge1xuICAgICAgICAgIGV2ZW50ID0gJ2VuZCc7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5lbWl0KGV2ZW50LCBjb2RlLCBzaWduYWwpO1xuXG4gICAgICAgIC8vIGZpbmFsbHkgY2xlYW4gdXAgdGhlIHByb2MgYW5kIG1ha2Ugc3VyZSB0byByZXNldCBvdXIgZXhpdFxuICAgICAgICAvLyBleHBlY3RhdGlvbnNcbiAgICAgICAgdGhpcy5wcm9jID0gbnVsbDtcbiAgICAgICAgdGhpcy5leHBlY3RpbmdFeGl0ID0gZmFsc2U7XG4gICAgICB9KTtcblxuICAgICAgLy8gaWYgdGhlIHVzZXIgaGFzbid0IGdpdmVuIHVzIGEgc3RhcnREZXRlY3RvciwgaW5zdGVhZCBqdXN0IHJlc29sdmVcbiAgICAgIC8vIHdoZW4gc3RhcnREZWxheSBtcyBoYXZlIHBhc3NlZFxuICAgICAgaWYgKCFzdGFydERldGVjdG9yKSB7XG4gICAgICAgIHNldFRpbWVvdXQoKCkgPT4geyByZXNvbHZlKCk7IH0sIHN0YXJ0RGVsYXkpO1xuICAgICAgfVxuXG4gICAgICAvLyBpZiB0aGUgdXNlciBoYXMgZ2l2ZW4gdXMgYSB0aW1lb3V0LCBzdGFydCB0aGUgY2xvY2sgZm9yIHJlamVjdGluZ1xuICAgICAgLy8gdGhlIHByb21pc2UgaWYgd2UgdGFrZSB0b28gbG9uZyB0byBzdGFydFxuICAgICAgaWYgKF8uaXNOdW1iZXIodGltZW91dE1zKSkge1xuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICByZWplY3QobmV3IEVycm9yKGBUaGUgcHJvY2VzcyBkaWQgbm90IHN0YXJ0IHdpdGhpbiAke3RpbWVvdXRNc31tcyBgICtcbiAgICAgICAgICAgIGAoY21kOiAnJHt0aGlzLnJlcH0nKWApKTtcbiAgICAgICAgfSwgdGltZW91dE1zKTtcbiAgICAgIH1cbiAgICB9KS5maW5hbGx5KCgpID0+IHtcbiAgICAgIGlmIChkZXRhY2ggJiYgdGhpcy5wcm9jKSB7XG4gICAgICAgIHRoaXMucHJvYy51bnJlZigpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgaGFuZGxlTGFzdExpbmVzICgpIHtcbiAgICBmb3IgKGxldCBzdHJlYW0gb2YgWydzdGRvdXQnLCAnc3RkZXJyJ10pIHtcbiAgICAgIGlmICh0aGlzLmxhc3RMaW5lUG9ydGlvbltzdHJlYW1dKSB7XG4gICAgICAgIGNvbnN0IGxhc3RMaW5lcyA9IFt0aGlzLmxhc3RMaW5lUG9ydGlvbltzdHJlYW1dXTtcbiAgICAgICAgdGhpcy5lbWl0KGBsaW5lcy0ke3N0cmVhbX1gLCBsYXN0TGluZXMpO1xuICAgICAgICB0aGlzLmVtaXRMaW5lcyhzdHJlYW0sIGxhc3RMaW5lcyk7XG4gICAgICAgIHRoaXMubGFzdExpbmVQb3J0aW9uW3N0cmVhbV0gPSAnJztcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIHtOb2RlSlMuU2lnbmFsc30gc2lnbmFsXG4gICAqIEBwYXJhbSB7bnVtYmVyfSB0aW1lb3V0XG4gICAqIEByZXR1cm5zIHtQcm9taXNlPHZvaWQ+fVxuICAgKi9cbiAgYXN5bmMgc3RvcCAoc2lnbmFsID0gJ1NJR1RFUk0nLCB0aW1lb3V0ID0gMTAwMDApIHtcbiAgICBpZiAoIXRoaXMuaXNSdW5uaW5nKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbid0IHN0b3AgcHJvY2VzczsgaXQncyBub3QgY3VycmVudGx5IHJ1bm5pbmcgKGNtZDogJyR7dGhpcy5yZXB9JylgKTtcbiAgICB9XG4gICAgLy8gbWFrZSBzdXJlIHRvIGVtaXQgYW55IGRhdGEgaW4gb3VyIGxpbmVzIGJ1ZmZlciB3aGVuZXZlciB3ZSdyZSBkb25lIHdpdGhcbiAgICAvLyB0aGUgcHJvY1xuICAgIHRoaXMuaGFuZGxlTGFzdExpbmVzKCk7XG4gICAgcmV0dXJuIGF3YWl0IG5ldyBCKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHRoaXMucHJvYz8ub24oJ2Nsb3NlJywgcmVzb2x2ZSk7XG4gICAgICB0aGlzLmV4cGVjdGluZ0V4aXQgPSB0cnVlO1xuICAgICAgdGhpcy5wcm9jPy5raWxsKHNpZ25hbCk7XG4gICAgICAvLyB0aGlzIHRpbWVvdXQgbmVlZHMgdW5yZWYoKSBvciBub2RlIHdpbGwgd2FpdCBmb3IgdGhlIHRpbWVvdXQgdG8gZmlyZSBiZWZvcmVcbiAgICAgIC8vIGV4aXRpbmcgdGhlIHByb2Nlc3MuXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgcmVqZWN0KG5ldyBFcnJvcihgUHJvY2VzcyBkaWRuJ3QgZW5kIGFmdGVyICR7dGltZW91dH1tcyAoY21kOiAnJHt0aGlzLnJlcH0nKWApKTtcbiAgICAgIH0sIHRpbWVvdXQpLnVucmVmKCk7XG4gICAgfSk7XG4gIH1cblxuICBhc3luYyBqb2luIChhbGxvd2VkRXhpdENvZGVzID0gWzBdKSB7XG4gICAgaWYgKCF0aGlzLmlzUnVubmluZykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3Qgam9pbiBwcm9jZXNzOyBpdCBpcyBub3QgY3VycmVudGx5IHJ1bm5pbmcgKGNtZDogJyR7dGhpcy5yZXB9JylgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYXdhaXQgbmV3IEIoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5wcm9jPy5vbignZXhpdCcsIChjb2RlKSA9PiB7XG4gICAgICAgIGlmIChjb2RlICE9PSBudWxsICYmIGFsbG93ZWRFeGl0Q29kZXMuaW5kZXhPZihjb2RlKSA9PT0gLTEpIHtcbiAgICAgICAgICByZWplY3QobmV3IEVycm9yKGBQcm9jZXNzIGVuZGVkIHdpdGggZXhpdGNvZGUgJHtjb2RlfSAoY21kOiAnJHt0aGlzLnJlcH0nKWApKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXNvbHZlKGNvZGUpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qXG4gICAqIFRoaXMgd2lsbCBvbmx5IHdvcmsgaWYgdGhlIHByb2Nlc3MgaXMgY3JlYXRlZCB3aXRoIHRoZSBgZGV0YWNoZWRgIG9wdGlvblxuICAgKi9cbiAgZGV0YWNoUHJvY2VzcyAoKSB7XG4gICAgaWYgKCF0aGlzLm9wdHMuZGV0YWNoZWQpIHtcbiAgICAgIC8vIHRoaXMgbWVhbnMgdGhhdCB0aGVyZSBpcyBhIG1pc2NvbmZpZ3VyYXRpb24gaW4gdGhlIGNhbGxpbmcgY29kZVxuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmFibGUgdG8gZGV0YWNoIHByb2Nlc3MgdGhhdCBpcyBub3Qgc3RhcnRlZCB3aXRoICdkZXRhY2hlZCcgb3B0aW9uYCk7XG4gICAgfVxuICAgIGlmICh0aGlzLnByb2MpIHtcbiAgICAgIHRoaXMucHJvYy51bnJlZigpO1xuICAgIH1cbiAgfVxuXG4gIGdldCBwaWQgKCkge1xuICAgIHJldHVybiB0aGlzLnByb2MgPyB0aGlzLnByb2MucGlkIDogbnVsbDtcbiAgfVxufVxuXG5leHBvcnQgeyBTdWJQcm9jZXNzIH07XG5leHBvcnQgZGVmYXVsdCBTdWJQcm9jZXNzO1xuXG4vKipcbiAqIEBjYWxsYmFjayBTdGFydERldGVjdG9yXG4gKiBAcGFyYW0ge3N0cmluZ30gc3Rkb3V0XG4gKiBAcGFyYW0ge3N0cmluZ30gW3N0ZGVycl1cbiAqIEByZXR1cm5zIHthbnl9XG4gKi9cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFFQTs7QUFDQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFKQSxNQUFNO0VBQUVBO0FBQUYsSUFBbUJDLGVBQXpCO0FBVUEsTUFBTUMsdUJBQXVCLEdBQUcsTUFBaEM7O0FBRUEsU0FBU0MsU0FBVCxDQUFvQkMsR0FBcEIsRUFBeUJDLFlBQXpCLEVBQXVDO0VBQ3JDLE9BQU9ELEdBQUcsQ0FBQ0UsTUFBSixHQUFhRCxZQUFiLEdBRUYsSUFBR0QsR0FBRyxDQUFDRyxNQUFKLENBQVdILEdBQUcsQ0FBQ0UsTUFBSixHQUFhRCxZQUF4QixDQUFzQyxFQUExQyxDQUE0Q0UsTUFBNUMsQ0FBbUQsQ0FBbkQsQ0FGRyxHQUdISCxHQUhKO0FBSUQ7O0FBR0QsTUFBTUksVUFBTixTQUF5QlIsWUFBekIsQ0FBc0M7RUFLcENTLGVBQWU7RUFHZkMsSUFBSTtFQUdKQyxJQUFJO0VBS0pDLEdBQUc7RUFLSEMsSUFBSTtFQUtKQyxhQUFhO0VBS2JDLEdBQUc7O0VBT0hDLFdBQVcsQ0FBRUosR0FBRixFQUFPRCxJQUFJLEdBQUcsRUFBZCxFQUFrQkUsSUFBSSxH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
|
|
283
|
+
exports.default = SubProcess;
|
|
284
|
+
/**
|
|
285
|
+
* @callback StartDetector
|
|
286
|
+
* @param {string} stdout
|
|
287
|
+
* @param {string} [stderr]
|
|
288
|
+
* @returns {any}
|
|
289
|
+
*/
|
|
290
|
+
//# sourceMappingURL=subprocess.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subprocess.js","sourceRoot":"","sources":["../../lib/subprocess.js"],"names":[],"mappings":"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"}
|
package/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
module.exports = require('./build/lib
|
|
1
|
+
module.exports = require('./build/lib');
|
package/lib/exec.js
CHANGED
|
@@ -47,10 +47,9 @@ async function exec (cmd, args = [], opts = /** @type {T} */({})) {
|
|
|
47
47
|
let stdoutArr = [], stderrArr = [], timer = null;
|
|
48
48
|
|
|
49
49
|
// if the process errors out, reject the promise
|
|
50
|
-
proc.on('error', /** @param {NodeJS.ErrnoException} err */(err) => {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
err = formatEnoent(err, cmd, opts.cwd);
|
|
50
|
+
proc.on('error', /** @param {NodeJS.ErrnoException} err */ async (err) => {
|
|
51
|
+
if (err.code === 'ENOENT') {
|
|
52
|
+
err = await formatEnoent(err, cmd, opts.cwd?.toString());
|
|
54
53
|
}
|
|
55
54
|
reject(err);
|
|
56
55
|
});
|