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.
@@ -1,285 +1,290 @@
1
1
  "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.default = exports.SubProcess = void 0;
9
-
10
- require("source-map-support/register");
11
-
12
- var _child_process = require("child_process");
13
-
14
- var _events = _interopRequireDefault(require("events"));
15
-
16
- var _bluebird = _interopRequireDefault(require("bluebird"));
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
- return str.length > suffixLength ? ` ${str.substr(str.length - suffixLength)}`.substr(1) : str;
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
- lastLinePortion;
35
- proc;
36
- args;
37
- cmd;
38
- opts;
39
- expectingExit;
40
- rep;
41
-
42
- constructor(cmd, args = [], opts = {}) {
43
- super();
44
- if (!cmd) throw new Error('Command is required');
45
- if (!_lodash.default.isString(cmd)) throw new Error('Command must be a string');
46
- if (!_lodash.default.isArray(args)) throw new Error('Args must be an array');
47
- this.cmd = cmd;
48
- this.args = args;
49
- this.proc = null;
50
- this.opts = opts;
51
- this.expectingExit = false;
52
- this.rep = (0, _shellQuote.quote)([cmd, ...args]);
53
- this.lastLinePortion = {
54
- stdout: '',
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
- if (_lodash.default.isNumber(startDetector)) {
81
- startDelay = startDetector;
82
- startDetector = null;
48
+ get isRunning() {
49
+ // presence of `proc` means we have connected and started
50
+ return !!this.proc;
83
51
  }
84
-
85
- if (_lodash.default.isBoolean(startDetector) && startDetector) {
86
- if (!this.opts.detached) {
87
- throw new Error(`Unable to detach process that is not started with 'detached' option`);
88
- }
89
-
90
- detach = true;
91
- startDetector = genericStartDetector;
92
- } else if (_lodash.default.isBoolean(timeoutMs) && timeoutMs) {
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
- return await new _bluebird.default((resolve, reject) => {
102
- this.proc = (0, _child_process.spawn)(this.cmd, this.args, this.opts);
103
-
104
- if (this.proc.stdout) {
105
- this.proc.stdout.setEncoding(this.opts.encoding || 'utf8');
106
- }
107
-
108
- if (this.proc.stderr) {
109
- this.proc.stderr.setEncoding(this.opts.encoding || 'utf8');
110
- }
111
-
112
- this.lastLinePortion = {
113
- stdout: '',
114
- stderr: ''
115
- };
116
-
117
- const handleOutput = streams => {
118
- const {
119
- stdout,
120
- stderr
121
- } = streams;
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
- this.emit('output', stdout, stderr);
133
-
134
- for (const [streamName, streamData] of _lodash.default.toPairs(streams)) {
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
- this.proc.on('error', err => {
157
- var _this$proc, _this$proc2, _this$proc3;
158
-
159
- (_this$proc = this.proc) === null || _this$proc === void 0 ? void 0 : _this$proc.removeAllListeners('exit');
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(err);
169
- (_this$proc3 = this.proc) === null || _this$proc3 === void 0 ? void 0 : _this$proc3.unref();
170
- this.proc = null;
171
- });
172
-
173
- if (this.proc.stdout) {
174
- this.proc.stdout.on('data', chunk => handleOutput({
175
- stdout: chunk.toString(),
176
- stderr: ''
177
- }));
178
- }
179
-
180
- if (this.proc.stderr) {
181
- this.proc.stderr.on('data', chunk => handleOutput({
182
- stdout: '',
183
- stderr: chunk.toString()
184
- }));
185
- }
186
-
187
- this.proc.on('exit', (code, signal) => {
188
- this.handleLastLines();
189
- this.emit('exit', code, signal);
190
- let event = this.expectingExit ? 'stop' : 'die';
191
-
192
- if (!this.expectingExit && code === 0) {
193
- event = 'end';
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
- async stop(signal = 'SIGTERM', timeout = 10000) {
231
- if (!this.isRunning) {
232
- throw new Error(`Can't stop process; it's not currently running (cmd: '${this.rep}')`);
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
- this.handleLastLines();
236
- return await new _bluebird.default((resolve, reject) => {
237
- var _this$proc4, _this$proc5;
238
-
239
- (_this$proc4 = this.proc) === null || _this$proc4 === void 0 ? void 0 : _this$proc4.on('close', resolve);
240
- this.expectingExit = true;
241
- (_this$proc5 = this.proc) === null || _this$proc5 === void 0 ? void 0 : _this$proc5.kill(signal);
242
- setTimeout(() => {
243
- reject(new Error(`Process didn't end after ${timeout}ms (cmd: '${this.rep}')`));
244
- }, timeout).unref();
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
- return await new _bluebird.default((resolve, reject) => {
254
- var _this$proc6;
255
-
256
- (_this$proc6 = this.proc) === null || _this$proc6 === void 0 ? void 0 : _this$proc6.on('exit', code => {
257
- if (code !== null && allowedExitCodes.indexOf(code) === -1) {
258
- reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));
259
- } else {
260
- resolve(code);
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
- if (this.proc) {
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
- var _default = SubProcess;
284
- exports.default = _default;
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/index.js');
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
- // @ts-ignore
52
- if (err.errno === 'ENOENT') {
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
  });