@nodesuite/process
Advanced tools
Comparing version 0.3.26 to 0.3.27
{ | ||
"nonCachedDurationMs": 4426.381531999999 | ||
"nonCachedDurationMs": 3511.1366249999846 | ||
} |
{ | ||
"nonCachedDurationMs": 5237.867054999995 | ||
"nonCachedDurationMs": 5348.414936000001 | ||
} |
{ | ||
"files": { | ||
"libraries/process/.rush/temp/shrinkwrap-deps.json": "cea9ddbd6e9611a412dac258221eca8f8704e1d7", | ||
"libraries/process/.rush/temp/shrinkwrap-deps.json": "b47423c76b02fabcd7150de5225e45db89bfe1db", | ||
"libraries/process/.eslintrc.js": "da8f1d5b00175fe9df49681a80b909d918ac6736", | ||
"libraries/process/CHANGELOG.json": "542aaf0cd010962d016bfa5b3373dc4254f30e6a", | ||
"libraries/process/CHANGELOG.md": "f62e1e838ef5c93626ef5f28fcf382ae06f66e2a", | ||
"libraries/process/CHANGELOG.json": "2282e52120198dd0a084642eaa097add837a1074", | ||
"libraries/process/CHANGELOG.md": "03bb63d3a967bd68aa6dce34111f46dbf6b2770f", | ||
"libraries/process/README.md": "7ccf2c0f3dd5c464ba236834650e60f378ba6bba", | ||
"libraries/process/config/rig.json": "54137d20557298060eb70cf9e72e9ce1c7b7e130", | ||
"libraries/process/package.json": "1b388e4f15c39ae5e2a7f3bc9111472163a3d466", | ||
"libraries/process/package.json": "f5552ba8f53f041d2bbe12010d6d910da4d384b9", | ||
"libraries/process/src/core/exec.ts": "914b376a510f77905337efe6633aeb53c6538731", | ||
@@ -17,9 +17,9 @@ "libraries/process/src/core/index.ts": "e02fe96e7449fd9e1d6f194a29f285c0ad68722d", | ||
"libraries/process/src/errors/index.ts": "95971b616f7de477d74b7822fad038512f9e12c9", | ||
"libraries/process/src/errors/message-timeout.error.ts": "cfd8f48f752f484aeae72aa6dd744c0b7998896e", | ||
"libraries/process/src/errors/open-timeout.error.ts": "6bd2c6596dedb4bc2a537d359a94ad31f8f4f0e2", | ||
"libraries/process/src/errors/process-configuration.error.ts": "3a58c493b48e5f95f6433341695ae002feb41e04", | ||
"libraries/process/src/errors/process-execution.error.ts": "847bc4ace4ca56b8b124af45cd066a47eeef4007", | ||
"libraries/process/src/errors/process-not-available.error.ts": "a4902534f8351f123a9642ebcfb621486e2dcee0", | ||
"libraries/process/src/errors/process-spawn.error.ts": "ca15af5a1ffc16685d6a0789389c7476738f2a3b", | ||
"libraries/process/src/errors/process-termination.error.ts": "ea6afe8549bdd2db46f820a170d0c427a1ba26da", | ||
"libraries/process/src/errors/message-timeout.error.ts": "ef7df0b63367204c38226b2d74a0270e76e09228", | ||
"libraries/process/src/errors/open-timeout.error.ts": "238445823e2ab2f1e4e7ff1d9b75116fd0ee4758", | ||
"libraries/process/src/errors/process-configuration.error.ts": "ace4de70db6920fb070a685d1412931aa9d69642", | ||
"libraries/process/src/errors/process-execution.error.ts": "eacd58cbc2bf7f743e70be08845096cadb3d9864", | ||
"libraries/process/src/errors/process-not-available.error.ts": "380574f46867a144054b648742e2e02313bee9e7", | ||
"libraries/process/src/errors/process-spawn.error.ts": "0c26b86ccb93728fa9d7cb277a55b24928cc0a39", | ||
"libraries/process/src/errors/process-termination.error.ts": "e76d7178cbc3e59a150529bbfc9c6fe6be5b6691", | ||
"libraries/process/src/index.ts": "21dcf0913ba551d5f4038d803b74b8fc0c81b08f", | ||
@@ -26,0 +26,0 @@ "libraries/process/src/promises/close.ts": "1f712029498d20c2102a4a184de2625c42c57a71", |
{ | ||
"files": { | ||
"libraries/process/.rush/temp/shrinkwrap-deps.json": "cea9ddbd6e9611a412dac258221eca8f8704e1d7", | ||
"libraries/process/.rush/temp/shrinkwrap-deps.json": "b47423c76b02fabcd7150de5225e45db89bfe1db", | ||
"libraries/process/.eslintrc.js": "da8f1d5b00175fe9df49681a80b909d918ac6736", | ||
"libraries/process/CHANGELOG.json": "542aaf0cd010962d016bfa5b3373dc4254f30e6a", | ||
"libraries/process/CHANGELOG.md": "f62e1e838ef5c93626ef5f28fcf382ae06f66e2a", | ||
"libraries/process/CHANGELOG.json": "2282e52120198dd0a084642eaa097add837a1074", | ||
"libraries/process/CHANGELOG.md": "03bb63d3a967bd68aa6dce34111f46dbf6b2770f", | ||
"libraries/process/README.md": "7ccf2c0f3dd5c464ba236834650e60f378ba6bba", | ||
"libraries/process/config/rig.json": "54137d20557298060eb70cf9e72e9ce1c7b7e130", | ||
"libraries/process/package.json": "1b388e4f15c39ae5e2a7f3bc9111472163a3d466", | ||
"libraries/process/package.json": "f5552ba8f53f041d2bbe12010d6d910da4d384b9", | ||
"libraries/process/src/core/exec.ts": "914b376a510f77905337efe6633aeb53c6538731", | ||
@@ -17,9 +17,9 @@ "libraries/process/src/core/index.ts": "e02fe96e7449fd9e1d6f194a29f285c0ad68722d", | ||
"libraries/process/src/errors/index.ts": "95971b616f7de477d74b7822fad038512f9e12c9", | ||
"libraries/process/src/errors/message-timeout.error.ts": "cfd8f48f752f484aeae72aa6dd744c0b7998896e", | ||
"libraries/process/src/errors/open-timeout.error.ts": "6bd2c6596dedb4bc2a537d359a94ad31f8f4f0e2", | ||
"libraries/process/src/errors/process-configuration.error.ts": "3a58c493b48e5f95f6433341695ae002feb41e04", | ||
"libraries/process/src/errors/process-execution.error.ts": "847bc4ace4ca56b8b124af45cd066a47eeef4007", | ||
"libraries/process/src/errors/process-not-available.error.ts": "a4902534f8351f123a9642ebcfb621486e2dcee0", | ||
"libraries/process/src/errors/process-spawn.error.ts": "ca15af5a1ffc16685d6a0789389c7476738f2a3b", | ||
"libraries/process/src/errors/process-termination.error.ts": "ea6afe8549bdd2db46f820a170d0c427a1ba26da", | ||
"libraries/process/src/errors/message-timeout.error.ts": "ef7df0b63367204c38226b2d74a0270e76e09228", | ||
"libraries/process/src/errors/open-timeout.error.ts": "238445823e2ab2f1e4e7ff1d9b75116fd0ee4758", | ||
"libraries/process/src/errors/process-configuration.error.ts": "ace4de70db6920fb070a685d1412931aa9d69642", | ||
"libraries/process/src/errors/process-execution.error.ts": "eacd58cbc2bf7f743e70be08845096cadb3d9864", | ||
"libraries/process/src/errors/process-not-available.error.ts": "380574f46867a144054b648742e2e02313bee9e7", | ||
"libraries/process/src/errors/process-spawn.error.ts": "0c26b86ccb93728fa9d7cb277a55b24928cc0a39", | ||
"libraries/process/src/errors/process-termination.error.ts": "e76d7178cbc3e59a150529bbfc9c6fe6be5b6691", | ||
"libraries/process/src/index.ts": "21dcf0913ba551d5f4038d803b74b8fc0c81b08f", | ||
@@ -26,0 +26,0 @@ "libraries/process/src/promises/close.ts": "1f712029498d20c2102a4a184de2625c42c57a71", |
@@ -5,2 +5,8 @@ { | ||
{ | ||
"version": "0.3.27", | ||
"tag": "@nodesuite/process_v0.3.27", | ||
"date": "Sat, 28 Jan 2023 01:11:23 GMT", | ||
"comments": {} | ||
}, | ||
{ | ||
"version": "0.3.26", | ||
@@ -7,0 +13,0 @@ "tag": "@nodesuite/process_v0.3.26", |
# Change Log - @nodesuite/process | ||
This log was last generated on Thu, 05 Jan 2023 03:17:01 GMT and should not be manually modified. | ||
This log was last generated on Sat, 28 Jan 2023 01:11:23 GMT and should not be manually modified. | ||
## 0.3.27 | ||
Sat, 28 Jan 2023 01:11:23 GMT | ||
_Version update only_ | ||
## 0.3.26 | ||
@@ -6,0 +11,0 @@ Thu, 05 Jan 2023 03:17:01 GMT |
@@ -9,5 +9,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="",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,u]=["close","data","disconnect","error","exit","message","open","spawn"],Go=[d,E,z,c,R,j,G,u],_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,O,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,O,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:O,...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,x;let n=setTimeout(()=>{let l=new T(t??e.pid,r);console.warn(l.message),s(l);},r),p=(l,g)=>{s({code:l,signal:g});},a=l=>{s({error:l});},m=l=>{var L,A;let g=l.toString().trim();!o(g)||(clearTimeout(n),(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(g));};(S=e.stdout)==null||S.on(E,m),(x=e.stderr)==null||x.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(u,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(u,()=>{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(O);});let n=m=>{let S=m.toString().trim();return !s.filters||s.filters.every(x=>!S.includes(x))?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{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}; | ||
var T=class extends Error{constructor(o,r){super(`Message listener on child process "${o}" timed out after ${r}ms.`);this.name="MessageTimeoutError",this.command=o,this.timeout=r;}};var P=class extends Error{constructor(o,r){super(`Open state listener on child process "${o}" timed out after ${r}ms.`);this.name="OpenTimeoutError",this.command=o,this.timeout=r;}};var I=class extends Error{constructor(o,r){super(`Encountered an error while configuring child process: ${JSON.stringify(o)}`,{cause:r});this.name="ProcessConfigurationError",this.config=o;}};var y=class extends Error{constructor(o,r){super(`Encountered an error executing child process ${o}: ${r}`);this.name="ProcessExecutionError",this.command=o;}};var f=class extends Error{constructor(o="at unspecified executable path"){super(`Encountered an error spawning child process ${o}.`);this.name="ProcessNotAvailableError",this.command=o;}};var k=class extends Error{constructor(o,r){super(`Encountered an error spawning child process ${o}: ${r}`);this.name="ProcessSpawnError",this.command=o;}};var N=class extends Error{constructor(o,r){super(`Encountered an error killing child process ${o}: ${r.message}`,{cause:r});this.name="ProcessTerminationError",this.command=o,this.error=r;}};var C=e=>{try{let t=(n="",p=[])=>[...[n,...p].map(E=>E.trim()).filter(E=>!!E)],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 I(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,a,z,c,R,j,G,u]=["close","data","disconnect","error","exit","message","open","spawn"],Go=[d,a,z,c,R,j,G,u],_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,ae,Ee,le,fe,ue,Oe,xe,ge,Te,Pe,Ie,ye,O,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,ae,Ee,le,fe,ue,Oe,xe,ge,Te,Pe,Ie,ye,O,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:O,...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,x;let n=setTimeout(()=>{let l=new T(t??e.pid,r);console.warn(l.message),s(l);},r),p=(l,g)=>{s({code:l,signal:g});},E=l=>{s({error:l});},m=l=>{var L,A;let g=l.toString().trim();!o(g)||(clearTimeout(n),(L=e.stdout)==null||L.off(a,m),(A=e.stderr)==null||A.off(a,m),e.off(d,p),e.off(c,E),i(g));};(S=e.stdout)==null||S.on(a,m),(x=e.stderr)==null||x.on(a,m),e.once(d,p),e.once(c,E);});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(u,n),o&&setTimeout(()=>{let p=new P(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(u,()=>{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(O);});let n=m=>{let S=m.toString().trim();return !s.filters||s.filters.every(x=>!S.includes(x))?S:void 0},p=m=>{let S=n(m);S&&process.stdout.write(`${S} | ||
`);},E=m=>{let S=n(m);S&&process.stderr.write(`${S} | ||
`);};return s.stdout&&s.stdout.on(a,p),s.stderr&&s.stderr.on(a,E),s};var K=class extends je{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}; | ||
@@ -27,7 +27,7 @@ exports.BIGINT_TYPE = te; | ||
exports.OBJECT_TYPE = ee; | ||
exports.OpenTimeoutError = I; | ||
exports.OpenTimeoutError = P; | ||
exports.PROCESS_CLOSED_STATE = v; | ||
exports.PROCESS_CLOSE_EVENT = d; | ||
exports.PROCESS_CLOSING_STATE = Fe; | ||
exports.PROCESS_DATA_EVENT = E; | ||
exports.PROCESS_DATA_EVENT = a; | ||
exports.PROCESS_DISCONNECT_EVENT = z; | ||
@@ -41,3 +41,3 @@ exports.PROCESS_ERROR_EVENT = c; | ||
exports.PROCESS_SPAWN_EVENT = u; | ||
exports.ProcessConfigurationError = P; | ||
exports.ProcessConfigurationError = I; | ||
exports.ProcessExecutionError = y; | ||
@@ -58,4 +58,4 @@ exports.ProcessManager = K; | ||
exports.SIGINT = Se; | ||
exports.SIGIO = Ee; | ||
exports.SIGIOT = ae; | ||
exports.SIGIO = ae; | ||
exports.SIGIOT = Ee; | ||
exports.SIGKILL = le; | ||
@@ -69,4 +69,4 @@ exports.SIGLOST = De; | ||
exports.SIGSEGV = Te; | ||
exports.SIGSTKFLT = Ie; | ||
exports.SIGSTOP = Pe; | ||
exports.SIGSTKFLT = Pe; | ||
exports.SIGSTOP = Ie; | ||
exports.SIGSYS = ye; | ||
@@ -115,2 +115,2 @@ exports.SIGTERM = O; | ||
//# sourceMappingURL=out.js.map | ||
//# 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        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"]} | ||
//# 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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AU,SAAU,SAAU,UAAW,QAAQ,EAKzCC,GAAoB,CAC/BL,EACAC,GACAC,GACAC,GACAC,EACF,ECpBO,GAAM,CACXE,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,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,MAClB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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.name = \"MessageTimeoutError\"\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.name = \"OpenTimeoutError\"\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.name = \"ProcessConfigurationError\"\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.name = \"ProcessExecutionError\"\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.name = \"ProcessNotAvailableError\"\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.name = \"ProcessSpawnError\"\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.name = \"ProcessTerminationError\"\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        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.3.26", | ||
"version": "0.3.27", | ||
"description": "Enhanced Node child-process management.", | ||
@@ -29,4 +29,4 @@ "keywords": [ | ||
"tslib": "^2.4.1", | ||
"@nodesuite/defer": "0.3.26", | ||
"@nodesuite/timer": "0.3.26" | ||
"@nodesuite/defer": "0.3.27", | ||
"@nodesuite/timer": "0.3.27" | ||
}, | ||
@@ -42,3 +42,3 @@ "devDependencies": { | ||
"dpdm": "^3.10.0", | ||
"eslint": "8.22.0", | ||
"eslint": "8.32.0", | ||
"npm-check-updates": "^15.3.4", | ||
@@ -49,4 +49,4 @@ "npm-run-all": "^4.1.5", | ||
"typescript": "4.7.4", | ||
"@nodesuite/eslint-config": "0.3.26", | ||
"@nodesuite/node-rig": "0.3.26" | ||
"@nodesuite/eslint-config": "0.3.27", | ||
"@nodesuite/node-rig": "0.3.27" | ||
}, | ||
@@ -53,0 +53,0 @@ "engines": { |
@@ -14,2 +14,3 @@ /** | ||
) | ||
this.name = "MessageTimeoutError" | ||
this.command = command | ||
@@ -16,0 +17,0 @@ this.timeout = timeout |
@@ -14,2 +14,3 @@ /** | ||
) | ||
this.name = "OpenTimeoutError" | ||
this.command = command | ||
@@ -16,0 +17,0 @@ this.timeout = timeout |
@@ -15,4 +15,5 @@ import type { Options, ProcessConfig } from "../types" | ||
) | ||
this.name = "ProcessConfigurationError" | ||
this.config = config | ||
} | ||
} |
@@ -6,4 +6,5 @@ export class ProcessExecutionError extends Error { | ||
super(`Encountered an error executing child process ${command}: ${stderr}`) | ||
this.name = "ProcessExecutionError" | ||
this.command = command | ||
} | ||
} |
@@ -6,4 +6,5 @@ export class ProcessNotAvailableError extends Error { | ||
super(`Encountered an error spawning child process ${command}.`) | ||
this.name = "ProcessNotAvailableError" | ||
this.command = command | ||
} | ||
} |
@@ -6,4 +6,5 @@ export class ProcessSpawnError extends Error { | ||
super(`Encountered an error spawning child process ${command}: ${stderr}`) | ||
this.name = "ProcessSpawnError" | ||
this.command = command | ||
} | ||
} |
@@ -10,2 +10,3 @@ export class ProcessTerminationError extends Error { | ||
) | ||
this.name = "ProcessTerminationError" | ||
this.command = command | ||
@@ -12,0 +13,0 @@ this.error = error |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
268942
2789
+ Added@nodesuite/defer@0.3.27(transitive)
+ Added@nodesuite/timer@0.3.27(transitive)
- Removed@nodesuite/defer@0.3.26(transitive)
- Removed@nodesuite/timer@0.3.26(transitive)
Updated@nodesuite/defer@0.3.27
Updated@nodesuite/timer@0.3.27