Socket
Socket
Sign inDemoInstall

@nodesuite/process

Package Overview
Dependencies
Maintainers
1
Versions
55
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@nodesuite/process - npm Package Compare versions

Comparing version 0.1.11 to 0.1.12

12

.rush/temp/package-deps_build_prod.json

@@ -5,7 +5,7 @@ {

"libraries/process/.eslintrc.js": "da8f1d5b00175fe9df49681a80b909d918ac6736",
"libraries/process/CHANGELOG.json": "00b6b00157301935396946ab25a3eaab16e74959",
"libraries/process/CHANGELOG.md": "3651a607c0fa85a5e23e7f8051d67dfc9bf9ae50",
"libraries/process/CHANGELOG.json": "966af5dce37c88182f4472674dbc255625feca21",
"libraries/process/CHANGELOG.md": "6628c02a97c4aa1e34a0faee49b326145fbdcabe",
"libraries/process/README.md": "7ccf2c0f3dd5c464ba236834650e60f378ba6bba",
"libraries/process/config/rig.json": "54137d20557298060eb70cf9e72e9ce1c7b7e130",
"libraries/process/package.json": "3e081baeb1e63c0b42e8a4aab80ef53fe9a3b67d",
"libraries/process/package.json": "bf8c36bfac2a26752c0ac75d3941b2ce57f0e910",
"libraries/process/src/core/exec.ts": "914b376a510f77905337efe6633aeb53c6538731",

@@ -16,3 +16,3 @@ "libraries/process/src/core/index.ts": "9e1418a405052d3046ea619c79cc271da681d310",

"libraries/process/src/core/manager.ts": "605cbe19fbe6658b15960cecdcba0f9d3c01a3c5",
"libraries/process/src/core/spawn.ts": "aeac1c2ae7796a015fe380812964703ad0f8800d",
"libraries/process/src/core/spawn.ts": "65ab576a86967970cc782f84fb91b5217baca00c",
"libraries/process/src/errors/index.ts": "50982ed061f2021d73fc30f95e626f7695aa704d",

@@ -29,5 +29,5 @@ "libraries/process/src/errors/message-timeout.error.ts": "cfd8f48f752f484aeae72aa6dd744c0b7998896e",

"libraries/process/src/promises/index.ts": "a38afa14be19a3632a7974566cfbc03696b2e192",
"libraries/process/src/promises/message.ts": "8d25675b89863fa75e501d8201933f78f8440160",
"libraries/process/src/promises/message.ts": "152e08a79f2ec39272f407cbf801c46f09d49ee3",
"libraries/process/src/promises/open.ts": "fd7c53cbee154f753e8d91f390bb5d7433703856",
"libraries/process/src/support/configure.ts": "e70aa0d741637ad9a650c97620c6283f33a8785d",
"libraries/process/src/support/configure.ts": "e8d43d25e7f9d0edb5015fdab104309dd07cbfe8",
"libraries/process/src/support/delay.ts": "aa87c9aa7e152d41bd6fe6aa79ef38f9cea4a289",

@@ -34,0 +34,0 @@ "libraries/process/src/support/index.ts": "792252b94592ab205683d321d2fdba5db95962e1",

@@ -5,7 +5,7 @@ {

"libraries/process/.eslintrc.js": "da8f1d5b00175fe9df49681a80b909d918ac6736",
"libraries/process/CHANGELOG.json": "00b6b00157301935396946ab25a3eaab16e74959",
"libraries/process/CHANGELOG.md": "3651a607c0fa85a5e23e7f8051d67dfc9bf9ae50",
"libraries/process/CHANGELOG.json": "966af5dce37c88182f4472674dbc255625feca21",
"libraries/process/CHANGELOG.md": "6628c02a97c4aa1e34a0faee49b326145fbdcabe",
"libraries/process/README.md": "7ccf2c0f3dd5c464ba236834650e60f378ba6bba",
"libraries/process/config/rig.json": "54137d20557298060eb70cf9e72e9ce1c7b7e130",
"libraries/process/package.json": "3e081baeb1e63c0b42e8a4aab80ef53fe9a3b67d",
"libraries/process/package.json": "bf8c36bfac2a26752c0ac75d3941b2ce57f0e910",
"libraries/process/src/core/exec.ts": "914b376a510f77905337efe6633aeb53c6538731",

@@ -16,3 +16,3 @@ "libraries/process/src/core/index.ts": "9e1418a405052d3046ea619c79cc271da681d310",

"libraries/process/src/core/manager.ts": "605cbe19fbe6658b15960cecdcba0f9d3c01a3c5",
"libraries/process/src/core/spawn.ts": "aeac1c2ae7796a015fe380812964703ad0f8800d",
"libraries/process/src/core/spawn.ts": "65ab576a86967970cc782f84fb91b5217baca00c",
"libraries/process/src/errors/index.ts": "50982ed061f2021d73fc30f95e626f7695aa704d",

@@ -29,5 +29,5 @@ "libraries/process/src/errors/message-timeout.error.ts": "cfd8f48f752f484aeae72aa6dd744c0b7998896e",

"libraries/process/src/promises/index.ts": "a38afa14be19a3632a7974566cfbc03696b2e192",
"libraries/process/src/promises/message.ts": "8d25675b89863fa75e501d8201933f78f8440160",
"libraries/process/src/promises/message.ts": "152e08a79f2ec39272f407cbf801c46f09d49ee3",
"libraries/process/src/promises/open.ts": "fd7c53cbee154f753e8d91f390bb5d7433703856",
"libraries/process/src/support/configure.ts": "e70aa0d741637ad9a650c97620c6283f33a8785d",
"libraries/process/src/support/configure.ts": "e8d43d25e7f9d0edb5015fdab104309dd07cbfe8",
"libraries/process/src/support/delay.ts": "aa87c9aa7e152d41bd6fe6aa79ef38f9cea4a289",

@@ -34,0 +34,0 @@ "libraries/process/src/support/index.ts": "792252b94592ab205683d321d2fdba5db95962e1",

@@ -5,2 +5,8 @@ {

{
"version": "0.1.12",
"tag": "@nodesuite/process_v0.1.12",
"date": "Sat, 17 Sep 2022 08:55:36 GMT",
"comments": {}
},
{
"version": "0.1.11",

@@ -7,0 +13,0 @@ "tag": "@nodesuite/process_v0.1.11",

# Change Log - @nodesuite/process
This log was last generated on Sat, 17 Sep 2022 08:48:05 GMT and should not be manually modified.
This log was last generated on Sat, 17 Sep 2022 08:55:36 GMT and should not be manually modified.
## 0.1.12
Sat, 17 Sep 2022 08:55:36 GMT
_Version update only_
## 0.1.11

@@ -6,0 +11,0 @@ Sat, 17 Sep 2022 08:48:05 GMT

@@ -405,3 +405,3 @@ import Node, { ForkOptions as ForkOptions$1, SpawnOptions as SpawnOptions$1, ExecOptions as ExecOptions$1, StdioOptions } from 'node:child_process';

*/
declare const spawn: (command: string, args?: string[], options?: SpawnOptions) => Promise<ChildProcess>;
declare const spawn: (command: string, args?: string[], { filters, ...options }?: SpawnOptions) => Promise<ChildProcess>;

@@ -408,0 +408,0 @@ /**

@@ -15,5 +15,5 @@ 'use strict';

var T=class extends Error{constructor(o,r){super(`Message listener on child process "${o}" timed out after ${r}ms.`);this.command=o,this.timeout=r;}};var I=class extends Error{constructor(o,r){super(`Open state listener on child process "${o}" timed out after ${r}ms.`);this.command=o,this.timeout=r;}};var P=class extends Error{constructor(o,r){super(`Encountered an error while configuring child process: ${JSON.stringify(o)}`,{cause:r});this.config=o;}};var y=class extends Error{constructor(o,r){super(`Encountered an error executing child process ${o}: ${r}`);this.command=o;}};var f=class extends Error{constructor(o="at unspecified executable path"){super(`Encountered an error spawning child process ${o}.`);this.command=o;}};var k=class extends Error{constructor(o,r){super(`Encountered an error spawning child process ${o}: ${r}`);this.command=o;}};var N=class extends Error{constructor(o,r){super(`Encountered an error killing child process ${o}: ${r.message}`,{cause:r});this.command=o,this.error=r;}};var C=e=>{try{let t=(n="",d=[])=>[...[n,...d].map(a=>a.trim()).filter(a=>!!a)],o=(n={})=>({...process.env,...n}),r=n=>({...n,stdio:n.stdio??[process.stdin,"pipe","pipe"],env:o(n.env)}),i=t(e.command,e.args),s=r(e.options);return {args:i,options:s}}catch(t){throw new P(e,t)}};var _=e=>new Promise(t=>setTimeout(t,e));var V=util.promisify(child_process.exec),D=child_process.spawn,Oo=child_process.fork;var Co=async(e,t=[],o={})=>{let r=C({command:e,args:t,options:o}),{stdout:i,stderr:s}=await V(r.args.join(" "),r.options);if(s)throw new y(e,s);return i??""};var [m,E,z,p,R,j,G,O]=["close","data","disconnect","error","exit","message","open","spawn"],Go=[m,E,z,p,R,j,G,O],_o=[m,R];var [J,b,Z,Q]=["exec","spawn","fork","kill"],ho=[J,b,Z,Q];var [q,ee,oe,re,te]=["string","object","number","boolean","bigint"],vo=[q,ee,oe,re,te];var [se,ne,ie,pe,ce,me,de,Se,Ee,ae,le,fe,ue,Oe,xe,ge,Te,Ie,Pe,ye,x,Ne,Ce,Re,Ge,_e,be,he,we,ve,Le,Ae,ke,Ve,De,Ue]=["SIGALRM","SIGBUS","SIGCHLD","SIGCONT","SIGFPE","SIGHUP","SIGILL","SIGINT","SIGIO","SIGIOT","SIGKILL","SIGPIPE","SIGPOLL","SIGPROF","SIGPWR","SIGQUIT","SIGSEGV","SIGSTKFLT","SIGSTOP","SIGSYS","SIGTERM","SIGTRAP","SIGTSTP","SIGTTIN","SIGTTOU","SIGUNUSED","SIGURG","SIGUSR1","SIGUSR2","SIGVTALRM","SIGWINCH","SIGXCPU","SIGXFSZ","SIGBREAK","SIGLOST","SIGINFO"],Ao=[se,ne,ie,pe,ce,me,de,Se,Ee,ae,le,fe,ue,Oe,xe,ge,Te,Ie,Pe,ye,x,Ne,Ce,Re,Ge,_e,be,he,we,ve,Le,Ae,ke,Ve,De,Ue];var [h,w,Fe,v]=["opening","opened","closing","closed"],Vo=[h,w,Fe,v];var [Me,$e,Be,Ke,We]=["overlapped","pipe","ignore","inherit","ipc"],Uo=[Me,$e,Be,Ke,We],[He,Xe,Ye,Fo]=["stdin","stdout","stderr","stdio"],Mo=[He],$o=[Xe,Ye];var Ko=e=>typeof e=="object"&&!!e&&Object.keys(e).includes("cmd");var ir=async(e,t={})=>{try{let{timeout:o,event:r,signal:i}={timeout:5e3,event:R,signal:x,...t};if(e.killed)return;if(e.killing)return Promise.race([e.killing,_(o)]);e.killing=Promise.race([new Promise(s=>{for(let n=0;n<100;n++)e.killed&&s();}),new Promise((s,n)=>{e.once(r,()=>{s();}),e.once(p,()=>{n();}),e.kill(i),e.killed&&s();}),_(o)]),await e.killing,e.removeAllListeners();}catch(o){throw new N(e.command,o)}};var U=e=>()=>new Promise((t,o)=>{e.killed&&t({code:void 0,signal:e.signalCode??void 0}),e.once(m,(r,i)=>{t({code:r,signal:i});}),e.once(p,r=>{o({error:r});});});var F=(e,t)=>(o,r=9e4)=>new Promise((i,s)=>{var S,g;let n=setTimeout(()=>{let l=new T(t??e.pid,r);console.warn(l.message),s(l);},r),d=(l,u)=>{s({code:l,signal:u});},a=l=>{s({error:l});},c=l=>{var L,A;let u=l.toString().trim();!o(u)||(clearTimeout(n),console.debug("Matched awaited message from child process.",u),(L=e.stdout)==null||L.off(E,c),(A=e.stderr)==null||A.off(E,c),e.off(m,d),e.off(p,a),i(u));};(S=e.stdout)==null||S.on(E,c),(g=e.stderr)==null||g.on(E,c),e.once(m,d),e.once(p,a);});var M=(e,t)=>async o=>new Promise((r,i)=>{e.pid&&r(),e.killed&&i("Cannot await open on killed process.");let s=d=>{i(d);},n=()=>{e.removeListener(p,s),r();};e.once(p,s),e.once(O,n),o&&setTimeout(()=>{let d=new I(t??e.pid,o);console.warn(d.message),i(d);},o);});var $=(e,{command:t,method:o,filters:r})=>{let i=new timer.Timer,s=Object.assign(e,{command:t,method:o,timer:i,filters:r,killing:void 0,state:h,untilOpen:M(e,t),untilClose:U(e),untilMessage:F(e,t)});s.once(O,()=>{s.state=w,console.debug(`Process "${t}" opened.`);}),s.once(m,()=>{s.state=v,console.debug(`Process "${t}" closed.`);}),s.on(p,c=>{console.debug(`Process "${t}" error: ${c.message}`),s.killed||s.kill(x);});let n=c=>{let S=c.toString().trim();return !s.filters||s.filters.every(g=>!S.includes(g))?S:void 0},d=c=>{let S=n(c);S&&process.stdout.write(`${S}
`);},a=c=>{let S=n(c);S&&process.stderr.write(`${S}
`);};return s.stdout&&s.stdout.on(E,d),s.stderr&&s.stderr.on(E,a),s};var K=class extends je__default["default"]{constructor(){super(...arguments);this.#o=defer.defer();this.#e=defer.defer();this.#r=!1;this.#t=!1;}#o;#e;#r;#t;get command(){return this._command}get pid(){return this.process().pid}process(){if(!this._process)throw new f(this.command);return this._process}untilClose(){return this.#e.untilResolved()}_setOpen(o){return this.#r?this.#o.promise:(this.once(G,()=>this.#o.resolve()),o())}_setClose(o){return this.#t?this.#e.promise:(this.once(m,()=>this.#e.resolve()),o())}_completeOpen(){if(this._process)this.emit(G),this.#o.resolve();else throw new f(this.command)}_completeClose(){if(this._process)this._process.timer.stop(),this.emit(m),this.#e.resolve(),this._process.removeAllListeners(),this.removeAllListeners();else throw new f(this.command)}};var vr=async(e,t=[],o={})=>{let r=C({args:t,options:o}),i=b,s=o.filters??[],n=$(D(e,r.args,r.options),{command:e,method:i,filters:s});return await n.untilOpen(),n};
var T=class extends Error{constructor(o,r){super(`Message listener on child process "${o}" timed out after ${r}ms.`);this.command=o,this.timeout=r;}};var I=class extends Error{constructor(o,r){super(`Open state listener on child process "${o}" timed out after ${r}ms.`);this.command=o,this.timeout=r;}};var P=class extends Error{constructor(o,r){super(`Encountered an error while configuring child process: ${JSON.stringify(o)}`,{cause:r});this.config=o;}};var y=class extends Error{constructor(o,r){super(`Encountered an error executing child process ${o}: ${r}`);this.command=o;}};var f=class extends Error{constructor(o="at unspecified executable path"){super(`Encountered an error spawning child process ${o}.`);this.command=o;}};var k=class extends Error{constructor(o,r){super(`Encountered an error spawning child process ${o}: ${r}`);this.command=o;}};var N=class extends Error{constructor(o,r){super(`Encountered an error killing child process ${o}: ${r.message}`,{cause:r});this.command=o,this.error=r;}};var C=e=>{try{let t=(n="",p=[])=>[...[n,...p].map(a=>a.trim()).filter(a=>!!a)],o=(n={})=>({...process.env,...n}),r=({stdio:n,...p})=>({...p,stdio:n??[process.stdin,"pipe","pipe"],env:o(p.env)}),i=t(e.command,e.args),s=r(e.options);return {args:i,options:s}}catch(t){throw new P(e,t)}};var _=e=>new Promise(t=>setTimeout(t,e));var V=util.promisify(child_process.exec),D=child_process.spawn,Oo=child_process.fork;var Co=async(e,t=[],o={})=>{let r=C({command:e,args:t,options:o}),{stdout:i,stderr:s}=await V(r.args.join(" "),r.options);if(s)throw new y(e,s);return i??""};var [d,E,z,c,R,j,G,O]=["close","data","disconnect","error","exit","message","open","spawn"],Go=[d,E,z,c,R,j,G,O],_o=[d,R];var [J,b,Z,Q]=["exec","spawn","fork","kill"],ho=[J,b,Z,Q];var [q,ee,oe,re,te]=["string","object","number","boolean","bigint"],vo=[q,ee,oe,re,te];var [se,ne,ie,pe,ce,me,de,Se,Ee,ae,le,fe,ue,Oe,xe,ge,Te,Ie,Pe,ye,x,Ne,Ce,Re,Ge,_e,be,he,we,ve,Le,Ae,ke,Ve,De,Ue]=["SIGALRM","SIGBUS","SIGCHLD","SIGCONT","SIGFPE","SIGHUP","SIGILL","SIGINT","SIGIO","SIGIOT","SIGKILL","SIGPIPE","SIGPOLL","SIGPROF","SIGPWR","SIGQUIT","SIGSEGV","SIGSTKFLT","SIGSTOP","SIGSYS","SIGTERM","SIGTRAP","SIGTSTP","SIGTTIN","SIGTTOU","SIGUNUSED","SIGURG","SIGUSR1","SIGUSR2","SIGVTALRM","SIGWINCH","SIGXCPU","SIGXFSZ","SIGBREAK","SIGLOST","SIGINFO"],Ao=[se,ne,ie,pe,ce,me,de,Se,Ee,ae,le,fe,ue,Oe,xe,ge,Te,Ie,Pe,ye,x,Ne,Ce,Re,Ge,_e,be,he,we,ve,Le,Ae,ke,Ve,De,Ue];var [h,w,Fe,v]=["opening","opened","closing","closed"],Vo=[h,w,Fe,v];var [Me,$e,Be,Ke,We]=["overlapped","pipe","ignore","inherit","ipc"],Uo=[Me,$e,Be,Ke,We],[He,Xe,Ye,Fo]=["stdin","stdout","stderr","stdio"],Mo=[He],$o=[Xe,Ye];var Ko=e=>typeof e=="object"&&!!e&&Object.keys(e).includes("cmd");var ir=async(e,t={})=>{try{let{timeout:o,event:r,signal:i}={timeout:5e3,event:R,signal:x,...t};if(e.killed)return;if(e.killing)return Promise.race([e.killing,_(o)]);e.killing=Promise.race([new Promise(s=>{for(let n=0;n<100;n++)e.killed&&s();}),new Promise((s,n)=>{e.once(r,()=>{s();}),e.once(c,()=>{n();}),e.kill(i),e.killed&&s();}),_(o)]),await e.killing,e.removeAllListeners();}catch(o){throw new N(e.command,o)}};var U=e=>()=>new Promise((t,o)=>{e.killed&&t({code:void 0,signal:e.signalCode??void 0}),e.once(d,(r,i)=>{t({code:r,signal:i});}),e.once(c,r=>{o({error:r});});});var F=(e,t)=>(o,r=9e4)=>new Promise((i,s)=>{var S,g;let n=setTimeout(()=>{let l=new T(t??e.pid,r);console.warn(l.message),s(l);},r),p=(l,u)=>{s({code:l,signal:u});},a=l=>{s({error:l});},m=l=>{var L,A;let u=l.toString().trim();!o(u)||(clearTimeout(n),console.debug("Matched awaited message from child process.",u),(L=e.stdout)==null||L.off(E,m),(A=e.stderr)==null||A.off(E,m),e.off(d,p),e.off(c,a),i(u));};(S=e.stdout)==null||S.on(E,m),(g=e.stderr)==null||g.on(E,m),e.once(d,p),e.once(c,a);});var M=(e,t)=>async o=>new Promise((r,i)=>{e.pid&&r(),e.killed&&i("Cannot await open on killed process.");let s=p=>{i(p);},n=()=>{e.removeListener(c,s),r();};e.once(c,s),e.once(O,n),o&&setTimeout(()=>{let p=new I(t??e.pid,o);console.warn(p.message),i(p);},o);});var $=(e,{command:t,method:o,filters:r})=>{let i=new timer.Timer,s=Object.assign(e,{command:t,method:o,timer:i,filters:r,killing:void 0,state:h,untilOpen:M(e,t),untilClose:U(e),untilMessage:F(e,t)});s.once(O,()=>{s.state=w,console.debug(`Process "${t}" opened.`);}),s.once(d,()=>{s.state=v,console.debug(`Process "${t}" closed.`);}),s.on(c,m=>{console.debug(`Process "${t}" error: ${m.message}`),s.killed||s.kill(x);});let n=m=>{let S=m.toString().trim();return !s.filters||s.filters.every(g=>!S.includes(g))?S:void 0},p=m=>{let S=n(m);S&&process.stdout.write(`${S}
`);},a=m=>{let S=n(m);S&&process.stderr.write(`${S}
`);};return s.stdout&&s.stdout.on(E,p),s.stderr&&s.stderr.on(E,a),s};var K=class extends je__default["default"]{constructor(){super(...arguments);this.#o=defer.defer();this.#e=defer.defer();this.#r=!1;this.#t=!1;}#o;#e;#r;#t;get command(){return this._command}get pid(){return this.process().pid}process(){if(!this._process)throw new f(this.command);return this._process}untilClose(){return this.#e.untilResolved()}_setOpen(o){return this.#r?this.#o.promise:(this.once(G,()=>this.#o.resolve()),o())}_setClose(o){return this.#t?this.#e.promise:(this.once(d,()=>this.#e.resolve()),o())}_completeOpen(){if(this._process)this.emit(G),this.#o.resolve();else throw new f(this.command)}_completeClose(){if(this._process)this._process.timer.stop(),this.emit(d),this.#e.resolve(),this._process.removeAllListeners(),this.removeAllListeners();else throw new f(this.command)}};var vr=async(e,t=[],{filters:o,...r}={})=>{let i=C({args:t,options:r}),s=b,n=$(D(e,i.args,i.options),{command:e,method:s,filters:o??[]});return await n.untilOpen(),n};

@@ -35,7 +35,7 @@ exports.BIGINT_TYPE = te;

exports.PROCESS_CLOSED_STATE = v;
exports.PROCESS_CLOSE_EVENT = m;
exports.PROCESS_CLOSE_EVENT = d;
exports.PROCESS_CLOSING_STATE = Fe;
exports.PROCESS_DATA_EVENT = E;
exports.PROCESS_DISCONNECT_EVENT = z;
exports.PROCESS_ERROR_EVENT = p;
exports.PROCESS_ERROR_EVENT = c;
exports.PROCESS_EXIT_EVENT = R;

@@ -117,2 +117,2 @@ exports.PROCESS_MESSAGE_EVENT = j;

exports.spawn = vr;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/errors/message-timeout.error.ts","../src/errors/open-timeout.error.ts","../src/errors/process-configuration.error.ts","../src/errors/process-execution.error.ts","../src/errors/process-not-available.error.ts","../src/errors/process-spawn.error.ts","../src/errors/process-termination.error.ts","../src/support/configure.ts","../src/support/delay.ts","../src/support/vendor.ts","../src/core/exec.ts","../src/types/events.ts","../src/types/methods.ts","../src/types/serializable.ts","../src/types/signals.ts","../src/types/states.ts","../src/types/stdio.ts","../src/types/vendor.ts","../src/core/kill.ts","../src/core/manage.ts","../src/promises/close.ts","../src/promises/message.ts","../src/promises/open.ts","../src/core/manager.ts","../src/core/spawn.ts"],"names":["MessageTimeoutError","command","timeout","OpenTimeoutError","ProcessConfigurationError","config","error","ProcessExecutionError","stderr","ProcessNotAvailableError","ProcessSpawnError","ProcessTerminationError","configure","parseArgs","args","value","mergeEnv","env","parseOptions","options","delay","ms","resolve","exec","fork","spawn","promisify","nodeExec","nodeSpawn","nodeFork","stdout","PROCESS_CLOSE_EVENT","PROCESS_DATA_EVENT","PROCESS_DISCONNECT_EVENT","PROCESS_ERROR_EVENT","PROCESS_EXIT_EVENT","PROCESS_MESSAGE_EVENT","PROCESS_OPEN_EVENT","PROCESS_SPAWN_EVENT","processEvents","closeEvents","EXEC","SPAWN","FORK","KILL","executionMethods","STRING_TYPE","OBJECT_TYPE","NUMBER_TYPE","BOOLEAN_TYPE","BIGINT_TYPE","serializableTypes","SIGALRM","SIGBUS","SIGCHLD","SIGCONT","SIGFPE","SIGHUP","SIGILL","SIGINT","SIGIO","SIGIOT","SIGKILL","SIGPIPE","SIGPOLL","SIGPROF","SIGPWR","SIGQUIT","SIGSEGV","SIGSTKFLT","SIGSTOP","SIGSYS","SIGTERM","SIGTRAP","SIGTSTP","SIGTTIN","SIGTTOU","SIGUNUSED","SIGURG","SIGUSR1","SIGUSR2","SIGVTALRM","SIGWINCH","SIGXCPU","SIGXFSZ","SIGBREAK","SIGLOST","SIGINFO","signals","PROCESS_OPENING_STATE","PROCESS_OPENED_STATE","PROCESS_CLOSING_STATE","PROCESS_CLOSED_STATE","processStates","IO_OVERLAPPED","IO_PIPE","IO_IGNORE","IO_INHERIT","IO_IPC","ioTypes","STDIN","STDOUT","STDERR","STDIO","inputTypes","outputTypes","isProcessError","kill","childProcess","event","signal","i","reject","Timer","promisifyClose","code","promisifyMessage","validate","_a","_b","timer","onClose","onError","onData","data","message","promisifyOpen","onSpawn","manage","nativeChildProcess","method","filters","filter","onStdout","onStderr","EventEmitter","defer","ProcessManager","#opener","#closer","#isOpening","#isClosing","open","close"],"mappings":"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C,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACF,EAAI,CACF,UACA,SACA,UACA,UACA,SACA,SACA,SACA,SACA,QACA,SACA,UACA,UACA,UACA,UACA,SACA,UACA,UACA,YACA,UACA,SACA,UACA,UACA,UACA,UACA,UACA,YACA,SACA,UACA,UACA,YACA,WACA,UACA,UACA,WACA,UACA,SACF,EAEaC,GAAsC,CACjDpC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACF,ECjHO,GAAM,CACXE,EACAC,EACAC,GACAC,CACF,EAAI,CAAC,UAAW,SAAU,UAAW,QAAQ,EAEhCC,GAAgB,CAC3BJ,EACAC,EACAC,GACAC,CACF,ECTO,GAAM,CAACE,GAAeC,GAASC,GAAWC,GAAYC,EAAM,EAAI,CACrE,aACA,OACA,SACA,UACA,KACF,EAKaC,GAAU,CACrBL,GACAC,GACAC,GACAC,GACAC,EACF,EAUa,CAACE,GAAOC,GAAQC,GAAQC,EAAK,EAAI,CAC5C,QACA,SACA,SACA,OACF,EAKaC,GAAa,CAACJ,EAAK,EAKnBK,GAAc,CAACJ,GAAQC,EAAM,EC6BnC,IAAMI,GAAkBpG,GAC7B,OAAOA,GAAU,UAAY,CAAC,CAACA,GAAS,OAAO,KAAKA,CAAK,EAAE,SAAS,KAAK,EC9DpE,IAAMqG,GAAO,MAClBC,EACAzF,EAAgC,CAAC,IACf,CAClB,GAAI,CACF,GAAM,CAAE,QAAAjB,EAAS,MAAA2G,EAAO,OAAAC,CAAO,EAAiB,CAC9C,QAAS,IACT,MAAO3E,EACP,OAAQqC,EACR,GAA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","sourcesContent":["/**\n * Throws when an awaited message does not return from child process within given timeout.\n *\n * @public\n */\nexport class MessageTimeoutError extends Error {\n  public readonly command: string | number | undefined\n  public readonly timeout: number\n\n  public constructor(command: string | number | undefined, timeout: number) {\n    super(\n      `Message listener on child process \"${command}\" timed out after ${timeout}ms.`\n    )\n    this.command = command\n    this.timeout = timeout\n  }\n}\n","/**\n * Throws when a child process does not open within given timeout.\n *\n * @public\n */\nexport class OpenTimeoutError extends Error {\n  public readonly command: string | number | undefined\n  public readonly timeout: number\n\n  public constructor(command: string | number | undefined, timeout: number) {\n    super(\n      `Open state listener on child process \"${command}\" timed out after ${timeout}ms.`\n    )\n    this.command = command\n    this.timeout = timeout\n  }\n}\n","import type { Options, ProcessConfig } from \"../types\"\n\nexport class ProcessConfigurationError extends Error {\n  public readonly config: Partial<ProcessConfig<Options>>\n\n  public constructor(config: Partial<ProcessConfig<Options>>, error: Error) {\n    super(\n      `Encountered an error while configuring child process: ${JSON.stringify(\n        config\n      )}`,\n      {\n        cause: error\n      }\n    )\n    this.config = config\n  }\n}\n","export class ProcessExecutionError extends Error {\n  public readonly command: string\n\n  public constructor(command: string, stderr?: string) {\n    super(`Encountered an error executing child process ${command}: ${stderr}`)\n    this.command = command\n  }\n}\n","export class ProcessNotAvailableError extends Error {\n  public readonly command: string\n\n  public constructor(command: string = \"at unspecified executable path\") {\n    super(`Encountered an error spawning child process ${command}.`)\n    this.command = command\n  }\n}\n","export class ProcessSpawnError extends Error {\n  public readonly command: string\n\n  public constructor(command: string, stderr?: string) {\n    super(`Encountered an error spawning child process ${command}: ${stderr}`)\n    this.command = command\n  }\n}\n","export class ProcessTerminationError extends Error {\n  public readonly command: string | undefined\n  public readonly error: Error\n\n  public constructor(command: string | undefined, error: Error) {\n    super(\n      `Encountered an error killing child process ${command}: ${error.message}`,\n      { cause: error }\n    )\n    this.command = command\n    this.error = error\n  }\n}\n","import { ProcessConfigurationError } from \"../errors\"\nimport type {\n  ExecOptions,\n  ForkOptions,\n  ProcessConfig,\n  ProcessEnv,\n  SpawnOptions\n} from \"../types\"\n\n/**\n * Prepares child process arguments and options prior to execution.\n *\n * @param config - User input as configuration object.\n *\n * @internal\n */\nexport const configure = <O extends SpawnOptions | ForkOptions | ExecOptions>(\n  config: ProcessConfig<O>\n): ProcessConfig<O> => {\n  try {\n    // Strips empty elements and trims args array.\n    const parseArgs = (command: string = \"\", args: string[] = []): string[] => [\n      ...[command, ...args]\n        .map((value: string) => value.trim())\n        .filter((value) => !!value)\n    ]\n\n    // Merges environment variables from current process with any provided by child process options.\n    const mergeEnv = (env: ProcessEnv = {}): ProcessEnv => ({\n      ...process.env,\n      ...env\n    })\n\n    // Merges process options with current environment variables.\n    const parseOptions = <O extends SpawnOptions | ForkOptions | ExecOptions>(\n      options: O\n    ): O => ({\n      ...options,\n      stdio: options.stdio ?? [process.stdin, \"pipe\", \"pipe\"],\n      env: mergeEnv(options.env)\n    })\n\n    const args: string[] = parseArgs(config.command, config.args)\n    const options: O = parseOptions(config.options)\n\n    return {\n      args,\n      options\n    }\n  } catch (error) {\n    throw new ProcessConfigurationError(config, error as Error)\n  }\n}\n","/**\n * Simple timeout function.\n *\n * @param ms - Number of milliseconds to wait.\n *\n * @internal\n */\nexport const delay = (ms: number): Promise<void> =>\n  new Promise<void>((resolve) => setTimeout(resolve, ms))\n","import { exec, fork, spawn } from \"node:child_process\"\nimport { promisify } from \"node:util\"\n\nimport type { NodeExec, NodeFork, NodeSpawn } from \"../types\"\n\n/**\n * Promisified Node exec method.\n *\n * @internal\n */\nexport const nodeExec: NodeExec = promisify(exec)\n\n/**\n * Original node spawn method.\n *\n * @internal\n */\nexport const nodeSpawn: NodeSpawn = spawn\n\n/**\n * Original node fork method.\n *\n * @internal\n */\nexport const nodeFork: NodeFork = fork\n","import { ProcessExecutionError } from \"../errors\"\nimport { configure, nodeExec } from \"../support\"\nimport type { ExecOptions, ProcessConfig } from \"../types\"\n\n/**\n * Provide async child process executor.\n *\n * @remarks\n * Throws error on `stderr` output unless suppressed.\n * If process is long-running, do not await the Promise.\n * Environment variables from current process are injected through to child process.\n *\n * @public\n */\nexport const exec = async (\n  command: string,\n  args: string[] = [],\n  options: ExecOptions = {}\n): Promise<string> => {\n  // Configure args and options.\n  const config: ProcessConfig<ExecOptions> = configure({\n    command,\n    args,\n    options\n  })\n\n  // Await child process execution.\n  const { stdout, stderr } = await nodeExec(\n    config.args.join(` `),\n    config.options\n  )\n\n  // Check stderr for any error messages.\n  if (stderr) {\n    throw new ProcessExecutionError(command, stderr)\n  }\n\n  // Return stdout.\n  return stdout ?? \"\"\n}\n","/**\n * @public\n */\nexport const [\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_DISCONNECT_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_EXIT_EVENT,\n  PROCESS_MESSAGE_EVENT,\n  PROCESS_OPEN_EVENT,\n  PROCESS_SPAWN_EVENT\n] = [\n  \"close\",\n  \"data\",\n  \"disconnect\",\n  \"error\",\n  \"exit\",\n  \"message\",\n  \"open\",\n  \"spawn\"\n] as const\n\n/**\n * @public\n */\nexport const processEvents = [\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_DISCONNECT_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_EXIT_EVENT,\n  PROCESS_MESSAGE_EVENT,\n  PROCESS_OPEN_EVENT,\n  PROCESS_SPAWN_EVENT\n] as const\n\n/**\n * @public\n */\nexport type ProcessEvent = typeof processEvents[number]\n\n/**\n * @public\n */\nexport const closeEvents = [PROCESS_CLOSE_EVENT, PROCESS_EXIT_EVENT] as const\n\n/**\n * @public\n */\nexport type CloseEvent = typeof closeEvents[number]\n","/**\n * @public\n */\nexport const [EXEC, SPAWN, FORK, KILL] = [\n  \"exec\",\n  \"spawn\",\n  \"fork\",\n  \"kill\"\n] as const\n\n/**\n * @public\n */\nexport const executionMethods = [EXEC, SPAWN, FORK, KILL] as const\n\n/**\n * @public\n */\nexport type ExecutionMethod = typeof executionMethods[number]\n","/**\n * @internal\n */\nexport const [\n  STRING_TYPE,\n  OBJECT_TYPE,\n  NUMBER_TYPE,\n  BOOLEAN_TYPE,\n  BIGINT_TYPE\n] = [\"string\", \"object\", \"number\", \"boolean\", \"bigint\"] as const\n\n/**\n * @internal\n */\nexport const serializableTypes = [\n  STRING_TYPE,\n  OBJECT_TYPE,\n  NUMBER_TYPE,\n  BOOLEAN_TYPE,\n  BIGINT_TYPE\n] as const\n\n/**\n * @internal\n */\nexport type SerializableType = typeof serializableTypes[number]\n\n/**\n * @internal\n */\nexport interface SerializableTypes {\n  string: string\n  object: object\n  number: number\n  boolean: boolean\n  bigint: boolean\n}\n","export const [\n  SIGALRM,\n  SIGBUS,\n  SIGCHLD,\n  SIGCONT,\n  SIGFPE,\n  SIGHUP,\n  SIGILL,\n  SIGINT,\n  SIGIO,\n  SIGIOT,\n  SIGKILL,\n  SIGPIPE,\n  SIGPOLL,\n  SIGPROF,\n  SIGPWR,\n  SIGQUIT,\n  SIGSEGV,\n  SIGSTKFLT,\n  SIGSTOP,\n  SIGSYS,\n  SIGTERM,\n  SIGTRAP,\n  SIGTSTP,\n  SIGTTIN,\n  SIGTTOU,\n  SIGUNUSED,\n  SIGURG,\n  SIGUSR1,\n  SIGUSR2,\n  SIGVTALRM,\n  SIGWINCH,\n  SIGXCPU,\n  SIGXFSZ,\n  SIGBREAK,\n  SIGLOST,\n  SIGINFO\n] = [\n  \"SIGALRM\",\n  \"SIGBUS\",\n  \"SIGCHLD\",\n  \"SIGCONT\",\n  \"SIGFPE\",\n  \"SIGHUP\",\n  \"SIGILL\",\n  \"SIGINT\",\n  \"SIGIO\",\n  \"SIGIOT\",\n  \"SIGKILL\",\n  \"SIGPIPE\",\n  \"SIGPOLL\",\n  \"SIGPROF\",\n  \"SIGPWR\",\n  \"SIGQUIT\",\n  \"SIGSEGV\",\n  \"SIGSTKFLT\",\n  \"SIGSTOP\",\n  \"SIGSYS\",\n  \"SIGTERM\",\n  \"SIGTRAP\",\n  \"SIGTSTP\",\n  \"SIGTTIN\",\n  \"SIGTTOU\",\n  \"SIGUNUSED\",\n  \"SIGURG\",\n  \"SIGUSR1\",\n  \"SIGUSR2\",\n  \"SIGVTALRM\",\n  \"SIGWINCH\",\n  \"SIGXCPU\",\n  \"SIGXFSZ\",\n  \"SIGBREAK\",\n  \"SIGLOST\",\n  \"SIGINFO\"\n] as const\n\nexport const signals: Readonly<NodeJS.Signals[]> = [\n  SIGALRM,\n  SIGBUS,\n  SIGCHLD,\n  SIGCONT,\n  SIGFPE,\n  SIGHUP,\n  SIGILL,\n  SIGINT,\n  SIGIO,\n  SIGIOT,\n  SIGKILL,\n  SIGPIPE,\n  SIGPOLL,\n  SIGPROF,\n  SIGPWR,\n  SIGQUIT,\n  SIGSEGV,\n  SIGSTKFLT,\n  SIGSTOP,\n  SIGSYS,\n  SIGTERM,\n  SIGTRAP,\n  SIGTSTP,\n  SIGTTIN,\n  SIGTTOU,\n  SIGUNUSED,\n  SIGURG,\n  SIGUSR1,\n  SIGUSR2,\n  SIGVTALRM,\n  SIGWINCH,\n  SIGXCPU,\n  SIGXFSZ,\n  SIGBREAK,\n  SIGLOST,\n  SIGINFO\n] as const\n\nexport type Signal = typeof signals[number]\n","export const [\n  PROCESS_OPENING_STATE,\n  PROCESS_OPENED_STATE,\n  PROCESS_CLOSING_STATE,\n  PROCESS_CLOSED_STATE\n] = [\"opening\", \"opened\", \"closing\", \"closed\"] as const\n\nexport const processStates = [\n  PROCESS_OPENING_STATE,\n  PROCESS_OPENED_STATE,\n  PROCESS_CLOSING_STATE,\n  PROCESS_CLOSED_STATE\n] as const\n\nexport type ProcessState = typeof processStates[number]\n","/**\n * @public\n */\nexport const [IO_OVERLAPPED, IO_PIPE, IO_IGNORE, IO_INHERIT, IO_IPC] = [\n  \"overlapped\",\n  \"pipe\",\n  \"ignore\",\n  \"inherit\",\n  \"ipc\"\n] as const\n\n/**\n * @public\n */\nexport const ioTypes = [\n  IO_OVERLAPPED,\n  IO_PIPE,\n  IO_IGNORE,\n  IO_INHERIT,\n  IO_IPC\n] as const\n\n/**\n * @public\n */\nexport type IOType = typeof ioTypes[number]\n\n/**\n * @public\n */\nexport const [STDIN, STDOUT, STDERR, STDIO] = [\n  \"stdin\",\n  \"stdout\",\n  \"stderr\",\n  \"stdio\"\n] as const\n\n/**\n * @public\n */\nexport const inputTypes = [STDIN]\n\n/**\n * @public\n */\nexport const outputTypes = [STDOUT, STDERR]\n\n/**\n * @public\n */\nexport type InputType = typeof inputTypes[number]\n\n/**\n * @public\n */\nexport type OutputType = typeof outputTypes[number]\n","import type Node from \"node:child_process\"\n\nimport type { STDERR, STDOUT } from \"./stdio\"\n\nexport type NodeChildProcess = Node.ChildProcess\n\nexport type NodeExecOptions = Node.ExecOptions\nexport type NodeSpawnOptions = Node.SpawnOptions\nexport type NodeForkOptions = Node.ForkOptions\nexport type NodeStdioOptions = Node.StdioOptions\n\nexport type Serializable = string | object | number | boolean | bigint\n\n/**\n * String output from child process execution.\n *\n * @public\n */\nexport interface ProcessResult {\n  [STDOUT]?: string\n  [STDERR]?: string\n}\n\n/**\n * Common process.env values.\n *\n * @public\n */\nexport interface ProcessEnv {\n  TZ?: string\n  NODE_ENV?: \"development\" | \"test\" | \"production\"\n\n  [key: string]: string | undefined\n}\n\n/**\n * NodeJS \"exec\" command.\n *\n * @public\n */\nexport type NodeExec = (\n  command: string,\n  options: NodeExecOptions\n) => Promise<ProcessResult>\n\n/**\n * NodeJS \"spawn\" command.\n *\n * @public\n */\nexport type NodeSpawn = (\n  command: string,\n  args: ReadonlyArray<string>,\n  options: NodeSpawnOptions\n) => NodeChildProcess\n\n/**\n * NodeJS \"fork\" command.\n *\n * @public\n */\nexport type NodeFork = (\n  command: string,\n  args: ReadonlyArray<string>,\n  options: NodeForkOptions\n) => NodeChildProcess\n\n/**\n * Type guard to determine if a value is a valid process error.\n *\n * @param error - Possible error value to test.\n *\n * @public\n */\nexport const isProcessError = (error: unknown): error is Node.ExecException =>\n  typeof error === \"object\" && !!error && Object.keys(error).includes(\"cmd\")\n","import { ProcessTerminationError } from \"../errors\"\nimport { delay } from \"../support\"\nimport { PROCESS_ERROR_EVENT, PROCESS_EXIT_EVENT, SIGTERM } from \"../types\"\nimport type { ChildProcess, KillOptions } from \"../types\"\n\n/**\n * Terminates a child childProcess and awaits for a closed state.\n *\n * @remarks\n * Removes any listeners attached to the childProcess.\n *\n * @public\n */\nexport const kill = async (\n  childProcess: ChildProcess,\n  options: Partial<KillOptions> = {}\n): Promise<void> => {\n  try {\n    const { timeout, event, signal }: KillOptions = {\n      timeout: 5000,\n      event: PROCESS_EXIT_EVENT,\n      signal: SIGTERM,\n      ...options\n    }\n\n    // If process already killed, terminate immediately.\n    if (childProcess.killed) {\n      return\n    }\n\n    // If already awaiting a kill event, return previous promise race.\n    if (childProcess.killing) {\n      return Promise.race([childProcess.killing, delay(timeout)])\n    }\n\n    // Attach the first kill race.\n    childProcess.killing = Promise.race([\n      new Promise<void>((resolve) => {\n        // Poll for a killed in case event is already triggered.\n        for (let i: number = 0; i < 100; i++) {\n          if (childProcess.killed) {\n            resolve()\n          }\n        }\n      }),\n      new Promise<void>((resolve, reject) => {\n        // Await close or exit event before resolving.\n        childProcess.once(event, () => {\n          resolve()\n        })\n\n        // Abort early if an error occurs.\n        childProcess.once(PROCESS_ERROR_EVENT, () => {\n          reject()\n        })\n\n        // Send termination signal.\n        childProcess.kill(signal)\n\n        // Resolve if process is already terminated by the time listeners are attached.\n        if (childProcess.killed) {\n          resolve()\n        }\n      }),\n      delay(timeout)\n    ])\n\n    await childProcess.killing\n\n    // Removes all listeners after termination.\n    childProcess.removeAllListeners()\n  } catch (error) {\n    throw new ProcessTerminationError(childProcess.command, error as Error)\n  }\n}\n","import { Timer } from \"@nodesuite/timer\"\nimport type { PerformanceTimer } from \"@nodesuite/timer\"\n\nimport { promisifyClose, promisifyMessage, promisifyOpen } from \"../promises\"\nimport {\n  PROCESS_CLOSE_EVENT,\n  PROCESS_CLOSED_STATE,\n  PROCESS_DATA_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_OPENED_STATE,\n  PROCESS_OPENING_STATE,\n  PROCESS_SPAWN_EVENT,\n  SIGTERM\n} from \"../types\"\nimport type { ChildProcess, NodeChildProcess } from \"../types\"\n\n/**\n * Utility function to append several management tools to a spawned or forked process.\n *\n * @remarks\n * This function should not be called directly, only indirectly via `spawn` or `fork`.\n *\n * @param nativeChildProcess - Native child process to augment.\n * @param command - Command name or executable path called by `spawn` or `fork`.\n * @param method - Execution method (`spawn`, `fork`) used to spawn the process.\n * @param filters - String filters used to reduce stdout and stderr noise.\n *\n * @internal\n */\nexport const manage = (\n  nativeChildProcess: NodeChildProcess,\n  {\n    command,\n    method,\n    filters\n  }: Pick<ChildProcess, \"command\" | \"method\" | \"filters\">\n): ChildProcess => {\n  // Initialize a timer to track duration.\n  const timer: PerformanceTimer = new Timer()\n\n  // Attach the additional \"management\" properties to the base child process.\n  const childProcess: ChildProcess = Object.assign(nativeChildProcess, {\n    command,\n    method,\n    timer,\n    filters,\n    killing: undefined,\n    state: PROCESS_OPENING_STATE,\n    untilOpen: promisifyOpen(nativeChildProcess, command),\n    untilClose: promisifyClose(nativeChildProcess),\n    untilMessage: promisifyMessage(nativeChildProcess, command)\n  })\n\n  // Change state and notify debugger on state changes.\n\n  childProcess.once(PROCESS_SPAWN_EVENT, () => {\n    childProcess.state = PROCESS_OPENED_STATE\n    console.debug(`Process \"${command}\" opened.`)\n  })\n\n  childProcess.once(PROCESS_CLOSE_EVENT, () => {\n    childProcess.state = PROCESS_CLOSED_STATE\n    console.debug(`Process \"${command}\" closed.`)\n  })\n\n  childProcess.on(PROCESS_ERROR_EVENT, (error: Error) => {\n    console.debug(`Process \"${command}\" error: ${error.message}`)\n    if (!childProcess.killed) {\n      childProcess.kill(SIGTERM)\n    }\n  })\n\n  const filter = (data: Buffer): string | undefined => {\n    const message: string = data.toString().trim()\n    return !childProcess.filters ||\n      childProcess.filters.every((filter) => !message.includes(filter))\n      ? message\n      : undefined\n  }\n\n  const onStdout = (data: Buffer): void => {\n    const message: string | undefined = filter(data)\n    if (message) {\n      process.stdout.write(`${message}\\n`)\n    }\n  }\n\n  const onStderr = (data: Buffer): void => {\n    const message: string | undefined = filter(data)\n    if (message) {\n      process.stderr.write(`${message}\\n`)\n    }\n  }\n\n  if (childProcess.stdout) {\n    childProcess.stdout.on(PROCESS_DATA_EVENT, onStdout)\n  }\n\n  if (childProcess.stderr) {\n    childProcess.stderr.on(PROCESS_DATA_EVENT, onStderr)\n  }\n\n  return childProcess\n}\n","import { PROCESS_CLOSE_EVENT, PROCESS_ERROR_EVENT } from \"../types\"\nimport type { CloseReason, NodeChildProcess, Signal } from \"../types\"\n\n/**\n * Awaits a close event from a specified child process.\n *\n * @param childProcess - Spawned child process to monitor.\n *\n * @internal\n */\nexport const promisifyClose =\n  (childProcess: NodeChildProcess) => (): Promise<CloseReason> =>\n    new Promise<CloseReason>((resolve, reject) => {\n      // If process already killed, resolve immediately.\n      if (childProcess.killed) {\n        resolve({\n          code: undefined,\n          signal: childProcess.signalCode ?? undefined\n        })\n      }\n\n      // Listen for close event and resolve with payload.\n      childProcess.once(\n        PROCESS_CLOSE_EVENT,\n        (code: number | undefined, signal: Signal | undefined) => {\n          resolve({\n            code,\n            signal\n          })\n        }\n      )\n\n      // Abort on errors.\n      childProcess.once(PROCESS_ERROR_EVENT, (error: Error) => {\n        reject({\n          error\n        })\n      })\n    })\n","import { MessageTimeoutError } from \"../errors\"\nimport {\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_ERROR_EVENT\n} from \"../types\"\nimport type { NodeChildProcess, Signal, Validate } from \"../types\"\n\n/**\n * Awaits a specific message event from a specified child process.\n *\n * @remarks\n * Has a default timeout of 90s.\n *\n * @param childProcess - Spawned child process to monitor.\n * @param command - Optional name of command for debugging.\n *\n * @internal\n */\nexport const promisifyMessage =\n  (childProcess: NodeChildProcess, command?: string) =>\n  (validate: Validate, timeout: number = 90000): Promise<string> =>\n    new Promise((resolve, reject) => {\n      // If a timeout was requested, start a timer to reject promise if reached.\n      const timer: NodeJS.Timer = setTimeout(() => {\n        const error: Error = new MessageTimeoutError(\n          command ?? childProcess.pid,\n          timeout\n        )\n        console.warn(error.message)\n        reject(error)\n      }, timeout)\n\n      // Abort observer if process closes before a match is found.\n      const onClose = (\n        code: number | undefined,\n        signal: Signal | undefined\n      ): void => {\n        reject({ code, signal })\n      }\n\n      // Abort observer if process errors before a match is found.\n      const onError = (error: Error): void => {\n        reject({\n          error\n        })\n      }\n\n      // Matching logic, generally a Zod schema or function that throws if invalid.\n      // We must remove this listener upon resolution to avoid memory leaks.\n      const onData = (data: Buffer): void => {\n        const message: string = data.toString().trim()\n\n        if (!validate(message)) {\n          return\n        }\n\n        // Clear the rejection timeout.\n        clearTimeout(timer)\n\n        console.debug(`Matched awaited message from child process.`, message)\n\n        childProcess.stdout?.off(PROCESS_DATA_EVENT, onData)\n        childProcess.stderr?.off(PROCESS_DATA_EVENT, onData)\n\n        childProcess.off(PROCESS_CLOSE_EVENT, onClose)\n        childProcess.off(PROCESS_ERROR_EVENT, onError)\n\n        resolve(message)\n      }\n\n      childProcess.stdout?.on(PROCESS_DATA_EVENT, onData)\n      childProcess.stderr?.on(PROCESS_DATA_EVENT, onData)\n\n      childProcess.once(PROCESS_CLOSE_EVENT, onClose)\n      childProcess.once(PROCESS_ERROR_EVENT, onError)\n    })\n","import { OpenTimeoutError } from \"../errors\"\nimport { PROCESS_ERROR_EVENT, PROCESS_SPAWN_EVENT } from \"../types\"\nimport type { NodeChildProcess } from \"../types\"\n\n/**\n * Awaits a `spawn` event from a specified child process.\n *\n * @param childProcess - Spawned child process to monitor.\n * @param command - Optional name of command for debugging.\n *\n * @internal\n */\nexport const promisifyOpen =\n  (childProcess: NodeChildProcess, command?: string) =>\n  async (timeout?: number): Promise<void> =>\n    new Promise<void>((resolve, reject) => {\n      // If process already open, return immediately.\n      if (childProcess.pid) {\n        resolve()\n      }\n\n      // Do not await killed processes.\n      if (childProcess.killed) {\n        reject(`Cannot await open on killed process.`)\n      }\n\n      // Abort on errors while spawning.\n      const onError = (error?: Error): void => {\n        reject(error)\n      }\n\n      // Handle successful spawn event.\n      const onSpawn = (): void => {\n        // Remove abort listener.\n        childProcess.removeListener(PROCESS_ERROR_EVENT, onError)\n\n        // Once process is spawned, convert to observable.\n        resolve()\n      }\n\n      // Bind listeners.\n      childProcess.once(PROCESS_ERROR_EVENT, onError)\n      childProcess.once(PROCESS_SPAWN_EVENT, onSpawn)\n\n      // If a timeout was requested, abort if reached.\n      if (timeout) {\n        setTimeout(() => {\n          const error: Error = new OpenTimeoutError(\n            command ?? childProcess.pid,\n            timeout\n          )\n          console.warn(error.message)\n          reject(error)\n        }, timeout)\n      }\n    })\n","import EventEmitter from \"node:events\"\nimport { defer } from \"@nodesuite/defer\"\nimport type { Deferral } from \"@nodesuite/defer\"\n\nimport { ProcessNotAvailableError } from \"../errors\"\nimport { PROCESS_CLOSE_EVENT, PROCESS_OPEN_EVENT } from \"../types\"\nimport type { ChildProcess } from \"../types\"\n\n/**\n * Abstract utility wrapper for building process-based classes.\n *\n * @remarks\n * Inheritors should implement own \"open\" and \"close\" logic which is provided to\n * the \"setOpen\" and \"setClose\" handlers.\n *\n * Importantly, to release the opener and closer promises, the \"open\" and \"close\"\n * logic should emit the appropriate process event to signal ready state.\n *\n * @public\n */\nexport abstract class ProcessManager extends EventEmitter {\n  /**\n   * Static reference to the intended executable path.\n   *\n   * @internal\n   */\n  protected _command: string | undefined\n\n  /**\n   * Internal child process.\n   *\n   * @internal\n   */\n  protected _process: ChildProcess | undefined\n\n  /**\n   * Deferred promise to present if opening process has already begun.\n   *\n   * @internal\n   */\n  readonly #opener: Deferral = defer()\n\n  /**\n   * Deferred promise to present if closing process has already begun.\n   *\n   * @internal\n   */\n  readonly #closer: Deferral = defer()\n\n  /**\n   * Flag to avoid multiple open.\n   *\n   * @internal\n   */\n  #isOpening: boolean = false\n\n  /**\n   * Flag to avoid multiple closes.\n   *\n   * @internal\n   */\n  #isClosing: boolean = false\n\n  /**\n   * Access the executable path of the underlying child process.\n   *\n   * @public\n   */\n  public get command(): string | undefined {\n    return this._command\n  }\n\n  /**\n   * The process id of the internal child process.\n   *\n   * @public\n   */\n  public get pid(): number | undefined {\n    return this.process().pid\n  }\n\n  /**\n   * Expose the internal child process and assert ready state.\n   *\n   * @public\n   */\n  public process(): ChildProcess {\n    if (!this._process) {\n      throw new ProcessNotAvailableError(this.command)\n    }\n    return this._process\n  }\n\n  /**\n   * Awaits the deferred close event.\n   *\n   * @public\n   */\n  public untilClose(): Promise<void> {\n    return this.#closer.untilResolved()\n  }\n\n  /**\n   * Returns an existing open or sets an opening state.\n   *\n   * @remarks\n   * This is used to stack duplicate open calls into the single promise.\n   *\n   * @internal\n   */\n  protected _setOpen(open: () => Promise<void>): Promise<void> | undefined {\n    if (this.#isOpening) {\n      return this.#opener.promise\n    } else {\n      this.once(PROCESS_OPEN_EVENT, () => this.#opener.resolve())\n      return open()\n    }\n  }\n\n  /**\n   * Returns an existing close or sets a closing state.\n   *\n   * @remarks\n   * This is used to stack duplicate close calls into the single promise.\n   *\n   * @internal\n   */\n  protected _setClose(close: () => Promise<void>): Promise<void> | undefined {\n    if (this.#isClosing) {\n      return this.#closer.promise\n    } else {\n      this.once(PROCESS_CLOSE_EVENT, () => this.#closer.resolve())\n      return close()\n    }\n  }\n\n  /**\n   * Completes the opening process if started.\n   *\n   * @internal\n   */\n  protected _completeOpen(): void {\n    if (this._process) {\n      this.emit(PROCESS_OPEN_EVENT)\n      this.#opener.resolve()\n    } else {\n      throw new ProcessNotAvailableError(this.command)\n    }\n  }\n\n  /**\n   * Completes the closing process if started.\n   *\n   * @internal\n   */\n  protected _completeClose(): void {\n    if (this._process) {\n      this._process.timer.stop()\n      this.emit(PROCESS_CLOSE_EVENT)\n      this.#closer.resolve()\n      this._process.removeAllListeners()\n      this.removeAllListeners()\n    } else {\n      throw new ProcessNotAvailableError(this.command)\n    }\n  }\n}\n","import { configure, nodeSpawn } from \"../support\"\nimport { SPAWN } from \"../types\"\nimport { manage } from \"./manage\"\nimport type {\n  ChildProcess,\n  ExecutionMethod,\n  ProcessConfig,\n  SpawnOptions\n} from \"../types\"\n\n/**\n * Spawns an observable child process and awaits a ready state.\n *\n * @remarks\n * Optionally attaches hooks to any valid child process event.\n * Automatically injects process.env into env options.\n * Forked processes \"inherit\" stdio rather than \"pipe\" as default.\n * Environment variables from current process are injected through to child process.\n *\n * @public\n */\nexport const spawn = async (\n  command: string,\n  args: string[] = [],\n  options: SpawnOptions = {}\n): Promise<ChildProcess> => {\n  // Configure args and options.\n  const config: ProcessConfig<SpawnOptions> = configure({ args, options })\n  const method: ExecutionMethod = SPAWN\n  const filters: string[] = options.filters ?? []\n\n  // Spawn a new child process.\n  const childProcess: ChildProcess = manage(\n    nodeSpawn(command, config.args, config.options),\n    {\n      command,\n      method,\n      filters\n    }\n  )\n\n  // Await completed spawn event.\n  await childProcess.untilOpen()\n\n  return childProcess\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/errors/message-timeout.error.ts","../src/errors/open-timeout.error.ts","../src/errors/process-configuration.error.ts","../src/errors/process-execution.error.ts","../src/errors/process-not-available.error.ts","../src/errors/process-spawn.error.ts","../src/errors/process-termination.error.ts","../src/support/configure.ts","../src/support/delay.ts","../src/support/vendor.ts","../src/core/exec.ts","../src/types/events.ts","../src/types/methods.ts","../src/types/serializable.ts","../src/types/signals.ts","../src/types/states.ts","../src/types/stdio.ts","../src/types/vendor.ts","../src/core/kill.ts","../src/core/manage.ts","../src/promises/close.ts","../src/promises/message.ts","../src/promises/open.ts","../src/core/manager.ts","../src/core/spawn.ts"],"names":["MessageTimeoutError","command","timeout","OpenTimeoutError","ProcessConfigurationError","config","error","ProcessExecutionError","stderr","ProcessNotAvailableError","ProcessSpawnError","ProcessTerminationError","configure","parseArgs","args","value","mergeEnv","env","parseOptions","stdio","options","delay","ms","resolve","exec","fork","spawn","promisify","nodeExec","nodeSpawn","nodeFork","stdout","PROCESS_CLOSE_EVENT","PROCESS_DATA_EVENT","PROCESS_DISCONNECT_EVENT","PROCESS_ERROR_EVENT","PROCESS_EXIT_EVENT","PROCESS_MESSAGE_EVENT","PROCESS_OPEN_EVENT","PROCESS_SPAWN_EVENT","processEvents","closeEvents","EXEC","SPAWN","FORK","KILL","executionMethods","STRING_TYPE","OBJECT_TYPE","NUMBER_TYPE","BOOLEAN_TYPE","BIGINT_TYPE","serializableTypes","SIGALRM","SIGBUS","SIGCHLD","SIGCONT","SIGFPE","SIGHUP","SIGILL","SIGINT","SIGIO","SIGIOT","SIGKILL","SIGPIPE","SIGPOLL","SIGPROF","SIGPWR","SIGQUIT","SIGSEGV","SIGSTKFLT","SIGSTOP","SIGSYS","SIGTERM","SIGTRAP","SIGTSTP","SIGTTIN","SIGTTOU","SIGUNUSED","SIGURG","SIGUSR1","SIGUSR2","SIGVTALRM","SIGWINCH","SIGXCPU","SIGXFSZ","SIGBREAK","SIGLOST","SIGINFO","signals","PROCESS_OPENING_STATE","PROCESS_OPENED_STATE","PROCESS_CLOSING_STATE","PROCESS_CLOSED_STATE","processStates","IO_OVERLAPPED","IO_PIPE","IO_IGNORE","IO_INHERIT","IO_IPC","ioTypes","STDIN","STDOUT","STDERR","STDIO","inputTypes","outputTypes","isProcessError","kill","childProcess","event","signal","i","reject","Timer","promisifyClose","code","promisifyMessage","validate","_a","_b","timer","onClose","onError","onData","data","message","promisifyOpen","onSpawn","manage","nativeChildProcess","method","filters","filter","onStdout","onStderr","EventEmitter","defer","ProcessManager","#opener","#closer","#isOpening","#isClosing","open","close"],"mappings":"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,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACF,EAAI,CACF,UACA,SACA,UACA,UACA,SACA,SACA,SACA,SACA,QACA,SACA,UACA,UACA,UACA,UACA,SACA,UACA,UACA,YACA,UACA,SACA,UACA,UACA,UACA,UACA,UACA,YACA,SACA,UACA,UACA,YACA,WACA,UACA,UACA,WACA,UACA,SACF,EAEaC,GAAsC,CACjDpC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACF,ECjHO,GAAM,CACXE,EACAC,EACAC,GACAC,CACF,EAAI,CAAC,UAAW,SAAU,UAAW,QAAQ,EAEhCC,GAAgB,CAC3BJ,EACAC,EACAC,GACAC,CACF,ECTO,GAAM,CAACE,GAAeC,GAASC,GAAWC,GAAYC,EAAM,EAAI,CACrE,aACA,OACA,SACA,UACA,KACF,EAKaC,GAAU,CACrBL,GACAC,GACAC,GACAC,GACAC,EACF,EAUa,CAACE,GAAOC,GAAQC,GAAQC,EAAK,EAAI,CAC5C,QACA,SACA,SACA,OACF,EAKaC,GAAa,CAACJ,EAAK,EAKnBK,GAAc,CAACJ,GAAQC,EAAM,EC6BnC,IAAMI,GAAkBrG,GAC7B,OAAOA,GAAU,UAAY,CAAC,CAACA,GAAS,OAAO,KAAKA,CAAK,EAAE,SAAS,KAAK,EC9DpE,IAAMsG,GAAO,MAClBC,EACAzF,EAAgC,CAAC,IACf,CAClB,GAAI,CACF,GAAM,CAAE,QAAAlB,EAAS,MAAA4G,EAAO,OAAAC,CAAO,EAAiB,CAC9C,QAAS,IACT,MAAO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","sourcesContent":["/**\n * Throws when an awaited message does not return from child process within given timeout.\n *\n * @public\n */\nexport class MessageTimeoutError extends Error {\n  public readonly command: string | number | undefined\n  public readonly timeout: number\n\n  public constructor(command: string | number | undefined, timeout: number) {\n    super(\n      `Message listener on child process \"${command}\" timed out after ${timeout}ms.`\n    )\n    this.command = command\n    this.timeout = timeout\n  }\n}\n","/**\n * Throws when a child process does not open within given timeout.\n *\n * @public\n */\nexport class OpenTimeoutError extends Error {\n  public readonly command: string | number | undefined\n  public readonly timeout: number\n\n  public constructor(command: string | number | undefined, timeout: number) {\n    super(\n      `Open state listener on child process \"${command}\" timed out after ${timeout}ms.`\n    )\n    this.command = command\n    this.timeout = timeout\n  }\n}\n","import type { Options, ProcessConfig } from \"../types\"\n\nexport class ProcessConfigurationError extends Error {\n  public readonly config: Partial<ProcessConfig<Options>>\n\n  public constructor(config: Partial<ProcessConfig<Options>>, error: Error) {\n    super(\n      `Encountered an error while configuring child process: ${JSON.stringify(\n        config\n      )}`,\n      {\n        cause: error\n      }\n    )\n    this.config = config\n  }\n}\n","export class ProcessExecutionError extends Error {\n  public readonly command: string\n\n  public constructor(command: string, stderr?: string) {\n    super(`Encountered an error executing child process ${command}: ${stderr}`)\n    this.command = command\n  }\n}\n","export class ProcessNotAvailableError extends Error {\n  public readonly command: string\n\n  public constructor(command: string = \"at unspecified executable path\") {\n    super(`Encountered an error spawning child process ${command}.`)\n    this.command = command\n  }\n}\n","export class ProcessSpawnError extends Error {\n  public readonly command: string\n\n  public constructor(command: string, stderr?: string) {\n    super(`Encountered an error spawning child process ${command}: ${stderr}`)\n    this.command = command\n  }\n}\n","export class ProcessTerminationError extends Error {\n  public readonly command: string | undefined\n  public readonly error: Error\n\n  public constructor(command: string | undefined, error: Error) {\n    super(\n      `Encountered an error killing child process ${command}: ${error.message}`,\n      { cause: error }\n    )\n    this.command = command\n    this.error = error\n  }\n}\n","import { ProcessConfigurationError } from \"../errors\"\nimport type {\n  ExecOptions,\n  ForkOptions,\n  ProcessConfig,\n  ProcessEnv,\n  SpawnOptions\n} from \"../types\"\n\n/**\n * Prepares child process arguments and options prior to execution.\n *\n * @param config - User input as configuration object.\n *\n * @internal\n */\nexport const configure = <O extends SpawnOptions | ForkOptions | ExecOptions>(\n  config: ProcessConfig<O>\n): ProcessConfig<O> => {\n  try {\n    // Strips empty elements and trims args array.\n    const parseArgs = (command: string = \"\", args: string[] = []): string[] => [\n      ...[command, ...args]\n        .map((value: string) => value.trim())\n        .filter((value) => !!value)\n    ]\n\n    // Merges environment variables from current process with any provided by child process options.\n    const mergeEnv = (env: ProcessEnv = {}): ProcessEnv => ({\n      ...process.env,\n      ...env\n    })\n\n    // Merges process options with current environment variables.\n    const parseOptions = <O extends SpawnOptions | ForkOptions | ExecOptions>({\n      stdio,\n      ...options\n    }: O): O =>\n      ({\n        ...options,\n        stdio: stdio ?? [process.stdin, \"pipe\", \"pipe\"],\n        env: mergeEnv(options.env)\n      } as O)\n\n    const args: string[] = parseArgs(config.command, config.args)\n    const options: O = parseOptions(config.options)\n\n    return {\n      args,\n      options\n    }\n  } catch (error) {\n    throw new ProcessConfigurationError(config, error as Error)\n  }\n}\n","/**\n * Simple timeout function.\n *\n * @param ms - Number of milliseconds to wait.\n *\n * @internal\n */\nexport const delay = (ms: number): Promise<void> =>\n  new Promise<void>((resolve) => setTimeout(resolve, ms))\n","import { exec, fork, spawn } from \"node:child_process\"\nimport { promisify } from \"node:util\"\n\nimport type { NodeExec, NodeFork, NodeSpawn } from \"../types\"\n\n/**\n * Promisified Node exec method.\n *\n * @internal\n */\nexport const nodeExec: NodeExec = promisify(exec)\n\n/**\n * Original node spawn method.\n *\n * @internal\n */\nexport const nodeSpawn: NodeSpawn = spawn\n\n/**\n * Original node fork method.\n *\n * @internal\n */\nexport const nodeFork: NodeFork = fork\n","import { ProcessExecutionError } from \"../errors\"\nimport { configure, nodeExec } from \"../support\"\nimport type { ExecOptions, ProcessConfig } from \"../types\"\n\n/**\n * Provide async child process executor.\n *\n * @remarks\n * Throws error on `stderr` output unless suppressed.\n * If process is long-running, do not await the Promise.\n * Environment variables from current process are injected through to child process.\n *\n * @public\n */\nexport const exec = async (\n  command: string,\n  args: string[] = [],\n  options: ExecOptions = {}\n): Promise<string> => {\n  // Configure args and options.\n  const config: ProcessConfig<ExecOptions> = configure({\n    command,\n    args,\n    options\n  })\n\n  // Await child process execution.\n  const { stdout, stderr } = await nodeExec(\n    config.args.join(` `),\n    config.options\n  )\n\n  // Check stderr for any error messages.\n  if (stderr) {\n    throw new ProcessExecutionError(command, stderr)\n  }\n\n  // Return stdout.\n  return stdout ?? \"\"\n}\n","/**\n * @public\n */\nexport const [\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_DISCONNECT_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_EXIT_EVENT,\n  PROCESS_MESSAGE_EVENT,\n  PROCESS_OPEN_EVENT,\n  PROCESS_SPAWN_EVENT\n] = [\n  \"close\",\n  \"data\",\n  \"disconnect\",\n  \"error\",\n  \"exit\",\n  \"message\",\n  \"open\",\n  \"spawn\"\n] as const\n\n/**\n * @public\n */\nexport const processEvents = [\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_DISCONNECT_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_EXIT_EVENT,\n  PROCESS_MESSAGE_EVENT,\n  PROCESS_OPEN_EVENT,\n  PROCESS_SPAWN_EVENT\n] as const\n\n/**\n * @public\n */\nexport type ProcessEvent = typeof processEvents[number]\n\n/**\n * @public\n */\nexport const closeEvents = [PROCESS_CLOSE_EVENT, PROCESS_EXIT_EVENT] as const\n\n/**\n * @public\n */\nexport type CloseEvent = typeof closeEvents[number]\n","/**\n * @public\n */\nexport const [EXEC, SPAWN, FORK, KILL] = [\n  \"exec\",\n  \"spawn\",\n  \"fork\",\n  \"kill\"\n] as const\n\n/**\n * @public\n */\nexport const executionMethods = [EXEC, SPAWN, FORK, KILL] as const\n\n/**\n * @public\n */\nexport type ExecutionMethod = typeof executionMethods[number]\n","/**\n * @internal\n */\nexport const [\n  STRING_TYPE,\n  OBJECT_TYPE,\n  NUMBER_TYPE,\n  BOOLEAN_TYPE,\n  BIGINT_TYPE\n] = [\"string\", \"object\", \"number\", \"boolean\", \"bigint\"] as const\n\n/**\n * @internal\n */\nexport const serializableTypes = [\n  STRING_TYPE,\n  OBJECT_TYPE,\n  NUMBER_TYPE,\n  BOOLEAN_TYPE,\n  BIGINT_TYPE\n] as const\n\n/**\n * @internal\n */\nexport type SerializableType = typeof serializableTypes[number]\n\n/**\n * @internal\n */\nexport interface SerializableTypes {\n  string: string\n  object: object\n  number: number\n  boolean: boolean\n  bigint: boolean\n}\n","export const [\n  SIGALRM,\n  SIGBUS,\n  SIGCHLD,\n  SIGCONT,\n  SIGFPE,\n  SIGHUP,\n  SIGILL,\n  SIGINT,\n  SIGIO,\n  SIGIOT,\n  SIGKILL,\n  SIGPIPE,\n  SIGPOLL,\n  SIGPROF,\n  SIGPWR,\n  SIGQUIT,\n  SIGSEGV,\n  SIGSTKFLT,\n  SIGSTOP,\n  SIGSYS,\n  SIGTERM,\n  SIGTRAP,\n  SIGTSTP,\n  SIGTTIN,\n  SIGTTOU,\n  SIGUNUSED,\n  SIGURG,\n  SIGUSR1,\n  SIGUSR2,\n  SIGVTALRM,\n  SIGWINCH,\n  SIGXCPU,\n  SIGXFSZ,\n  SIGBREAK,\n  SIGLOST,\n  SIGINFO\n] = [\n  \"SIGALRM\",\n  \"SIGBUS\",\n  \"SIGCHLD\",\n  \"SIGCONT\",\n  \"SIGFPE\",\n  \"SIGHUP\",\n  \"SIGILL\",\n  \"SIGINT\",\n  \"SIGIO\",\n  \"SIGIOT\",\n  \"SIGKILL\",\n  \"SIGPIPE\",\n  \"SIGPOLL\",\n  \"SIGPROF\",\n  \"SIGPWR\",\n  \"SIGQUIT\",\n  \"SIGSEGV\",\n  \"SIGSTKFLT\",\n  \"SIGSTOP\",\n  \"SIGSYS\",\n  \"SIGTERM\",\n  \"SIGTRAP\",\n  \"SIGTSTP\",\n  \"SIGTTIN\",\n  \"SIGTTOU\",\n  \"SIGUNUSED\",\n  \"SIGURG\",\n  \"SIGUSR1\",\n  \"SIGUSR2\",\n  \"SIGVTALRM\",\n  \"SIGWINCH\",\n  \"SIGXCPU\",\n  \"SIGXFSZ\",\n  \"SIGBREAK\",\n  \"SIGLOST\",\n  \"SIGINFO\"\n] as const\n\nexport const signals: Readonly<NodeJS.Signals[]> = [\n  SIGALRM,\n  SIGBUS,\n  SIGCHLD,\n  SIGCONT,\n  SIGFPE,\n  SIGHUP,\n  SIGILL,\n  SIGINT,\n  SIGIO,\n  SIGIOT,\n  SIGKILL,\n  SIGPIPE,\n  SIGPOLL,\n  SIGPROF,\n  SIGPWR,\n  SIGQUIT,\n  SIGSEGV,\n  SIGSTKFLT,\n  SIGSTOP,\n  SIGSYS,\n  SIGTERM,\n  SIGTRAP,\n  SIGTSTP,\n  SIGTTIN,\n  SIGTTOU,\n  SIGUNUSED,\n  SIGURG,\n  SIGUSR1,\n  SIGUSR2,\n  SIGVTALRM,\n  SIGWINCH,\n  SIGXCPU,\n  SIGXFSZ,\n  SIGBREAK,\n  SIGLOST,\n  SIGINFO\n] as const\n\nexport type Signal = typeof signals[number]\n","export const [\n  PROCESS_OPENING_STATE,\n  PROCESS_OPENED_STATE,\n  PROCESS_CLOSING_STATE,\n  PROCESS_CLOSED_STATE\n] = [\"opening\", \"opened\", \"closing\", \"closed\"] as const\n\nexport const processStates = [\n  PROCESS_OPENING_STATE,\n  PROCESS_OPENED_STATE,\n  PROCESS_CLOSING_STATE,\n  PROCESS_CLOSED_STATE\n] as const\n\nexport type ProcessState = typeof processStates[number]\n","/**\n * @public\n */\nexport const [IO_OVERLAPPED, IO_PIPE, IO_IGNORE, IO_INHERIT, IO_IPC] = [\n  \"overlapped\",\n  \"pipe\",\n  \"ignore\",\n  \"inherit\",\n  \"ipc\"\n] as const\n\n/**\n * @public\n */\nexport const ioTypes = [\n  IO_OVERLAPPED,\n  IO_PIPE,\n  IO_IGNORE,\n  IO_INHERIT,\n  IO_IPC\n] as const\n\n/**\n * @public\n */\nexport type IOType = typeof ioTypes[number]\n\n/**\n * @public\n */\nexport const [STDIN, STDOUT, STDERR, STDIO] = [\n  \"stdin\",\n  \"stdout\",\n  \"stderr\",\n  \"stdio\"\n] as const\n\n/**\n * @public\n */\nexport const inputTypes = [STDIN]\n\n/**\n * @public\n */\nexport const outputTypes = [STDOUT, STDERR]\n\n/**\n * @public\n */\nexport type InputType = typeof inputTypes[number]\n\n/**\n * @public\n */\nexport type OutputType = typeof outputTypes[number]\n","import type Node from \"node:child_process\"\n\nimport type { STDERR, STDOUT } from \"./stdio\"\n\nexport type NodeChildProcess = Node.ChildProcess\n\nexport type NodeExecOptions = Node.ExecOptions\nexport type NodeSpawnOptions = Node.SpawnOptions\nexport type NodeForkOptions = Node.ForkOptions\nexport type NodeStdioOptions = Node.StdioOptions\n\nexport type Serializable = string | object | number | boolean | bigint\n\n/**\n * String output from child process execution.\n *\n * @public\n */\nexport interface ProcessResult {\n  [STDOUT]?: string\n  [STDERR]?: string\n}\n\n/**\n * Common process.env values.\n *\n * @public\n */\nexport interface ProcessEnv {\n  TZ?: string\n  NODE_ENV?: \"development\" | \"test\" | \"production\"\n\n  [key: string]: string | undefined\n}\n\n/**\n * NodeJS \"exec\" command.\n *\n * @public\n */\nexport type NodeExec = (\n  command: string,\n  options: NodeExecOptions\n) => Promise<ProcessResult>\n\n/**\n * NodeJS \"spawn\" command.\n *\n * @public\n */\nexport type NodeSpawn = (\n  command: string,\n  args: ReadonlyArray<string>,\n  options: NodeSpawnOptions\n) => NodeChildProcess\n\n/**\n * NodeJS \"fork\" command.\n *\n * @public\n */\nexport type NodeFork = (\n  command: string,\n  args: ReadonlyArray<string>,\n  options: NodeForkOptions\n) => NodeChildProcess\n\n/**\n * Type guard to determine if a value is a valid process error.\n *\n * @param error - Possible error value to test.\n *\n * @public\n */\nexport const isProcessError = (error: unknown): error is Node.ExecException =>\n  typeof error === \"object\" && !!error && Object.keys(error).includes(\"cmd\")\n","import { ProcessTerminationError } from \"../errors\"\nimport { delay } from \"../support\"\nimport { PROCESS_ERROR_EVENT, PROCESS_EXIT_EVENT, SIGTERM } from \"../types\"\nimport type { ChildProcess, KillOptions } from \"../types\"\n\n/**\n * Terminates a child childProcess and awaits for a closed state.\n *\n * @remarks\n * Removes any listeners attached to the childProcess.\n *\n * @public\n */\nexport const kill = async (\n  childProcess: ChildProcess,\n  options: Partial<KillOptions> = {}\n): Promise<void> => {\n  try {\n    const { timeout, event, signal }: KillOptions = {\n      timeout: 5000,\n      event: PROCESS_EXIT_EVENT,\n      signal: SIGTERM,\n      ...options\n    }\n\n    // If process already killed, terminate immediately.\n    if (childProcess.killed) {\n      return\n    }\n\n    // If already awaiting a kill event, return previous promise race.\n    if (childProcess.killing) {\n      return Promise.race([childProcess.killing, delay(timeout)])\n    }\n\n    // Attach the first kill race.\n    childProcess.killing = Promise.race([\n      new Promise<void>((resolve) => {\n        // Poll for a killed in case event is already triggered.\n        for (let i: number = 0; i < 100; i++) {\n          if (childProcess.killed) {\n            resolve()\n          }\n        }\n      }),\n      new Promise<void>((resolve, reject) => {\n        // Await close or exit event before resolving.\n        childProcess.once(event, () => {\n          resolve()\n        })\n\n        // Abort early if an error occurs.\n        childProcess.once(PROCESS_ERROR_EVENT, () => {\n          reject()\n        })\n\n        // Send termination signal.\n        childProcess.kill(signal)\n\n        // Resolve if process is already terminated by the time listeners are attached.\n        if (childProcess.killed) {\n          resolve()\n        }\n      }),\n      delay(timeout)\n    ])\n\n    await childProcess.killing\n\n    // Removes all listeners after termination.\n    childProcess.removeAllListeners()\n  } catch (error) {\n    throw new ProcessTerminationError(childProcess.command, error as Error)\n  }\n}\n","import { Timer } from \"@nodesuite/timer\"\nimport type { PerformanceTimer } from \"@nodesuite/timer\"\n\nimport { promisifyClose, promisifyMessage, promisifyOpen } from \"../promises\"\nimport {\n  PROCESS_CLOSE_EVENT,\n  PROCESS_CLOSED_STATE,\n  PROCESS_DATA_EVENT,\n  PROCESS_ERROR_EVENT,\n  PROCESS_OPENED_STATE,\n  PROCESS_OPENING_STATE,\n  PROCESS_SPAWN_EVENT,\n  SIGTERM\n} from \"../types\"\nimport type { ChildProcess, NodeChildProcess } from \"../types\"\n\n/**\n * Utility function to append several management tools to a spawned or forked process.\n *\n * @remarks\n * This function should not be called directly, only indirectly via `spawn` or `fork`.\n *\n * @param nativeChildProcess - Native child process to augment.\n * @param command - Command name or executable path called by `spawn` or `fork`.\n * @param method - Execution method (`spawn`, `fork`) used to spawn the process.\n * @param filters - String filters used to reduce stdout and stderr noise.\n *\n * @internal\n */\nexport const manage = (\n  nativeChildProcess: NodeChildProcess,\n  {\n    command,\n    method,\n    filters\n  }: Pick<ChildProcess, \"command\" | \"method\" | \"filters\">\n): ChildProcess => {\n  // Initialize a timer to track duration.\n  const timer: PerformanceTimer = new Timer()\n\n  // Attach the additional \"management\" properties to the base child process.\n  const childProcess: ChildProcess = Object.assign(nativeChildProcess, {\n    command,\n    method,\n    timer,\n    filters,\n    killing: undefined,\n    state: PROCESS_OPENING_STATE,\n    untilOpen: promisifyOpen(nativeChildProcess, command),\n    untilClose: promisifyClose(nativeChildProcess),\n    untilMessage: promisifyMessage(nativeChildProcess, command)\n  })\n\n  // Change state and notify debugger on state changes.\n\n  childProcess.once(PROCESS_SPAWN_EVENT, () => {\n    childProcess.state = PROCESS_OPENED_STATE\n    console.debug(`Process \"${command}\" opened.`)\n  })\n\n  childProcess.once(PROCESS_CLOSE_EVENT, () => {\n    childProcess.state = PROCESS_CLOSED_STATE\n    console.debug(`Process \"${command}\" closed.`)\n  })\n\n  childProcess.on(PROCESS_ERROR_EVENT, (error: Error) => {\n    console.debug(`Process \"${command}\" error: ${error.message}`)\n    if (!childProcess.killed) {\n      childProcess.kill(SIGTERM)\n    }\n  })\n\n  const filter = (data: Buffer): string | undefined => {\n    const message: string = data.toString().trim()\n    return !childProcess.filters ||\n      childProcess.filters.every((filter) => !message.includes(filter))\n      ? message\n      : undefined\n  }\n\n  const onStdout = (data: Buffer): void => {\n    const message: string | undefined = filter(data)\n    if (message) {\n      process.stdout.write(`${message}\\n`)\n    }\n  }\n\n  const onStderr = (data: Buffer): void => {\n    const message: string | undefined = filter(data)\n    if (message) {\n      process.stderr.write(`${message}\\n`)\n    }\n  }\n\n  if (childProcess.stdout) {\n    childProcess.stdout.on(PROCESS_DATA_EVENT, onStdout)\n  }\n\n  if (childProcess.stderr) {\n    childProcess.stderr.on(PROCESS_DATA_EVENT, onStderr)\n  }\n\n  return childProcess\n}\n","import { PROCESS_CLOSE_EVENT, PROCESS_ERROR_EVENT } from \"../types\"\nimport type { CloseReason, NodeChildProcess, Signal } from \"../types\"\n\n/**\n * Awaits a close event from a specified child process.\n *\n * @param childProcess - Spawned child process to monitor.\n *\n * @internal\n */\nexport const promisifyClose =\n  (childProcess: NodeChildProcess) => (): Promise<CloseReason> =>\n    new Promise<CloseReason>((resolve, reject) => {\n      // If process already killed, resolve immediately.\n      if (childProcess.killed) {\n        resolve({\n          code: undefined,\n          signal: childProcess.signalCode ?? undefined\n        })\n      }\n\n      // Listen for close event and resolve with payload.\n      childProcess.once(\n        PROCESS_CLOSE_EVENT,\n        (code: number | undefined, signal: Signal | undefined) => {\n          resolve({\n            code,\n            signal\n          })\n        }\n      )\n\n      // Abort on errors.\n      childProcess.once(PROCESS_ERROR_EVENT, (error: Error) => {\n        reject({\n          error\n        })\n      })\n    })\n","import { MessageTimeoutError } from \"../errors\"\nimport {\n  PROCESS_CLOSE_EVENT,\n  PROCESS_DATA_EVENT,\n  PROCESS_ERROR_EVENT\n} from \"../types\"\nimport type { NodeChildProcess, Signal, Validate } from \"../types\"\n\n/**\n * Awaits a specific message event from a specified child process.\n *\n * @remarks\n * Has a default timeout of 90s.\n *\n * @param childProcess - Spawned child process to monitor.\n * @param command - Optional name of command for debugging.\n *\n * @internal\n */\nexport const promisifyMessage =\n  (childProcess: NodeChildProcess, command?: string) =>\n  (validate: Validate, timeout: number = 90000): Promise<string> =>\n    new Promise((resolve, reject) => {\n      // If a timeout was requested, start a timer to reject promise if reached.\n      const timer: NodeJS.Timer = setTimeout(() => {\n        const error: Error = new MessageTimeoutError(\n          command ?? childProcess.pid,\n          timeout\n        )\n        console.warn(error.message)\n        reject(error)\n      }, timeout)\n\n      // Abort observer if process closes before a match is found.\n      const onClose = (\n        code: number | undefined,\n        signal: Signal | undefined\n      ): void => {\n        reject({ code, signal })\n      }\n\n      // Abort observer if process errors before a match is found.\n      const onError = (error: Error): void => {\n        reject({\n          error\n        })\n      }\n\n      // Search messages based on validation function.\n      // We must remove this listener upon resolution to avoid memory leaks.\n      const onData = (data: Buffer): void => {\n        const message: string = data.toString().trim()\n\n        if (!validate(message)) {\n          return\n        }\n\n        // Clear the rejection timeout.\n        clearTimeout(timer)\n\n        console.debug(`Matched awaited message from child process.`, message)\n\n        childProcess.stdout?.off(PROCESS_DATA_EVENT, onData)\n        childProcess.stderr?.off(PROCESS_DATA_EVENT, onData)\n\n        childProcess.off(PROCESS_CLOSE_EVENT, onClose)\n        childProcess.off(PROCESS_ERROR_EVENT, onError)\n\n        resolve(message)\n      }\n\n      childProcess.stdout?.on(PROCESS_DATA_EVENT, onData)\n      childProcess.stderr?.on(PROCESS_DATA_EVENT, onData)\n\n      childProcess.once(PROCESS_CLOSE_EVENT, onClose)\n      childProcess.once(PROCESS_ERROR_EVENT, onError)\n    })\n","import { OpenTimeoutError } from \"../errors\"\nimport { PROCESS_ERROR_EVENT, PROCESS_SPAWN_EVENT } from \"../types\"\nimport type { NodeChildProcess } from \"../types\"\n\n/**\n * Awaits a `spawn` event from a specified child process.\n *\n * @param childProcess - Spawned child process to monitor.\n * @param command - Optional name of command for debugging.\n *\n * @internal\n */\nexport const promisifyOpen =\n  (childProcess: NodeChildProcess, command?: string) =>\n  async (timeout?: number): Promise<void> =>\n    new Promise<void>((resolve, reject) => {\n      // If process already open, return immediately.\n      if (childProcess.pid) {\n        resolve()\n      }\n\n      // Do not await killed processes.\n      if (childProcess.killed) {\n        reject(`Cannot await open on killed process.`)\n      }\n\n      // Abort on errors while spawning.\n      const onError = (error?: Error): void => {\n        reject(error)\n      }\n\n      // Handle successful spawn event.\n      const onSpawn = (): void => {\n        // Remove abort listener.\n        childProcess.removeListener(PROCESS_ERROR_EVENT, onError)\n\n        // Once process is spawned, convert to observable.\n        resolve()\n      }\n\n      // Bind listeners.\n      childProcess.once(PROCESS_ERROR_EVENT, onError)\n      childProcess.once(PROCESS_SPAWN_EVENT, onSpawn)\n\n      // If a timeout was requested, abort if reached.\n      if (timeout) {\n        setTimeout(() => {\n          const error: Error = new OpenTimeoutError(\n            command ?? childProcess.pid,\n            timeout\n          )\n          console.warn(error.message)\n          reject(error)\n        }, timeout)\n      }\n    })\n","import EventEmitter from \"node:events\"\nimport { defer } from \"@nodesuite/defer\"\nimport type { Deferral } from \"@nodesuite/defer\"\n\nimport { ProcessNotAvailableError } from \"../errors\"\nimport { PROCESS_CLOSE_EVENT, PROCESS_OPEN_EVENT } from \"../types\"\nimport type { ChildProcess } from \"../types\"\n\n/**\n * Abstract utility wrapper for building process-based classes.\n *\n * @remarks\n * Inheritors should implement own \"open\" and \"close\" logic which is provided to\n * the \"setOpen\" and \"setClose\" handlers.\n *\n * Importantly, to release the opener and closer promises, the \"open\" and \"close\"\n * logic should emit the appropriate process event to signal ready state.\n *\n * @public\n */\nexport abstract class ProcessManager extends EventEmitter {\n  /**\n   * Static reference to the intended executable path.\n   *\n   * @internal\n   */\n  protected _command: string | undefined\n\n  /**\n   * Internal child process.\n   *\n   * @internal\n   */\n  protected _process: ChildProcess | undefined\n\n  /**\n   * Deferred promise to present if opening process has already begun.\n   *\n   * @internal\n   */\n  readonly #opener: Deferral = defer()\n\n  /**\n   * Deferred promise to present if closing process has already begun.\n   *\n   * @internal\n   */\n  readonly #closer: Deferral = defer()\n\n  /**\n   * Flag to avoid multiple open.\n   *\n   * @internal\n   */\n  #isOpening: boolean = false\n\n  /**\n   * Flag to avoid multiple closes.\n   *\n   * @internal\n   */\n  #isClosing: boolean = false\n\n  /**\n   * Access the executable path of the underlying child process.\n   *\n   * @public\n   */\n  public get command(): string | undefined {\n    return this._command\n  }\n\n  /**\n   * The process id of the internal child process.\n   *\n   * @public\n   */\n  public get pid(): number | undefined {\n    return this.process().pid\n  }\n\n  /**\n   * Expose the internal child process and assert ready state.\n   *\n   * @public\n   */\n  public process(): ChildProcess {\n    if (!this._process) {\n      throw new ProcessNotAvailableError(this.command)\n    }\n    return this._process\n  }\n\n  /**\n   * Awaits the deferred close event.\n   *\n   * @public\n   */\n  public untilClose(): Promise<void> {\n    return this.#closer.untilResolved()\n  }\n\n  /**\n   * Returns an existing open or sets an opening state.\n   *\n   * @remarks\n   * This is used to stack duplicate open calls into the single promise.\n   *\n   * @internal\n   */\n  protected _setOpen(open: () => Promise<void>): Promise<void> | undefined {\n    if (this.#isOpening) {\n      return this.#opener.promise\n    } else {\n      this.once(PROCESS_OPEN_EVENT, () => this.#opener.resolve())\n      return open()\n    }\n  }\n\n  /**\n   * Returns an existing close or sets a closing state.\n   *\n   * @remarks\n   * This is used to stack duplicate close calls into the single promise.\n   *\n   * @internal\n   */\n  protected _setClose(close: () => Promise<void>): Promise<void> | undefined {\n    if (this.#isClosing) {\n      return this.#closer.promise\n    } else {\n      this.once(PROCESS_CLOSE_EVENT, () => this.#closer.resolve())\n      return close()\n    }\n  }\n\n  /**\n   * Completes the opening process if started.\n   *\n   * @internal\n   */\n  protected _completeOpen(): void {\n    if (this._process) {\n      this.emit(PROCESS_OPEN_EVENT)\n      this.#opener.resolve()\n    } else {\n      throw new ProcessNotAvailableError(this.command)\n    }\n  }\n\n  /**\n   * Completes the closing process if started.\n   *\n   * @internal\n   */\n  protected _completeClose(): void {\n    if (this._process) {\n      this._process.timer.stop()\n      this.emit(PROCESS_CLOSE_EVENT)\n      this.#closer.resolve()\n      this._process.removeAllListeners()\n      this.removeAllListeners()\n    } else {\n      throw new ProcessNotAvailableError(this.command)\n    }\n  }\n}\n","import { configure, nodeSpawn } from \"../support\"\nimport { SPAWN } from \"../types\"\nimport { manage } from \"./manage\"\nimport type {\n  ChildProcess,\n  ExecutionMethod,\n  ProcessConfig,\n  SpawnOptions\n} from \"../types\"\n\n/**\n * Spawns an observable child process and awaits a ready state.\n *\n * @remarks\n * Optionally attaches hooks to any valid child process event.\n * Automatically injects process.env into env options.\n * Forked processes \"inherit\" stdio rather than \"pipe\" as default.\n * Environment variables from current process are injected through to child process.\n *\n * @public\n */\nexport const spawn = async (\n  command: string,\n  args: string[] = [],\n  { filters, ...options }: SpawnOptions = {}\n): Promise<ChildProcess> => {\n  // Configure args and options.\n  const config: ProcessConfig<SpawnOptions> = configure({ args, options })\n  const method: ExecutionMethod = SPAWN\n\n  // Spawn a new child process.\n  const childProcess: ChildProcess = manage(\n    nodeSpawn(command, config.args, config.options),\n    {\n      command,\n      method,\n      filters: filters ?? []\n    }\n  )\n\n  // Await completed spawn event.\n  await childProcess.untilOpen()\n\n  return childProcess\n}\n"]}
{
"$schema": "https://json.schemastore.org/package",
"name": "@nodesuite/process",
"version": "0.1.11",
"version": "0.1.12",
"description": "Enhanced Node child-process management.",

@@ -28,9 +28,9 @@ "keywords": [

"dependencies": {
"@nodesuite/defer": "0.1.11",
"@nodesuite/timer": "0.1.11",
"@nodesuite/defer": "0.1.12",
"@nodesuite/timer": "0.1.12",
"tslib": "^2.4.0"
},
"devDependencies": {
"@nodesuite/eslint-config": "0.1.11",
"@nodesuite/node-rig": "0.1.11",
"@nodesuite/eslint-config": "0.1.12",
"@nodesuite/node-rig": "0.1.12",
"@rushstack/eslint-config": "^3.0.1",

@@ -37,0 +37,0 @@ "@rushstack/heft": "^0.47.9",

@@ -25,3 +25,3 @@ import { configure, nodeSpawn } from "../support"

args: string[] = [],
options: SpawnOptions = {}
{ filters, ...options }: SpawnOptions = {}
): Promise<ChildProcess> => {

@@ -31,3 +31,2 @@ // Configure args and options.

const method: ExecutionMethod = SPAWN
const filters: string[] = options.filters ?? []

@@ -40,3 +39,3 @@ // Spawn a new child process.

method,
filters
filters: filters ?? []
}

@@ -43,0 +42,0 @@ )

@@ -49,3 +49,3 @@ import { MessageTimeoutError } from "../errors"

// Matching logic, generally a Zod schema or function that throws if invalid.
// Search messages based on validation function.
// We must remove this listener upon resolution to avoid memory leaks.

@@ -52,0 +52,0 @@ const onData = (data: Buffer): void => {

@@ -35,9 +35,11 @@ import { ProcessConfigurationError } from "../errors"

// Merges process options with current environment variables.
const parseOptions = <O extends SpawnOptions | ForkOptions | ExecOptions>(
options: O
): O => ({
...options,
stdio: options.stdio ?? [process.stdin, "pipe", "pipe"],
env: mergeEnv(options.env)
})
const parseOptions = <O extends SpawnOptions | ForkOptions | ExecOptions>({
stdio,
...options
}: O): O =>
({
...options,
stdio: stdio ?? [process.stdin, "pipe", "pipe"],
env: mergeEnv(options.env)
} as O)

@@ -44,0 +46,0 @@ const args: string[] = parseArgs(config.command, config.args)

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc