@willbooster/wb 13.12.8 → 13.12.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +3 -3
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import e from"node:fs";import t from"node:path";import n from"yargs";import{hideBin as r}from"yargs/helpers";import o,{execFileSync as s,spawn as i,spawnSync as a}from"node:child_process";import{createHash as c}from"node:crypto";import l from"chalk";import{globby as d}from"globby";import{config as u}from"dotenv";import{expand as p}from"dotenv-expand";import f,{constants as h}from"node:os";import{PromisePool as m}from"minimal-promise-pool";import g from"kill-port";import w from"node:fs/promises";import{createServer as y}from"node:net";import{distance as b}from"fastest-levenshtein";const v={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV || "development">. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || NODE_ENV || "development">.',type:"boolean",default:!0},"include-root-env":{description:"Include .env files in root directory if the project is in a monorepo and --env option is not used.",type:"boolean",default:!0},"check-env":{description:"Check whether the keys of the loaded .env files are same with the given .env file.",type:"string",default:".env.example"},verbose:{description:"Whether to show verbose information",type:"boolean",alias:"v"}};const k=new Map;function A(e){const n=k.get(e);if(n)return n;const r=u({path:t.resolve(e),processEnv:{},quiet:!0}).parsed??{};return k.set(e,r),r}function P(e){return e instanceof Error&&"code"in e}function E(e,t="SIGTERM"){if(!Number.isInteger(e)||e<=0)throw new Error(`Invalid pid: ${e}`);if("win32"===process.platform)return void function(e){try{$("taskkill",["/PID",String(e),"/T","/F"],{maxBuffer:1048576,timeout:2e3})}catch(e){if(x(e))return;throw e}}(e);const n=function(e){const{stdout:t}=$("ps",["-Ao","pid=,ppid="],{maxBuffer:1048576,timeout:2e3}),n=function(e){const t=new Map;for(const n of e.split("\n")){const e=/^\s*(\d+)\s+(\d+)\s*$/.exec(n);if(!e)continue;const r=Number(e[1]),o=Number(e[2]),s=t.get(o);s?s.push(r):t.set(o,[r])}return t}(t);return function(e,t){const n=[],r=[...t.get(e)??[]];let o=0;for(;o<r.length;){const e=r[o];o+=1,n.push(e),r.push(...t.get(e)??[])}return n}(e,n)}(e),r=function(e,t){const n=t.toReversed();return n.push(e),n}(e,n);for(const e of r)S(e,t)}function S(e,t){try{process.kill(e,t)}catch(e){if(x(e))return;throw e}}function $(e,t,n){try{return{stdout:s(e,[...t],{encoding:"utf8",maxBuffer:n?.maxBuffer,timeout:n?.timeout,stdio:["ignore","pipe","pipe"]}),stderr:""}}catch(n){const r=function(e){if("object"!=typeof e||null===e||!("stderr"in e))return"";const t=e.stderr;if("string"==typeof t)return t;if(Buffer.isBuffer(t))return t.toString("utf8");return""}(n);throw new R(e,t,r,function(e){if(P(e))return e.code;if("object"==typeof e&&null!==e&&"status"in e){const t=e.status;if("number"==typeof t)return t}return}(n))}}function x(e){return!(!P(e)||"ESRCH"!==e.code)||e instanceof R&&/no such process|not found|not recognized|there is no running instance/i.test(e.stderr)}class R extends Error{constructor(e,t,n,r){super(`Command failed: ${e} ${t.join(" ")}`),this.name="CommandExecutionError",this.stderr=n,this.code=r}}async function j(e,t,n){return new Promise((r,o)=>{try{const s=i(e,t??[],n??{});s.stdout?.setEncoding?.("utf8"),s.stderr?.setEncoding?.("utf8");let a="",c="";const l=D(process.stdout,n?.omitBlankLinesWhilePrinting),d=D(process.stderr,n?.omitBlankLinesWhilePrinting);s.stdout?.on("data",e=>{a+=e,n?.printingStdout&&l.write(e)}),s.stderr?.on("data",e=>{n?.mergeOutAndError?a+=e:c+=e,n?.printingStderr&&d.write(e)});let u=!1;const p=()=>{if(!u&&s.pid){u=!0,n?.verbose&&console.info(`treeKill(${s.pid})`);try{E(s.pid)}catch(e){n?.verbose&&console.warn(`Failed to treeKill(${s.pid})`,e)}}},f="win32"===process.platform?["SIGINT","SIGTERM"]:["SIGINT","SIGTERM","SIGQUIT"],h=new Map,m=()=>{process.removeListener("beforeExit",p);for(const[e,t]of h)process.removeListener(e,t);h.clear()};if(n?.killOnExit){process.on("beforeExit",p);for(const e of f){const t=()=>{p(),m(),0===process.listenerCount(e)&&process.kill(process.pid,e)};h.set(e,t),process.on(e,t)}}s.on("error",e=>{m(),s.removeAllListeners("close"),o(e)}),s.on("close",(e,t)=>{m(),l.flush(),d.flush(),void 0===s.pid?o(new Error("Process has no pid.")):r({pid:s.pid,stdout:a,stderr:c,status:e,signal:t})}),n?.input&&(s.stdin?.write(n.input),s.stdin?.end())}catch(e){o(e)}})}const O=new RegExp(`${String.fromCodePoint(27)}\\[[0-?]*[ -/]*[@-~]`,"g");function D(e,t=!1){if(!t)return{write:t=>e.write(t),flush:()=>{}};let n="";return{write:t=>{n+=t;const r=n.split(/\r?\n/);n=r.pop()??"";for(const t of r)N(t)||e.write(`${t}\n`)},flush:()=>{N(n)||e.write(n),n=""}}}function N(e){return 0===e.replaceAll(O,"").trim().length}function T(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?typeof e:"null"));return e}function C(e,t,n){"symbol"==typeof t&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}function I(e){var t=function(e,t){if("object"!=typeof e||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t);if("object"!=typeof r)return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==typeof t?t:t+""}
1
+ import e from"node:fs";import t from"node:path";import n from"yargs";import{hideBin as r}from"yargs/helpers";import o,{execFileSync as s,spawn as i,spawnSync as a}from"node:child_process";import{createHash as c}from"node:crypto";import l from"chalk";import{globby as d}from"globby";import{config as u}from"dotenv";import{expand as p}from"dotenv-expand";import f,{constants as h}from"node:os";import{PromisePool as m}from"minimal-promise-pool";import g from"kill-port";import w from"node:fs/promises";import{createServer as y}from"node:net";import{distance as b}from"fastest-levenshtein";const v={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV || "development">. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || NODE_ENV || "development">.',type:"boolean",default:!0},"include-root-env":{description:"Include .env files in root directory if the project is in a monorepo and --env option is not used.",type:"boolean",default:!0},"check-env":{description:"Check whether the keys of the loaded .env files are same with the given .env file.",type:"string",default:".env.example"},verbose:{description:"Whether to show verbose information",type:"boolean",alias:"v"}};const k=new Map;function A(e){const n=k.get(e);if(n)return n;const r=u({path:t.resolve(e),processEnv:{},quiet:!0}).parsed??{};return k.set(e,r),r}function E(e){return e instanceof Error&&"code"in e}function P(e,t="SIGTERM"){if(!Number.isInteger(e)||e<=0)throw new Error(`Invalid pid: ${e}`);if("win32"===process.platform)return void function(e){try{$("taskkill",["/PID",String(e),"/T","/F"],{maxBuffer:1048576,timeout:2e3})}catch(e){if(x(e))return;throw e}}(e);const n=function(e){const{stdout:t}=$("ps",["-Ao","pid=,ppid="],{maxBuffer:1048576,timeout:2e3}),n=function(e){const t=new Map;for(const n of e.split("\n")){const e=/^\s*(\d+)\s+(\d+)\s*$/.exec(n);if(!e)continue;const r=Number(e[1]),o=Number(e[2]),s=t.get(o);s?s.push(r):t.set(o,[r])}return t}(t);return function(e,t){const n=[],r=[...t.get(e)??[]];let o=0;for(;o<r.length;){const e=r[o];o+=1,n.push(e),r.push(...t.get(e)??[])}return n}(e,n)}(e),r=function(e,t){const n=t.toReversed();return n.push(e),n}(e,n);for(const e of r)S(e,t)}function S(e,t){try{process.kill(e,t)}catch(e){if(x(e))return;throw e}}function $(e,t,n){try{return{stdout:s(e,[...t],{encoding:"utf8",maxBuffer:n?.maxBuffer,timeout:n?.timeout,stdio:["ignore","pipe","pipe"]}),stderr:""}}catch(n){const r=function(e){if("object"!=typeof e||null===e||!("stderr"in e))return"";const t=e.stderr;if("string"==typeof t)return t;if(Buffer.isBuffer(t))return t.toString("utf8");return""}(n);throw new R(e,t,r,function(e){if(E(e))return e.code;if("object"==typeof e&&null!==e&&"status"in e){const t=e.status;if("number"==typeof t)return t}return}(n))}}function x(e){return!(!E(e)||"ESRCH"!==e.code)||e instanceof R&&/no such process|not found|not recognized|there is no running instance/i.test(e.stderr)}class R extends Error{constructor(e,t,n,r){super(`Command failed: ${e} ${t.join(" ")}`),this.name="CommandExecutionError",this.stderr=n,this.code=r}}async function j(e,t,n){return new Promise((r,o)=>{try{const s=i(e,t??[],n??{});s.stdout?.setEncoding?.("utf8"),s.stderr?.setEncoding?.("utf8");let a="",c="";const l=D(process.stdout,n?.omitBlankLinesWhilePrinting),d=D(process.stderr,n?.omitBlankLinesWhilePrinting);s.stdout?.on("data",e=>{a+=e,n?.printingStdout&&l.write(e)}),s.stderr?.on("data",e=>{n?.mergeOutAndError?a+=e:c+=e,n?.printingStderr&&d.write(e)});let u=!1;const p=()=>{if(!u&&s.pid){u=!0,n?.verbose&&console.info(`treeKill(${s.pid})`);try{P(s.pid)}catch(e){n?.verbose&&console.warn(`Failed to treeKill(${s.pid})`,e)}}},f="win32"===process.platform?["SIGINT","SIGTERM"]:["SIGINT","SIGTERM","SIGQUIT"],h=new Map,m=()=>{process.removeListener("beforeExit",p);for(const[e,t]of h)process.removeListener(e,t);h.clear()};if(n?.killOnExit){process.on("beforeExit",p);for(const e of f){const t=()=>{p(),m(),0===process.listenerCount(e)&&process.kill(process.pid,e)};h.set(e,t),process.on(e,t)}}s.on("error",e=>{m(),s.removeAllListeners("close"),o(e)}),s.on("close",(e,t)=>{m(),l.flush(),d.flush(),void 0===s.pid?o(new Error("Process has no pid.")):r({pid:s.pid,stdout:a,stderr:c,status:e,signal:t})}),n?.input&&(s.stdin?.write(n.input),s.stdin?.end())}catch(e){o(e)}})}const O=new RegExp(`${String.fromCodePoint(27)}\\[[0-?]*[ -/]*[@-~]`,"g");function D(e,t=!1){if(!t)return{write:t=>e.write(t),flush:()=>{}};let n="";return{write:t=>{n+=t;const r=n.split(/\r?\n/);n=r.pop()??"";for(const t of r)N(t)||e.write(`${t}\n`)},flush:()=>{N(n)||e.write(n),n=""}}}function N(e){return 0===e.replaceAll(O,"").trim().length}function T(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?typeof e:"null"));return e}function C(e,t,n){"symbol"==typeof t&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}function I(e){var t=function(e,t){if("object"!=typeof e||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t);if("object"!=typeof r)return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==typeof t?t:t+""}
2
2
  /**
3
3
  * [js-sha3]{@link https://github.com/emn178/js-sha3}
4
4
  *
@@ -6,5 +6,5 @@ import e from"node:fs";import t from"node:path";import n from"yargs";import{hide
6
6
  * @author Chen, Yi-Cyuan [emn178@gmail.com]
7
7
  * @copyright Chen, Yi-Cyuan 2015-2023
8
8
  * @license MIT
9
- */const _=[..."0123456789abcdef"],B=[6,1536,393216,100663296],L=[0,8,16,24],F=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];const z=e=>{const t=[];for(const[n,r]of e.entries())t[n]=r;return t};class M{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(e,t,n){this.padding=t,this.outputBits=n,this.blockCount=1600-(e<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=n>>5,this.extraBytes=(31&n)>>3;for(let e=0;e<50;++e)this.s[e]=0}update(e){if(this.finalized)throw new Error("finalize already called");const t=this.blocks,n=this.byteCount,r=e.length,o=this.blockCount,s=this.s;let i,a,c=0;for(;c<r;){if(this.reset)for(this.reset=!1,t[0]=this.block,i=1;i<o+1;++i)t[i]=0;for(i=this.start;c<r&&i<n;++c)a=e.codePointAt(c)||0,a<128?t[i>>2]|=a<<L[3&i++]:a<2048?(t[i>>2]|=(192|a>>6)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]):a<55296||a>=57344?(t[i>>2]|=(224|a>>12)<<L[3&i++],t[i>>2]|=(128|a>>6&63)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]):(a=65536+((1023&a)<<10|1023&(e.codePointAt(++c)||0)),t[i>>2]|=(240|a>>18)<<L[3&i++],t[i>>2]|=(128|a>>12&63)<<L[3&i++],t[i>>2]|=(128|a>>6&63)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]);if(this.lastByteIndex=i,i>=n){for(this.start=i-n,this.block=t[o],i=0;i<o;++i)s[i]^=t[i];U(s),this.reset=!0}else this.start=i}return this}finalize(){if(this.finalized)return;this.finalized=!0;const e=this.blocks;let t=this.lastByteIndex;const n=this.blockCount,r=this.s;if(e[t>>2]|=this.padding[3&t],this.lastByteIndex===this.byteCount)for(e[0]=e[n],t=1;t<n+1;++t)e[t]=0;for(e[n-1]|=2147483648,t=0;t<n;++t)r[t]^=e[t];U(r)}hex(){this.finalize();const e=this.blockCount;let t=this.s;const n=this.outputBlocks,r=this.extraBytes;let o,s=0,i=0,a="";for(;i<n;){for(s=0;s<e&&i<n;++s,++i)o=t[s],a+=_[o>>4&15]+_[15&o]+_[o>>12&15]+_[o>>8&15]+_[o>>20&15]+_[o>>16&15]+_[o>>28&15]+_[o>>24&15];i%e===0&&(t=z(t),U(t),s=0)}return r&&(o=t[s],a+=_[o>>4&15]+_[15&o],r>1&&(a+=_[o>>12&15]+_[o>>8&15]),r>2&&(a+=_[o>>20&15]+_[o>>16&15])),a}}const U=function(e){let t,n,r,o,s,i,a,c,l,d,u,p,f,h,m,g,w,y,b,v,k,A,P,E,S,$,x,R,j,O,D,N,T,C,I,_,B,L,z,M,U,W,J,Y,V,q,G,K,H,Q,Z,X,ee,te,ne,re,oe,se,ie,ae,ce,le,de;for(r=0;r<48;r+=2)o=e[0]^e[10]^e[20]^e[30]^e[40],s=e[1]^e[11]^e[21]^e[31]^e[41],i=e[2]^e[12]^e[22]^e[32]^e[42],a=e[3]^e[13]^e[23]^e[33]^e[43],c=e[4]^e[14]^e[24]^e[34]^e[44],l=e[5]^e[15]^e[25]^e[35]^e[45],d=e[6]^e[16]^e[26]^e[36]^e[46],u=e[7]^e[17]^e[27]^e[37]^e[47],p=e[8]^e[18]^e[28]^e[38]^e[48],f=e[9]^e[19]^e[29]^e[39]^e[49],t=p^(i<<1|a>>>31),n=f^(a<<1|i>>>31),e[0]^=t,e[1]^=n,e[10]^=t,e[11]^=n,e[20]^=t,e[21]^=n,e[30]^=t,e[31]^=n,e[40]^=t,e[41]^=n,t=o^(c<<1|l>>>31),n=s^(l<<1|c>>>31),e[2]^=t,e[3]^=n,e[12]^=t,e[13]^=n,e[22]^=t,e[23]^=n,e[32]^=t,e[33]^=n,e[42]^=t,e[43]^=n,t=i^(d<<1|u>>>31),n=a^(u<<1|d>>>31),e[4]^=t,e[5]^=n,e[14]^=t,e[15]^=n,e[24]^=t,e[25]^=n,e[34]^=t,e[35]^=n,e[44]^=t,e[45]^=n,t=c^(p<<1|f>>>31),n=l^(f<<1|p>>>31),e[6]^=t,e[7]^=n,e[16]^=t,e[17]^=n,e[26]^=t,e[27]^=n,e[36]^=t,e[37]^=n,e[46]^=t,e[47]^=n,t=d^(o<<1|s>>>31),n=u^(s<<1|o>>>31),e[8]^=t,e[9]^=n,e[18]^=t,e[19]^=n,e[28]^=t,e[29]^=n,e[38]^=t,e[39]^=n,e[48]^=t,e[49]^=n,h=e[0],m=e[1],q=e[11]<<4|e[10]>>>28,G=e[10]<<4|e[11]>>>28,R=e[20]<<3|e[21]>>>29,j=e[21]<<3|e[20]>>>29,ae=e[31]<<9|e[30]>>>23,ce=e[30]<<9|e[31]>>>23,W=e[40]<<18|e[41]>>>14,J=e[41]<<18|e[40]>>>14,C=e[2]<<1|e[3]>>>31,I=e[3]<<1|e[2]>>>31,g=e[13]<<12|e[12]>>>20,w=e[12]<<12|e[13]>>>20,K=e[22]<<10|e[23]>>>22,H=e[23]<<10|e[22]>>>22,O=e[33]<<13|e[32]>>>19,D=e[32]<<13|e[33]>>>19,le=e[42]<<2|e[43]>>>30,de=e[43]<<2|e[42]>>>30,te=e[5]<<30|e[4]>>>2,ne=e[4]<<30|e[5]>>>2,_=e[14]<<6|e[15]>>>26,B=e[15]<<6|e[14]>>>26,y=e[25]<<11|e[24]>>>21,b=e[24]<<11|e[25]>>>21,Q=e[34]<<15|e[35]>>>17,Z=e[35]<<15|e[34]>>>17,N=e[45]<<29|e[44]>>>3,T=e[44]<<29|e[45]>>>3,E=e[6]<<28|e[7]>>>4,S=e[7]<<28|e[6]>>>4,re=e[17]<<23|e[16]>>>9,oe=e[16]<<23|e[17]>>>9,L=e[26]<<25|e[27]>>>7,z=e[27]<<25|e[26]>>>7,v=e[36]<<21|e[37]>>>11,k=e[37]<<21|e[36]>>>11,X=e[47]<<24|e[46]>>>8,ee=e[46]<<24|e[47]>>>8,Y=e[8]<<27|e[9]>>>5,V=e[9]<<27|e[8]>>>5,$=e[18]<<20|e[19]>>>12,x=e[19]<<20|e[18]>>>12,se=e[29]<<7|e[28]>>>25,ie=e[28]<<7|e[29]>>>25,M=e[38]<<8|e[39]>>>24,U=e[39]<<8|e[38]>>>24,A=e[48]<<14|e[49]>>>18,P=e[49]<<14|e[48]>>>18,e[0]=h^~g&y,e[1]=m^~w&b,e[10]=E^~$&R,e[11]=S^~x&j,e[20]=C^~_&L,e[21]=I^~B&z,e[30]=Y^~q&K,e[31]=V^~G&H,e[40]=te^~re&se,e[41]=ne^~oe&ie,e[2]=g^~y&v,e[3]=w^~b&k,e[12]=$^~R&O,e[13]=x^~j&D,e[22]=_^~L&M,e[23]=B^~z&U,e[32]=q^~K&Q,e[33]=G^~H&Z,e[42]=re^~se&ae,e[43]=oe^~ie&ce,e[4]=y^~v&A,e[5]=b^~k&P,e[14]=R^~O&N,e[15]=j^~D&T,e[24]=L^~M&W,e[25]=z^~U&J,e[34]=K^~Q&X,e[35]=H^~Z&ee,e[44]=se^~ae&le,e[45]=ie^~ce&de,e[6]=v^~A&h,e[7]=k^~P&m,e[16]=O^~N&E,e[17]=D^~T&S,e[26]=M^~W&C,e[27]=U^~J&I,e[36]=Q^~X&Y,e[37]=Z^~ee&V,e[46]=ae^~le&te,e[47]=ce^~de&ne,e[8]=A^~h&g,e[9]=P^~m&w,e[18]=N^~E&$,e[19]=T^~S&x,e[28]=W^~C&_,e[29]=J^~I&B,e[38]=X^~Y&q,e[39]=ee^~V&G,e[48]=le^~te&re,e[49]=de^~ne&oe,e[0]^=F[r],e[1]^=F[r+1]},W=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,r,o])=>{e.name=t,e.message=n,void 0===r?delete e.stack:e.stack=r,void 0!==o&&(e.cause=o)}},t={instance:Uint8Array,from:e=>[btoa(Y.decode(e))],create:([e])=>J.encode(atob(e))},n={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,r]of t)e.set(n,r)}},r={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},o={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},s={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},i={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,n,r,o,s,i].map(e=>[e.instance.name,e]))}(),J=new TextEncoder,Y=new TextDecoder("utf-8");function V(e,t=W){return JSON.stringify(K(e,t))}function q(e){if(void 0===e)return-1;if("number"==typeof e){if(Number.isNaN(e))return-3;if(!Number.isFinite(e))return e<0?-5:-4}return null}const G=[];function K(e,t=W){const n=q(e);if(null!==n)return n;const r=[],o=new Map;return function e(n){const s=q(n);if(null!==s)return s;let i=o.get(n);if(void 0!==i)return i;switch(i=r.length,typeof n){case"number":case"string":case"boolean":r[i]=n,o.set(n,i);break;case"bigint":r[i]=[-6,n.toString(16)],o.set(n,i);break;case"object":if(null===n)r[i]=n,o.set(n,i);else if(Array.isArray(n)){const t=function(e){if(G.length<e){const t=G.length;G.length=e,G.fill(-2,t,e)}return G.slice(0,e)}(n.length);r[i]=t,o.set(n,i);for(const[r,o]of n.entries())t[r]=e(o)}else{const[s,a]=function(e,t){const n=e.constructor;if("function"==typeof n){const r=n.name,o=t.get(r);if(void 0!==o)return[r,o.from(e)]}const r=Object.entries(e),o=r.length,s=Array.from({length:o+o});for(let e=0;e<o;e++){const t=r[e],n=e+e;s[n]=t[0],s[n+1]=t[1]}return["",s]}(n,t),c=a.length,l=Array.from({length:c+1});l[0]=s,r[i]=l,o.set(n,i);for(let t=0;t<c;t++)l[t+1]=e(a[t])}}return i}(e),r}function H(e,t){return function(e){return new M(512,B,512).update(e).hex()}(V([e,t]))}const Q=function({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:t=H}={}){return function(n,r){let o,s,i;return"getter"===r?.kind?function(){const r=t(this,[]),a=Date.now();return(i!==r||a-s>e)&&(i=r,o=n.call(this),s=a),o}:function(...a){const c=t(this,a),l=Date.now();return(i!==c||l-s>e)&&(i=c,o=r?n.call(this,...a):n(...a),s=l),o}}}({getCacheKey:H});function Z(e){return!!e&&"0"!==e&&"false"!==e}let X;class ee{static{[X]=function(e,t,n,r,o){var s,i,a,c,l,d,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,h=Object.create,m=[h(null),h(null)],g=t.length;function w(t,n,r){return function(o,s){n&&(s=o,o=e);for(var i=0;i<t.length;i++)s=t[i].apply(o,r?[s]:[]);return r?s:o}}function y(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function b(e,t,n,r,o,a,c,l,d,u,p){function h(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),b=t[3],v=!c,k=1===o,A=3===o,P=4===o,E=2===o;function S(t,n,r){return function(o,s){return n&&(s=o,o=e),r&&r(o),$[t].call(o,s)}}if(!v){var $={},x=[],R=A?"get":P||k?"set":"value";if(d?(u||k?$={get:C(function(){return b(this)},r,"get"),set:function(e){t[4](this,e)}}:$[R]=b,u||C($[R],r,E?"":R)):u||($=Object.getOwnPropertyDescriptor(e,r)),!u&&!d){if((i=m[+l][r])&&7!==(i^o))throw Error("Decorating two elements with the same name ("+$[R].name+") is not supported yet");m[+l][r]=o<3?1:o}}for(var j=e,O=g.length-1;O>=0;O-=n?2:1){var D=y(g[O],"A decorator","be",!0),N=n?g[O-1]:void 0,T={},I={kind:["field","accessor","method","getter","setter","class"][o],name:r,metadata:s,addInitializer:function(e,t){if(e.v)throw new TypeError("attempted to call addInitializer after decoration was finished");y(t,"An initializer","be",!0),a.push(t)}.bind(null,T)};if(v)i=D.call(N,j,I),T.v=1,y(i,"class decorators","return")&&(j=i);else if(I.static=l,I.private=d,i=I.access={has:d?p.bind():function(e){return r in e}},P||(i.get=d?E?function(e){return h(e),$.value}:S("get",0,h):function(e){return e[r]}),E||A||(i.set=d?S("set",0,h):function(e,t){e[r]=t}),j=D.call(N,k?{get:$.get,set:$.set}:$[R],I),T.v=1,k){if("object"==typeof j&&j)(i=y(j.get,"accessor.get"))&&($.get=i),(i=y(j.set,"accessor.set"))&&($.set=i),(i=y(j.init,"accessor.init"))&&x.unshift(i);else if(void 0!==j)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(j,(u?"field":"method")+" decorators","return")&&(u?x.unshift(j):$[R]=j)}return o<2&&c.push(w(x,l,1),w(a,l,0)),u||v||(d?k?c.splice(-1,0,S("get",l),S("set",l)):c.push(E?$[R]:y.call.bind($[R])):f(e,r,$)),j}function v(e){return f(e,p,{configurable:!0,enumerable:!0,value:s})}return s=h(null==s?null:s),l=[],d=function(e){e&&l.push(w(e))},u=function(t,r){for(var s=0;s<n.length;s++){var i=n[s],d=i[1],u=7&d;if((8&d)==t&&!u==r){var p=i[2],f=!!i[3],h=16&d;b(t?e:e.prototype,i,h,f?"#"+p:I(p),u,u<2?[]:t?c=c||[]:a=a||[],l,!!t,f,r,t&&f?function(t){return T(t)===e}:o)}}},u(8,0),u(0,0),u(8,1),u(0,1),d(a),d(c),i=l,g||v(e),{e:i,get c(){var n=[];return g&&[v(e=b(e,[t],r,e.name,5,n)),w(n,1)]}}}(this,[],[[Q,3,"isBunAvailable"],[Q,3,"usesBunPackageManager"],[Q,3,"buildCommand"],[Q,3,"rootDirPath"],[Q,3,"dockerfile"],[Q,3,"hasDockerfile"],[Q,3,"hasSourceCode"],[Q,3,"name"],[Q,3,"dockerImageName"],[Q,3,"env"],[Q,3,"packageJson"],[Q,3,"packageJsonPath"],[Q,3,"hasPrisma"],[Q,3,"hasDrizzle"],[Q,3,"databaseOrm"],[Q,3,"hasVitest"],[Q,3,"hasOxlint"],[Q,3,"hasOxfmt"],[Q,3,"hasPrettier"],[Q,3,"hasPoetryLock"],[Q,3,"hasPubspecYaml"],[Q,3,"preferredLinter"],[Q,3,"hasPlaywrightConfig"],[Q,3,"skipLaunchingServerForPlaywright"],[Q,3,"dockerPackageJson"],[Q,3,"binExists"],[Q,3,"rootPackageJson"]]).e}argv=void X(this);pathByName=new Map;constructor(e,n,r){this._dirPath=t.resolve(e),this.argv=n,this.loadEnv=r}get isBunAvailable(){return!!this.hasBunToolVersion()||this.usesBunPackageManager}get usesBunPackageManager(){return!!this.hasBunLockfile()||this.hasBunPackageManager()}hasBunToolVersion(){try{return/(^|\n)bun\s/.test(e.readFileSync(t.join(this.rootDirPath,".tool-versions"),"utf8"))}catch{return!1}}hasBunLockfile(){return["bun.lock","bun.lockb"].some(n=>e.existsSync(t.join(this.rootDirPath,n)))}hasBunPackageManager(){const e=this.rootPackageJson?.packageManager??this.packageJson.packageManager;return"string"==typeof e&&e.startsWith("bun@")}get buildCommand(){return this.packageJson.scripts?.build?.includes("buildIfNeeded")?"YARN run build":this.packageJson.scripts?.build?"YARN wb buildIfNeeded "+(this.argv.verbose?"--verbose":""):"echo 'No build script'"}get dirPath(){return this._dirPath}get rootDirPath(){return e.existsSync(t.join(this.dirPath,"..","..","package.json"))?t.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return e.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return e.existsSync(t.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){if(!this.loadEnv)return process.env;const[n,r]=function(n,r){let o=(n.env??[]).map(e=>t.resolve(r,e.toString()));const s=n.cascadeEnv??(n.cascadeNodeEnv?process.env.NODE_ENV||"development":n.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof s){if(0===o.length&&(o.push(t.join(r,".env")),n.includeRootEnv)){const n=t.resolve(r,"..","..");e.existsSync(t.join(n,"package.json"))&&o.push(t.join(n,".env"))}o=o.flatMap(e=>s?[`${e}.${s}.local`,`${e}.local`,`${e}.${s}`,e]:[`${e}.local`,e])}o=o.filter(t=>e.existsSync(t)).map(e=>t.relative(r,e)),n.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",o.join(", ")));const i=[],a={};for(const e of o){const o=[];for(const[n,s]of Object.entries(A(t.join(r,e))))n in a||n in process.env||(a[n]=s,o.push(n));i.push([e,o]),n.verbose&&o.length>0&&console.info(`Read ${o.length} environment variables from ${e}`)}if(n.verbose||console.info(`Read env files: ${i.map(([e,t])=>t.length>0?`${e} (${t.join(", ")})`:e).join(", ")||"nothing"}`),n.checkEnv){const e=Object.keys(A(t.join(r,n.checkEnv))).filter(e=>!(e in a)&&!(e in process.env));if(e.length>0)throw new Error(`Missing environment variables in [${o.join(", ")}]: [${e.join(", ")}]`)}return[p({parsed:a,processEnv:{}}).parsed??a,i]}(this.argv,this.dirPath);for(const[e,t]of r)console.info(`Loaded ${t} environment variables from ${e}`);return{...n,...process.env}}get packageJson(){return JSON.parse(e.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return t.join(this.dirPath,"package.json")}get hasPrisma(){return!!this.getOwnDependencyVersion("prisma")}get hasDrizzle(){return!!this.getOwnDependencyVersion("drizzle-orm")}get databaseOrm(){return this.hasPrisma?"prisma":this.hasDrizzle?"drizzle":void 0}get hasVitest(){return!!(this.packageJson.dependencies?.vitest??this.packageJson.devDependencies?.vitest)}get hasOxlint(){return this.hasDependency("oxlint")}get hasOxfmt(){return this.hasDependency("oxfmt")}get hasPrettier(){return this.hasDependency("prettier")}get hasPoetryLock(){return e.existsSync(t.join(this.dirPath,"poetry.lock"))||e.existsSync(t.join(this.rootDirPath,"poetry.lock"))}get hasPubspecYaml(){return e.existsSync(t.join(this.dirPath,"pubspec.yaml"))||e.existsSync(t.join(this.rootDirPath,"pubspec.yaml"))}get preferredLinter(){if(this.hasOxlint)return"oxlint"}hasOwnDependency(e){return!!this.getOwnDependencyVersion(e)}get hasPlaywrightConfig(){try{return!!this.findFile("playwright.config.ts")}catch{return!1}}get skipLaunchingServerForPlaywright(){if(Z(this.env.CI))return!1;try{const t=this.findFile("playwright.config.ts");return/\bwebServer\b/.test(e.readFileSync(t,"utf8"))}catch{return!1}}get dockerPackageJson(){return t.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(e.readFileSync(t.join(t.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let n=!1,r=this.dirPath;for(;;){const o=t.join(r,"node_modules",".bin");if(e.existsSync(o)&&(this.env.PATH=`${o}:${this.env.PATH}`,n=!0),e.existsSync(t.join(r,".git")))break;const s=t.dirname(r);if(r===s)break;r=s}return n}findFile(n){let r=this.pathByName.get(n);if(r)return r;if(r=[n,t.join("..","..",n)].map(e=>t.resolve(this.dirPath,e)).find(t=>e.existsSync(t)),!r)throw new Error(`File not found: ${n}`);return this.pathByName.set(n,r),r}hasDependency(e){return!!(this.getOwnDependencyVersion(e)??this.getDependencyVersion(this.rootPackageJson,e))}getOwnDependencyVersion(e){return this.getDependencyVersion(this.packageJson,e)}getDependencyVersion(e,t){if(e)return e.dependencies?.[t]??e.devDependencies?.[t]??e.optionalDependencies?.[t]??e.peerDependencies?.[t]}get rootPackageJson(){if(this.rootDirPath===this.dirPath)return this.packageJson;try{return JSON.parse(e.readFileSync(t.join(this.rootDirPath,"package.json"),"utf8"))}catch(e){return void console.error(`[wb] Failed to read or parse ${t.join(this.rootDirPath,"package.json")}`,e)}}}function te(n,r=!0,o){if(o??=process.cwd(),e.existsSync(t.join(o,"package.json")))return new ee(o,n,r)}async function ne(e,t=!0,n){const r=re(e,t,n);if(r)return{...r,descendants:r.root===r.self?await oe(e,r.root,t):[r.self]}}function re(n,r=!0,o){if(o??=process.cwd(),!e.existsSync(t.join(o,"package.json")))return;const s=new ee(o,n,r);let i=s;if(!s.packageJson.workspaces&&t.dirname(o).endsWith("/packages")){const s=t.resolve(o,"..","..");e.existsSync(t.join(s,"package.json"))&&(i=new ee(s,n,r))}return{root:i,self:s}}async function oe(n,r,o){const s=[r],i=r.packageJson.workspaces;if(!Array.isArray(i))return s;const a=[],c=[];for(const n of i.map(e=>t.join(r.dirPath,e)))e.existsSync(n)?c.push(n):a.push(n);c.push(...await d(a,{dot:!0,onlyDirectories:!0}));for(const r of c)e.existsSync(t.join(r,"package.json"))&&s.push(new ee(r,n,o));return s}const se=process.versions.bun||process.argv[0]?.endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),ie=se?"bun --bun run":"node",ae=se?"bun":"yarn",ce=se?"bun --bun run":"yarn",le={command:"buildIfNeeded",describe:"Build code if changes are detected",builder:{command:{description:"A build command (default: yarn|bun build)",type:"string",alias:"c"}},async handler(n){await async function(n,r){const s=te(n,!0,r);if(!s)return console.error(l.red("No project found.")),!0;const i=n.command??(s.packageJson.scripts?.build?se?"bun run build":"yarn build":void 0);if(!i)return console.info(l.green("Skip to build because no build command is defined.")),!1;if(n={...n,command:i},!e.existsSync(t.join(s.rootDirPath,".git")))return de(s,n),!0;const[a,d,u]=await async function(n,r){const s=t.resolve(n.dirPath,"node_modules",".cache","build"),i=t.resolve(s,"last-build");await e.promises.mkdir(s,{recursive:!0});const a=c("sha256"),l=o.execSync("git rev-parse HEAD",{cwd:n.dirPath}).toString().trim();a.update(l);const d=JSON.stringify(Object.entries(n.env).filter(([e])=>!ue.has(e)).toSorted(([e],[t])=>e.localeCompare(t)));a.update(d),await async function(e,t,n){return new Promise(r=>{const s=o.spawnSync("git",["status","--porcelain"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").filter(e=>e.length>0).map(e=>e.slice(2).trim()).map(t=>"test"===e.env.WB_ENV?t.replace(/packages\/wb\/test\/fixtures\/[^/]+\//,""):t).filter(e=>(pe.some(t=>e.includes(t))||fe.some(t=>e.endsWith(t)))&&!he.some(t=>e.includes(t)));t.verbose&&console.info(`Changed files: ${s.join(", ")}`);const i=o.spawn("git",["diff","--",...s],{cwd:e.rootDirPath});i.stdout.on("data",e=>{n.update(e),t.verbose&&(console.info("Data:",e),console.info("Hash:",n.copy().digest("hex")))}),i.on("close",()=>{r()})})}(n,r,a);const u=a.digest("hex"),p=await async function(e){try{return await e()}catch(e){if("object"==typeof e&&e&&"code"in e&&"ENOENT"===e.code)return;throw e}}(()=>e.promises.readFile(i,"utf8"));return[p===u,i,u]}(s,n);if(a)return console.info(l.green(`Skip to run '${n.command}' 💫`)),!1;if(!de(s,n))return;n.dryRun||await e.promises.writeFile(d,u,"utf8");return!0}(n)}};function de(e,t){if(console.info(l.green(`Run '${t.command}'`)),!t.dryRun){const n=o.spawnSync(t.command??"",{cwd:e.dirPath,env:e.env,shell:!0,stdio:"inherit"});if(0!==n.status)return process.exitCode=n.status??1,!1}return!0}const ue=new Set(["CI","PWDEBUG","TMPDIR"]);const pe=["src/","public/"],fe=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],he=["test/","tests/","__tests__/","test-fixtures/","test/fixtures/"];const me=new m,ge={exitIfFailed:!0};async function we(e,t,n,r=ge){const o=be(e,t);if(ve(o.printable,t,n.silent?"Command":"Start"),n.verbose&&ve(o.runnable,t,"Start (raw)",!0),n.dryRun)return ke(o.printable,0,r,{silentSuccess:n.silent}),0;const s=Boolean(n.silent&&r.processSilentOutput),i=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:n.silent?"pipe":"inherit",timeout:r.timeout,mergeOutAndError:s,killOnExit:!0,printingStdout:n.silent&&!s,printingStderr:n.silent&&!s,omitBlankLinesWhilePrinting:n.silent,verbose:n.verbose});if(s){const e=r.processSilentOutput?.(i.stdout).trim();e&&(process.stdout.write(e),process.stdout.write("\n"))}return r.onSignal?.(i.signal),ke(o.printable,i.status,r,{silentSuccess:n.silent}),i.status??1}function ye(e,t,n,r=ge){return me.runAndWaitForReturnValue(async()=>{const o=be(e,t);if(ve(o.printable,t,"Start (parallel)",!0),n.dryRun)return ve(o.printable,t,"Started (log)"),n.verbose&&ve(o.runnable,t,"Started (raw)",!0),ke(o.printable,0,r),0;const s=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose});r.onSignal?.(s.signal),ve(o.printable,t,"Started (log)"),n.verbose&&ve(o.runnable,t,"Started (raw)",!0);const i=s.stdout.trim();return i&&!r.printRawOutput&&(process.stdout.write(i),process.stdout.write("\n")),ke(o.printable,s.status,r),s.status??1})}function be(e,t){const n=t.usesBunPackageManager?"bun --bun run":"yarn";let r=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA generate ",t.packageJson.dependencies?.blitz?"PRISMA generate ":"PRISMA generate --no-hints ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN run ",t.usesBunPackageManager?`${n} `:"YARN run ").replaceAll("BUN ",t.usesBunPackageManager?`${n} `:"YARN ").replaceAll("YARN run ",t.usesBunPackageManager?`${n} `:"yarn run ");t.usesBunPackageManager&&(r=r.replaceAll("YARN build-ts run","bun --bun run").replaceAll("bun --bun run bun --bun run","bun --bun run").replaceAll("dist/index.js","src/index.ts")),r=r.trim();const o=Pe(r.replaceAll("YARN ",`${n} `)),s=Pe(r.replaceAll("YARN playwright ",`${n} playwright `).replaceAll("YARN ",!t.usesBunPackageManager&&t.binExists?"":`${n} `));return{printable:`${n} dotenv${t.env.WB_ENV?` -c=${t.env.WB_ENV||"development"}`:""} -- ${o}`,runnable:s}}function ve(e,t,n="Start",r=!1){console.info("\n"+(r?l.gray:l.cyan)(l.bold(`${n}:`),e)+l.gray(` at ${t.dirPath}`))}function ke(e,t,n,r={}){if(0===t){if(r.silentSuccess)return;console.info(l.green(l.bold("Finished:"),e))}else console.info(l.red(l.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1)}function Ae(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function Pe(e){return e.includes("next dev")||e.includes("playwright")||e.includes("prisma")||e.includes("test/e2e-additional")?e.replaceAll("bun --bun","bun"):e}const Ee={...v,"working-dir":{description:"A working directory",type:"string",alias:"w"},"dry-run":{description:"Whether to skip actual command execution",type:"boolean",alias:["dry","d"]}};function Se(e){const t=[];for(const n of Object.keys(v)){const r=$e(e,n);if(void 0!==r)if("boolean"!=typeof r)if("string"!=typeof r&&"number"!=typeof r){if(Array.isArray(r))for(const e of r)t.push(`--${n}=${e}`)}else t.push(`--${n}=${r}`);else t.push(r?`--${n}`:`--${n}=false`)}return t}function $e(e,t){const n=t.replaceAll(/-([a-z])/g,(e,t)=>t.toUpperCase()),r=e;return r[t]??r[n]}const xe={command:"concurrently <commands...>",describe:"Run commands concurrently",builder:{...Ee,"kill-others":{description:"Kill other commands when one command exits",type:"boolean"},"kill-others-on-fail":{description:"Kill other commands when one command fails",type:"boolean"},success:{description:"Define successful completion criteria",type:"string",choices:["all","first"],default:"all"},commands:{description:"Commands to run concurrently",type:"array"}},async handler(e){"win32"===process.platform&&(console.error(l.red("This command is not supported on Windows.")),process.exit(1));const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));const n=(e.commands??[]).map(String).filter(Boolean);0===n.length&&(console.error(l.red("No commands provided.")),process.exit(1));try{const r=await async function(e){const t=e.commands.map(t=>o.spawn(be(t,e.project).runnable,{cwd:e.project.dirPath,detached:!0,env:Ae(e.project.env,{ci:e.ci,forceColor:e.forceColor}),shell:!0,stdio:"inherit"}));let n,r,s,i=!1;const a=[],c=Array.from({length:t.length}),l=t.map((n,o)=>new Promise(l=>{let d=!1;const u=n=>{d||(d=!0,c[o]=n,r??=n,!i&&function(e,t){return"first"===t.success||t.killOthers||t.killOthersOnFail&&0!==e}(n,e)&&(s=n,i=!0,a.push(je(t,"SIGTERM"))),l())};n.once("error",e=>{console.error("Failed to start child process:",e),u(1)}),n.once("exit",(e,t)=>{u(Re(e??void 0,t??void 0))})})),d=e=>{n??=e,i||(i=!0,a.push(je(t,e)))},u=()=>{d("SIGINT")},p=()=>{d("SIGTERM")},f=()=>{d("SIGQUIT")};process.on("SIGINT",u),process.on("SIGTERM",p),process.on("SIGQUIT",f);try{await Promise.all(l),await Promise.all(a)}finally{process.removeListener("SIGINT",u),process.removeListener("SIGTERM",p),process.removeListener("SIGQUIT",f)}if(n)return Re(void 0,n);if("first"===e.success)return r??1;if(void 0!==s)return s;for(const e of c)if(void 0!==e&&0!==e)return e;return 0}({commands:n,project:t,killOthers:e.killOthers??!1,killOthersOnFail:e.killOthersOnFail??!1,success:e.success,ci:"boolean"==typeof e.ci?e.ci:void 0,forceColor:"boolean"==typeof e.forceColor?e.forceColor:void 0});process.exit(r)}catch(e){console.error(l.red(e instanceof Error?e.message:String(e))),process.exit(1)}}};function Re(e,t){return void 0!==e?e:t&&t in h.signals?128+h.signals[t]:1}async function je(e,t){const n=Oe(function(e){return e.flatMap(e=>void 0===e.pid?[]:[e.pid])}(e),t);0!==n.length&&await async function(e){const t=Date.now()+5e3;for(;Date.now()<t;){if(e.every(De))return!1;await Ne(Math.min(100,t-Date.now()))}return!0}(n)&&Oe(n,"SIGKILL")}function Oe(e,t){const n=[];for(const r of e)try{if(!Te(r,t))continue;n.push(r),E(r,t)}catch(e){console.warn("Failed to kill child process:",e)}return n}function De(e){try{return process.kill(-e,0),!1}catch(e){return!!Ce(e)}}async function Ne(e){await new Promise(t=>setTimeout(t,e))}function Te(e,t){try{return process.kill(-e,t),!0}catch(e){if(Ce(e))return!1;throw e}}function Ce(e){return"object"==typeof e&&null!==e&&"code"in e&&"ESRCH"===e.code}const Ie={command:"kill-port-if-non-ci",describe:"Kill the port specified by PORT environment variable if non-CI.",builder:{},async handler(e){await async function(e){const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));if(Z(t.env.CI))return void console.info(`Skip killing port due to CI: ${t.env.CI}`);const n=t.env.PORT,r=Number(n);(!Number.isInteger(r)||r<=0)&&(console.error(l.red(`PORT environment variable is invalid: ${n}`)),process.exit(1));console.info(`Killing the port: ${r}`);try{await g(r)}catch{}}(e)}};function _e(e,t){if(!function(e,t){return 0!==e||function(e){return/\bwarn(?:ing)?s?\b/i.test(e.replaceAll(/\b(?:0|no) warnings?\b/gi,""))}(Be(t))}(e,t))return;const n=function(e){return Be(e).trim()}(t);n&&(process.stdout.write(n),process.stdout.write("\n"))}function Be(e){return e.replaceAll(/\(node:\d+\) Warning: The 'NO_COLOR' env is ignored due to the 'FORCE_COLOR' env being set\.\n\(Use `node --trace-warnings \.\.\.` to show where the warning was created\)\n?/g,"")}function Le(e){return e.map(e=>Fe(e)).join(" ")}function Fe(e){return/^[\w./:=,@%+-]+$/u.test(e)?e:`'${e.replaceAll("'","'\"'\"'")}'`}const ze=new Set(["astro","cjs","cts","js","jsx","mjs","mts","svelte","ts","tsx","vue"]),Me=new Set(["py"]),Ue=new Set(["dart"]),We=new Set([...ze,"css","gql","graphql","hbs","htm","html","json","json5","jsonc","less","md","mdx","scss","toml","yaml","yml"]),Je=new Set(["cjs","css","cts","htm","html","java","js","json","json5","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),Ye=new Set([...Je].filter(e=>!We.has(e))),Ve="!**/test{-,/}fixtures/**",qe={command:"lint [files...]",describe:"Lint code",builder:{fix:{description:"Fix the linting errors",type:"boolean"},format:{description:"Format the code",type:"boolean"},quiet:{description:"Report errors only",type:"boolean"},silent:{description:"Print only failed or warning command output",type:"boolean"}},async handler(e){const t=await Ge(e);t&&process.exit(t)}};async function Ge(e){if("win32"===process.platform)return console.error(l.red("This command is not supported on Windows.")),1;const n=await ne(e,!1);if(!n)return console.error(l.red("No project found.")),1;const r=function(e){const t=new Set;for(const n of[...e.files??[],...e._.slice(1),...e["--"]??[]])t.add(String(n));return[...t]}(e),o=new Map,s=new Map,i=new Map,a=new Map,c=[],d=[];let u,p,f=!1;if(r.length>0){const h=await Promise.all(r.map(async e=>{const n=t.resolve(e),r=await async function(e){try{if((await w.stat(e)).isDirectory())return"directory"}catch{}return"other"}(n);return{fileKind:r,filePath:n}}));for(const{fileKind:r,filePath:u}of h){if(u.endsWith("/test/fixtures")||u.includes("/test/fixtures/")||u.endsWith("/test-fixtures")||u.includes("/test-fixtures/"))continue;const p=t.extname(u).slice(1);if(u.endsWith("/package.json"))d.push(u);else{d.push(...st(n.descendants,u,r));for(const{lintPath:t,project:d}of it(n.descendants,u,r)){if(d.hasPoetryLock&&("directory"===r||Me.has(p))){const e=i.get(d)??[];if(e.push(t),i.set(d,e),"directory"!==r)continue}if(d.hasPubspecYaml&&("directory"===r||Ue.has(p))){const e=a.get(d)??[];if(e.push(t),a.set(d,e),"directory"!==r)continue}if("directory"===r||ct(d,p)){const n=o.get(d)??[];if(n.push(t),o.set(d,n),e.format)if("directory"===r&&d.hasOxfmt){const e=s.get(d)??[];e.push(t),s.set(d,e),c.push(ot(t),Ve)}else for(const e of rt(d,t,r,p))if(d.hasOxfmt){const t=s.get(d)??[];t.push(e),s.set(d,t)}else c.push(e)}else if(e.format&&(Je.has(p)||We.has(p)))if(d.hasOxfmt&&We.has(p)){const e=s.get(d)??[];e.push(t),s.set(d,e)}else Je.has(p)&&c.push(t);else at(p)&&!d.preferredLinter&&(console.error(l.red(`No linter found for ${d.name}. Install Oxlint.`)),f=!0)}}}u=[...new Set(c)],p=[...new Set(d)]}else u=function(e,n){const r=new Set([`**/{.*/,}*.{${[...Ye].join(",")}}`,Ve]);for(const o of n){if(!lt(o))continue;const n=t.join(o.dirPath,"**/{.*/,}*.{"+[...Je].join(",")+"}");r.add(t.relative(e,n)||n)}return[...r]}(n.self.dirPath,n.descendants),p=n.descendants.map(e=>e.packageJsonPath);const h=[],m={exitIfFailed:!1,forceColor:!e.printAllOutput};if(r.length>0){for(const[t,n]of o){const r=Xe(t,e,n);r&&h.push(Ke(r,t,e,m))}if(e.format)for(const[t,n]of s)h.push(Ke(et(n),t,e,m));for(const[t,n]of i)h.push(Ke(tt(e,n),t,e,m));for(const[t,n]of a)h.push(Ke(nt(e,n),t,e,m))}else{for(const t of n.descendants){if(t.packageJson.workspaces&&!t.hasSourceCode)continue;const n=Xe(t,e);n&&h.push(Ke(n,t,e,m))}for(const t of n.descendants)t.hasPoetryLock&&h.push(Ke(tt(e),t,e,m)),t.hasPubspecYaml&&h.push(Ke(nt(e),t,e,m)),t.hasOxfmt&&e.format&&h.push(Ke(et(),t,e,m))}const g=await Promise.all(h);He(g,e);const y=g.map(e=>e.exitCode);if(f||y.some(e=>0!==e))return 1;if(e.format){if(u.length>0&&n.self.hasPrettier){const t=await Ke(Le(["YARN","prettier","--cache","--color","--no-error-on-unmatched-pattern","--write","--",...u]),n.self,e,m);He([t],e),y.push(t.exitCode)}if(p.length>0){const t=await Ke(Le(["YARN","sort-package-json","--",...p]),n.self,e,m);He([t],e),y.push(t.exitCode)}}return y.some(e=>0!==e)?1:0}function Ke(e,t,n,r){if(n.silent){const o=be(e,t);return function(e,t,n,r=ge){return me.runAndWaitForReturnValue(async()=>{const o=be(e,t);if(n.dryRun)return{exitCode:0,output:""};const s=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose});return r.onSignal?.(s.signal),{exitCode:s.status??1,output:s.stdout}})}(e,t,n,r).then(e=>({...e,command:o.printable,cwd:t.dirPath}))}return ye(e,t,n,r).then(e=>({exitCode:e}))}function He(e,t){const n=t.silent&&!t.printAllOutput?e.filter(e=>0!==e.exitCode):e;if(0!==n.length)for(const e of n)"output"in e&&(t.printAllOutput?Qe(e):(t.silent&&Ze(e.command,e.cwd),_e(e.exitCode,e.output)))}function Qe(e){if(Ze(e.command,e.cwd),0===e.exitCode&&((t=e.command).includes(" oxfmt ")||t.includes(" sort-package-json ")))return void console.info(l.green("Succeeded."));var t;const n=e.output.trim();n&&(process.stdout.write(n),process.stdout.write("\n"))}function Ze(e,t){console.info("\n"+l.cyan(l.bold("Command:"),e)+l.gray(` at ${t}`))}function Xe(e,t,n){if("oxlint"===e.preferredLinter)return Le(["YARN","oxlint","--no-error-on-unmatched-pattern",...t.quiet?["--quiet"]:[],...t.fix?["--fix"]:[],...n??["."]])}function et(e){return Le(["YARN","oxfmt","--write","--no-error-on-unmatched-pattern",...e??["."],"!**/package.json"])}function tt(e,t){const n=t&&t.length>0?t:["."];return(e.fix||e.format?[Le(["poetry","run","isort","--profile","black","--filter-files",...n]),Le(["poetry","run","black",...n]),Le(["poetry","run","flake8",...e.quiet?["-q"]:[],...n])]:[Le(["poetry","run","flake8",...e.quiet?["-q"]:[],...n])]).join(" && ")}function nt(e,t){const n=t&&t.length>0?t:["."],r=[];return(e.fix||e.format)&&r.push(Le(["dart","format",...n])),r.push(Le(["dart","analyze",...n])),r.join(" && ")}function rt(e,t,n,r){return"directory"===n&&e.hasOxfmt?[t]:"directory"===n&&lt(e)?[t,Ve]:function(e,t){return e.hasOxfmt?We.has(t):!!lt(e)||Ye.has(t)}(e,r)?[t]:[]}function ot(e){return t.join(e,`**/{.*/,}*.{${[...Ye].join(",")}}`)}function st(e,n,r){return"directory"!==r?[]:e.filter(e=>e.packageJsonPath===t.join(n,"package.json")||e.packageJsonPath.startsWith(`${n}/`)).map(e=>e.packageJsonPath)}function it(e,t,n){if("directory"===n){const n=e.filter(e=>e.dirPath===t||e.dirPath.startsWith(`${t}/`));if(n.length>0)return n.map(e=>({lintPath:e.dirPath,project:e}))}const r=function(e,t){let n;for(const r of e)t!==r.dirPath&&!t.startsWith(`${r.dirPath}/`)||n&&!(r.dirPath.length>n.dirPath.length)||(n=r);return n}(e,t);return r?[{lintPath:t,project:r}]:[]}function at(e){return ze.has(e)||Me.has(e)||Ue.has(e)}function ct(e,t){return"oxlint"===e.preferredLinter&&ze.has(t)}function lt(e){return!e.hasOxfmt&&"oxlint"===e.preferredLinter}function*dt(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const ut=["@willbooster/wb","build-ts"],pt={command:"optimizeForDockerBuild",describe:"Optimize configuration when building a Docker image",builder:{outside:{description:"Whether the optimization is executed outside a docker container or not",type:"boolean",alias:"o"}},async handler(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1));for(const o of dt("optimizeForDockerBuild",r.descendants)){const r=o.packageJson,s=["dependencies","devDependencies"];for(const e of s){const t=r[e]??{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ft(n,r),ht(r),mt(r),n.dryRun)continue;const i=n.outside?t.join(o.dirPath,"dist"):o.dirPath;await e.promises.mkdir(i,{recursive:!0}),await e.promises.writeFile(t.join(i,"package.json"),JSON.stringify(r),"utf8")}n.dryRun||n.outside||(o.spawnSync(ae,["install"],{stdio:"inherit"}),console.info("Installed dependencies."))}};function ft(e,t){!function(e){const t=e.devDependencies??{},n=e.dependencies??{},r=[];for(const e of ut){const o=t[e];o&&(n[e]||(n[e]=o,r.push(e)),delete t[e])}r.length>0&&(e.dependencies=n);console.info("Promoted runtime devDependencies:",r.join(", ")||"none")}(t),e.outside?function(e){const t=e.devDependencies??{},n=["artillery","concurrently","conventional-changelog-conventionalcommits","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","railway","semantic-release","sort-package-json","wait-on","vitest"],r=[];for(const e of Object.keys(t))(n.some(t=>e.includes(t))||e.includes("willbooster")&&e.includes("config"))&&(delete t[e],r.push(e));console.info("Removed devDependencies:",r.join(", ")||"none")}(t):(delete t.devDependencies,console.info("Removed all devDependencies."))}function ht(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts??{},o=[];for(const[e,s]of Object.entries(r))(t.some(t=>e.startsWith(t))||n.some(e=>s.includes(e)||s.trim()===e.trim()))&&(delete r[e],o.push(e));console.info("Removed scripts:",o.join(", ")||"none")}function mt(e){delete e.private,delete e.publishConfig,delete e.prettier}const gt="file:";const wt=new class{deploy(e,t=""){return this.migrate(e,t)}migrate(e,t=""){return`YARN drizzle-kit migrate ${t}`}migrateDev(e,t=""){return`YARN drizzle-kit generate ${t}`}reset(e,n=""){const r=function(e){const n=e.env.DATABASE_PATH??function(e){const t=e.env.DATABASE_URL;if(!t?.startsWith(gt))return;const n=t.slice(5).replace(/[?#].*$/,"");if(!n)return;return n}(e);if(!n)return;const r=t.isAbsolute(n)?n:t.resolve(e.dirPath,n);return`rm -f "${r}" "${r}-wal" "${r}-shm"`}(e);return r?`${r} && ${this.migrate(e,n)} && ${this.seed(e)}`:"echo 'wb db reset supports Drizzle only when DATABASE_PATH or file: DATABASE_URL is set.' && exit 1"}seed(e,t){return t?`BUN build-ts run ${t}`:e.packageJson.scripts?.seed?"YARN run seed":"true"}studio(e,t,n=""){return t?"echo 'wb db studio for Drizzle does not support db-url-or-path.' && exit 1":`YARN drizzle-kit studio ${n}`}},yt="file:",bt=[{schemaPath:t.join("prisma","schema.prisma"),dbPath:"prisma"},{schemaPath:t.join("prisma","schema"),dbPath:t.join("prisma","schema")},{schemaPath:t.join("db","schema.prisma"),dbPath:"db"}];function vt(e){return e.packageJson.dependencies?.blitz?"db/mount":"prisma/mount"}function kt(n){return bt.find(({schemaPath:r})=>e.existsSync(t.resolve(n.dirPath,r)))?.dbPath}const At=new class{cleanUpLitestream(e){const t=vt(e);var n;return`${`if [ -f "${n=`${t}/prod.sqlite3`}" ]; then printf 'PRAGMA wal_checkpoint(TRUNCATE);' | PRISMA db execute --stdin --url "${yt}${n}"; fi && rm -f "${n}".* "${n}"-*`}; rm -Rf ${t}/.prod.sqlite3* || true`}deploy(e,t=""){return`PRISMA migrate deploy ${t}`}deployForce(e){const t=vt(e),n=`rm -Rf "${`${t}/prod.sqlite3`}"*`;return`${n}; PRISMA migrate reset --force --skip-seed && ${n}\n && litestream restore -config litestream.yml -o ${t}/prod.sqlite3 ${t}/prod.sqlite3 && ls -ahl ${t}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}listBackups(e){return`litestream ltx -config litestream.yml ${vt(e)}/prod.sqlite3`}migrate(e,t=""){return`PRISMA migrate deploy ${t} && PRISMA generate && ${this.seed(e)}`}migrateDev(e,t=""){return`PRISMA migrate dev ${t}`}reset(e,n=""){const r=[],o=function(e){const n=e.env.DATABASE_URL;if(!n?.startsWith(yt))return;const r=n.slice(5).replace(/[?#].*$/,"");if(!r)return;const o=kt(e),s=t.isAbsolute(r)?r:t.resolve(e.dirPath,o??".",r);return`rm -f "${s}" "${s}-wal" "${s}-shm"`}(e);o&&r.push(o);const s=["PRISMA migrate reset --force",n].filter(Boolean).join(" ");return r.push(s),e.packageJson.dependencies?.blitz&&r.push(this.seed(e)),r.filter(Boolean).join(" && ")}restore(e,t){return`rm -Rf ${t}*; litestream restore -config litestream.yml -o ${t} ${vt(e)}/prod.sqlite3`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?`BUN build-ts run ${t}`:e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}studio(e,n,r=""){let o="";if(n)try{new URL(n),o=`DATABASE_URL=${n} `}catch{const e=t.resolve(n);o=`DATABASE_URL=${yt}${e} `}else if(e.env.DATABASE_URL?.startsWith(yt)){const n=kt(e);if(n){const r=t.resolve(e.dirPath,n,e.env.DATABASE_URL.slice(5));o=`DATABASE_URL=${yt}${r} `}}return`${o}PRISMA studio ${r}`}},Pt={},Et={command:"prisma",aliases:["db"],describe:"Run database commands. Use '--' to stop wb option parsing and forward the remaining arguments to Prisma. Drizzle projects use drizzle-kit. Example: wb prisma migrate-dev -- --name init",builder:e=>e.parserConfiguration({"populate--":!0}).command(St).command($t).command(xt).command(Rt).command(jt).command(Ot).command(Dt).command(Nt).command(Tt).command(Ct).command(It).command(_t).demandCommand().strict(!1),handler(){}},St={command:"cleanup-litestream",describe:"Clean up temporal Litestream files",builder:Pt,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma cleanup-litestream",t))await we(At.cleanUpLitestream(n),n,e)}},$t={command:"create-litestream-config",describe:"Create Litestream configuration file",builder:Pt,async handler(e){const t=await Lt(e,"prisma");for(const{project:e}of zt("prisma create-litestream-config",t))Bt(e)}},xt={command:"deploy",describe:"Apply migration to DB without initializing it",builder:Pt,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db deploy",t))await we(Ft(r).deploy(o,n),o,e)}},Rt={command:"deploy-force",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:Pt,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma deploy-force",t))await we(At.deployForce(n),n,e)}},jt={command:"list-backups",describe:"List Litestream backups",builder:Pt,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma list-backups",t))await we(At.listBackups(n),n,e)}},Ot={command:"migrate",describe:"Apply migration to DB with initializing it",builder:Pt,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db migrate",t))await we(Ft(r).migrate(o,n),o,e)}},Dt={command:"migrate-dev",describe:"Create a migration file",builder:Pt,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db migrate-dev",t))await we(Ft(r).migrateDev(o,n),o,e)}},Nt={command:"reset",describe:"Reset DB",builder:Pt,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db reset",t))await we(Ft(r).reset(o,n),o,e);if("test"!==process.env.WB_ENV){process.env.WB_ENV="test";for(const{orm:t,project:r}of zt("WB_ENV=test db reset",await Lt(e)))await we(Ft(t).reset(r,n),r,e)}}},Tt={command:"restore",describe:"Restore DB from Litestream's backup",builder:{...Pt,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma restore",t)){const t=e.output??(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await we(At.restore(n,t),n,e)}}},Ct={command:"seed",describe:"Populate DB with seed data",builder:{...Pt,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await Lt(e);for(const{orm:n,project:r}of zt("db seed",t))await we(Ft(n).seed(r,e.file),r,e)}},It={command:"studio [db-url-or-path]",describe:"Open database studio",builder:{...Pt,"db-url-or-path":{description:"URL or path to the database",type:"string"},restored:{description:"Whether to open the default restored database (<db|prisma>/restored.sqlite3).",type:"boolean"}},async handler(e){if(e.restored&&e.dbUrlOrPath)throw new Error("You cannot specify both --restored and --db-url-or-path.");const t=await Lt(e),n=Mt(e,["db-url-or-path","restored"]);for(const{orm:r,project:o}of zt("db studio",t)){const t=e.restored?o.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await we(Ft(r).studio(o,t,n),o,e)}}},_t={command:"$0 <args..>",describe:"Pass the command and arguments to the detected ORM as is. Additional Prisma flags can also be forwarded after '--'.",builder:{args:{type:"array"}},async handler(e){const t=await Lt(e),n=[(e.args?.join(" ")??"").trimEnd(),Mt(e,["args"])].filter(Boolean).join(" ");for(const{orm:r,project:o}of zt(`db ${n}`,t)){const t="prisma"===r?`PRISMA ${n}`:`YARN drizzle-kit ${n}`;await we(t,o,e)}}};function Bt(t){const n=`${t.packageJson.dependencies?.blitz?"db":"prisma"}/mount/prod.sqlite3`,r={CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME:t.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY:t.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY},o=Object.entries(r).filter(([,e])=>!e).map(([e])=>e);if(o.length>0)throw new Error(`Missing environment variables for Litestream: ${o.join(", ")}`);const s="staging"===t.env.WB_ENV?"5m":"1h",i=`dbs:\n - path: ${n}\n busy-timeout: 5s\n checkpoint-interval: 1m\n replica:\n type: s3\n endpoint: https://${r.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n bucket: ${r.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n access-key-id: ${r.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n secret-access-key: ${r.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n snapshot-interval: 24h # Create a backup per day\n retention: 72h # Keep backups for 3 days\n retention-check-interval: ${s}\n sync-interval: 1m\n`,a="/etc/litestream.yml";try{e.writeFileSync(a,i),console.info(`Generated ${a}`)}catch(e){const t=e instanceof Error?e.message:String(e);throw new Error(`Failed to write ${a}: ${t}`,{cause:e})}}async function Lt(e,t){const n=await ne(e);n||(console.error(l.red("No project found.")),process.exit(1));const r=n.descendants.map(e=>e.databaseOrm?{project:e,orm:e.databaseOrm}:void 0).filter(e=>!(!e||t&&e.orm!==t));return 0===r.length&&(console.error(l.red(t?`No ${t} project found.`:"No supported database ORM project found.")),process.exit(1)),r}function Ft(e){return"prisma"===e?At:wt}function*zt(e,t){const n=new Map(t.map(e=>[e.project,e]));for(const r of dt(e,t.map(({project:e})=>e))){const e=n.get(r);if(!e)throw new Error(`Failed to detect database ORM for ${r.name}.`);yield e}}function Mt(e,t=[]){const n=[],r=Object.keys(Ee),o=Object.values(Ee).flatMap(e=>"alias"in e?Array.isArray(e.alias)?e.alias:[e.alias]:[]).map(String),s=new Set([...t,...r,...o,"--","_","$0"]);for(const[t,r]of Object.entries(e))if(!s.has(t)){const o=t.replaceAll(/[A-Z]/g,e=>`-${e.toLowerCase()}`);if(o!==t&&void 0!==e[o])continue;if("boolean"==typeof r&&r)n.push(`--${t}`);else if("string"==typeof r||"number"==typeof r)n.push(`--${t}`,String(r));else if(Array.isArray(r))for(const e of r)n.push(`--${t}`,String(e))}const i=Array.isArray(e["--"])?e["--"].map(String):[];return Le([...n,...i])}const Ut={command:"retry [command] [args...]",describe:"Retry the given command until it succeeds",builder:{retry:{description:"A maximum retry count",type:"number",alias:"r",default:3}},async handler(e){const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));const n=[e.command,...e.args??[],...e._.slice(1)].filter(Boolean);let r=0;for(let o=0;o<e.retry;o++)if(o>0&&console.info(`\n${l.yellow(`#${o} Retrying: ${n.join(" ")}`)}`),r=await we(n.join(" "),t,e,{exitIfFailed:!1,onSignal:e=>{e&&process.exit(1)}}),0===r)return;process.exit(r)}},Wt={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await ne(e,!1,t);n||(console.error(l.red("No project found.")),process.exit(1));for(const t of dt("setup",n.descendants)){const r=await w.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===f.platform()){const n=["pstree"];await ye(`brew install ${n.join(" ")}`,t,e)}r.some(e=>e.isFile()&&e.name.includes("-version"))&&await we("asdf install",t,e,{exitIfFailed:!1})}if(r.some(e=>e.isFile()&&"pyproject.toml"===e.name)){await ye("poetry config virtualenvs.in-project true",t,e);const[,n]=o.execSync("asdf current python").toString().trim().split(/\s+/);await ye(`poetry env use ${n}`,t,e),await me.promiseAll(),await we("poetry run pip install --upgrade pip",t,e),await we("poetry install --ansi",t,e)}t!==n.root&&n.root.packageJson.scripts?.["gen-code"]||!t.packageJson.scripts?.["gen-code"]||await we(`${ce} gen-code`,t,e)}const r=n.descendants.find(e=>e.packageJson.devDependencies?.playwright);r&&await we(`${ce} playwright install --with-deps`,r,e)}(e)}};function Jt(e){return e.silent?" > /dev/null":""}const Yt=new Set;async function Vt(e,t){const n=await async function(e){for(const t of["127.0.0.1","::"]){if(!await Kt(t,e))return!1}return!0}(e);n||await qt(e,t);const r=async()=>{Yt.has(e)||(Yt.add(e),await qt(e,t))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,r)}async function qt(e,t){await async function(e,t){await async function(e,t){try{const n=await async function(e,t){const{stdout:n}=await j("docker",["ps","-q",...e],{cwd:t.dirPath,env:t.env});return n.split(/\s+/).map(e=>e.trim()).filter(Boolean)}(e,t);if(0===n.length)return;await j("docker",["rm","-f",...n],{cwd:t.dirPath,env:t.env})}catch{}}(["--filter",`publish=${e}`],t)}(e,t);try{await g(e)}catch{}}async function Gt(e,t){const n=Number(e);if(!n)throw new Error(`The given port (${n}) is invalid.`);return await Vt(n,t),n}async function Kt(e,t){return new Promise(n=>{const r=y();r.once("error",e=>{"EADDRINUSE"!==e.code?"EAFNOSUPPORT"!==e.code?n(!1):n(!0):n(!1)}),r.once("listening",()=>{r.close(()=>{n(!0)})}),r.listen(t,e)})}const Ht=new class{buildImage(e,n){const r=e.dockerPackageJson.scripts?.["docker/build/prepare"]?"YARN run docker/build/prepare && ":"";return`cd ${t.dirname(e.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${e.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n --build-arg WB_ENV=${e.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t="",n=""){return`${this.stop(e)} && ${this.start(e,t,n)}`}start(e,t="",n=""){!function(e,t){const n=()=>{if(Yt.has(e))return;Yt.add(e),ve(e,t);const{status:n}=a(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});ke(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e);return`docker run --rm ${n.includes("/bin/bash")?"-it ":""}--publish ${e.env.PORT}:8080 --name ${e.dockerImageName} ${t} ${e.dockerImageName} ${n}`}stop(e){return`true $(docker rm -f $(docker container ls -q -f name=${e.dockerImageName}) 2> /dev/null)`}stopAll(){return"true $(docker rm -f $(docker ps -q) 2> /dev/null)"}};class Qt{constructor(e){this.shouldWaitAndOpenApp=e}buildDocker(e,t){return Ht.buildImage(e,t)}async startDev(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",this.startDevProtected(e,t),this.waitAndOpenApp(e)]):this.startDevProtected(e,t)}async startProduction(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",this.startProductionProtected(e,t),this.waitAndOpenApp(e)]):this.startProductionProtected(e,t)}async startTest(e,t){return await Gt(e.env.PORT,e),this.startProductionProtected(e,t)}async startDocker(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?`${this.buildDocker(e,"development")}\n && ${Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??""),this.waitAndOpenApp(e)])}`:`${this.buildDocker(e,"development")}\n && ${Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProductionProtected(e,t){const n=function(e){try{return e.findFile("ecosystem.config.cjs")}catch{return}}(e),r=void 0===n?[("YARN wb buildIfNeeded "+(t.verbose?"--verbose":"")).trim(),`${e.isBunAvailable?"bun":"node"} dist/index.js ${t.normalizedArgsText??""}`.trim()]:[e.buildCommand,`pm2-runtime start --no-autorestart ${n}`];return[...[...e.hasPrisma?[At.migrate(e)]:[],...e.hasDrizzle?[wt.migrate(e)]:[]].flatMap(e=>e.split("&&")),...r].filter(Boolean).map(e=>`${e} ${Jt(t)}`.trim()).join(" && ")}testE2EDev(e,t,n){return this.testE2EProtected(e,t,this.startDevProtected(e,t),n)}testE2EProduction(e,t,n){return this.testE2EProtected(e,t,this.startProductionProtected(e,t),n)}testE2EDocker(e,t,n){return this.testE2EProtected(e,t,Ht.stopAndStart(e),n)}async testStart(e,t){return await Gt(e.env.PORT,e),`${n="NODE_ENV",r="",`${n}=${Fe(r)}`} ${Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",this.startDevProtected(e,t),this.waitApp(e)])}`;var n,r}async testE2EProtected(e,t,n,{forwardedPlaywrightArgs:r=[],playwrightArgs:o=["test","test/e2e/"]}){const s=await Gt(e.env.PORT,e),i=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",a=function(e,t,n,r=[]){const o=["BUN","playwright"],s=t?.map(String);if("test"!==e[0]||!s?.length)return Zt([...o,...e,...r],n);const i=e.slice(1),a=Xt(i),c=0===a.length?i:i.filter((e,t)=>!a.includes(t));return Zt([...o,"test",...s,...c,...r],n)}(o,t.targets,t.bail,r);return e.skipLaunchingServerForPlaywright?`${a}${i}`:Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",`${n} && exit 1`,`wait-on -t 600000 -i 2000 http-get://127.0.0.1:${s}\n && ${a}${i}`])}testUnit(e,t){const n=t.targets?.map(String);return e.hasVitest?Le(["YARN","vitest","run",...n?.length?n:["test/unit/"],"--color","--passWithNoTests","--allowOnly","--watch=false",...t.bail?["--bail=1"]:[]]):e.isBunAvailable?Le(["bun","test",...n?.length?n:["test/unit/"],...t.bail?["--bail"]:[]]):'echo "No tests."'}waitApp(e){const t=e.env.PORT;return`wait-on -t 10000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${t}`}waitAndOpenApp(e){const t=e.env.PORT;return`${this.waitApp(e)} || wait-on http-get://127.0.0.1:${t} && open-cli http://\${HOST:-localhost}:${t}`}}function Zt(e,t){const n=e.indexOf("playwright"),r=-1!==n&&"test"===e[n+1];return t&&r?e.some(e=>"--max-failures"===e||e.startsWith("--max-failures="))?Le(e):Le([...e,"--max-failures=1"]):Le(e)}function Xt(e){let t;const n=[];for(const[r,o]of e.entries()){if(t){if("required"===t||!o.startsWith("-")){t=void 0;continue}t=void 0}if("--"===o)return[...n,...e.slice(r+1).map((e,t)=>r+1+t)];if(o.startsWith("--")){if(o.includes("="))continue;en.has(o)?t="required":tn.has(o)&&(t="optional")}else{if(o.startsWith("-")&&"-"!==o){const e=o.slice(0,2);2===o.length&&nn.has(e)&&(t="required");continue}n.push(r)}}return n}const en=new Set(["--browser","--config","--grep","--grep-invert","--global-timeout","--max-failures","--output","--project","--repeat-each","--reporter","--retries","--shard","--test-list","--test-list-invert","--timeout","--trace","--tsconfig","--ui-host","--ui-port","--ui-title","--workers"]),tn=new Set(["--only-changed","--update-snapshots","--update-source-method"]),nn=new Set(["-c","-g","-j"]);const rn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`blitz dev ${t.normalizedArgsText??""}`}};const on=new class extends Qt{constructor(){super(!1)}startDevProtected(e,t){return`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`}async testE2EProtected(e,t,n,r={}){if(e.hasPlaywrightConfig)return super.testE2EProtected(e,t,n,r);const o=await Gt(e.env.PORT,e),s=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",i=t.targets?.map(String),a=i?.length?i:["test/e2e/"],c=this.testUnit(e,{...t,targets:a});return Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",`${n} && exit 1`,`wait-on -t 600000 -i 2000 http-get://127.0.0.1:${o} && ${c}${s}`])}};const sn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`next dev --turbopack ${t.normalizedArgsText??""}`}};const an=new class extends Qt{constructor(){super(!1)}startDevProtected(e,t){throw new Error("This method should not be called.")}startDev(e,t){return Promise.resolve(`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`)}startProduction(e,t){return Promise.resolve(`${e.buildCommand} && ${ie} dist/index.js ${t.normalizedArgsText??""} | tee server.log`)}startTest(){return Promise.resolve("echo 'do nothing.'")}startDocker(e,t){return Promise.resolve(`${this.buildDocker(e,"development")} && ${Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`)}testE2EDev(){return Promise.resolve("echo 'do nothing.'")}testE2EProduction(){return Promise.resolve("echo 'do nothing.'")}testE2EDocker(){return Promise.resolve("echo 'do nothing.'")}testStart(){return Promise.resolve("echo 'do nothing.'")}};const cn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`remix dev ${t.normalizedArgsText??""}`}};const ln=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`YARN vite dev ${t.normalizedArgsText??""}`.trim()}startProductionProtected(e,t){return`${e.buildCommand} && YARN vite preview ${t.normalizedArgsText??""}`.trim()}},dn=["express","fastify","elysia","hono"],un={watch:{description:"Whether to watch files",type:"boolean"},args:{description:"Arguments for core command",type:"array",alias:"a",default:[]},"docker-options":{description:'Arguments for "docker run"',type:"array",default:[]},mode:{description:"Start mode: dev[elopment] (default) | staging | docker | docker-debug | test",type:"string",alias:"m"}},pn={command:"start [args..]",describe:"Start app. Use '--' to stop wb option parsing and forward the remaining arguments to the underlying app command. Example: wb start -- --host 0.0.0.0",builder:e=>e.parserConfiguration({"populate--":!0}).options(un),async handler(e){!function(e){e.normalizedArgsText=[...e.args??[],...e._?.slice(1)??[],...e["--"]??[]].map(e=>Fe(String(e))).join(" "),e.normalizedDockerOptionsText=(e.dockerOptions??[]).map(e=>Fe(String(e))).join(" ")}(e);const t=await ne(e);t||(console.error(l.red("No project found.")),process.exit(1));for(const n of t.descendants){const t=n.packageJson.dependencies??{},r=n.packageJson.devDependencies??{};let o;if(t.blitz)o=rn;else if(t.next)o=sn;else if(r["@remix-run/dev"])o=cn;else if(r.vite)o=ln;else if(dn.some(e=>t[e])&&!t["firebase-functions"]||n.hasDockerfile&&/EXPOSE\s+8080/.test(n.dockerfile))o=on;else{if(!t["build-ts"]&&!r["build-ts"])continue;o=an}switch(console.info(`Running "start" for ${n.name} ...`),e.mode??"dev"){case"dev":case"development":process.env.WB_ENV||="development",await we(await o.startDev(n,e),n,e);break;case"staging":process.env.WB_ENV||="staging",await we(await o.startProduction(n,e),n,e);break;case"docker":process.env.WB_ENV||="staging",await we(await o.startDocker(n,e),n,e);break;case"docker-debug":process.env.WB_ENV||="staging",e.normalizedArgsText="'/bin/bash'",await we(await o.startDocker(n,e),n,e);break;case"test":{process.env.WB_ENV||="test";const t=await o.startTest(n,e);await we(t,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}},fn=new RegExp(`${String.fromCodePoint(27)}\\[[0-?]*[ -/]*[@-~]`,"g"),hn={e2e:{description:"E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace",type:"string",choices:["headless","headless-dev","headed","headed-dev","docker","docker-debug","debug","generate","trace"],default:"headless"},silent:{description:"Reduce redundant outputs",type:"boolean"},bail:{description:"Stop tests after the first failure",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"}},mn={targets:{description:"Test target paths",type:"array"}},gn={command:"test [targets...]",describe:"Test project. If you pass no arguments, it will run all tests. Use '--' to stop wb option parsing and forward the remaining flags to Playwright. Example: wb test -- --grep 'uploaded image asset'",builder:e=>e.parserConfiguration({"populate--":!0}).options({...hn,...mn}),async handler(e){await wn(e)}};async function wn(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1)),process.env.FORCE_COLOR||="3",delete process.env.NO_COLOR,process.env.WB_ENV||="test";const o=n.targets??[],s=n["--"]??[],{shouldRunE2e:i,shouldRunUnit:a}=function(e,t=[]){const n=e.some(e=>e.includes("/e2e")),r=e.some(e=>e.includes("/unit")),o=0===e.length&&0===t.length;return{shouldRunUnit:o||r,shouldRunE2e:o||n||t.length>0}}(o,s);for(const c of r.descendants){const r=c.packageJson.dependencies??{},l=c.packageJson.devDependencies??{};let d;d=r.blitz?rn:r.next?sn:l["@remix-run/dev"]?cn:l.vite?ln:dn.some(e=>r[e])&&!r["firebase-functions"]?on:an,console.info(`Running "test" for ${c.name} ...`);const u=yn(c);if(a&&!1!==u){const e=o.filter(e=>e.includes("/unit")),t=e.length>0?e:u.length>0?u:void 0,r={...n,targets:t};await vn(d.testUnit(c,r),c,n,{timeout:n.unitTimeout})}if(!i||!e.existsSync(t.join(c.dirPath,"test","e2e")))continue;const p=o.filter(e=>e.includes("/e2e")),f={...n,targets:p.length>0?p:void 0};switch(n.e2e){case"headless":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s),forwardedPlaywrightArgs:s}),c,n);continue;case"headless-dev":await vn(await d.testE2EDev(c,f,{playwrightArgs:Sn(p,s),forwardedPlaywrightArgs:s}),c,n);continue;case"docker":await bn(c,f,d,Sn(p,s),s);continue;case"docker-debug":await bn(c,f,d,Sn(p,s,["--debug"]),s);continue}if(r.blitz||r.next||l["@remix-run/dev"]||l.vite)switch(n.e2e){case"headed":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s,["--headed"]),forwardedPlaywrightArgs:s}),c,n);break;case"headed-dev":await vn(await d.testE2EDev(c,f,{playwrightArgs:Sn(p,s,["--headed"]),forwardedPlaywrightArgs:s}),c,n);break;case"debug":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s,["--debug"]),forwardedPlaywrightArgs:s}),c,n);break;case"generate":await vn(await d.testE2EProduction(c,f,{playwrightArgs:["codegen",`http://localhost:${c.env.PORT}`]}),c,n);break;case"trace":await vn("BUN playwright show-trace",c,n)}}}function yn(n){return e.existsSync(t.join(n.dirPath,"test","unit"))?[]:!(!n.hasVitest||!e.existsSync(t.join(n.dirPath,"test")))&&(e.existsSync(t.join(n.dirPath,"test","e2e"))?["test","--exclude","test/e2e/**"]:["test"])}async function bn(e,t,n,r,o){e.env.WB_DOCKER||="1",await we(`${n.buildDocker(e,"test")}${Jt(t)}`,e,t),process.exitCode=await vn(await n.testE2EDocker(e,t,{playwrightArgs:r,forwardedPlaywrightArgs:o}),e,t,{exitIfFailed:!1}),await we(Ht.stop(e),e,t)}function vn(e,t,n,r={}){return we(e,t,n,{...r,processSilentOutput:kn})}function kn(e){const t=[],n=new Set,r=[];for(const o of function*(e){let t=0;for(;t<=e.length;){const n=e.indexOf("\n",t);if(-1===n)return void(yield e.slice(t));yield e.slice(t,n),t=n+1}}(e)){const e=Pn(o);n.has(e)||(t.some(t=>En(t,e))||(An(t,n,e),r.push(o)))}return r.join("\n")}function An(e,t,n){if(e.push(n),t.add(n),e.length<=200)return;const r=e.shift();void 0!==r&&t.delete(r)}function Pn(e){return e.replaceAll(fn,"").trim().replaceAll(/^(?:\[[^\]]+\]\s*)+/g,"").replaceAll(/\(node:\d+\)/g,"(node:<number>)").replaceAll(/\b\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?Z?\b/g,"<timestamp>").replaceAll(/([?&]cache=)\d+/g,"$1<number>")}function En(e,t){const n=Math.max(e.length,t.length);return 0===n||!(Math.abs(e.length-t.length)>.05*n)&&b(e,t)/n<=.05}function Sn(e,t=[],n=[]){const r=Xt(t).length>0;return["test",...e.length>0||r?[]:["test/e2e/"],...n]}const $n={command:"test-on-ci",describe:"Test project on CI with no options.",builder:{silent:{description:"Reduce redundant outputs",type:"boolean"}},async handler(n){await async function(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1));process.env.CI||="1",process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";for(const o of r.descendants){const r=o.packageJson.dependencies??{},s=o.packageJson.devDependencies??{};let i;i=r.blitz?rn:r.next?sn:s["@remix-run/dev"]?cn:s.vite?ln:dn.some(e=>r[e])&&!r["firebase-functions"]?on:an,console.info(`Running "test-on-ci" for ${o.name} ...`);const a=o.hasDockerfile;if(a&&await ye(Ht.stopAll(),o,n),e.existsSync(t.join(o.dirPath,"test","unit"))&&await ye(i.testUnit(o,n).replaceAll(" --allowOnly",""),o,n),e.existsSync(t.join(o.dirPath,"test","e2e"))){await ye(await i.testStart(o,n),o,n),await me.promiseAll(),a&&(o.env.WB_DOCKER||="1",await we(`${i.buildDocker(o,"test")}${Jt(n)}`,o,n));const e=a?await i.testE2EDocker(o,n,{}):await i.testE2EProduction(o,n,{});process.exitCode=await we(e.replaceAll(" --allowOnly",""),o,n,{exitIfFailed:!1}),a&&await we(Ht.stop(o),o,n)}}}(n)}};const xn={command:"tree-kill <pid> [signal]",describe:"Kill the given process and all descendants",builder:e=>e.positional("pid",{description:"The process ID to kill.",type:"number",demandOption:!0}).option("signal",{description:"Signal to send to the process tree.",type:"string",default:"SIGTERM"}),handler(e){try{const t=e.signal;if(!(t in h.signals))throw new Error(`Invalid signal: ${t}`);E(e.pid,t)}catch(e){console.error(e instanceof Error?e.message:String(e)),process.exit(1)}}},Rn={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(n){process.exit(await async function(n){const r=await ne(n,!1);if(!r)return console.error(l.red("No project found.")),1;let o=!1;const s=r.descendants.map(async s=>{const i=[];for(s.packageJson.workspaces&&!s.hasSourceCode||i.push(...function(e){if(e.hasOwnDependency("@typescript/native-preview"))return["BUN tsgo --noEmit"];if(e.hasOwnDependency("typescript"))return["BUN tsc --noEmit"];return[]}(s)),!s.packageJson.workspaces&&s.hasOwnDependency("pyright")&&i.push("YARN pyright");i.length>0;){const a=await ye(i.join(" && "),s,n,{ci:r.descendants.length>1,exitIfFailed:!1,forceColor:!0}),c=t.join(s.dirPath,".next");if(!a||!e.existsSync(c))return a;e.rmSync(c,{force:!0,recursive:!0}),console.info(l.yellow("Removed `.next` directory. We will re-try type checking.")),o=!0}}),i=await Promise.all(s);let a=0;for(const[e,t]of i.entries())if(t){(r.descendants[e]?.packageJson.dependencies??{}).blitz&&console.info(l.yellow('Please try "yarn gen-code" if you face unknown type errors.')),a=t}a||console.info(l.green(o?"-----\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.":"No type errors found."));return a}(n))}};const jn={...Rn,command:"tc"},On={command:"verify",describe:"Verify project code",builder:{full:{type:"boolean",default:!1,describe:"Run tests after verifying project code"}},async handler(n){const r=re(n,!1);r||(console.error(l.red("No project found.")),process.exit(1)),await(n.full?async function(n,r){const o=function(n){const r=Date.now(),o=t.join(n.dirPath,".wb");e.mkdirSync(o,{recursive:!0});const s=t.join(o,"verify-full.log"),i=e.openSync(s,"w"),a=process.stdout.write.bind(process.stdout),c=process.stderr.write.bind(process.stderr);let d=!1,u=!1;process.stdout.write=Cn(process.stdout.fd,i),process.stderr.write=Cn(process.stderr.fd,i),console.info(l.cyan(l.bold("Full log:"),s));const p=()=>{if(u)return;u=!0,process.stdout.write=a,process.stderr.write=c;const t=function(e){const t=Math.round(e/1e3),n=Math.floor(t/60),r=t%60;if(0===n)return`${r}s`;return`${n}m ${r}s`}(Date.now()-r),n=`${d?"Succeeded":"Failed"} in ${t}. Full log: ${s}\n`,o=d?l.green(n):l.red(n);a(o),e.writeSync(i,n),e.closeSync(i)};return process.once("exit",p),{fail:e=>{d=!1,e&&console.error(e)},finish:()=>{process.removeListener("exit",p),p()},succeed:()=>{d=!0}}}(n);try{await Dn(n,r),await async function(e,t){await wn({...t,_:["test"],e2e:"headless",silent:!0})}(0,r),o.succeed()}catch(e){throw o.fail(e),e}finally{o.finish()}}(r.self,n):Dn(r.self,n))}};async function Dn(e,t){await Tn(`${ae} install`,e,t),e.packageJson.scripts?.["gen-code"]&&await Tn(`${ae} gen-code`,e,t),await Nn("format",()=>Ge({...t,_:["lint"],format:!0,printAllOutput:!0,silent:!0}),{allowFailure:!0,silent:!0}),await Nn("lint-fix",()=>Ge({...t,_:["lint"],fix:!0,printAllOutput:!0,quiet:!0,silent:!0}),{silent:!0})}async function Nn(e,t,n={}){n.silent||console.info("\n"+l.cyan(l.bold("Start:"),e));const r=await t()??0;return 0===r||n.allowFailure?n.silent||console.info(l.green(l.bold("Finished:"),e)):(console.info(l.red(l.bold(`Failed (exit code ${r}):`),e)),process.exit(r)),r}async function Tn(e,t,n,r={}){if(function(e,t){console.info("\n"+l.cyan(l.bold("Command:"),e)+l.gray(` at ${t}`))}(e,t.dirPath),n.dryRun)return 0;const o=await j(e,void 0,{cwd:t.dirPath,env:Ae(t.env,{forceColor:!1}),shell:!0,stdio:"pipe",mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose}),s=o.status??1;return r.printRawOutput||function(e,t,n){if(0===t&&(e===`${ae} install`||e===`${ae} gen-code`))return void console.info(l.green("Succeeded."));const r=n.trim();r&&(process.stdout.write(r),process.stdout.write("\n"))}(e,s,o.stdout),0===s||r.allowFailure||(console.info(l.red(l.bold(`Failed (exit code ${s}):`),e)),process.exit(s)),s}function Cn(t,n){return(r,o,s)=>{const i="string"==typeof r?Buffer.from(r,"string"==typeof o?o:"utf8"):r;return e.writeSync(n,i),e.writeSync(t,i),"function"==typeof o&&o(),s?.(),!0}}await n(r(process.argv)).scriptName("wb").options(Ee).middleware(e=>{const n=e["working-dir"];if(n){const e=t.resolve(n);process.chdir(e)}!function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const t of Object.keys(e)){const n=t.toUpperCase();(n.startsWith("NPM_")||n.startsWith("YARN_")||n.startsWith("BERRY_")||"PROJECT_CWD"===n||"INIT_CWD"===n)&&delete e[t]}}(process.env)}).command(On).command(le).command(xe).command(Ie).command(qe).command(pt).command(Et).command(Ut).command(Wt).command(pn).command(gn).command($n).command(xn).command(Rn).command(jn).demandCommand().strict().version(function(){let n=t.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(t.join(n,"package.json"));)n=t.dirname(n);return JSON.parse(e.readFileSync(t.join(n,"package.json"),"utf8")).version}()).help().argv;let In=!1;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,()=>{if(!In){In=!0;try{E(process.pid)}catch(e){console.warn(`Failed to treeKill(${process.pid}) during shutdown:`,e)}process.exit()}});
10
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../../shared-lib-node/src/env.ts","../../shared-lib-node/src/errno.ts","../../shared-lib-node/src/treeKill.ts","../../shared-lib-node/src/processTree.ts","../../shared-lib-node/src/spawn.ts","../../../node_modules/at-decorators/dist/hash.js","../../../node_modules/at-decorators/dist/oson/constructors.js","../../../node_modules/at-decorators/dist/oson/stringify.js","../../../node_modules/at-decorators/dist/getCacheKey.js","../../../node_modules/at-decorators/dist/memoizeOne.js","../src/utils/ci.ts","../src/project.ts","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/utils/promisePool.ts","../src/scripts/run.ts","../src/sharedOptionsBuilder.ts","../src/commands/concurrently.ts","../src/commands/killPortIfNonCi.ts","../src/utils/output.ts","../src/utils/shell.ts","../src/commands/lint.ts","../src/commands/commandUtils.ts","../src/commands/optimizeForDockerBuild.ts","../src/scripts/drizzleScripts.ts","../src/scripts/prismaScripts.ts","../src/commands/prisma.ts","../src/commands/retry.ts","../src/commands/setup.ts","../src/scripts/builder.ts","../src/utils/process.ts","../src/utils/port.ts","../src/scripts/dockerScripts.ts","../src/scripts/execution/baseScripts.ts","../src/scripts/execution/blitzScripts.ts","../src/scripts/execution/httpServerScripts.ts","../src/scripts/execution/nextScripts.ts","../src/scripts/execution/plainAppScripts.ts","../src/scripts/execution/remixScripts.ts","../src/scripts/execution/viteScripts.ts","../src/commands/httpServerPackages.ts","../src/commands/start.ts","../src/commands/test.ts","../src/commands/testOnCi.ts","../src/commands/treeKill.ts","../src/commands/typecheck.ts","../src/commands/verifyCode.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\nimport { expand } from 'dotenv-expand';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const yargsOptionsBuilderForEnv = {\n  env: {\n    description: '.env files to be loaded.',\n    type: 'array',\n  },\n  'cascade-env': {\n    description:\n      'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n    type: 'string',\n  },\n  'cascade-node-env': {\n    description: 'Same with --cascade-env=<NODE_ENV || \"development\">. Preferred over `auto-cascade-env`.',\n    type: 'boolean',\n  },\n  'auto-cascade-env': {\n    description: 'Same with --cascade-env=<WB_ENV || NODE_ENV || \"development\">.',\n    type: 'boolean',\n    default: true,\n  },\n  'include-root-env': {\n    description: 'Include .env files in root directory if the project is in a monorepo and --env option is not used.',\n    type: 'boolean',\n    default: true,\n  },\n  'check-env': {\n    description: 'Check whether the keys of the loaded .env files are same with the given .env file.',\n    type: 'string',\n    default: '.env.example',\n  },\n  verbose: {\n    description: 'Whether to show verbose information',\n    type: 'boolean',\n    alias: 'v',\n  },\n} as const;\n\nexport type EnvReaderOptions = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof yargsOptionsBuilderForEnv>>>;\n\n/**\n * This function reads environment variables from `.env` files.\n * Note it does not assign them in `process.env`.\n * @return [envVars, [envPaths, envVarNames][]]\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): [Record<string, string>, [string, string[]][]] {\n  let envPaths = (argv.env ?? []).map((envPath) => path.resolve(cwd, envPath.toString()));\n  const cascade =\n    argv.cascadeEnv ??\n    (argv.cascadeNodeEnv\n      ? process.env.NODE_ENV || 'development'\n      : argv.autoCascadeEnv\n        ? process.env.WB_ENV || process.env.NODE_ENV || 'development'\n        : undefined);\n  if (typeof cascade === 'string') {\n    if (envPaths.length === 0) {\n      envPaths.push(path.join(cwd, '.env'));\n      if (argv.includeRootEnv) {\n        const rootPath = path.resolve(cwd, '..', '..');\n        if (fs.existsSync(path.join(rootPath, 'package.json'))) {\n          envPaths.push(path.join(rootPath, '.env'));\n        }\n      }\n    }\n    envPaths = envPaths.flatMap((envPath) =>\n      cascade\n        ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n        : [`${envPath}.local`, envPath]\n    );\n  }\n  envPaths = envPaths.filter((envPath) => fs.existsSync(envPath)).map((envPath) => path.relative(cwd, envPath));\n  if (argv.verbose) {\n    console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`);\n    console.info('Reading env files:', envPaths.join(', '));\n  }\n\n  const envPathAndLoadedEnvVarNames: [string, string[]][] = [];\n  const envVars: Record<string, string> = {};\n  for (const envPath of envPaths) {\n    const keys: string[] = [];\n    for (const [key, value] of Object.entries(readEnvFile(path.join(cwd, envPath)))) {\n      if (!(key in envVars) && !(key in process.env)) {\n        envVars[key] = value;\n        keys.push(key);\n      }\n    }\n    envPathAndLoadedEnvVarNames.push([envPath, keys]);\n    if (argv.verbose && keys.length > 0) {\n      console.info(`Read ${keys.length} environment variables from ${envPath}`);\n    }\n  }\n  if (!argv.verbose) {\n    console.info(\n      `Read env files: ${envPathAndLoadedEnvVarNames.map(([envPath, keys]) => (keys.length > 0 ? `${envPath} (${keys.join(', ')})` : envPath)).join(', ') || 'nothing'}`\n    );\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv)));\n    const missingKeys = exampleKeys.filter((key) => !(key in envVars) && !(key in process.env));\n    if (missingKeys.length > 0) {\n      throw new Error(`Missing environment variables in [${envPaths.join(', ')}]: [${missingKeys.join(', ')}]`);\n    }\n  }\n  return [expand({ parsed: envVars, processEnv: {} }).parsed ?? envVars, envPathAndLoadedEnvVarNames];\n}\n\n/**\n * This function read environment variables from `.env` files and assign them in `process.env`.\n * */\nexport function readAndApplyEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): Record<string, string | undefined> {\n  const [envVars] = readEnvironmentVariables(argv, cwd);\n  for (const [key, value] of Object.entries(envVars)) {\n    if (!(key in process.env)) {\n      process.env[key] = value;\n    }\n  }\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string): Record<string, string> {\n  const cached = cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {}, quiet: true }).parsed ?? {};\n  cachedEnvVars.set(filePath, parsed);\n  return parsed;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n  // Remove npm & yarn environment variables from process.env\n  if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n    envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n      // Temporary directory in macOS\n      .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n      // Temporary directories in Linux\n      .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n      .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n  }\n  for (const key of Object.keys(envVars)) {\n    const upperKey = key.toUpperCase();\n    if (\n      upperKey.startsWith('NPM_') ||\n      upperKey.startsWith('YARN_') ||\n      upperKey.startsWith('BERRY_') ||\n      upperKey === 'PROJECT_CWD' ||\n      upperKey === 'INIT_CWD'\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete envVars[key];\n    }\n  }\n}\n","export function isErrnoException(error: unknown): error is NodeJS.ErrnoException {\n  return error instanceof Error && 'code' in error;\n}\n","import { execFileSync } from 'node:child_process';\n\nimport { isErrnoException } from './errno.js';\nimport { buildChildrenByParentMap, collectDescendantPids as collectDescendantPidsFromMap } from './processTree.js';\n\nexport function treeKill(pid: number, signal: NodeJS.Signals = 'SIGTERM'): void {\n  if (!Number.isInteger(pid) || pid <= 0) {\n    throw new Error(`Invalid pid: ${pid}`);\n  }\n\n  if (process.platform === 'win32') {\n    killTreeOnWindows(pid);\n    return;\n  }\n\n  const descendants = collectDescendantPids(pid);\n  const targetPids = toChildrenFirstPids(pid, descendants);\n  for (const targetPid of targetPids) {\n    killIfNeeded(targetPid, signal);\n  }\n}\n\nfunction killIfNeeded(pid: number, signal: NodeJS.Signals): void {\n  try {\n    process.kill(pid, signal);\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return;\n    }\n    throw error;\n  }\n}\n\nfunction killTreeOnWindows(pid: number): void {\n  try {\n    runCommand('taskkill', ['/PID', String(pid), '/T', '/F'], {\n      maxBuffer: 1024 * 1024,\n      timeout: 2000,\n    });\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return;\n    }\n    throw error;\n  }\n}\n\nfunction collectDescendantPids(rootPid: number): number[] {\n  const { stdout } = runCommand(\n    'ps',\n    ['-Ao', 'pid=,ppid='],\n    // Keep command bounded so watch-mode kill loops cannot hang this path.\n    { maxBuffer: 1024 * 1024, timeout: 2000 }\n  );\n  const childrenByParent = buildChildrenByParentMap(stdout);\n  return collectDescendantPidsFromMap(rootPid, childrenByParent);\n}\n\nfunction toChildrenFirstPids(pid: number, descendants: readonly number[]): number[] {\n  const targetPids = descendants.toReversed();\n  targetPids.push(pid);\n  return targetPids;\n}\n\nfunction runCommand(\n  command: string,\n  args: readonly string[],\n  options?: { timeout: number; maxBuffer: number }\n): { stdout: string; stderr: string } {\n  try {\n    const stdout = execFileSync(command, [...args], {\n      encoding: 'utf8',\n      maxBuffer: options?.maxBuffer,\n      timeout: options?.timeout,\n      stdio: ['ignore', 'pipe', 'pipe'],\n    });\n    return { stdout, stderr: '' };\n  } catch (error) {\n    const stderr = extractStderr(error);\n    throw new CommandExecutionError(command, args, stderr, toExitCode(error));\n  }\n}\n\nfunction isNoSuchProcessError(error: unknown): boolean {\n  if (isErrnoException(error) && error.code === 'ESRCH') {\n    return true;\n  }\n\n  if (error instanceof CommandExecutionError) {\n    return /no such process|not found|not recognized|there is no running instance/i.test(error.stderr);\n  }\n  return false;\n}\n\nfunction toExitCode(error: unknown): number | string | undefined {\n  if (isErrnoException(error)) {\n    return error.code;\n  }\n  if (typeof error === 'object' && error !== null && 'status' in error) {\n    const status = (error as { status: unknown }).status;\n    if (typeof status === 'number') {\n      return status;\n    }\n  }\n  return undefined;\n}\n\nfunction extractStderr(error: unknown): string {\n  if (typeof error !== 'object' || error === null || !('stderr' in error)) {\n    return '';\n  }\n\n  const stderr = (error as Record<'stderr', unknown>).stderr;\n  if (typeof stderr === 'string') {\n    return stderr;\n  }\n  if (Buffer.isBuffer(stderr)) {\n    return stderr.toString('utf8');\n  }\n  return '';\n}\n\nclass CommandExecutionError extends Error {\n  readonly stderr: string;\n  readonly code: number | string | undefined;\n\n  constructor(command: string, args: readonly string[], stderr: string, code: number | string | undefined) {\n    super(`Command failed: ${command} ${args.join(' ')}`);\n    this.name = 'CommandExecutionError';\n    this.stderr = stderr;\n    this.code = code;\n  }\n}\n","export function buildChildrenByParentMap(psOutput: string): Map<number, number[]> {\n  const childrenByParent = new Map<number, number[]>();\n  for (const line of psOutput.split('\\n')) {\n    const matched = /^\\s*(\\d+)\\s+(\\d+)\\s*$/.exec(line);\n    if (!matched) {\n      continue;\n    }\n\n    const childPid = Number(matched[1]);\n    const parentPid = Number(matched[2]);\n    const children = childrenByParent.get(parentPid);\n    if (children) {\n      children.push(childPid);\n    } else {\n      childrenByParent.set(parentPid, [childPid]);\n    }\n  }\n  return childrenByParent;\n}\n\nexport function collectDescendantPids(rootPid: number, childrenByParent: Map<number, number[]>): number[] {\n  const descendants: number[] = [];\n  const queue = [...(childrenByParent.get(rootPid) ?? [])];\n  let index = 0;\n  while (index < queue.length) {\n    const pid = queue[index] as number;\n    index += 1;\n    descendants.push(pid);\n    queue.push(...(childrenByParent.get(pid) ?? []));\n  }\n  return descendants;\n}\n","import type {\n  SpawnOptions,\n  SpawnOptionsWithoutStdio,\n  SpawnOptionsWithStdioTuple,\n  SpawnSyncReturns,\n  StdioNull,\n  StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport { treeKill } from './treeKill.js';\n\n/**\n * Return type for spawnAsync function, based on SpawnSyncReturns but without output and error properties\n */\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\n/**\n * Options for spawnAsync function, extending various Node.js spawn options with additional functionality\n */\nexport type SpawnAsyncOptions = (\n  | SpawnOptionsWithoutStdio\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n  | SpawnOptions\n) & {\n  /** Input string to write to the spawned process's stdin */\n  input?: string;\n  /** If true, stderr output will be merged into stdout */\n  mergeOutAndError?: boolean;\n  /** If true, the spawned process will be killed when the parent process exits */\n  killOnExit?: boolean;\n  /** If true, enables verbose logging of process operations */\n  verbose?: boolean;\n  /** If true, stdout data will be printed to console as it's received */\n  printingStdout?: boolean;\n  /** If true, stderr data will be printed to console as it's received */\n  printingStderr?: boolean;\n  /** If true, blank-only lines are skipped while printing stdout/stderr in realtime */\n  omitBlankLinesWhilePrinting?: boolean;\n};\n\n/**\n * Spawns a child process asynchronously and returns a promise that resolves with the process results\n *\n * This function provides a Promise-based wrapper around Node.js's spawn function with additional features:\n * - Automatic encoding of stdout/stderr as UTF-8\n * - Option to merge stderr into stdout\n * - Option to automatically kill the process on parent exit\n * - Option to provide input via stdin\n * - Verbose logging capability\n *\n * @param command - The command to run\n * @param args - List of string arguments\n * @param options - Configuration options for the spawned process\n * @returns Promise that resolves with the process results including pid, stdout, stderr, status, and signal\n * @throws Will reject the promise if the process fails to spawn or encounters an error\n *\n * @example\n * ```typescript\n * const result = await spawnAsync('ls', ['-la'], { verbose: true });\n * console.log(result.stdout);\n * ```\n */\nexport async function spawnAsync(\n  command: string,\n  args?: readonly string[],\n  options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n  return new Promise((resolve, reject) => {\n    try {\n      const proc = spawn(command, args ?? [], options ?? {});\n      // `setEncoding` is undefined in Bun\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stdout?.setEncoding?.('utf8');\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      const stdoutPrinter = createRealtimePrinter(process.stdout, options?.omitBlankLinesWhilePrinting);\n      const stderrPrinter = createRealtimePrinter(process.stderr, options?.omitBlankLinesWhilePrinting);\n      proc.stdout?.on('data', (data: string) => {\n        stdout += data;\n        if (options?.printingStdout) {\n          stdoutPrinter.write(data);\n        }\n      });\n      proc.stderr?.on('data', (data: string) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += data;\n        }\n        if (options?.printingStderr) {\n          stderrPrinter.write(data);\n        }\n      });\n\n      let stopped = false;\n      const stopProcess = (): void => {\n        if (stopped || !proc.pid) return;\n\n        stopped = true;\n        if (options?.verbose) {\n          console.info(`treeKill(${proc.pid})`);\n        }\n        try {\n          treeKill(proc.pid);\n        } catch (error) {\n          if (options?.verbose) {\n            console.warn(`Failed to treeKill(${proc.pid})`, error);\n          }\n        }\n      };\n      const cleanupSignals: NodeJS.Signals[] =\n        process.platform === 'win32' ? ['SIGINT', 'SIGTERM'] : ['SIGINT', 'SIGTERM', 'SIGQUIT'];\n      const signalHandlers = new Map<NodeJS.Signals, () => void>();\n      const removeKillOnExitHandlers = (): void => {\n        process.removeListener('beforeExit', stopProcess);\n        for (const [signal, handler] of signalHandlers) {\n          process.removeListener(signal, handler);\n        }\n        signalHandlers.clear();\n      };\n      if (options?.killOnExit) {\n        process.on('beforeExit', stopProcess);\n        for (const signal of cleanupSignals) {\n          const handleSignal = (): void => {\n            stopProcess();\n            removeKillOnExitHandlers();\n            if (process.listenerCount(signal) === 0) {\n              process.kill(process.pid, signal);\n            }\n          };\n          signalHandlers.set(signal, handleSignal);\n          process.on(signal, handleSignal);\n        }\n      }\n\n      proc.on('error', (error) => {\n        removeKillOnExitHandlers();\n        proc.removeAllListeners('close');\n        reject(error);\n      });\n      proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n        removeKillOnExitHandlers();\n        stdoutPrinter.flush();\n        stderrPrinter.flush();\n        if (proc.pid === undefined) {\n          reject(new Error('Process has no pid.'));\n        } else {\n          resolve({\n            pid: proc.pid,\n            stdout,\n            stderr,\n            status: code,\n            signal,\n          });\n        }\n      });\n\n      if (options?.input) {\n        proc.stdin?.write(options.input);\n        proc.stdin?.end();\n      }\n    } catch (error) {\n      // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n      reject(error);\n    }\n  });\n}\n\nconst ANSI_ESCAPE_CODE_REGEXP = new RegExp(`${String.fromCodePoint(27)}\\\\[[0-?]*[ -/]*[@-~]`, 'g');\n\nfunction createRealtimePrinter(\n  stream: NodeJS.WriteStream,\n  omitBlankLines = false\n): { write: (data: string) => void; flush: () => void } {\n  if (!omitBlankLines) {\n    return {\n      write: (data) => stream.write(data),\n      flush: () => {},\n    };\n  }\n\n  let pending = '';\n  return {\n    write: (data) => {\n      pending += data;\n      const lines = pending.split(/\\r?\\n/);\n      pending = lines.pop() ?? '';\n      for (const line of lines) {\n        if (!isBlankLine(line)) {\n          stream.write(`${line}\\n`);\n        }\n      }\n    },\n    flush: () => {\n      if (!isBlankLine(pending)) {\n        stream.write(pending);\n      }\n      pending = '';\n    },\n  };\n}\n\nfunction isBlankLine(line: string): boolean {\n  return line.replaceAll(ANSI_ESCAPE_CODE_REGEXP, '').trim().length === 0;\n}\n","/**\n * [js-sha3]{@link https://github.com/emn178/js-sha3}\n *\n * @version 0.9.3\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2015-2023\n * @license MIT\n */\nconst t=[...\"0123456789abcdef\"],s=[6,1536,393216,100663296],i=[0,8,16,24],e=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];function o(t){return new h(512,s,512).update(t).hex()}const n=t=>{const s=[];for(const[i,e]of t.entries())s[i]=e;return s};class h{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(t,s,i){this.padding=s,this.outputBits=i,this.blockCount=1600-(t<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=i>>5,this.extraBytes=(31&i)>>3;for(let t=0;t<50;++t)this.s[t]=0}update(t){if(this.finalized)throw new Error(\"finalize already called\");const s=this.blocks,e=this.byteCount,o=t.length,n=this.blockCount,h=this.s;let l,c,f=0;for(;f<o;){if(this.reset)for(this.reset=!1,s[0]=this.block,l=1;l<n+1;++l)s[l]=0;for(l=this.start;f<o&&l<e;++f)c=t.codePointAt(f)||0,c<128?s[l>>2]|=c<<i[3&l++]:c<2048?(s[l>>2]|=(192|c>>6)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):c<55296||c>=57344?(s[l>>2]|=(224|c>>12)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):(c=65536+((1023&c)<<10|1023&(t.codePointAt(++f)||0)),s[l>>2]|=(240|c>>18)<<i[3&l++],s[l>>2]|=(128|c>>12&63)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]);if(this.lastByteIndex=l,l>=e){for(this.start=l-e,this.block=s[n],l=0;l<n;++l)h[l]^=s[l];r(h),this.reset=!0}else this.start=l}return this}finalize(){if(this.finalized)return;this.finalized=!0;const t=this.blocks;let s=this.lastByteIndex;const i=this.blockCount,e=this.s;if(t[s>>2]|=this.padding[3&s],this.lastByteIndex===this.byteCount)for(t[0]=t[i],s=1;s<i+1;++s)t[s]=0;for(t[i-1]|=2147483648,s=0;s<i;++s)e[s]^=t[s];r(e)}hex(){this.finalize();const s=this.blockCount;let i=this.s;const e=this.outputBlocks,o=this.extraBytes;let h,l=0,c=0,f=\"\";for(;c<e;){for(l=0;l<s&&c<e;++l,++c)h=i[l],f+=t[h>>4&15]+t[15&h]+t[h>>12&15]+t[h>>8&15]+t[h>>20&15]+t[h>>16&15]+t[h>>28&15]+t[h>>24&15];c%s===0&&(i=n(i),r(i),l=0)}return o&&(h=i[l],f+=t[h>>4&15]+t[15&h],o>1&&(f+=t[h>>12&15]+t[h>>8&15]),o>2&&(f+=t[h>>20&15]+t[h>>16&15])),f}}const r=function(t){let s,i,o,n,h,r,l,c,f,a,u,d,b,k,y,x,B,p,C,z,I,g,w,A,P,E,j,m,q,v,D,F,G,H,J,K,L,M,N,O,Q,R,S,T,U,V,W,X,Y,Z,$,_,tt,st,it,et,ot,nt,ht,rt,lt,ct,ft;for(o=0;o<48;o+=2)n=t[0]^t[10]^t[20]^t[30]^t[40],h=t[1]^t[11]^t[21]^t[31]^t[41],r=t[2]^t[12]^t[22]^t[32]^t[42],l=t[3]^t[13]^t[23]^t[33]^t[43],c=t[4]^t[14]^t[24]^t[34]^t[44],f=t[5]^t[15]^t[25]^t[35]^t[45],a=t[6]^t[16]^t[26]^t[36]^t[46],u=t[7]^t[17]^t[27]^t[37]^t[47],d=t[8]^t[18]^t[28]^t[38]^t[48],b=t[9]^t[19]^t[29]^t[39]^t[49],s=d^(r<<1|l>>>31),i=b^(l<<1|r>>>31),t[0]^=s,t[1]^=i,t[10]^=s,t[11]^=i,t[20]^=s,t[21]^=i,t[30]^=s,t[31]^=i,t[40]^=s,t[41]^=i,s=n^(c<<1|f>>>31),i=h^(f<<1|c>>>31),t[2]^=s,t[3]^=i,t[12]^=s,t[13]^=i,t[22]^=s,t[23]^=i,t[32]^=s,t[33]^=i,t[42]^=s,t[43]^=i,s=r^(a<<1|u>>>31),i=l^(u<<1|a>>>31),t[4]^=s,t[5]^=i,t[14]^=s,t[15]^=i,t[24]^=s,t[25]^=i,t[34]^=s,t[35]^=i,t[44]^=s,t[45]^=i,s=c^(d<<1|b>>>31),i=f^(b<<1|d>>>31),t[6]^=s,t[7]^=i,t[16]^=s,t[17]^=i,t[26]^=s,t[27]^=i,t[36]^=s,t[37]^=i,t[46]^=s,t[47]^=i,s=a^(n<<1|h>>>31),i=u^(h<<1|n>>>31),t[8]^=s,t[9]^=i,t[18]^=s,t[19]^=i,t[28]^=s,t[29]^=i,t[38]^=s,t[39]^=i,t[48]^=s,t[49]^=i,k=t[0],y=t[1],V=t[11]<<4|t[10]>>>28,W=t[10]<<4|t[11]>>>28,m=t[20]<<3|t[21]>>>29,q=t[21]<<3|t[20]>>>29,rt=t[31]<<9|t[30]>>>23,lt=t[30]<<9|t[31]>>>23,R=t[40]<<18|t[41]>>>14,S=t[41]<<18|t[40]>>>14,H=t[2]<<1|t[3]>>>31,J=t[3]<<1|t[2]>>>31,x=t[13]<<12|t[12]>>>20,B=t[12]<<12|t[13]>>>20,X=t[22]<<10|t[23]>>>22,Y=t[23]<<10|t[22]>>>22,v=t[33]<<13|t[32]>>>19,D=t[32]<<13|t[33]>>>19,ct=t[42]<<2|t[43]>>>30,ft=t[43]<<2|t[42]>>>30,st=t[5]<<30|t[4]>>>2,it=t[4]<<30|t[5]>>>2,K=t[14]<<6|t[15]>>>26,L=t[15]<<6|t[14]>>>26,p=t[25]<<11|t[24]>>>21,C=t[24]<<11|t[25]>>>21,Z=t[34]<<15|t[35]>>>17,$=t[35]<<15|t[34]>>>17,F=t[45]<<29|t[44]>>>3,G=t[44]<<29|t[45]>>>3,A=t[6]<<28|t[7]>>>4,P=t[7]<<28|t[6]>>>4,et=t[17]<<23|t[16]>>>9,ot=t[16]<<23|t[17]>>>9,M=t[26]<<25|t[27]>>>7,N=t[27]<<25|t[26]>>>7,z=t[36]<<21|t[37]>>>11,I=t[37]<<21|t[36]>>>11,_=t[47]<<24|t[46]>>>8,tt=t[46]<<24|t[47]>>>8,T=t[8]<<27|t[9]>>>5,U=t[9]<<27|t[8]>>>5,E=t[18]<<20|t[19]>>>12,j=t[19]<<20|t[18]>>>12,nt=t[29]<<7|t[28]>>>25,ht=t[28]<<7|t[29]>>>25,O=t[38]<<8|t[39]>>>24,Q=t[39]<<8|t[38]>>>24,g=t[48]<<14|t[49]>>>18,w=t[49]<<14|t[48]>>>18,t[0]=k^~x&p,t[1]=y^~B&C,t[10]=A^~E&m,t[11]=P^~j&q,t[20]=H^~K&M,t[21]=J^~L&N,t[30]=T^~V&X,t[31]=U^~W&Y,t[40]=st^~et&nt,t[41]=it^~ot&ht,t[2]=x^~p&z,t[3]=B^~C&I,t[12]=E^~m&v,t[13]=j^~q&D,t[22]=K^~M&O,t[23]=L^~N&Q,t[32]=V^~X&Z,t[33]=W^~Y&$,t[42]=et^~nt&rt,t[43]=ot^~ht&lt,t[4]=p^~z&g,t[5]=C^~I&w,t[14]=m^~v&F,t[15]=q^~D&G,t[24]=M^~O&R,t[25]=N^~Q&S,t[34]=X^~Z&_,t[35]=Y^~$&tt,t[44]=nt^~rt&ct,t[45]=ht^~lt&ft,t[6]=z^~g&k,t[7]=I^~w&y,t[16]=v^~F&A,t[17]=D^~G&P,t[26]=O^~R&H,t[27]=Q^~S&J,t[36]=Z^~_&T,t[37]=$^~tt&U,t[46]=rt^~ct&st,t[47]=lt^~ft&it,t[8]=g^~k&x,t[9]=w^~y&B,t[18]=F^~A&E,t[19]=G^~P&j,t[28]=R^~H&K,t[29]=S^~J&L,t[38]=_^~T&V,t[39]=tt^~U&W,t[48]=ct^~st&et,t[49]=ft^~it&ot,t[0]^=e[o],t[1]^=e[o+1]};export{o as sha3_512};\n//# sourceMappingURL=hash.js.map\n","const e=\"\",t=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,a,s])=>{e.name=t,e.message=n,void 0===a?delete e.stack:e.stack=a,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(a.decode(e))],create:([e])=>n.encode(atob(e))},s={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,a]of t)e.set(n,a)}},o={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},r={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},c={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},d={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,s,o,r,c,d].map(e=>[e.instance.name,e]))}(),n=new TextEncoder,a=new TextDecoder(\"utf-8\");export{t as GLOBAL_CONSTRUCTOR_MAP,e as PLAIN_OBJECT_LABEL};\n//# sourceMappingURL=constructors.js.map\n","import{GLOBAL_CONSTRUCTOR_MAP as t,PLAIN_OBJECT_LABEL as n}from\"./constructors.js\";const e=-1,r=-2,o=-3,i=-4,s=-5,c=-6;function f(n,e=t){return JSON.stringify(a(n,e))}function u(t){if(void 0===t)return-1;if(\"number\"==typeof t){if(Number.isNaN(t))return-3;if(!Number.isFinite(t))return t<0?-5:-4}return null}const l=[];function a(e,r=t){const o=u(e);if(null!==o)return o;const i=[],s=new Map;return function t(e){const o=u(e);if(null!==o)return o;let c=s.get(e);if(void 0!==c)return c;switch(c=i.length,typeof e){case\"number\":case\"string\":case\"boolean\":i[c]=e,s.set(e,c);break;case\"bigint\":i[c]=[-6,e.toString(16)],s.set(e,c);break;case\"object\":if(null===e)i[c]=e,s.set(e,c);else if(Array.isArray(e)){const n=function(t){if(l.length<t){const n=l.length;l.length=t,l.fill(-2,n,t)}return l.slice(0,t)}(e.length);i[c]=n,s.set(e,c);for(const[r,o]of e.entries())n[r]=t(o)}else{const[o,f]=function(t,e){const r=t.constructor;if(\"function\"==typeof r){const n=r.name,o=e.get(n);if(void 0!==o)return[n,o.from(t)]}const o=Object.entries(t),i=o.length,s=Array.from({length:i+i});for(let t=0;t<i;t++){const n=o[t],e=t+t;s[e]=n[0],s[e+1]=n[1]}return[n,s]}(e,r),u=f.length,l=Array.from({length:u+1});l[0]=o,i[c]=l,s.set(e,c);for(let n=0;n<u;n++)l[n+1]=t(f[n])}}return c}(e),i}export{r as ARRAY_HOLE_INDEX,c as BIG_INT_LABEL,o as NAN_INDEX,s as NEG_INF_INDEX,i as POS_INF_INDEX,e as UNDEFINED_INDEX,a as listify,f as stringify};\n//# sourceMappingURL=stringify.js.map\n","import{sha3_512 as r}from\"./hash.js\";import{stringify as n}from\"./oson/stringify.js\";function o(o,t){return r(n([o,t]))}function t(r,o){return n([r,o])}function i(){return\"\"}export{i as getCacheKeyOfEmptyString,o as getCacheKeyOfHash,t as getCacheKeyOfStringified};\n//# sourceMappingURL=getCacheKey.js.map\n","import{getCacheKeyOfHash as t,getCacheKeyOfEmptyString as e}from\"./getCacheKey.js\";const n=r({getCacheKey:t}),c=r({getCacheKey:e});function r({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:n=t}={}){return function(t,c){let r,o,i;return\"getter\"===c?.kind?function(){const c=n(this,[]),a=Date.now();return(i!==c||a-o>e)&&(i=c,r=t.call(this),o=a),r}:function(...a){const u=n(this,a),h=Date.now();return(i!==u||h-o>e)&&(i=u,r=c?t.call(this,...a):t(...a),o=h),r}}}export{n as memoizeOne,r as memoizeOneFactory,c as memoizeOneWithEmptyHash};\n//# sourceMappingURL=memoizeOne.js.map\n","export function isCI(ciEnv: string | undefined): boolean {\n  return !!ciEnv && ciEnv !== '0' && ciEnv !== 'false';\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport { readEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport { memoizeOne } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nimport { isCI } from './utils/ci.js';\n\nexport type DatabaseOrm = 'prisma' | 'drizzle';\n\nexport class Project {\n  private readonly argv: EnvReaderOptions;\n  private readonly loadEnv: boolean;\n  private readonly pathByName = new Map<string, string>();\n\n  private readonly _dirPath: string;\n\n  constructor(dirPath: string, argv: EnvReaderOptions, loadEnv: boolean) {\n    this._dirPath = path.resolve(dirPath);\n    this.argv = argv;\n    this.loadEnv = loadEnv;\n  }\n\n  @memoizeOne\n  get isBunAvailable(): boolean {\n    if (this.hasBunToolVersion()) return true;\n    return this.usesBunPackageManager;\n  }\n\n  @memoizeOne\n  get usesBunPackageManager(): boolean {\n    if (this.hasBunLockfile()) return true;\n    return this.hasBunPackageManager();\n  }\n\n  private hasBunToolVersion(): boolean {\n    try {\n      return /(^|\\n)bun\\s/.test(fs.readFileSync(path.join(this.rootDirPath, '.tool-versions'), 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  private hasBunLockfile(): boolean {\n    // Some repositories rely on the lockfile or packageManager field instead of mise.\n    // Docker optimization must follow the target project, not the runtime that launched wb.\n    return ['bun.lock', 'bun.lockb'].some((fileName) => fs.existsSync(path.join(this.rootDirPath, fileName)));\n  }\n\n  private hasBunPackageManager(): boolean {\n    const packageManager = this.rootPackageJson?.packageManager ?? this.packageJson.packageManager;\n    return typeof packageManager === 'string' && packageManager.startsWith('bun@');\n  }\n\n  @memoizeOne\n  get buildCommand(): string {\n    return this.packageJson.scripts?.build?.includes('buildIfNeeded')\n      ? 'YARN run build'\n      : this.packageJson.scripts?.build\n        ? `YARN wb buildIfNeeded ${this.argv.verbose ? '--verbose' : ''}`\n        : \"echo 'No build script'\";\n  }\n\n  get dirPath(): string {\n    return this._dirPath;\n  }\n\n  @memoizeOne\n  get rootDirPath(): string {\n    return fs.existsSync(path.join(this.dirPath, '..', '..', 'package.json'))\n      ? path.resolve(this.dirPath, '..', '..')\n      : this.dirPath;\n  }\n\n  @memoizeOne\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoizeOne\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoizeOne\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoizeOne\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoizeOne\n  get env(): Record<string, string | undefined> {\n    if (!this.loadEnv) return process.env;\n\n    const [envVars, envPathAndLoadedEnvVarCountPairs] = readEnvironmentVariables(this.argv, this.dirPath);\n    for (const [envPath, count] of envPathAndLoadedEnvVarCountPairs) {\n      console.info(`Loaded ${count} environment variables from ${envPath}`);\n    }\n    return { ...envVars, ...process.env };\n  }\n\n  @memoizeOne\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8')) as PackageJson;\n  }\n\n  @memoizeOne\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoizeOne\n  get hasPrisma(): boolean {\n    return !!this.getOwnDependencyVersion('prisma');\n  }\n\n  @memoizeOne\n  get hasDrizzle(): boolean {\n    return !!this.getOwnDependencyVersion('drizzle-orm');\n  }\n\n  @memoizeOne\n  get databaseOrm(): DatabaseOrm | undefined {\n    if (this.hasPrisma) return 'prisma';\n    if (this.hasDrizzle) return 'drizzle';\n    return;\n  }\n\n  @memoizeOne\n  get hasVitest(): boolean {\n    return !!(this.packageJson.dependencies?.vitest ?? this.packageJson.devDependencies?.vitest);\n  }\n\n  @memoizeOne\n  get hasOxlint(): boolean {\n    return this.hasDependency('oxlint');\n  }\n\n  @memoizeOne\n  get hasOxfmt(): boolean {\n    return this.hasDependency('oxfmt');\n  }\n\n  @memoizeOne\n  get hasPrettier(): boolean {\n    return this.hasDependency('prettier');\n  }\n\n  @memoizeOne\n  get hasPoetryLock(): boolean {\n    return (\n      fs.existsSync(path.join(this.dirPath, 'poetry.lock')) || fs.existsSync(path.join(this.rootDirPath, 'poetry.lock'))\n    );\n  }\n\n  @memoizeOne\n  get hasPubspecYaml(): boolean {\n    return (\n      fs.existsSync(path.join(this.dirPath, 'pubspec.yaml')) ||\n      fs.existsSync(path.join(this.rootDirPath, 'pubspec.yaml'))\n    );\n  }\n\n  @memoizeOne\n  get preferredLinter(): 'oxlint' | undefined {\n    if (this.hasOxlint) return 'oxlint';\n    return;\n  }\n\n  hasOwnDependency(packageName: string): boolean {\n    return !!this.getOwnDependencyVersion(packageName);\n  }\n\n  @memoizeOne\n  get hasPlaywrightConfig(): boolean {\n    try {\n      return !!this.findFile('playwright.config.ts');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get skipLaunchingServerForPlaywright(): boolean {\n    if (isCI(this.env.CI)) return false;\n    try {\n      const configPath = this.findFile('playwright.config.ts');\n      return /\\bwebServer\\b/.test(fs.readFileSync(configPath, 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : (JSON.parse(\n          fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8')\n        ) as PackageJson);\n  }\n\n  @memoizeOne\n  get binExists(): boolean {\n    let binFound = false;\n    let currentPath = this.dirPath;\n    for (;;) {\n      const binPath = path.join(currentPath, 'node_modules', '.bin');\n      if (fs.existsSync(binPath)) {\n        this.env.PATH = `${binPath}:${this.env.PATH}`;\n        binFound = true;\n      }\n\n      if (fs.existsSync(path.join(currentPath, '.git'))) {\n        break;\n      }\n      const parentPath = path.dirname(currentPath);\n      if (currentPath === parentPath) {\n        break;\n      }\n      currentPath = parentPath;\n    }\n    return binFound;\n  }\n\n  findFile(fileName: string): string {\n    let filePath = this.pathByName.get(fileName);\n    if (filePath) return filePath;\n\n    filePath = [fileName, path.join('..', '..', fileName)]\n      .map((p) => path.resolve(this.dirPath, p))\n      .find((p) => fs.existsSync(p));\n    if (!filePath) {\n      throw new Error(`File not found: ${fileName}`);\n    }\n    this.pathByName.set(fileName, filePath);\n    return filePath;\n  }\n\n  private hasDependency(packageName: string): boolean {\n    return !!(\n      this.getOwnDependencyVersion(packageName) ?? this.getDependencyVersion(this.rootPackageJson, packageName)\n    );\n  }\n\n  private getOwnDependencyVersion(packageName: string): string | undefined {\n    return this.getDependencyVersion(this.packageJson, packageName);\n  }\n\n  private getDependencyVersion(packageJson: PackageJson | undefined, packageName: string): string | undefined {\n    if (!packageJson) return;\n\n    return (\n      packageJson.dependencies?.[packageName] ??\n      packageJson.devDependencies?.[packageName] ??\n      packageJson.optionalDependencies?.[packageName] ??\n      packageJson.peerDependencies?.[packageName]\n    );\n  }\n\n  @memoizeOne\n  private get rootPackageJson(): PackageJson | undefined {\n    if (this.rootDirPath === this.dirPath) return this.packageJson;\n\n    try {\n      return JSON.parse(fs.readFileSync(path.join(this.rootDirPath, 'package.json'), 'utf8')) as PackageJson;\n    } catch (error) {\n      console.error(`[wb] Failed to read or parse ${path.join(this.rootDirPath, 'package.json')}`, error);\n      return;\n    }\n  }\n}\n\nexport interface FoundProjects {\n  root: Project;\n  self: Project;\n  descendants: Project[];\n}\n\nexport function findSelfProject(argv: EnvReaderOptions, loadEnv = true, dirPath?: string): Project | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  return new Project(dirPath, argv, loadEnv);\n}\n\nexport async function findDescendantProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Promise<FoundProjects | undefined> {\n  const rootAndSelfProjects = findRootAndSelfProjects(argv, loadEnv, dirPath);\n  if (!rootAndSelfProjects) return;\n\n  return {\n    ...rootAndSelfProjects,\n    descendants:\n      rootAndSelfProjects.root === rootAndSelfProjects.self\n        ? await getAllDescendantProjects(argv, rootAndSelfProjects.root, loadEnv)\n        : [rootAndSelfProjects.self],\n  };\n}\n\nexport function findRootAndSelfProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Omit<FoundProjects, 'descendants'> | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  const thisProject = new Project(dirPath, argv, loadEnv);\n  let rootProject = thisProject;\n  if (!thisProject.packageJson.workspaces && path.dirname(dirPath).endsWith('/packages')) {\n    const rootDirPath = path.resolve(dirPath, '..', '..');\n    if (fs.existsSync(path.join(rootDirPath, 'package.json'))) {\n      rootProject = new Project(rootDirPath, argv, loadEnv);\n    }\n  }\n  return { root: rootProject, self: thisProject };\n}\n\nasync function getAllDescendantProjects(\n  argv: EnvReaderOptions,\n  rootProject: Project,\n  loadEnv: boolean\n): Promise<Project[]> {\n  const projects = [rootProject];\n\n  const workspace = rootProject.packageJson.workspaces;\n  if (!Array.isArray(workspace)) return projects;\n\n  const globPattern: string[] = [];\n  const packageDirs: string[] = [];\n  for (const workspacePath of workspace.map((ws: string) => path.join(rootProject.dirPath, ws))) {\n    if (fs.existsSync(workspacePath)) {\n      packageDirs.push(workspacePath);\n    } else {\n      globPattern.push(workspacePath);\n    }\n  }\n  packageDirs.push(...(await globby(globPattern, { dot: true, onlyDirectories: true })));\n  for (const subPackageDirPath of packageDirs) {\n    if (!fs.existsSync(path.join(subPackageDirPath, 'package.json'))) continue;\n\n    projects.push(new Project(subPackageDirPath, argv, loadEnv));\n  }\n  return projects;\n}\n","export const isRunningOnBun =\n  // Detect `bun --bun run wb ...`. cf. https://bun.sh/guides/util/detect-bun\n  process.versions.bun ||\n  // Detect `bun run wb ...`.\n  process.argv[0]?.endsWith('/bun') ||\n  process.env.npm_execpath?.endsWith('/bun');\n\nexport const runtimeWithArgs = isRunningOnBun ? 'bun --bun run' : 'node';\nexport const packageManager = isRunningOnBun ? 'bun' : 'yarn';\nexport const packageManagerWithRun = isRunningOnBun ? 'bun --bun run' : 'yarn';\n","import child_process from 'node:child_process';\nimport type { BinaryLike, Hash } from 'node:crypto';\nimport { createHash } from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport { ignoreEnoentAsync } from '@willbooster/shared-lib/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  command: {\n    description: 'A build command (default: yarn|bun build)',\n    type: 'string',\n    alias: 'c',\n  },\n} as const;\n\nexport const buildIfNeededCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'buildIfNeeded',\n  describe: 'Build code if changes are detected',\n  builder,\n  async handler(argv) {\n    await buildIfNeeded(argv);\n  },\n};\n\nexport async function buildIfNeeded(\n  // Test code requires Partial<...>\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>>>,\n  projectPathForTesting?: string\n): Promise<boolean | undefined> {\n  const project = findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\n\n  const buildCommand =\n    argv.command ??\n    (project.packageJson.scripts?.build ? (isRunningOnBun ? 'bun run build' : 'yarn build') : undefined);\n  if (!buildCommand) {\n    console.info(chalk.green('Skip to build because no build command is defined.'));\n    return false;\n  }\n  argv = { ...argv, command: buildCommand };\n\n  if (!fs.existsSync(path.join(project.rootDirPath, '.git'))) {\n    build(project, argv);\n    return true;\n  }\n\n  const [canSkip, cacheFilePath, contentHash] = await canSkipBuild(project, argv);\n  if (canSkip) {\n    console.info(chalk.green(`Skip to run '${argv.command}' 💫`));\n    return false;\n  }\n\n  if (!build(project, argv)) return;\n\n  if (!argv.dryRun) {\n    await fs.promises.writeFile(cacheFilePath, contentHash, 'utf8');\n  }\n  return true;\n}\n\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  console.info(chalk.green(`Run '${argv.command}'`));\n  if (!argv.dryRun) {\n    const ret = child_process.spawnSync(argv.command ?? '', {\n      cwd: project.dirPath,\n      env: project.env,\n      shell: true,\n      stdio: 'inherit',\n    });\n    if (ret.status !== 0) {\n      process.exitCode = ret.status ?? 1;\n      return false;\n    }\n  }\n  return true;\n}\n\nconst ignoringEnvVarNames = new Set(['CI', 'PWDEBUG', 'TMPDIR']);\n\nexport async function canSkipBuild(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>\n): Promise<[boolean, string, string]> {\n  const cacheDirectoryPath = path.resolve(project.dirPath, 'node_modules', '.cache', 'build');\n  const cacheFilePath = path.resolve(cacheDirectoryPath, 'last-build');\n  await fs.promises.mkdir(cacheDirectoryPath, { recursive: true });\n\n  const hash = createHash('sha256');\n\n  const commitHash = child_process.execSync('git rev-parse HEAD', { cwd: project.dirPath }).toString().trim();\n  hash.update(commitHash);\n\n  const environmentJson = JSON.stringify(\n    Object.entries(project.env)\n      .filter(([key]) => !ignoringEnvVarNames.has(key))\n      .toSorted(([key1], [key2]) => key1.localeCompare(key2))\n  );\n  hash.update(environmentJson);\n\n  await updateHashWithDiffResult(project, argv, hash);\n  const contentHash = hash.digest('hex');\n\n  const cachedContentHash = await ignoreEnoentAsync(() => fs.promises.readFile(cacheFilePath, 'utf8'));\n  return [cachedContentHash === contentHash, cacheFilePath, contentHash];\n}\n\nconst includePatterns = ['src/', 'public/'];\nconst includeSuffix = [\n  '.js',\n  '.cjs',\n  '.mjs',\n  '.jsx',\n  '.ts',\n  '.cts',\n  '.mts',\n  '.tsx',\n  '.json',\n  '.browserslistrc',\n  // Because some build commands affected by changes in `package.json`\n  'package.json',\n  'yarn.lock',\n];\nconst excludePatterns = ['test/', 'tests/', '__tests__/', 'test-fixtures/', 'test/fixtures/'];\n\nasync function updateHashWithDiffResult(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  hash: Hash\n): Promise<void> {\n  return new Promise((resolve) => {\n    const ret = child_process.spawnSync('git', ['status', '--porcelain'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const lines = ret.stdout\n      .trim()\n      .split('\\n')\n      .filter((line) => line.length > 0);\n    const filePaths = lines\n      .map((line) => line.slice(2).trim())\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/wb\\/test\\/fixtures\\/[^/]+\\//, '') : filePath\n      );\n    const filteredFilePaths = filePaths.filter(\n      (filePath) =>\n        (includePatterns.some((pattern) => filePath.includes(pattern)) ||\n          includeSuffix.some((suffix) => filePath.endsWith(suffix))) &&\n        !excludePatterns.some((pattern) => filePath.includes(pattern))\n    );\n    if (argv.verbose) {\n      console.info(`Changed files: ${filteredFilePaths.join(', ')}`);\n    }\n\n    // 'git diff --' works only on rootDirPath\n    const proc = child_process.spawn('git', ['diff', '--', ...filteredFilePaths], { cwd: project.rootDirPath });\n    proc.stdout.on('data', (data: BinaryLike) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info('Data:', data);\n        console.info('Hash:', hash.copy().digest('hex'));\n      }\n    });\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n","import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n  if (obj instanceof Error) return obj;\n  if (typeof obj === 'string') return new Error(obj);\n  try {\n    return new Error(JSON.stringify(obj));\n  } catch {\n    return new Error(String(obj));\n  }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport interface RetryOptions {\n  beforeRetry?: (error: unknown) => Promise<void>;\n  handleError?: (error: unknown) => Promise<void>;\n  /**\n   * The maximum number of total attempts, including the initial attempt.\n   * For example, `retryCount: 3` runs the function at most 3 times: 1 initial attempt and up to 2 retries.\n   */\n  retryCount?: number;\n  retryLogger?: (message: string) => void;\n  shouldRetry?: (error: unknown) => boolean;\n  sleepMilliseconds?: number;\n  updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of total attempts, including the initial attempt.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n  func: (failedCount: number) => T | Promise<T>,\n  {\n    beforeRetry,\n    handleError,\n    retryCount = 3,\n    retryLogger,\n    shouldRetry,\n    sleepMilliseconds = 0,\n    updateSleepMilliseconds,\n  }: RetryOptions = {}\n): Promise<T> {\n  let failedCount = 0;\n  for (;;) {\n    try {\n      return await func(failedCount);\n    } catch (error) {\n      await handleError?.(error);\n      failedCount++;\n      if (failedCount >= retryCount) {\n        throw error;\n      }\n      if (shouldRetry && !shouldRetry(error)) {\n        throw error;\n      }\n      if (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      if (updateSleepMilliseconds) {\n        sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n","import { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\n  onSignal?: (signal: NodeJS.Signals | null) => void;\n  forceColor?: boolean;\n  processSilentOutput?: (output: string) => string;\n  printRawOutput?: boolean;\n  timeout?: number;\n}\n\nconst defaultOptions: Options = {\n  exitIfFailed: true,\n};\n\nexport interface BufferedRunResult {\n  exitCode: number;\n  output: string;\n}\n\nexport async function runWithSpawn(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>> & { silent?: boolean },\n  opts: Options = defaultOptions\n): Promise<number> {\n  const normalizedScript = normalizeScript(script, project);\n  printStart(normalizedScript.printable, project, argv.silent ? 'Command' : 'Start');\n  if (argv.verbose) {\n    printStart(normalizedScript.runnable, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts, { silentSuccess: argv.silent });\n    return 0;\n  }\n\n  const shouldProcessSilentOutput = Boolean(argv.silent && opts.processSilentOutput);\n  const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, opts),\n    shell: true,\n    stdio: argv.silent ? 'pipe' : 'inherit',\n    timeout: opts.timeout,\n    mergeOutAndError: shouldProcessSilentOutput,\n    killOnExit: true,\n    printingStdout: argv.silent && !shouldProcessSilentOutput,\n    printingStderr: argv.silent && !shouldProcessSilentOutput,\n    omitBlankLinesWhilePrinting: argv.silent,\n    verbose: argv.verbose,\n  });\n  if (shouldProcessSilentOutput) {\n    const output = opts.processSilentOutput?.(ret.stdout).trim();\n    if (output) {\n      process.stdout.write(output);\n      process.stdout.write('\\n');\n    }\n  }\n  opts.onSignal?.(ret.signal);\n  printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts, { silentSuccess: argv.silent });\n  return ret.status ?? 1;\n}\n\nexport function runWithSpawnInParallel(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    printStart(normalizedScript.printable, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(normalizedScript.printable, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      printingStdout: opts.printRawOutput,\n      printingStderr: opts.printRawOutput,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    printStart(normalizedScript.printable, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n    }\n    const out = ret.stdout.trim();\n    if (out && !opts.printRawOutput) {\n      process.stdout.write(out);\n      process.stdout.write('\\n');\n    }\n    printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n    return ret.status ?? 1;\n  });\n}\n\nexport function runWithSpawnInParallelBuffered(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<BufferedRunResult> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    if (argv.dryRun) {\n      return {\n        exitCode: 0,\n        output: '',\n      };\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      printingStdout: opts.printRawOutput,\n      printingStderr: opts.printRawOutput,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    return {\n      exitCode: ret.status ?? 1,\n      output: ret.stdout,\n    };\n  });\n}\n\n/**\n * Replace capitalized commands (e.g., YARN, PRISMA, BUN) with suitable commands.\n */\nexport function normalizeScript(script: string, project: Project): { printable: string; runnable: string } {\n  const projectPackageManagerWithRun = project.usesBunPackageManager ? 'bun --bun run' : 'yarn';\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\n    .replaceAll(\n      'PRISMA generate ',\n      project.packageJson.dependencies?.blitz ? 'PRISMA generate ' : 'PRISMA generate --no-hints '\n    )\n    .replaceAll('PRISMA ', project.packageJson.dependencies?.blitz ? 'YARN blitz prisma ' : 'YARN prisma ')\n    .replaceAll('BUN run ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'YARN run ')\n    .replaceAll('BUN ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'YARN ')\n    // Avoid replacing `YARN run` with `run` by replacing `YARN` with `(yarn|bun --bun) run`.\n    .replaceAll('YARN run ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'yarn run ');\n  if (project.usesBunPackageManager) {\n    newScript = newScript\n      .replaceAll('YARN build-ts run', 'bun --bun run')\n      .replaceAll('bun --bun run bun --bun run', 'bun --bun run')\n      // Because bun can run src/index.ts directly.\n      .replaceAll('dist/index.js', 'src/index.ts');\n  }\n  newScript = newScript.trim();\n  const printableScript = fixBunCommand(newScript.replaceAll('YARN ', `${projectPackageManagerWithRun} `));\n  const runnableScript = fixBunCommand(\n    newScript\n      // Keep Playwright as a package-manager command instead of resolving it through node_modules/.bin.\n      .replaceAll('YARN playwright ', `${projectPackageManagerWithRun} playwright `)\n      .replaceAll(\n        'YARN ',\n        !project.usesBunPackageManager && project.binExists ? '' : `${projectPackageManagerWithRun} `\n      )\n  );\n  // Add cascade option when WB_ENV is defined\n  const cascadeOption = project.env.WB_ENV ? ` -c=${project.env.WB_ENV || 'development'}` : '';\n  return {\n    printable: `${projectPackageManagerWithRun} dotenv${cascadeOption} -- ${printableScript}`,\n    runnable: runnableScript,\n  };\n}\n\nexport function printStart(normalizedScript: string, project: Project, prefix = 'Start', weak = false): void {\n  console.info(\n    '\\n' +\n      (weak ? chalk.gray : chalk.cyan)(chalk.bold(`${prefix}:`), normalizedScript) +\n      chalk.gray(` at ${project.dirPath}`)\n  );\n}\n\nexport function printFinishedAndExitIfNeeded(\n  script: string,\n  exitCode: number | null,\n  opts: Omit<Options, 'timeout'>,\n  printOptions: { silentSuccess?: boolean } = {}\n): void {\n  if (exitCode === 0) {\n    if (printOptions.silentSuccess) return;\n    console.info(chalk.green(chalk.bold('Finished:'), script));\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}): `), script));\n    if (opts.exitIfFailed !== false) {\n      process.exit(exitCode ?? 1);\n    }\n  }\n}\n\nexport function configureEnv(\n  env: Record<string, string | undefined>,\n  opts: Options\n): Record<string, string | undefined> {\n  const newEnv = { ...env };\n  if (opts.ci) {\n    newEnv.CI = '1';\n  }\n  if (opts.forceColor) {\n    newEnv.FORCE_COLOR = '3';\n  }\n  return newEnv;\n}\n\nfunction fixBunCommand(command: string): string {\n  // cf. https://github.com/oven-sh/bun/issues/14359\n  return command.includes('next dev') ||\n    // cf. https://github.com/oven-sh/bun/issues/8222\n    command.includes('playwright') ||\n    // \"bun --bun prisma generate\" doesn't work\n    command.includes('prisma') ||\n    command.includes('test/e2e-additional')\n    ? command.replaceAll('bun --bun', 'bun')\n    : command;\n}\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node/src';\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  // This option is for debugging mainly.\n  'working-dir': {\n    description: 'A working directory',\n    type: 'string',\n    alias: 'w',\n  },\n  'dry-run': {\n    description: 'Whether to skip actual command execution',\n    type: 'boolean',\n    alias: ['dry', 'd'],\n  },\n} as const;\n\nexport function buildEnvReaderOptionArgs(argv: EnvReaderOptions): string[] {\n  const args: string[] = [];\n  for (const optionName of Object.keys(yargsOptionsBuilderForEnv)) {\n    const value = getOptionValue(argv, optionName);\n    if (value === undefined) continue;\n\n    if (typeof value === 'boolean') {\n      args.push(value ? `--${optionName}` : `--${optionName}=false`);\n      continue;\n    }\n    if (typeof value === 'string' || typeof value === 'number') {\n      args.push(`--${optionName}=${value}`);\n      continue;\n    }\n    if (Array.isArray(value)) {\n      for (const item of value) {\n        args.push(`--${optionName}=${item}`);\n      }\n    }\n  }\n  return args;\n}\n\nfunction getOptionValue(argv: EnvReaderOptions, optionName: string): unknown {\n  const camelCaseOptionName = optionName.replaceAll(/-([a-z])/g, (_, character: string) => character.toUpperCase());\n  const options = argv as Record<string, unknown>;\n  return options[optionName] ?? options[camelCaseOptionName];\n}\n","import child_process from 'node:child_process';\nimport { constants } from 'node:os';\n\nimport { treeKill } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject, type Project } from '../project.js';\nimport { configureEnv, normalizeScript } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst FORCE_KILL_DELAY_MS = 5000;\n\nconst builder = {\n  'kill-others': {\n    description: 'Kill other commands when one command exits',\n    type: 'boolean',\n  },\n  'kill-others-on-fail': {\n    description: 'Kill other commands when one command fails',\n    type: 'boolean',\n  },\n  success: {\n    description: 'Define successful completion criteria',\n    type: 'string',\n    choices: ['all', 'first'],\n    default: 'all',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  commands: {\n    description: 'Commands to run concurrently',\n    type: 'array',\n  },\n} as const;\n\ninterface RunConcurrentlyOptions {\n  commands: string[];\n  project: Project;\n  killOthers: boolean;\n  killOthersOnFail: boolean;\n  success: 'all' | 'first';\n  ci?: boolean;\n  forceColor?: boolean;\n}\n\nexport const concurrentlyCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof argumentsBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'concurrently <commands...>',\n  describe: 'Run commands concurrently',\n  builder: { ...sharedOptionsBuilder, ...builder, ...argumentsBuilder },\n  async handler(argv) {\n    if (process.platform === 'win32') {\n      console.error(chalk.red('This command is not supported on Windows.'));\n      process.exit(1);\n    }\n\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const commands = (argv.commands ?? []).map(String).filter(Boolean);\n    if (commands.length === 0) {\n      console.error(chalk.red('No commands provided.'));\n      process.exit(1);\n    }\n\n    try {\n      const exitCode = await runConcurrently({\n        commands,\n        project,\n        killOthers: argv.killOthers ?? false,\n        killOthersOnFail: argv.killOthersOnFail ?? false,\n        success: argv.success,\n        ci: typeof argv.ci === 'boolean' ? argv.ci : undefined,\n        forceColor: typeof argv.forceColor === 'boolean' ? argv.forceColor : undefined,\n      });\n      process.exit(exitCode);\n    } catch (error) {\n      console.error(chalk.red(error instanceof Error ? error.message : String(error)));\n      process.exit(1);\n    }\n  },\n};\n\nexport async function runConcurrently(options: RunConcurrentlyOptions): Promise<number> {\n  const children = options.commands.map((command) =>\n    child_process.spawn(normalizeScript(command, options.project).runnable, {\n      cwd: options.project.dirPath,\n      detached: true,\n      env: configureEnv(options.project.env, { ci: options.ci, forceColor: options.forceColor }),\n      shell: true,\n      stdio: 'inherit',\n    })\n  );\n\n  let stopping = false;\n  let interruptedSignal: NodeJS.Signals | undefined;\n  let firstResult: number | undefined;\n  let stopResult: number | undefined;\n  const forceKillPromises: Promise<void>[] = [];\n  const results = Array.from<number | undefined>({ length: children.length });\n  const waitForExitPromises = children.map((child, index) => {\n    return new Promise<void>((resolve) => {\n      let settled = false;\n      const settle = (exitCode: number): void => {\n        if (settled) return;\n\n        settled = true;\n        results[index] = exitCode;\n        firstResult ??= exitCode;\n\n        if (!stopping && shouldStopOthers(exitCode, options)) {\n          stopResult = exitCode;\n          stopping = true;\n          forceKillPromises.push(terminateChildren(children, 'SIGTERM'));\n        }\n        resolve();\n      };\n\n      child.once('error', (error) => {\n        console.error('Failed to start child process:', error);\n        settle(1);\n      });\n      child.once('exit', (code, signal) => {\n        settle(getExitCode(code ?? undefined, signal ?? undefined));\n      });\n    });\n  });\n\n  const stopAll = (signal: NodeJS.Signals): void => {\n    interruptedSignal ??= signal;\n    if (stopping) return;\n\n    stopping = true;\n    forceKillPromises.push(terminateChildren(children, signal));\n  };\n  const stopOnSigint = (): void => {\n    stopAll('SIGINT');\n  };\n  const stopOnSigterm = (): void => {\n    stopAll('SIGTERM');\n  };\n  const stopOnSigquit = (): void => {\n    stopAll('SIGQUIT');\n  };\n  process.on('SIGINT', stopOnSigint);\n  process.on('SIGTERM', stopOnSigterm);\n  process.on('SIGQUIT', stopOnSigquit);\n  try {\n    await Promise.all(waitForExitPromises);\n    await Promise.all(forceKillPromises);\n  } finally {\n    process.removeListener('SIGINT', stopOnSigint);\n    process.removeListener('SIGTERM', stopOnSigterm);\n    process.removeListener('SIGQUIT', stopOnSigquit);\n  }\n\n  if (interruptedSignal) {\n    return getExitCode(undefined, interruptedSignal);\n  }\n\n  if (options.success === 'first') {\n    return firstResult ?? 1;\n  }\n  if (stopResult !== undefined) {\n    return stopResult;\n  }\n  for (const result of results) {\n    if (result !== undefined && result !== 0) {\n      return result;\n    }\n  }\n  return 0;\n}\n\nfunction getExitCode(code: number | undefined, signal: NodeJS.Signals | undefined): number {\n  if (code !== undefined) {\n    return code;\n  }\n  if (signal && signal in constants.signals) {\n    return 128 + constants.signals[signal];\n  }\n  return 1;\n}\n\nfunction shouldStopOthers(\n  exitCode: number,\n  options: Pick<RunConcurrentlyOptions, 'killOthers' | 'killOthersOnFail' | 'success'>\n): boolean {\n  return options.success === 'first' || options.killOthers || (options.killOthersOnFail && exitCode !== 0);\n}\n\nasync function terminateChildren(children: child_process.ChildProcess[], signal: NodeJS.Signals): Promise<void> {\n  const forceKillPids = signalPids(toChildPids(children), signal);\n  if (forceKillPids.length === 0) return;\n\n  if (await waitForForceKill(forceKillPids)) {\n    signalPids(forceKillPids, 'SIGKILL');\n  }\n}\n\nfunction toChildPids(children: child_process.ChildProcess[]): number[] {\n  return children.flatMap((child) => (child.pid === undefined ? [] : [child.pid]));\n}\n\nfunction signalPids(pids: readonly number[], signal: NodeJS.Signals): number[] {\n  const signaledPids: number[] = [];\n  for (const pid of pids) {\n    try {\n      if (!killProcessGroup(pid, signal)) continue;\n\n      signaledPids.push(pid);\n      treeKill(pid, signal);\n    } catch (error) {\n      console.warn('Failed to kill child process:', error);\n    }\n  }\n  return signaledPids;\n}\n\nasync function waitForForceKill(pids: readonly number[]): Promise<boolean> {\n  const deadline = Date.now() + FORCE_KILL_DELAY_MS;\n  while (Date.now() < deadline) {\n    if (pids.every(isProcessGroupGone)) return false;\n\n    await sleep(Math.min(100, deadline - Date.now()));\n  }\n  return true;\n}\n\nfunction isProcessGroupGone(pid: number): boolean {\n  try {\n    process.kill(-pid, 0);\n    return false;\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return true;\n    }\n    return false;\n  }\n}\n\nasync function sleep(ms: number): Promise<void> {\n  await new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nfunction killProcessGroup(pid: number, signal: NodeJS.Signals): boolean {\n  try {\n    process.kill(-pid, signal);\n    return true;\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return false;\n    }\n    throw error;\n  }\n}\n\nfunction isNoSuchProcessError(error: unknown): boolean {\n  return typeof error === 'object' && error !== null && 'code' in error && error.code === 'ESRCH';\n}\n","import chalk from 'chalk';\nimport killPortProcess from 'kill-port';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isCI } from '../utils/ci.js';\n\nconst killPortIfNonCiBuilder = {} as const;\n\nexport const killPortIfNonCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'kill-port-if-non-ci',\n  describe: 'Kill the port specified by PORT environment variable if non-CI.',\n  builder: killPortIfNonCiBuilder,\n  async handler(argv) {\n    await killPortIfNonCi(argv);\n  },\n};\n\nexport async function killPortIfNonCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const project = findSelfProject(argv);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (isCI(project.env.CI)) {\n    console.info(`Skip killing port due to CI: ${project.env.CI}`);\n    return;\n  }\n\n  const portEnv = project.env.PORT;\n  const port = Number(portEnv);\n  if (!Number.isInteger(port) || port <= 0) {\n    console.error(chalk.red(`PORT environment variable is invalid: ${portEnv}`));\n    process.exit(1);\n  }\n\n  console.info(`Killing the port: ${port}`);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n","export function printBufferedOutput(exitCode: number, output: string): void {\n  if (!shouldPrintBufferedOutput(exitCode, output)) return;\n\n  const normalizedOutput = normalizeBufferedOutput(output);\n  if (normalizedOutput) {\n    process.stdout.write(normalizedOutput);\n    process.stdout.write('\\n');\n  }\n}\n\nexport function shouldPrintBufferedOutput(exitCode: number, output: string): boolean {\n  return exitCode !== 0 || hasWarningOutput(removeNoColorWarning(output));\n}\n\nexport function normalizeBufferedOutput(output: string): string {\n  return removeNoColorWarning(output).trim();\n}\n\nfunction hasWarningOutput(output: string): boolean {\n  return /\\bwarn(?:ing)?s?\\b/i.test(output.replaceAll(/\\b(?:0|no) warnings?\\b/gi, ''));\n}\n\nfunction removeNoColorWarning(output: string): string {\n  return output.replaceAll(\n    /\\(node:\\d+\\) Warning: The 'NO_COLOR' env is ignored due to the 'FORCE_COLOR' env being set\\.\\n\\(Use `node --trace-warnings \\.\\.\\.` to show where the warning was created\\)\\n?/g,\n    ''\n  );\n}\n","export function buildShellCommand(args: string[]): string {\n  return args.map((arg) => shellEscapeArgument(arg)).join(' ');\n}\n\nexport function buildShellEnvironmentAssignment(name: string, value: string): string {\n  return `${name}=${shellEscapeArgument(value)}`;\n}\n\nexport function shellEscapeArgument(arg: string): string {\n  return /^[\\w./:=,@%+-]+$/u.test(arg) ? arg : `'${arg.replaceAll(\"'\", `'\"'\"'`)}'`;\n}\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { BufferedRunResult } from '../scripts/run.js';\nimport { normalizeScript, runWithSpawnInParallel, runWithSpawnInParallelBuffered } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { printBufferedOutput } from '../utils/output.js';\nimport { buildShellCommand } from '../utils/shell.js';\n\nconst builder = {\n  fix: {\n    description: 'Fix the linting errors',\n    type: 'boolean',\n  },\n  format: {\n    description: 'Format the code',\n    type: 'boolean',\n  },\n  quiet: {\n    description: 'Report errors only',\n    type: 'boolean',\n  },\n  silent: {\n    description: 'Print only failed or warning command output',\n    type: 'boolean',\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  files: {\n    description: 'File and directory paths to lint',\n    type: 'array',\n  },\n} as const;\n\nexport type LintCommandOptions = InferredOptionTypes<\n  typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder\n>;\nexport type LintCommandArgv = ArgumentsCamelCase<LintCommandOptions> & {\n  '--'?: unknown[];\n  _: unknown[];\n  printAllOutput?: boolean;\n};\n\nconst oxlintExtensions = new Set(['astro', 'cjs', 'cts', 'js', 'jsx', 'mjs', 'mts', 'svelte', 'ts', 'tsx', 'vue']);\nconst pythonExtensions = new Set(['py']);\nconst dartExtensions = new Set(['dart']);\nconst oxfmtExtensions = new Set([\n  ...oxlintExtensions,\n  'css',\n  'gql',\n  'graphql',\n  'hbs',\n  'htm',\n  'html',\n  'json',\n  'json5',\n  'jsonc',\n  'less',\n  'md',\n  'mdx',\n  'scss',\n  'toml',\n  'yaml',\n  'yml',\n]);\nconst prettierExtensions = new Set([\n  'cjs',\n  'css',\n  'cts',\n  'htm',\n  'html',\n  'java',\n  'js',\n  'json',\n  'json5',\n  'jsonc',\n  'jsx',\n  'md',\n  'mjs',\n  'mts',\n  'scss',\n  'ts',\n  'tsx',\n  'vue',\n  'yaml',\n  'yml',\n]);\nconst prettierOnlyExtensions = new Set([...prettierExtensions].filter((ext) => !oxfmtExtensions.has(ext)));\nconst prettierFixtureIgnorePattern = '!**/test{-,/}fixtures/**';\n\ntype BufferedLintRunResult = BufferedRunResult & { command: string; cwd: string };\ntype LintRunResult = BufferedLintRunResult | { exitCode: number };\n\nexport const lintCommand: CommandModule<unknown, LintCommandOptions> = {\n  command: 'lint [files...]',\n  describe: 'Lint code',\n  builder,\n  async handler(argv) {\n    const exitCode = await lint(argv as LintCommandArgv);\n    if (exitCode) process.exit(exitCode);\n  },\n};\n\nexport async function lint(argv: LintCommandArgv): Promise<number> {\n  if (process.platform === 'win32') {\n    console.error(chalk.red('This command is not supported on Windows.'));\n    return 1;\n  }\n\n  const projects = await findDescendantProjects(argv, false);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    return 1;\n  }\n\n  const files = getLintTargetFiles(argv);\n  const lintFilePathsByProject = new Map<Project, string[]>();\n  const oxfmtFilePathsByProject = new Map<Project, string[]>();\n  const pythonFilePathsByProject = new Map<Project, string[]>();\n  const dartFilePathsByProject = new Map<Project, string[]>();\n  const prettierFilePaths: string[] = [];\n  const packageJsonFilePaths: string[] = [];\n  let missingLintToolForExplicitFiles = false;\n  let prettierArgs: string[];\n  let sortPackageJsonArgs: string[];\n  if (files.length > 0) {\n    const lintTargets = await Promise.all(\n      files.map(async (file) => {\n        const filePath = path.resolve(file);\n        const fileKind = await getLintTargetFileKind(filePath);\n        return { fileKind, filePath };\n      })\n    );\n    for (const { fileKind, filePath } of lintTargets) {\n      if (\n        filePath.endsWith('/test/fixtures') ||\n        filePath.includes('/test/fixtures/') ||\n        filePath.endsWith('/test-fixtures') ||\n        filePath.includes('/test-fixtures/')\n      ) {\n        continue;\n      }\n\n      const extension = path.extname(filePath).slice(1);\n      if (filePath.endsWith('/package.json')) {\n        packageJsonFilePaths.push(filePath);\n        continue;\n      }\n      packageJsonFilePaths.push(...getExplicitPackageJsonPaths(projects.descendants, filePath, fileKind));\n\n      for (const { lintPath, project } of getExplicitLintTargets(projects.descendants, filePath, fileKind)) {\n        if (project.hasPoetryLock && (fileKind === 'directory' || pythonExtensions.has(extension))) {\n          const pythonFilePaths = pythonFilePathsByProject.get(project) ?? [];\n          pythonFilePaths.push(lintPath);\n          pythonFilePathsByProject.set(project, pythonFilePaths);\n          if (fileKind !== 'directory') continue;\n        }\n        if (project.hasPubspecYaml && (fileKind === 'directory' || dartExtensions.has(extension))) {\n          const dartFilePaths = dartFilePathsByProject.get(project) ?? [];\n          dartFilePaths.push(lintPath);\n          dartFilePathsByProject.set(project, dartFilePaths);\n          if (fileKind !== 'directory') continue;\n        }\n        if (fileKind === 'directory' || supportsLintingExtension(project, extension)) {\n          const lintFilePaths = lintFilePathsByProject.get(project) ?? [];\n          lintFilePaths.push(lintPath);\n          lintFilePathsByProject.set(project, lintFilePaths);\n          if (argv.format) {\n            if (fileKind === 'directory' && project.hasOxfmt) {\n              const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n              oxfmtFilePaths.push(lintPath);\n              oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n              prettierFilePaths.push(buildPrettierOnlyDirectoryPattern(lintPath), prettierFixtureIgnorePattern);\n            } else {\n              for (const formatterPath of buildExplicitFormatterArgs(project, lintPath, fileKind, extension)) {\n                if (project.hasOxfmt) {\n                  const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n                  oxfmtFilePaths.push(formatterPath);\n                  oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n                } else {\n                  prettierFilePaths.push(formatterPath);\n                }\n              }\n            }\n          }\n        } else if (argv.format && (prettierExtensions.has(extension) || oxfmtExtensions.has(extension))) {\n          if (project.hasOxfmt && oxfmtExtensions.has(extension)) {\n            const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n            oxfmtFilePaths.push(lintPath);\n            oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n          } else if (prettierExtensions.has(extension)) {\n            prettierFilePaths.push(lintPath);\n          }\n        } else if (isPotentialLintTarget(extension) && !project.preferredLinter) {\n          console.error(chalk.red(`No linter found for ${project.name}. Install Oxlint.`));\n          missingLintToolForExplicitFiles = true;\n        }\n      }\n    }\n    prettierArgs = [...new Set(prettierFilePaths)];\n    sortPackageJsonArgs = [...new Set(packageJsonFilePaths)];\n  } else {\n    prettierArgs = buildPrettierArgs(projects.self.dirPath, projects.descendants);\n    sortPackageJsonArgs = projects.descendants.map((p) => p.packageJsonPath);\n  }\n\n  const lintPromises: Promise<LintRunResult>[] = [];\n  const lintRunOptions = { exitIfFailed: false, forceColor: !argv.printAllOutput } as const;\n  if (files.length > 0) {\n    for (const [project, lintFilePaths] of lintFilePathsByProject) {\n      const lintCommand = buildLintCommand(project, argv, lintFilePaths);\n      if (!lintCommand) continue;\n\n      lintPromises.push(runLintCommand(lintCommand, project, argv, lintRunOptions));\n    }\n    if (argv.format) {\n      for (const [project, oxfmtFilePaths] of oxfmtFilePathsByProject) {\n        lintPromises.push(runLintCommand(buildOxfmtCommand(oxfmtFilePaths), project, argv, lintRunOptions));\n      }\n    }\n    for (const [project, pythonFilePaths] of pythonFilePathsByProject) {\n      lintPromises.push(runLintCommand(buildPoetryCommand(argv, pythonFilePaths), project, argv, lintRunOptions));\n    }\n    for (const [project, dartFilePaths] of dartFilePathsByProject) {\n      lintPromises.push(runLintCommand(buildDartCommand(argv, dartFilePaths), project, argv, lintRunOptions));\n    }\n  } else {\n    for (const project of projects.descendants) {\n      if (project.packageJson.workspaces && !project.hasSourceCode) continue;\n\n      const lintCommand = buildLintCommand(project, argv);\n      if (!lintCommand) continue;\n\n      lintPromises.push(runLintCommand(lintCommand, project, argv, lintRunOptions));\n    }\n    for (const project of projects.descendants) {\n      if (project.hasPoetryLock) {\n        lintPromises.push(runLintCommand(buildPoetryCommand(argv), project, argv, lintRunOptions));\n      }\n      if (project.hasPubspecYaml) {\n        lintPromises.push(runLintCommand(buildDartCommand(argv), project, argv, lintRunOptions));\n      }\n      if (project.hasOxfmt && argv.format) {\n        lintPromises.push(runLintCommand(buildOxfmtCommand(), project, argv, lintRunOptions));\n      }\n    }\n  }\n  const lintResults = await Promise.all(lintPromises);\n  printSilentLintOutputs(lintResults, argv);\n  const lintExitCodes = lintResults.map((result) => result.exitCode);\n\n  if (missingLintToolForExplicitFiles || lintExitCodes.some((exitCode) => exitCode !== 0)) {\n    return 1;\n  }\n\n  if (argv.format) {\n    if (prettierArgs.length > 0 && projects.self.hasPrettier) {\n      const prettierResult = await runLintCommand(\n        buildShellCommand([\n          'YARN',\n          'prettier',\n          '--cache',\n          '--color',\n          '--no-error-on-unmatched-pattern',\n          '--write',\n          '--',\n          ...prettierArgs,\n        ]),\n        projects.self,\n        argv,\n        lintRunOptions\n      );\n      printSilentLintOutputs([prettierResult], argv);\n      lintExitCodes.push(prettierResult.exitCode);\n    }\n    if (sortPackageJsonArgs.length > 0) {\n      const sortPackageJsonResult = await runLintCommand(\n        buildShellCommand(['YARN', 'sort-package-json', '--', ...sortPackageJsonArgs]),\n        projects.self,\n        argv,\n        lintRunOptions\n      );\n      printSilentLintOutputs([sortPackageJsonResult], argv);\n      lintExitCodes.push(sortPackageJsonResult.exitCode);\n    }\n  }\n\n  return lintExitCodes.some((exitCode) => exitCode !== 0) ? 1 : 0;\n}\n\nfunction runLintCommand(\n  command: string,\n  project: Project,\n  argv: LintCommandArgv,\n  options: Parameters<typeof runWithSpawnInParallel>[3]\n): Promise<LintRunResult> {\n  if (argv.silent) {\n    const normalizedScript = normalizeScript(command, project);\n    return runWithSpawnInParallelBuffered(command, project, argv, options).then((result) => ({\n      ...result,\n      command: normalizedScript.printable,\n      cwd: project.dirPath,\n    }));\n  }\n  return runWithSpawnInParallel(command, project, argv, options).then((exitCode) => ({ exitCode }));\n}\n\nfunction printSilentLintOutputs(\n  results: LintRunResult[],\n  argv: Pick<LintCommandArgv, 'printAllOutput' | 'silent'>\n): void {\n  const printableResults =\n    argv.silent && !argv.printAllOutput ? results.filter((result) => result.exitCode !== 0) : results;\n  if (printableResults.length === 0) return;\n\n  for (const result of printableResults) {\n    if (!('output' in result)) continue;\n\n    if (argv.printAllOutput) {\n      printCommandOutput(result);\n    } else {\n      if (argv.silent) {\n        printCommandHeader(result.command, result.cwd);\n      }\n      printBufferedOutput(result.exitCode, result.output);\n    }\n  }\n}\n\nfunction printCommandOutput(result: BufferedLintRunResult): void {\n  printCommandHeader(result.command, result.cwd);\n\n  if (result.exitCode === 0 && shouldSuppressSuccessfulVerifyOutput(result.command)) {\n    console.info(chalk.green('Succeeded.'));\n    return;\n  }\n\n  const output = result.output.trim();\n  if (output) {\n    process.stdout.write(output);\n    process.stdout.write('\\n');\n  }\n}\n\nfunction printCommandHeader(command: string, cwd: string): void {\n  console.info('\\n' + chalk.cyan(chalk.bold('Command:'), command) + chalk.gray(` at ${cwd}`));\n}\n\nfunction shouldSuppressSuccessfulVerifyOutput(command: string): boolean {\n  return command.includes(' oxfmt ') || command.includes(' sort-package-json ');\n}\n\nexport function buildLintCommand(\n  project: Pick<Project, 'preferredLinter'>,\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string | undefined {\n  if (project.preferredLinter === 'oxlint') {\n    return buildShellCommand([\n      'YARN',\n      'oxlint',\n      '--no-error-on-unmatched-pattern',\n      ...(argv.quiet ? ['--quiet'] : []),\n      ...(argv.fix ? ['--fix'] : []),\n      ...(files ?? ['.']),\n    ]);\n  }\n  return;\n}\n\nexport function buildOxfmtCommand(files?: string[]): string {\n  return buildShellCommand([\n    'YARN',\n    'oxfmt',\n    '--write',\n    '--no-error-on-unmatched-pattern',\n    ...(files ?? ['.']),\n    '!**/package.json',\n  ]);\n}\n\nexport function buildPoetryCommand(\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string {\n  const targets = files && files.length > 0 ? files : ['.'];\n  const commands =\n    argv.fix || argv.format\n      ? [\n          buildShellCommand(['poetry', 'run', 'isort', '--profile', 'black', '--filter-files', ...targets]),\n          buildShellCommand(['poetry', 'run', 'black', ...targets]),\n          buildShellCommand(['poetry', 'run', 'flake8', ...(argv.quiet ? ['-q'] : []), ...targets]),\n        ]\n      : [buildShellCommand(['poetry', 'run', 'flake8', ...(argv.quiet ? ['-q'] : []), ...targets])];\n  return commands.join(' && ');\n}\n\nexport function buildDartCommand(\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string {\n  const targets = files && files.length > 0 ? files : ['.'];\n  const commands: string[] = [];\n  if (argv.fix || argv.format) {\n    commands.push(buildShellCommand(['dart', 'format', ...targets]));\n  }\n  commands.push(buildShellCommand(['dart', 'analyze', ...targets]));\n  return commands.join(' && ');\n}\n\nexport function buildPrettierArgs(\n  selfDirPath: string,\n  projects: Pick<Project, 'dirPath' | 'preferredLinter' | 'hasOxfmt'>[]\n): string[] {\n  const args = new Set<string>([`**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}`, prettierFixtureIgnorePattern]);\n  for (const project of projects) {\n    if (!needsPrettier(project)) continue;\n\n    const projectPattern = path.join(project.dirPath, '**/{.*/,}*.{' + [...prettierExtensions].join(',') + '}');\n    args.add(path.relative(selfDirPath, projectPattern) || projectPattern);\n  }\n  return [...args];\n}\n\nfunction findOwningProject(projects: Project[], filePath: string): Project | undefined {\n  let owningProject: Project | undefined;\n  for (const project of projects) {\n    if (\n      (filePath === project.dirPath || filePath.startsWith(`${project.dirPath}/`)) &&\n      (!owningProject || project.dirPath.length > owningProject.dirPath.length)\n    ) {\n      owningProject = project;\n    }\n  }\n  return owningProject;\n}\n\nexport function getLintTargetFiles(argv: Pick<LintCommandArgv, '--' | '_' | 'files'>): string[] {\n  const lintTargets = new Set<string>();\n  for (const value of [...(argv.files ?? []), ...argv._.slice(1), ...(argv['--'] ?? [])]) {\n    lintTargets.add(String(value));\n  }\n  return [...lintTargets];\n}\n\nexport async function getLintTargetFileKind(filePath: string): Promise<'directory' | 'other'> {\n  try {\n    const stats = await fs.stat(filePath);\n    if (stats.isDirectory()) return 'directory';\n  } catch {\n    // Missing paths are handled by the downstream tools.\n  }\n\n  return 'other';\n}\n\nexport function shouldFormatExplicitPathWithPrettier(\n  project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>,\n  extension: string\n): boolean {\n  if (project.hasOxfmt) return oxfmtExtensions.has(extension);\n  if (needsPrettier(project)) return true;\n  return prettierOnlyExtensions.has(extension);\n}\n\nexport function buildExplicitFormatterArgs(\n  project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>,\n  filePath: string,\n  fileKind: 'directory' | 'other',\n  extension: string\n): string[] {\n  if (fileKind === 'directory' && project.hasOxfmt) {\n    return [filePath];\n  }\n  if (fileKind === 'directory' && needsPrettier(project)) {\n    return [filePath, prettierFixtureIgnorePattern];\n  }\n  if (shouldFormatExplicitPathWithPrettier(project, extension)) {\n    return [filePath];\n  }\n  return [];\n}\n\nfunction buildPrettierOnlyDirectoryPattern(filePath: string): string {\n  return path.join(filePath, `**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}`);\n}\n\nexport function getExplicitPackageJsonPaths(\n  projects: Pick<Project, 'dirPath' | 'packageJsonPath'>[],\n  filePath: string,\n  fileKind: 'directory' | 'other'\n): string[] {\n  if (fileKind !== 'directory') return [];\n  return projects\n    .filter(\n      (project) =>\n        project.packageJsonPath === path.join(filePath, 'package.json') ||\n        project.packageJsonPath.startsWith(`${filePath}/`)\n    )\n    .map((project) => project.packageJsonPath);\n}\n\nexport function getExplicitLintTargets(\n  projects: Project[],\n  filePath: string,\n  fileKind: 'directory' | 'other'\n): { lintPath: string; project: Project }[] {\n  if (fileKind === 'directory') {\n    const descendantProjects = projects.filter(\n      (project) => project.dirPath === filePath || project.dirPath.startsWith(`${filePath}/`)\n    );\n    if (descendantProjects.length > 0) {\n      return descendantProjects.map((project) => ({ lintPath: project.dirPath, project }));\n    }\n  }\n\n  const project = findOwningProject(projects, filePath);\n  return project ? [{ lintPath: filePath, project }] : [];\n}\n\nfunction isPotentialLintTarget(extension: string): boolean {\n  return oxlintExtensions.has(extension) || pythonExtensions.has(extension) || dartExtensions.has(extension);\n}\n\nfunction supportsLintingExtension(project: Pick<Project, 'preferredLinter'>, extension: string): boolean {\n  if (project.preferredLinter === 'oxlint') return oxlintExtensions.has(extension);\n  return false;\n}\n\nfunction needsPrettier(project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>): boolean {\n  return !project.hasOxfmt && project.preferredLinter === 'oxlint';\n}\n","import type { Project } from '../project.js';\n\nexport function* prepareForRunningCommand(commandName: string, projects: Project[]): Generator<Project, void, unknown> {\n  for (const project of projects) {\n    console.info(`Running \"${commandName}\" for ${project.name} ...`);\n\n    yield project;\n  }\n}\n","import child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\n// These tools are declared as devDependencies in source repos, but optimized Docker\n// package.json files still need them for in-image codegen/build steps.\nconst runtimeDevDependencies = ['@willbooster/wb', 'build-ts'];\n\nconst builder = {\n  outside: {\n    description: 'Whether the optimization is executed outside a docker container or not',\n    type: 'boolean',\n    alias: 'o',\n  },\n} as const;\n\nexport const optimizeForDockerBuildCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'optimizeForDockerBuild',\n  describe: 'Optimize configuration when building a Docker image',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of prepareForRunningCommand('optimizeForDockerBuild', projects.descendants)) {\n      const packageJson: PackageJson = project.packageJson;\n      const keys = ['dependencies', 'devDependencies'] as const;\n      for (const key of keys) {\n        const deps = packageJson[key] ?? {};\n        for (const [name, value] of Object.entries(deps)) {\n          if (value?.startsWith('git@github.com:')) {\n            // Docker builds cannot access private SSH URLs unless credentials are forwarded.\n            // The Dockerfile copies those workspace packages into the image instead.\n            deps[name] = `./${name}`;\n          }\n        }\n      }\n\n      optimizeDevDependencies(argv, packageJson);\n\n      optimizeScripts(packageJson);\n\n      optimizeRootProps(packageJson);\n\n      if (argv.dryRun) continue;\n\n      const distDirPath = argv.outside ? path.join(project.dirPath, 'dist') : project.dirPath;\n      await fs.promises.mkdir(distDirPath, { recursive: true });\n      await fs.promises.writeFile(path.join(distDirPath, 'package.json'), JSON.stringify(packageJson), 'utf8');\n    }\n    if (!argv.dryRun && !argv.outside) {\n      child_process.spawnSync(packageManager, ['install'], {\n        stdio: 'inherit',\n      });\n      console.info('Installed dependencies.');\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  promoteRuntimeDevDependencies(packageJson);\n  if (argv.outside) {\n    // Outside optimization writes dist/package.json before Docker builds the app.\n    // Keep build-time packages for that later in-image build and remove only known non-build tooling.\n    removeUnnecessaryDevDependenciesForOutsideDockerBuild(packageJson);\n    return;\n  }\n\n  // Inside Docker, codegen/build has already finished, so production install should not see dev tooling.\n  delete packageJson.devDependencies;\n  console.info('Removed all devDependencies.');\n}\n\nfunction removeUnnecessaryDevDependenciesForOutsideDockerBuild(packageJson: PackageJson): void {\n  const devDeps = packageJson.devDependencies ?? {};\n  // In --outside mode, Docker still runs codegen/build before a second in-image optimization.\n  // Remove only tooling that is not needed for that build phase.\n  const nameWordsToBeRemoved = [\n    'artillery',\n    'concurrently',\n    'conventional-changelog-conventionalcommits',\n    'husky',\n    'imagemin',\n    'jest',\n    'kill-port',\n    'lint-staged',\n    'open-cli',\n    'playwright',\n    'prettier',\n    'pinst',\n    'railway',\n    'semantic-release',\n    'sort-package-json',\n    'wait-on',\n    'vitest',\n  ];\n  const removedDeps: string[] = [];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      // Shared config packages are needed only for lint/format/test commands, not Docker builds.\n      (name.includes('willbooster') && name.includes('config'))\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete devDeps[name];\n      removedDeps.push(name);\n    }\n  }\n  console.info('Removed devDependencies:', removedDeps.join(', ') || 'none');\n}\n\nfunction promoteRuntimeDevDependencies(packageJson: PackageJson): void {\n  const devDeps = packageJson.devDependencies ?? {};\n  const dependencies = packageJson.dependencies ?? {};\n  const promotedDeps: string[] = [];\n  for (const name of runtimeDevDependencies) {\n    const version = devDeps[name];\n    if (!version) continue;\n    if (!dependencies[name]) {\n      dependencies[name] = version;\n      promotedDeps.push(name);\n    }\n    delete devDeps[name];\n  }\n  if (promotedDeps.length > 0) {\n    packageJson.dependencies = dependencies;\n  }\n  console.info('Promoted runtime devDependencies:', promotedDeps.join(', ') || 'none');\n}\n\nfunction optimizeScripts(packageJson: PackageJson): void {\n  const nameWordsOfUnnecessaryScripts = ['check', 'deploy', 'format', 'lint', 'start', 'test'];\n  const contentWordsOfUnnecessaryScripts = ['pinst ', 'husky '];\n  const scripts = (packageJson.scripts ?? {}) as Record<string, string>;\n  const removedScripts: string[] = [];\n  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.startsWith(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete scripts[name];\n      removedScripts.push(name);\n    }\n  }\n  console.info('Removed scripts:', removedScripts.join(', ') || 'none');\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\n\nconst FILE_SCHEMA = 'file:';\n\nclass DrizzleScripts {\n  deploy(project: Project, additionalOptions = ''): string {\n    return this.migrate(project, additionalOptions);\n  }\n\n  migrate(_project: Project, additionalOptions = ''): string {\n    return `YARN drizzle-kit migrate ${additionalOptions}`;\n  }\n\n  migrateDev(_project: Project, additionalOptions = ''): string {\n    return `YARN drizzle-kit generate ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    const removeCommand = buildRemoveSqliteDbCommand(project);\n    if (!removeCommand) {\n      return \"echo 'wb db reset supports Drizzle only when DATABASE_PATH or file: DATABASE_URL is set.' && exit 1\";\n    }\n\n    return `${removeCommand} && ${this.migrate(project, additionalOptions)} && ${this.seed(project)}`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if (project.packageJson.scripts?.seed) return 'YARN run seed';\n    return 'true';\n  }\n\n  studio(_project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    if (dbUrlOrPath) {\n      return \"echo 'wb db studio for Drizzle does not support db-url-or-path.' && exit 1\";\n    }\n\n    return `YARN drizzle-kit studio ${additionalOptions}`;\n  }\n}\n\nfunction buildRemoveSqliteDbCommand(project: Project): string | undefined {\n  const dbPath = project.env.DATABASE_PATH ?? getFileDatabaseUrlPath(project);\n  if (!dbPath) return;\n\n  const absolutePath = path.isAbsolute(dbPath) ? dbPath : path.resolve(project.dirPath, dbPath);\n  return `rm -f \"${absolutePath}\" \"${absolutePath}-wal\" \"${absolutePath}-shm\"`;\n}\n\nfunction getFileDatabaseUrlPath(project: Project): string | undefined {\n  const dbUrl = project.env.DATABASE_URL;\n  if (!dbUrl?.startsWith(FILE_SCHEMA)) return;\n\n  const rawDbPath = dbUrl.slice(FILE_SCHEMA.length).replace(/[?#].*$/, '');\n  if (!rawDbPath) return;\n\n  return rawDbPath;\n}\n\nexport const drizzleScripts = new DrizzleScripts();\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { Project } from '../project.js';\n\nconst FILE_SCHEMA = 'file:';\n\nconst POSSIBLE_PRISMA_PATHS = [\n  { schemaPath: path.join('prisma', 'schema.prisma'), dbPath: 'prisma' },\n  { schemaPath: path.join('prisma', 'schema'), dbPath: path.join('prisma', 'schema') },\n  { schemaPath: path.join('db', 'schema.prisma'), dbPath: 'db' },\n];\n\n/**\n * A collection of scripts for executing Prisma commands.\n * Note that `PRISMA` is replaced with `YARN prisma` or `YARN blitz prisma`\n * and `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PrismaScripts {\n  cleanUpLitestream(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    const cleanUpCommand = buildWalCheckpointAndRemoveSqliteSidecarFilesCommand(`${dirPath}/prod.sqlite3`);\n    // Cleanup existing artifacts to avoid issues with Litestream replication.\n    // Note that don't merge multiple rm commands into one, because if one fails, the subsequent ones won't run.\n    return `${cleanUpCommand}; rm -Rf ${dirPath}/.prod.sqlite3* || true`;\n  }\n\n  deploy(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions}`;\n  }\n\n  deployForce(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    const removeDbCommand = buildRemoveSqliteDbCommand(`${dirPath}/prod.sqlite3`);\n    // `prisma migrate reset` can fail depending on the state of the existing database, so we remove it first.\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `${removeDbCommand}; PRISMA migrate reset --force --skip-seed && ${removeDbCommand}\n      && litestream restore -config litestream.yml -o ${dirPath}/prod.sqlite3 ${dirPath}/prod.sqlite3 && ls -ahl ${dirPath}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  listBackups(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `litestream ltx -config litestream.yml ${dirPath}/prod.sqlite3`;\n  }\n\n  migrate(project: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions} && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate dev ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    const steps: string[] = [];\n    const cleanupCommand = cleanUpSqliteDbIfNeeded(project);\n    if (cleanupCommand) steps.push(cleanupCommand);\n    const resetCommand = ['PRISMA migrate reset --force', additionalOptions].filter(Boolean).join(' ');\n    steps.push(resetCommand);\n    if (project.packageJson.dependencies?.blitz) {\n      // Blitz does not trigger seed automatically, so we need to run it manually.\n      steps.push(this.seed(project));\n    }\n    return steps.filter(Boolean).join(' && ');\n  }\n\n  restore(project: Project, outputPath: string): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `rm -Rf ${outputPath}*; litestream restore -config litestream.yml -o ${outputPath} ${dirPath}/prod.sqlite3`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.blitz) return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if ((project.packageJson.prisma as Record<string, string> | undefined)?.seed) return `YARN prisma db seed`;\n    return `if [ -e \"prisma/seeds.ts\" ]; then BUN build-ts run prisma/seeds.ts; fi`;\n  }\n\n  studio(project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    let prefix = '';\n    // Deal with Prisma issue: https://github.com/prisma/studio/issues/1273\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    } else if (project.env.DATABASE_URL?.startsWith(FILE_SCHEMA)) {\n      const baseDir = getPrismaBaseDir(project);\n      if (baseDir) {\n        const absolutePath = path.resolve(project.dirPath, baseDir, project.env.DATABASE_URL.slice(FILE_SCHEMA.length));\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    }\n    return `${prefix}PRISMA studio ${additionalOptions}`;\n  }\n}\n\nfunction getDatabaseDirPath(project: Project): string {\n  return project.packageJson.dependencies?.blitz ? 'db/mount' : 'prisma/mount';\n}\n\nfunction getPrismaBaseDir(project: Project): string | undefined {\n  return POSSIBLE_PRISMA_PATHS.find(({ schemaPath }) => fs.existsSync(path.resolve(project.dirPath, schemaPath)))\n    ?.dbPath;\n}\n\nfunction buildRemoveSqliteDbCommand(dbPath: string): string {\n  return `rm -Rf \"${dbPath}\"*`;\n}\n\nfunction buildWalCheckpointAndRemoveSqliteSidecarFilesCommand(dbPath: string): string {\n  return `if [ -f \"${dbPath}\" ]; then printf 'PRAGMA wal_checkpoint(TRUNCATE);' | PRISMA db execute --stdin --url \"${FILE_SCHEMA}${dbPath}\"; fi && rm -f \"${dbPath}\".* \"${dbPath}\"-*`;\n}\n\nexport function cleanUpSqliteDbIfNeeded(project: Project): string | undefined {\n  const dbUrl = project.env.DATABASE_URL;\n  if (!dbUrl?.startsWith(FILE_SCHEMA)) return;\n\n  const rawDbPath = dbUrl.slice(FILE_SCHEMA.length).replace(/[?#].*$/, '');\n  if (!rawDbPath) return;\n\n  const baseDir = getPrismaBaseDir(project);\n  const absolutePath = path.isAbsolute(rawDbPath)\n    ? rawDbPath\n    : path.resolve(project.dirPath, baseDir ?? '.', rawDbPath);\n\n  return `rm -f \"${absolutePath}\" \"${absolutePath}-wal\" \"${absolutePath}-shm\"`;\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import fs from 'node:fs';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { DatabaseOrm, Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport { drizzleScripts } from '../scripts/drizzleScripts.js';\nimport { prismaScripts } from '../scripts/prismaScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { buildShellCommand } from '../utils/shell.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const prismaCommand: CommandModule = {\n  command: 'prisma',\n  aliases: ['db'],\n  describe:\n    \"Run database commands. Use '--' to stop wb option parsing and forward the remaining arguments to Prisma. Drizzle projects use drizzle-kit. Example: wb prisma migrate-dev -- --name init\",\n  builder: (yargs) => {\n    return yargs\n      .parserConfiguration({ 'populate--': true })\n      .command(cleanUpLitestreamCommand)\n      .command(createLitestreamConfigCommand)\n      .command(deployCommand)\n      .command(deployForceCommand)\n      .command(listBackupsCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand()\n      .strict(false); // Allow unknown options to be passed through\n  },\n  handler() {\n    // Do nothing\n  },\n};\n\nconst cleanUpLitestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'cleanup-litestream',\n  describe: 'Clean up temporal Litestream files',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma cleanup-litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.cleanUpLitestream(project), project, argv);\n    }\n  },\n};\n\nconst createLitestreamConfigCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'create-litestream-config',\n  describe: 'Create Litestream configuration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma create-litestream-config', allProjects)) {\n      createLitestreamConfig(project);\n    }\n  },\n};\n\nconst deployCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy',\n  describe: 'Apply migration to DB without initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db deploy', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).deploy(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy-force',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma deploy-force', allProjects)) {\n      await runWithSpawn(prismaScripts.deployForce(project), project, argv);\n    }\n  },\n};\n\nconst listBackupsCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'list-backups',\n  describe: 'List Litestream backups',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma list-backups', allProjects)) {\n      await runWithSpawn(prismaScripts.listBackups(project), project, argv);\n    }\n  },\n};\n\nconst migrateCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate',\n  describe: 'Apply migration to DB with initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db migrate', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).migrate(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst migrateDevCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate-dev',\n  describe: 'Create a migration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db migrate-dev', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).migrateDev(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst resetCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'reset',\n  describe: 'Reset DB',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db reset', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).reset(project, unknownOptions), project, argv);\n    }\n    // Force to reset test database\n    if (process.env.WB_ENV !== 'test') {\n      process.env.WB_ENV = 'test';\n      for (const { orm, project } of prepareForRunningDatabaseOrmCommand(\n        'WB_ENV=test db reset',\n        await findDatabaseOrmProjects(argv)\n      )) {\n        await runWithSpawn(getDatabaseOrmScripts(orm).reset(project, unknownOptions), project, argv);\n      }\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...builder,\n  output: {\n    description: 'Output path of the restored database. Defaults to \"<db|prisma>/restored.sqlite3\".',\n    type: 'string',\n  },\n} as const;\n\nconst restoreCommand: CommandModule<unknown, InferredOptionTypes<typeof restoreBuilder>> = {\n  command: 'restore',\n  describe: \"Restore DB from Litestream's backup\",\n  builder: restoreBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma restore', allProjects)) {\n      const output =\n        argv.output ?? (project.packageJson.dependencies?.blitz ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, output), project, argv);\n    }\n  },\n};\n\nconst seedBuilder = {\n  ...builder,\n  file: {\n    alias: 'f',\n    description: 'Path of the seed script.',\n    type: 'string',\n  },\n} as const;\n\nconst seedCommand: CommandModule<unknown, InferredOptionTypes<typeof seedBuilder>> = {\n  command: 'seed',\n  describe: 'Populate DB with seed data',\n  builder: seedBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db seed', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).seed(project, argv.file), project, argv);\n    }\n  },\n};\n\nconst studioBuilder = {\n  ...builder,\n  'db-url-or-path': {\n    description: 'URL or path to the database',\n    type: 'string',\n  },\n  restored: {\n    description: 'Whether to open the default restored database (<db|prisma>/restored.sqlite3).',\n    type: 'boolean',\n  },\n} as const;\n\nconst studioCommand: CommandModule<unknown, InferredOptionTypes<typeof studioBuilder>> = {\n  command: 'studio [db-url-or-path]',\n  describe: 'Open database studio',\n  builder: studioBuilder,\n  async handler(argv) {\n    if (argv.restored && argv.dbUrlOrPath) {\n      throw new Error('You cannot specify both --restored and --db-url-or-path.');\n    }\n\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv, ['db-url-or-path', 'restored']);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db studio', allProjects)) {\n      const dbUrlOrPath = argv.restored\n        ? project.packageJson.dependencies?.blitz\n          ? 'db/restored.sqlite3'\n          : 'prisma/restored.sqlite3'\n        : argv.dbUrlOrPath?.toString();\n      await runWithSpawn(getDatabaseOrmScripts(orm).studio(project, dbUrlOrPath, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst defaultCommandBuilder = { args: { type: 'array' } } as const;\n\nconst defaultCommand: CommandModule<unknown, InferredOptionTypes<typeof defaultCommandBuilder>> = {\n  command: '$0 <args..>',\n  describe:\n    \"Pass the command and arguments to the detected ORM as is. Additional Prisma flags can also be forwarded after '--'.\",\n  builder: defaultCommandBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const script = (argv.args?.join(' ') ?? '').trimEnd();\n    const unknownOptions = extractUnknownOptions(argv, ['args']);\n    const fullCommand = [script, unknownOptions].filter(Boolean).join(' ');\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand(`db ${fullCommand}`, allProjects)) {\n      const command = orm === 'prisma' ? `PRISMA ${fullCommand}` : `YARN drizzle-kit ${fullCommand}`;\n      await runWithSpawn(command, project, argv);\n    }\n  },\n};\n\nfunction createLitestreamConfig(project: Project): void {\n  const dirName = project.packageJson.dependencies?.blitz ? 'db' : 'prisma';\n  const dbPath = `${dirName}/mount/prod.sqlite3`;\n  const requiredEnvVars = {\n    CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,\n    CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME: project.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,\n    CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,\n    CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY: project.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY,\n  } as const;\n  const missingEnvVars = Object.entries(requiredEnvVars)\n    .filter(([, value]) => !value)\n    .map(([key]) => key);\n  if (missingEnvVars.length > 0) {\n    throw new Error(`Missing environment variables for Litestream: ${missingEnvVars.join(', ')}`);\n  }\n\n  const retentionCheckInterval = project.env.WB_ENV === 'staging' ? '5m' : '1h';\n  const litestreamConfig = `dbs:\n  - path: ${dbPath}\n    busy-timeout: 5s\n    checkpoint-interval: 1m\n    replica:\n      type: s3\n      endpoint: https://${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n      bucket: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n      access-key-id: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n      secret-access-key: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n      snapshot-interval: 24h  # Create a backup per day\n      retention: 72h          # Keep backups for 3 days\n      retention-check-interval: ${retentionCheckInterval}\n      sync-interval: 1m\n`;\n\n  const configPath = '/etc/litestream.yml';\n  try {\n    fs.writeFileSync(configPath, litestreamConfig);\n    console.info(`Generated ${configPath}`);\n  } catch (error) {\n    const reason = error instanceof Error ? error.message : String(error);\n    throw new Error(`Failed to write ${configPath}: ${reason}`, {\n      cause: error,\n    });\n  }\n}\n\ninterface DatabaseOrmProject {\n  project: Project;\n  orm: DatabaseOrm;\n}\n\nasync function findDatabaseOrmProjects(argv: EnvReaderOptions, orm?: DatabaseOrm): Promise<DatabaseOrmProject[]> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  const filtered = projects.descendants\n    .map((project) => (project.databaseOrm ? { project, orm: project.databaseOrm } : undefined))\n    .filter((project): project is DatabaseOrmProject => !!project && (!orm || project.orm === orm));\n  if (filtered.length === 0) {\n    console.error(chalk.red(orm ? `No ${orm} project found.` : 'No supported database ORM project found.'));\n    process.exit(1);\n  }\n  return filtered;\n}\n\nfunction getDatabaseOrmScripts(orm: DatabaseOrm): typeof prismaScripts | typeof drizzleScripts {\n  return orm === 'prisma' ? prismaScripts : drizzleScripts;\n}\n\nfunction* prepareForRunningDatabaseOrmCommand(\n  commandName: string,\n  projects: DatabaseOrmProject[]\n): Generator<DatabaseOrmProject, void, unknown> {\n  const ormProjectByProject = new Map(projects.map((project) => [project.project, project]));\n  for (const project of prepareForRunningCommand(\n    commandName,\n    projects.map(({ project }) => project)\n  )) {\n    const ormProject = ormProjectByProject.get(project);\n    if (!ormProject) throw new Error(`Failed to detect database ORM for ${project.name}.`);\n\n    yield ormProject;\n  }\n}\n\n/**\n * Extract unknown options from argv to pass to ORM commands.\n */\nexport function extractUnknownOptions(argv: Record<string, unknown>, knownOptions: string[] = []): string {\n  const unknownOptions: string[] = [];\n\n  // Build list of known options from shared options builders\n  const sharedOptionKeys = Object.keys(sharedOptionsBuilder);\n  const sharedOptionAliases = Object.values(sharedOptionsBuilder)\n    .flatMap((option) => {\n      if ('alias' in option) {\n        return Array.isArray(option.alias) ? option.alias : [option.alias];\n      }\n      return [];\n    })\n    .map(String);\n\n  const allKnownOptions = new Set([\n    ...knownOptions,\n    ...sharedOptionKeys,\n    ...sharedOptionAliases,\n    // Internal yargs properties\n    '--',\n    '_',\n    '$0',\n  ]);\n\n  for (const [key, value] of Object.entries(argv)) {\n    if (!allKnownOptions.has(key)) {\n      // Skip camelCase versions of kebab-case options to avoid duplication\n      // If we have both 'create-only' and 'createOnly', prefer the kebab-case version\n      const kebabCaseKey = key.replaceAll(/[A-Z]/g, (match) => `-${match.toLowerCase()}`);\n      if (kebabCaseKey !== key && argv[kebabCaseKey] !== undefined) {\n        continue; // Skip camelCase version if kebab-case exists\n      }\n\n      // Handle boolean flags\n      if (typeof value === 'boolean' && value) {\n        unknownOptions.push(`--${key}`);\n      }\n      // Handle string/number values\n      else if (typeof value === 'string' || typeof value === 'number') {\n        unknownOptions.push(`--${key}`, String(value));\n      }\n      // Handle arrays\n      else if (Array.isArray(value)) {\n        for (const item of value) {\n          unknownOptions.push(`--${key}`, String(item));\n        }\n      }\n    }\n  }\n\n  const passthroughArgs = Array.isArray(argv['--']) ? argv['--'].map(String) : [];\n  return buildShellCommand([...unknownOptions, ...passthroughArgs]);\n}\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  retry: {\n    description: 'A maximum retry count',\n    type: 'number',\n    alias: 'r',\n    default: 3,\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  command: {\n    description: 'A command to retry',\n    type: 'string',\n  },\n  args: {\n    description: 'Arguments for the command',\n    type: 'array',\n  },\n} as const;\n\nexport const retryCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'retry [command] [args...]',\n  describe: 'Retry the given command until it succeeds',\n  builder,\n  async handler(argv) {\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const cmdAndArgs = [argv.command, ...(argv.args ?? []), ...argv._.slice(1)].filter(Boolean);\n    let lastStatus = 0;\n    for (let i = 0; i < argv.retry; i++) {\n      if (i > 0) {\n        console.info(`\\n${chalk.yellow(`#${i} Retrying: ${cmdAndArgs.join(' ')}`)}`);\n      }\n      // TODO: should we add single quotes around each argument?\n      lastStatus = await runWithSpawn(cmdAndArgs.join(' '), project, argv, {\n        exitIfFailed: false,\n        onSignal: (signal) => {\n          if (signal) {\n            process.exit(1);\n          }\n        },\n      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","import child_process from 'node:child_process';\nimport fs from 'node:fs/promises';\nimport os from 'node:os';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { packageManagerWithRun } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const setupCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'setup',\n  describe: 'Setup development environment. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    await setup(argv);\n  },\n};\n\n// Test code requires Partial<...>\nexport async function setup(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  projectPathForTesting?: string\n): Promise<void> {\n  const projects = await findDescendantProjects(argv, false, projectPathForTesting);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  for (const project of prepareForRunningCommand('setup', projects.descendants)) {\n    const dirents = await fs.readdir(project.dirPath, { withFileTypes: true });\n    if (project === projects.root) {\n      if (os.platform() === 'darwin') {\n        const packages = ['pstree'];\n        await runWithSpawnInParallel(`brew install ${packages.join(' ')}`, project, argv);\n      }\n\n      if (dirents.some((d) => d.isFile() && d.name.includes('-version'))) {\n        await runWithSpawn('asdf install', project, argv, { exitIfFailed: false });\n      }\n    }\n\n    if (dirents.some((d) => d.isFile() && d.name === 'pyproject.toml')) {\n      await runWithSpawnInParallel('poetry config virtualenvs.in-project true', project, argv);\n      const [, version] = child_process.execSync('asdf current python').toString().trim().split(/\\s+/);\n      await runWithSpawnInParallel(`poetry env use ${version}`, project, argv);\n      await promisePool.promiseAll();\n      await runWithSpawn('poetry run pip install --upgrade pip', project, argv);\n      await runWithSpawn('poetry install --ansi', project, argv);\n    }\n\n    if (\n      (project === projects.root || !projects.root.packageJson.scripts?.['gen-code']) &&\n      project.packageJson.scripts?.['gen-code']\n    ) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\n  }\n\n  const project = projects.descendants.find((p) => p.packageJson.devDependencies?.playwright);\n  if (project) {\n    await runWithSpawn(`${packageManagerWithRun} playwright install --with-deps`, project, argv);\n  }\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport { shellEscapeArgument } from '../utils/shell.js';\n\nexport const scriptOptionsBuilder = {\n  watch: {\n    description: 'Whether to watch files',\n    type: 'boolean',\n  },\n  args: {\n    description: 'Arguments for core command',\n    type: 'array',\n    alias: 'a',\n    default: [],\n  },\n  'docker-options': {\n    description: 'Arguments for \"docker run\"',\n    type: 'array',\n    default: [],\n  },\n} as const;\n\nexport type ScriptArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & {\n  '--'?: string[];\n  normalizedArgsText?: string;\n  normalizedDockerOptionsText?: string;\n  silent?: boolean;\n  verbose?: boolean;\n};\n\nexport function normalizeArgs(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & { '--'?: string[] }\n): void {\n  (argv as ScriptArgv).normalizedArgsText = [...(argv.args ?? []), ...(argv._?.slice(1) ?? []), ...(argv['--'] ?? [])]\n    .map((arg) => shellEscapeArgument(String(arg)))\n    .join(' ');\n  (argv as ScriptArgv).normalizedDockerOptionsText = (argv.dockerOptions ?? [])\n    .map((arg) => shellEscapeArgument(String(arg)))\n    .join(' ');\n}\n\nexport function toDevNull(argv: unknown): string {\n  return (argv as { silent: boolean }).silent ? ` > /dev/null` : '';\n}\n","import { spawnSync } from 'node:child_process';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nimport { isPortAvailable } from './port.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number, project: Project): Promise<void> {\n  const available = await isPortAvailable(port);\n  if (!available) {\n    await killPortContainerAndProcess(port, project);\n  }\n\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortContainerAndProcess(port, project);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortContainerAndProcess(port: number, project: Project): Promise<void> {\n  // We should stop Docker containers first because `kill-port` may fail to stop Docker containers.\n  await stopDockerContainerByPort(port, project);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function stopDockerContainerByImageName(imageName: string, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `name=${imageName}`], project);\n}\n\nexport async function stopDockerContainerByPort(port: number, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `publish=${port}`], project);\n}\n\nasync function removeDockerContainers(filterArgs: string[], project: Project): Promise<void> {\n  try {\n    const containerIds = await listDockerContainerIds(filterArgs, project);\n    if (containerIds.length === 0) return;\n\n    await spawnAsync('docker', ['rm', '-f', ...containerIds], {\n      cwd: project.dirPath,\n      env: project.env,\n    });\n  } catch {\n    // do nothing\n  }\n}\n\nasync function listDockerContainerIds(filterArgs: string[], project: Project): Promise<string[]> {\n  const { stdout } = await spawnAsync('docker', ['ps', '-q', ...filterArgs], {\n    cwd: project.dirPath,\n    env: project.env,\n  });\n  return stdout\n    .split(/\\s+/)\n    .map((id) => id.trim())\n    .filter(Boolean);\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = (): void => {\n    if (killed.has(script)) return;\n\n    killed.add(script);\n    printStart(script, project);\n    const { status } = spawnSync(script, { cwd: project.dirPath, shell: true, stdio: 'inherit' });\n    printFinishedAndExitIfNeeded(script, status, {});\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n","import { createServer } from 'node:net';\n\nimport type { Project } from '../project.js';\n\nimport { killPortProcessImmediatelyAndOnExit } from './process.js';\n\n/**\n * Checks the given port and kills any process using it.\n * Note wb always requires PORT environment variable.\n */\nexport async function checkAndKillPortProcess(rawPort: unknown, project: Project): Promise<number> {\n  const port = Number(rawPort);\n  if (!port) throw new Error(`The given port (${port}) is invalid.`);\n\n  await killPortProcessImmediatelyAndOnExit(port, project);\n  return port;\n}\n\n/**\n * Checks if a port is available.\n * @param port - The port number to check\n * @returns A promise that resolves to true if the port is available, false otherwise\n */\nexport async function isPortAvailable(port: number): Promise<boolean> {\n  // Check both stacks to catch processes bound only on IPv6 or IPv4.\n  for (const host of ['127.0.0.1', '::']) {\n    const available = await probePort(host, port);\n    if (!available) return false;\n  }\n  return true;\n}\n\nasync function probePort(host: string, port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = createServer();\n\n    server.once('error', (err: NodeJS.ErrnoException) => {\n      if (err.code === 'EADDRINUSE') {\n        resolve(false);\n        return;\n      }\n      if (err.code === 'EAFNOSUPPORT') {\n        resolve(true);\n        return;\n      }\n      resolve(false);\n    });\n\n    server.once('listening', () => {\n      server.close(() => {\n        resolve(true);\n      });\n    });\n\n    server.listen(port, host);\n  });\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\nimport { spawnSyncOnExit } from '../utils/process.js';\n\n/**\n * A collection of scripts for executing Docker commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass DockerScripts {\n  buildImage(project: Project, version: string): string {\n    // e.g. coding-booster uses `\"docker/build/prepare\": \"touch drill-users.csv\",`\n    const prefix = project.dockerPackageJson.scripts?.['docker/build/prepare']\n      ? 'YARN run docker/build/prepare && '\n      : '';\n    return `cd ${path.dirname(project.findFile('Dockerfile'))}\n    && ${prefix}YARN wb optimizeForDockerBuild --outside\n    && YARN wb retry -- docker build -t ${project.dockerImageName}\n        --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n\n  stopAndStart(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${this.start(project, additionalOptions, additionalArgs)}`;\n  }\n\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    const allocateTty = additionalArgs.includes('/bin/bash');\n    return `docker run --rm ${allocateTty ? '-it ' : ''}--publish ${project.env.PORT}:8080 --name ${project.dockerImageName} ${additionalOptions} ${project.dockerImageName} ${additionalArgs}`;\n  }\n\n  stop(project: Project): string {\n    return `true $(docker rm -f $(docker container ls -q -f name=${project.dockerImageName}) 2> /dev/null)`;\n  }\n\n  stopAll(): string {\n    return `true $(docker rm -f $(docker ps -q) 2> /dev/null)`;\n  }\n}\n\nexport const dockerScripts = new DockerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { buildEnvReaderOptionArgs } from '../../sharedOptionsBuilder.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport { buildShellCommand, buildShellEnvironmentAssignment } from '../../utils/shell.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { toDevNull } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\nimport { drizzleScripts } from '../drizzleScripts.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nexport interface TestE2EOptions {\n  /** '--e2e generate' calls 'codegen http://localhost:8080' */\n  playwrightArgs?: string[];\n  /** Raw Playwright args forwarded after `wb test -- ...` */\n  forwardedPlaywrightArgs?: string[];\n}\n\n/**\n * A collection of scripts for executing an app.\n * Note that YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nexport abstract class BaseScripts {\n  private readonly shouldWaitAndOpenApp: boolean;\n  protected constructor(shouldWaitAndOpenApp: boolean) {\n    this.shouldWaitAndOpenApp = shouldWaitAndOpenApp;\n  }\n\n  buildDocker(project: Project, version: string): string {\n    return dockerScripts.buildImage(project, version);\n  }\n\n  // ------------ START: start commands ------------\n  async startDev(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startDevProtected(project, argv);\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others-on-fail',\n      this.startDevProtected(project, argv),\n      this.waitAndOpenApp(project),\n    ]);\n  }\n  async startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startProductionProtected(project, argv);\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others-on-fail',\n      this.startProductionProtected(project, argv),\n      this.waitAndOpenApp(project),\n    ]);\n  }\n  async startTest(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    return this.startProductionProtected(project, argv);\n  }\n  async startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) {\n      return `${this.buildDocker(project, 'development')}\n      && ${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}`;\n    }\n\n    return `${this.buildDocker(project, 'development')}\n      && ${buildShellCommand([\n        'YARN',\n        'wb',\n        'concurrently',\n        ...buildEnvReaderOptionArgs(argv),\n        '--kill-others-on-fail',\n        dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? ''),\n        this.waitAndOpenApp(project),\n      ])}`;\n  }\n\n  protected abstract startDevProtected(_: Project, argv: ScriptArgv): string;\n  protected startProductionProtected(project: Project, argv: ScriptArgv): string {\n    const ecosystemConfigPath = findEcosystemConfigPath(project);\n    const commands =\n      ecosystemConfigPath === undefined\n        ? [\n            `YARN wb buildIfNeeded ${argv.verbose ? '--verbose' : ''}`.trim(),\n            `${project.isBunAvailable ? 'bun' : 'node'} dist/index.js ${argv.normalizedArgsText ?? ''}`.trim(),\n          ]\n        : [project.buildCommand, `pm2-runtime start --no-autorestart ${ecosystemConfigPath}`];\n\n    const migrationCommands = [\n      ...(project.hasPrisma ? [prismaScripts.migrate(project)] : []),\n      ...(project.hasDrizzle ? [drizzleScripts.migrate(project)] : []),\n    ];\n    return [...migrationCommands.flatMap((cmd) => cmd.split('&&')), ...commands]\n      .filter(Boolean)\n      .map((cmd) => `${cmd} ${toDevNull(argv)}`.trim())\n      .join(' && ');\n  }\n  // ------------ END: start commands ------------\n\n  // ------------ START: test (e2e) commands ------------\n  testE2EDev(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startDevProtected(project, argv), options);\n  }\n  testE2EProduction(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startProductionProtected(project, argv), options);\n  }\n  testE2EDocker(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, dockerScripts.stopAndStart(project), options);\n  }\n  async testStart(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    // Use empty NODE_ENV to avoid \"production\" mode in some frameworks like Blitz.js.\n    return `${buildShellEnvironmentAssignment('NODE_ENV', '')} ${buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      this.startDevProtected(project, argv),\n      this.waitApp(project),\n    ])}`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    { forwardedPlaywrightArgs = [], playwrightArgs = ['test', 'test/e2e/'] }: TestE2EOptions\n  ): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const playwrightCommand = buildPlaywrightCommand(playwrightArgs, argv.targets, argv.bail, forwardedPlaywrightArgs);\n    if (project.skipLaunchingServerForPlaywright) {\n      return `${playwrightCommand}${suffix}`;\n    }\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      `${startCommand} && exit 1`,\n      `wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && ${playwrightCommand}${suffix}`,\n    ]);\n  }\n  // ------------ END: test (e2e) commands ------------\n\n  testUnit(project: Project, argv: TestArgv): string {\n    const targets = argv.targets?.map(String);\n    if (project.hasVitest) {\n      // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n      return buildShellCommand([\n        'YARN',\n        'vitest',\n        'run',\n        ...(targets?.length ? targets : ['test/unit/']),\n        '--color',\n        '--passWithNoTests',\n        '--allowOnly',\n        '--watch=false',\n        ...(argv.bail ? ['--bail=1'] : []),\n      ]);\n    } else if (project.isBunAvailable) {\n      return buildShellCommand([\n        'bun',\n        'test',\n        ...(targets?.length ? targets : ['test/unit/']),\n        ...(argv.bail ? ['--bail'] : []),\n      ]);\n    }\n    return 'echo \"No tests.\"';\n  }\n\n  protected waitApp(project: Project): string {\n    const port = project.env.PORT;\n    return `wait-on -t 10000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 500 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${port}`;\n  }\n\n  protected waitAndOpenApp(project: Project): string {\n    const port = project.env.PORT;\n    return `${this.waitApp(\n      project\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n\nfunction findEcosystemConfigPath(project: Project): string | undefined {\n  try {\n    return project.findFile('ecosystem.config.cjs');\n  } catch {\n    return;\n  }\n}\n\nfunction buildPlaywrightCommand(\n  playwrightArgs: string[],\n  targets: TestArgv['targets'],\n  bail?: boolean,\n  forwardedPlaywrightArgs: string[] = []\n): string {\n  const base = ['BUN', 'playwright'];\n  const normalizedTargets = targets?.map(String);\n  if (playwrightArgs[0] !== 'test' || !normalizedTargets?.length) {\n    return appendPlaywrightBailOption([...base, ...playwrightArgs, ...forwardedPlaywrightArgs], bail);\n  }\n\n  const rest = playwrightArgs.slice(1);\n  const explicitTargetIndexes = findExplicitPlaywrightTargetIndexes(rest);\n  const restWithoutExplicitTarget =\n    explicitTargetIndexes.length === 0 ? rest : rest.filter((_, index) => !explicitTargetIndexes.includes(index));\n  return appendPlaywrightBailOption(\n    [...base, 'test', ...normalizedTargets, ...restWithoutExplicitTarget, ...forwardedPlaywrightArgs],\n    bail\n  );\n}\n\nfunction appendPlaywrightBailOption(commandArgs: string[], bail?: boolean): string {\n  const playwrightIndex = commandArgs.indexOf('playwright');\n  const isPlaywrightTestCommand = playwrightIndex !== -1 && commandArgs[playwrightIndex + 1] === 'test';\n  if (!bail || !isPlaywrightTestCommand) {\n    return buildShellCommand(commandArgs);\n  }\n  if (commandArgs.some((arg) => arg === '--max-failures' || arg.startsWith('--max-failures='))) {\n    return buildShellCommand(commandArgs);\n  }\n  return buildShellCommand([...commandArgs, '--max-failures=1']);\n}\n\nexport function findExplicitPlaywrightTargetIndexes(args: string[]): number[] {\n  let pendingValueMode: 'optional' | 'required' | undefined;\n  const targetIndexes: number[] = [];\n\n  for (const [index, arg] of args.entries()) {\n    if (pendingValueMode) {\n      if (pendingValueMode === 'required' || !arg.startsWith('-')) {\n        pendingValueMode = undefined;\n        continue;\n      }\n      pendingValueMode = undefined;\n    }\n\n    if (arg === '--') {\n      return [...targetIndexes, ...args.slice(index + 1).map((_, offset) => index + 1 + offset)];\n    }\n    if (arg.startsWith('--')) {\n      if (arg.includes('=')) continue;\n      if (PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES.has(arg)) {\n        pendingValueMode = 'required';\n      } else if (PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES.has(arg)) {\n        pendingValueMode = 'optional';\n      }\n      continue;\n    }\n    if (arg.startsWith('-') && arg !== '-') {\n      const shortOption = arg.slice(0, 2);\n      if (arg.length === 2 && PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES.has(shortOption)) {\n        pendingValueMode = 'required';\n      }\n      continue;\n    }\n    targetIndexes.push(index);\n  }\n\n  return targetIndexes;\n}\n\nconst PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES = new Set([\n  '--browser',\n  '--config',\n  '--grep',\n  '--grep-invert',\n  '--global-timeout',\n  '--max-failures',\n  '--output',\n  '--project',\n  '--repeat-each',\n  '--reporter',\n  '--retries',\n  '--shard',\n  '--test-list',\n  '--test-list-invert',\n  '--timeout',\n  '--trace',\n  '--tsconfig',\n  '--ui-host',\n  '--ui-port',\n  '--ui-title',\n  '--workers',\n]);\n\nconst PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES = new Set([\n  '--only-changed',\n  '--update-snapshots',\n  '--update-source-method',\n]);\n\nconst PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES = new Set(['-c', '-g', '-j']);\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Blitz.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass BlitzScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `blitz dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { buildEnvReaderOptionArgs } from '../../sharedOptionsBuilder.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport { buildShellCommand } from '../../utils/shell.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts, type TestE2EOptions } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass HttpServerScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    options: TestE2EOptions = {}\n  ): Promise<string> {\n    if (project.hasPlaywrightConfig) {\n      return super.testE2EProtected(project, argv, startCommand, options);\n    }\n\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const targets = argv.targets?.map(String);\n    const normalizedTargets = targets?.length ? targets : ['test/e2e/'];\n    const testCommand = this.testUnit(project, { ...argv, targets: normalizedTargets });\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      `${startCommand} && exit 1`,\n      `wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port} && ${testCommand}${suffix}`,\n    ]);\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Next.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass NextScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `next dev --turbopack ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.js';\nimport { SERVER_LOG_FILE } from '../../utils/log.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PlainAppScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected startDevProtected(_1: Project, _2: ScriptArgv): string {\n    throw new Error('This method should not be called.');\n  }\n\n  override startDev(_: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`\n    );\n  }\n  override startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${project.buildCommand} && ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''} | tee ${SERVER_LOG_FILE}`\n    );\n  }\n  override startTest(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${this.buildDocker(project, 'development')} && ${dockerScripts.stopAndStart(\n        project,\n        argv.normalizedDockerOptionsText ?? '',\n        argv.normalizedArgsText ?? ''\n      )}`\n    );\n  }\n\n  override testE2EDev(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EProduction(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EDocker(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testStart(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Remix commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass RemixScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `remix dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Vite-based apps with Playwright e2e tests.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass ViteScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN vite dev ${argv.normalizedArgsText ?? ''}`.trim();\n  }\n\n  protected override startProductionProtected(project: Project, argv: ScriptArgv): string {\n    return `${project.buildCommand} && YARN vite preview ${argv.normalizedArgsText ?? ''}`.trim();\n  }\n}\n\nexport const viteScripts = new ViteScripts();\n","export const httpServerPackages = ['express', 'fastify', 'elysia', 'hono'];\n","import chalk from 'chalk';\nimport type { Argv, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { normalizeArgs, scriptOptionsBuilder } from '../scripts/builder.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug | test',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const startCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'start [args..]',\n  describe:\n    \"Start app. Use '--' to stop wb option parsing and forward the remaining arguments to the underlying app command. Example: wb start -- --host 0.0.0.0\",\n  builder: (yargs: Argv<unknown>) =>\n    yargs.parserConfiguration({ 'populate--': true }).options(builder) as Argv<\n      InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>\n    >,\n  async handler(argv) {\n    normalizeArgs(argv);\n\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of projects.descendants) {\n      const deps = project.packageJson.dependencies ?? {};\n      const devDeps = project.packageJson.devDependencies ?? {};\n      let scripts: BaseScripts;\n      if (deps.blitz) {\n        scripts = blitzScripts;\n      } else if (deps.next) {\n        scripts = nextScripts;\n      } else if (devDeps['@remix-run/dev']) {\n        scripts = remixScripts;\n      } else if (devDeps.vite) {\n        scripts = viteScripts;\n      } else if (\n        (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) ||\n        (project.hasDockerfile && /EXPOSE\\s+8080/.test(project.dockerfile))\n      ) {\n        scripts = httpServerScripts;\n      } else if (deps['build-ts'] || devDeps['build-ts']) {\n        scripts = plainAppScripts;\n      } else {\n        continue;\n      }\n      console.info(`Running \"start\" for ${project.name} ...`);\n\n      switch (argv.mode ?? 'dev') {\n        case 'dev':\n        case 'development': {\n          process.env.WB_ENV ||= 'development';\n          await runWithSpawn(await scripts.startDev(project, argv), project, argv);\n          break;\n        }\n        case 'staging': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startProduction(project, argv), project, argv);\n          break;\n        }\n        case 'docker': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          process.env.WB_ENV ||= 'staging';\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'test': {\n          process.env.WB_ENV ||= 'test';\n          const script = await scripts.startTest(project, argv);\n          await runWithSpawn(script, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport { distance } from 'fastest-levenshtein';\nimport type { Argv, ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { scriptOptionsBuilder } from '../scripts/builder.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { findExplicitPlaywrightTargetIndexes } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst ANSI_ESCAPE_CODE_REGEXP = new RegExp(`${String.fromCodePoint(27)}\\\\[[0-?]*[ -/]*[@-~]`, 'g');\nconst SIMILAR_TEST_OUTPUT_LOOKBACK_LINE_COUNT = 200;\nconst SIMILAR_TEST_OUTPUT_DISTANCE_RATIO = 0.05;\n\nconst builder = {\n  e2e: {\n    description:\n      'E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace',\n    type: 'string',\n    choices: [\n      'headless',\n      'headless-dev',\n      'headed',\n      'headed-dev',\n      'docker',\n      'docker-debug',\n      'debug',\n      'generate',\n      'trace',\n    ],\n    default: 'headless',\n  },\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n  bail: {\n    description: 'Stop tests after the first failure',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  targets: {\n    description: 'Test target paths',\n    type: 'array',\n  },\n} as const;\n\ntype TestCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>;\n\nexport type TestArgv = Partial<\n  ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder & typeof argumentsBuilder>>\n>;\n\nexport type TestCommandArgv = ArgumentsCamelCase<TestCommandOptions> & { '--'?: string[] };\n\nexport const testCommand: CommandModule<unknown, TestCommandOptions> = {\n  command: 'test [targets...]',\n  describe:\n    \"Test project. If you pass no arguments, it will run all tests. Use '--' to stop wb option parsing and forward the remaining flags to Playwright. Example: wb test -- --grep 'uploaded image asset'\",\n  builder: (yargs: Argv<unknown>): Argv<TestCommandOptions> =>\n    yargs\n      .parserConfiguration({ 'populate--': true })\n      .options({ ...builder, ...argumentsBuilder }) as Argv<TestCommandOptions>,\n  async handler(argv) {\n    await test(argv as TestCommandArgv);\n  },\n};\n\nexport async function test(argv: TestCommandArgv): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.FORCE_COLOR ||= '3';\n  delete process.env.NO_COLOR;\n  process.env.WB_ENV ||= 'test';\n\n  // Get test targets from positional arguments\n  const testTargets = (argv.targets ?? []) as string[];\n  const forwardedPlaywrightArgs = argv['--'] ?? [];\n  const { shouldRunE2e, shouldRunUnit } = resolveTestExecutionTargets(testTargets, forwardedPlaywrightArgs);\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (devDeps.vite) {\n      scripts = viteScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    // Run unit tests if needed\n    const defaultUnitTargets = getDefaultUnitTargets(project);\n    if (shouldRunUnit && defaultUnitTargets !== false) {\n      const unitTargets = testTargets.filter((target) => target.includes('/unit'));\n      const targets =\n        unitTargets.length > 0 ? unitTargets : defaultUnitTargets.length > 0 ? defaultUnitTargets : undefined;\n      const unitArgv = { ...argv, targets };\n      await runTestCommand(scripts.testUnit(project, unitArgv), project, argv, { timeout: argv.unitTimeout });\n    }\n    // Skip e2e tests if not needed or no e2e directory exists\n    if (!shouldRunE2e || !fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      continue;\n    }\n\n    // Get e2e targets for this project\n    const e2eTargets = testTargets.filter((target) => target.includes('/e2e'));\n    const e2eArgv = { ...argv, targets: e2eTargets.length > 0 ? e2eTargets : undefined };\n\n    switch (argv.e2e) {\n      case 'headless': {\n        await runTestCommand(\n          await scripts.testE2EProduction(project, e2eArgv, {\n            playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n            forwardedPlaywrightArgs,\n          }),\n          project,\n          argv\n        );\n        continue;\n      }\n      case 'headless-dev': {\n        await runTestCommand(\n          await scripts.testE2EDev(project, e2eArgv, {\n            playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n            forwardedPlaywrightArgs,\n          }),\n          project,\n          argv\n        );\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(\n          project,\n          e2eArgv,\n          scripts,\n          buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n          forwardedPlaywrightArgs\n        );\n        continue;\n      }\n      case 'docker-debug': {\n        await testOnDocker(\n          project,\n          e2eArgv,\n          scripts,\n          buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--debug']),\n          forwardedPlaywrightArgs\n        );\n        continue;\n      }\n    }\n    if (deps.blitz || deps.next || devDeps['@remix-run/dev'] || devDeps.vite) {\n      switch (argv.e2e) {\n        case 'headed': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--headed']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'headed-dev': {\n          await runTestCommand(\n            await scripts.testE2EDev(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--headed']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'debug': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--debug']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'generate': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: ['codegen', `http://localhost:${project.env.PORT}`],\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'trace': {\n          await runTestCommand(`BUN playwright show-trace`, project, argv);\n          break;\n        }\n      }\n    }\n  }\n}\n\nfunction getDefaultUnitTargets(project: Project): string[] | false {\n  if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n    return [];\n  }\n  if (project.hasVitest && fs.existsSync(path.join(project.dirPath, 'test'))) {\n    return fs.existsSync(path.join(project.dirPath, 'test', 'e2e')) ? ['test', '--exclude', 'test/e2e/**'] : ['test'];\n  }\n  return false;\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof argumentsBuilder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string[],\n  forwardedPlaywrightArgs?: string[]\n): Promise<void> {\n  project.env.WB_DOCKER ||= '1';\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n  process.exitCode = await runTestCommand(\n    await scripts.testE2EDocker(project, argv, {\n      playwrightArgs,\n      forwardedPlaywrightArgs,\n    }),\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n\nfunction runTestCommand(\n  script: string,\n  project: Project,\n  argv: Parameters<typeof runWithSpawn>[2],\n  options: Parameters<typeof runWithSpawn>[3] = {}\n): Promise<number> {\n  return runWithSpawn(script, project, argv, {\n    ...options,\n    processSilentOutput: dedupeNoisyTestOutput,\n  });\n}\n\nfunction dedupeNoisyTestOutput(output: string): string {\n  const recentPrintedLines: string[] = [];\n  const recentPrintedLineSet = new Set<string>();\n  const dedupedLines: string[] = [];\n  for (const line of iterateLines(output)) {\n    const normalizedLine = normalizeLineForSimilarity(line);\n    if (recentPrintedLineSet.has(normalizedLine)) continue;\n    if (recentPrintedLines.some((printedLine) => areLinesSimilar(printedLine, normalizedLine))) continue;\n\n    pushRecentPrintedLine(recentPrintedLines, recentPrintedLineSet, normalizedLine);\n    dedupedLines.push(line);\n  }\n  return dedupedLines.join('\\n');\n}\n\nfunction* iterateLines(output: string): Generator<string> {\n  let lineStartIndex = 0;\n  while (lineStartIndex <= output.length) {\n    const lineEndIndex = output.indexOf('\\n', lineStartIndex);\n    if (lineEndIndex === -1) {\n      yield output.slice(lineStartIndex);\n      return;\n    }\n\n    yield output.slice(lineStartIndex, lineEndIndex);\n    lineStartIndex = lineEndIndex + 1;\n  }\n}\n\nfunction pushRecentPrintedLine(lines: string[], lineSet: Set<string>, line: string): void {\n  lines.push(line);\n  lineSet.add(line);\n  if (lines.length <= SIMILAR_TEST_OUTPUT_LOOKBACK_LINE_COUNT) return;\n\n  const removedLine = lines.shift();\n  if (removedLine !== undefined) {\n    lineSet.delete(removedLine);\n  }\n}\n\nfunction normalizeLineForSimilarity(line: string): string {\n  return line\n    .replaceAll(ANSI_ESCAPE_CODE_REGEXP, '')\n    .trim()\n    .replaceAll(/^(?:\\[[^\\]]+\\]\\s*)+/g, '')\n    .replaceAll(/\\(node:\\d+\\)/g, '(node:<number>)')\n    .replaceAll(/\\b\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?Z?\\b/g, '<timestamp>')\n    .replaceAll(/([?&]cache=)\\d+/g, '$1<number>');\n}\n\nfunction areLinesSimilar(a: string, b: string): boolean {\n  const maxLength = Math.max(a.length, b.length);\n  if (maxLength === 0) return true;\n  if (Math.abs(a.length - b.length) > maxLength * SIMILAR_TEST_OUTPUT_DISTANCE_RATIO) return false;\n\n  return distance(a, b) / maxLength <= SIMILAR_TEST_OUTPUT_DISTANCE_RATIO;\n}\n\nexport function buildPlaywrightArgsForE2E(\n  e2eTargets: string[],\n  forwardedPlaywrightArgs: string[] = [],\n  additionalArgs: string[] = []\n): string[] {\n  const hasForwardedPlaywrightTargets = findExplicitPlaywrightTargetIndexes(forwardedPlaywrightArgs).length > 0;\n  return ['test', ...(e2eTargets.length > 0 || hasForwardedPlaywrightTargets ? [] : ['test/e2e/']), ...additionalArgs];\n}\n\nexport function resolveTestExecutionTargets(\n  testTargets: string[],\n  forwardedPlaywrightArgs: string[] = []\n): { shouldRunUnit: boolean; shouldRunE2e: boolean } {\n  const hasE2eTargets = testTargets.some((target) => target.includes('/e2e'));\n  const hasUnitTargets = testTargets.some((target) => target.includes('/unit'));\n  const shouldRunAllTests = testTargets.length === 0 && forwardedPlaywrightArgs.length === 0;\n\n  return {\n    shouldRunUnit: shouldRunAllTests || hasUnitTargets,\n    shouldRunE2e: shouldRunAllTests || hasE2eTargets || forwardedPlaywrightArgs.length > 0,\n  };\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst testOnCiBuilder = {\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n} as const;\nexport const testOnCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'test-on-ci',\n  describe: 'Test project on CI with no options.',\n  builder: testOnCiBuilder,\n  async handler(argv) {\n    await testOnCi(argv);\n  },\n};\n\nexport async function testOnCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.CI ||= '1';\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (devDeps.vite) {\n      scripts = viteScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test-on-ci\" for ${project.name} ...`);\n\n    const hasDockerfile = project.hasDockerfile;\n    if (hasDockerfile) {\n      await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n    }\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      // CI mode disallows `only` to avoid including debug tests\n      await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv);\n    }\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      // Confirm dev server startup for consistency across projects with E2E tests.\n      await runWithSpawnInParallel(await scripts.testStart(project, argv), project, argv);\n      await promisePool.promiseAll();\n      if (hasDockerfile) {\n        project.env.WB_DOCKER ||= '1';\n        await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n      }\n      const script = hasDockerfile\n        ? await scripts.testE2EDocker(project, argv, {})\n        : await scripts.testE2EProduction(project, argv, {});\n      process.exitCode = await runWithSpawn(\n        // CI mode disallows `only` to avoid including debug tests\n        script.replaceAll(' --allowOnly', ''),\n        project,\n        argv,\n        {\n          exitIfFailed: false,\n        }\n      );\n      if (hasDockerfile) {\n        await runWithSpawn(dockerScripts.stop(project), project, argv);\n      }\n    }\n  }\n}\n","import { constants } from 'node:os';\n\nimport { treeKill } from '@willbooster/shared-lib-node/src';\nimport type { Argv, CommandModule } from 'yargs';\n\ninterface TreeKillCommandArgs {\n  pid: number;\n  signal: string;\n}\n\nconst builder = (yargs: Argv): Argv<TreeKillCommandArgs> =>\n  yargs\n    .positional('pid', {\n      description: 'The process ID to kill.',\n      type: 'number',\n      demandOption: true,\n    })\n    .option('signal', {\n      description: 'Signal to send to the process tree.',\n      type: 'string',\n      default: 'SIGTERM',\n    }) as Argv<TreeKillCommandArgs>;\n\nexport const treeKillCommand: CommandModule<object, TreeKillCommandArgs> = {\n  command: 'tree-kill <pid> [signal]',\n  describe: 'Kill the given process and all descendants',\n  builder,\n  handler(argv) {\n    try {\n      const signal = argv.signal as NodeJS.Signals;\n      if (!(signal in constants.signals)) {\n        throw new Error(`Invalid signal: ${signal}`);\n      }\n      treeKill(argv.pid, signal);\n    } catch (error) {\n      console.error(error instanceof Error ? error.message : String(error));\n      process.exit(1);\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport type { Project } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {} as const;\n\ntype TypeCheckCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>;\nexport type TypeCheckCommandArgv = ArgumentsCamelCase<TypeCheckCommandOptions>;\n\nexport const typeCheckCommand: CommandModule<unknown, TypeCheckCommandOptions> = {\n  command: 'typecheck',\n  describe: 'Run type checking. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    process.exit(await typeCheck(argv));\n  },\n};\n\nexport async function typeCheck(argv: TypeCheckCommandArgv): Promise<number> {\n  const projects = await findDescendantProjects(argv, false);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    return 1;\n  }\n\n  let removedNextDir = false as boolean;\n  const promises = projects.descendants.map(async (project) => {\n    const commands: string[] = [];\n    if (!project.packageJson.workspaces || project.hasSourceCode) {\n      commands.push(...buildTypeScriptTypeCheckCommands(project));\n    }\n    if (!project.packageJson.workspaces && project.hasOwnDependency('pyright')) {\n      commands.push('YARN pyright');\n    }\n    while (commands.length > 0) {\n      const exitCode = await runWithSpawnInParallel(commands.join(' && '), project, argv, {\n        // Disable interactive mode\n        ci: projects.descendants.length > 1,\n        exitIfFailed: false,\n        forceColor: true,\n      });\n\n      // Re-try type checking after removing `.next` directory\n      const nextDirPath = path.join(project.dirPath, '.next');\n      if (exitCode && fs.existsSync(nextDirPath)) {\n        fs.rmSync(nextDirPath, { force: true, recursive: true });\n        console.info(chalk.yellow('Removed `.next` directory. We will re-try type checking.'));\n        removedNextDir = true;\n        continue;\n      }\n\n      return exitCode;\n    }\n  });\n  const exitCodes = await Promise.all(promises);\n  let finalExitCode = 0;\n  for (const [i, exitCode] of exitCodes.entries()) {\n    if (exitCode) {\n      const deps = projects.descendants[i]?.packageJson.dependencies ?? {};\n      if (deps.blitz) {\n        console.info(chalk.yellow('Please try \"yarn gen-code\" if you face unknown type errors.'));\n      }\n      finalExitCode = exitCode;\n    }\n  }\n  if (!finalExitCode)\n    console.info(\n      chalk.green(\n        removedNextDir\n          ? '-----\\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.'\n          : 'No type errors found.'\n      )\n    );\n  return finalExitCode;\n}\n\nfunction buildTypeScriptTypeCheckCommands(project: Project): string[] {\n  if (project.hasOwnDependency('@typescript/native-preview')) {\n    return ['BUN tsgo --noEmit'];\n  }\n  if (project.hasOwnDependency('typescript')) {\n    return ['BUN tsc --noEmit'];\n  }\n  return [];\n}\n\nexport const tcCommand: CommandModule<unknown, TypeCheckCommandOptions> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findRootAndSelfProjects } from '../project.js';\nimport { configureEnv } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { lint, type LintCommandArgv } from './lint.js';\nimport { test, type TestCommandArgv } from './test.js';\n\nconst builder = {\n  full: {\n    type: 'boolean',\n    default: false,\n    describe: 'Run tests after verifying project code',\n  },\n} as const;\n\ntype VerifyCodeCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>;\ntype VerifyCodeCommandArgv = ArgumentsCamelCase<VerifyCodeCommandOptions>;\n\nexport const verifyCodeCommand: CommandModule<unknown, VerifyCodeCommandOptions> = {\n  command: 'verify',\n  describe: 'Verify project code',\n  builder,\n  async handler(argv) {\n    const projects = findRootAndSelfProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    await (argv.full ? verifyCodeFully(projects.self, argv) : verifyCode(projects.self, argv));\n  },\n};\n\nasync function verifyCodeFully(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  const reporter = startVerifyFullReporter(project);\n  try {\n    await verifyCode(project, argv);\n    await runProjectTest(project, argv);\n    reporter.succeed();\n  } catch (error) {\n    reporter.fail(error);\n    throw error;\n  } finally {\n    reporter.finish();\n  }\n}\n\nasync function verifyCode(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  await runPackageCommand(`${packageManager} install`, project, argv);\n  if (project.packageJson.scripts?.['gen-code']) {\n    await runPackageCommand(`${packageManager} gen-code`, project, argv);\n  }\n  await runInProcessCommand(\n    'format',\n    () =>\n      lint({\n        ...argv,\n        _: ['lint'],\n        format: true,\n        printAllOutput: true,\n        silent: true,\n      } as unknown as LintCommandArgv),\n    {\n      allowFailure: true,\n      silent: true,\n    }\n  );\n  await runInProcessCommand(\n    'lint-fix',\n    () =>\n      lint({\n        ...argv,\n        _: ['lint'],\n        fix: true,\n        printAllOutput: true,\n        quiet: true,\n        silent: true,\n      } as unknown as LintCommandArgv),\n    { silent: true }\n  );\n}\n\nasync function runProjectTest(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  await test({ ...argv, _: ['test'], e2e: 'headless', silent: true } as unknown as TestCommandArgv);\n}\n\nasync function runInProcessCommand(\n  commandName: string,\n  command: () => Promise<number | undefined>,\n  options: { allowFailure?: boolean; silent?: boolean } = {}\n): Promise<number> {\n  if (!options.silent) {\n    console.info('\\n' + chalk.cyan(chalk.bold('Start:'), commandName));\n  }\n  const exitCode = (await command()) ?? 0;\n  if (exitCode === 0 || options.allowFailure) {\n    if (!options.silent) {\n      console.info(chalk.green(chalk.bold('Finished:'), commandName));\n    }\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}):`), commandName));\n    process.exit(exitCode);\n  }\n  return exitCode;\n}\n\nasync function runPackageCommand(\n  command: string,\n  project: Project,\n  argv: VerifyCodeCommandArgv,\n  options: { allowFailure?: boolean; printRawOutput?: boolean } = {}\n): Promise<number> {\n  printCommand(command, project.dirPath);\n  if (argv.dryRun) {\n    return 0;\n  }\n\n  const ret = await spawnAsync(command, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, { forceColor: false }),\n    shell: true,\n    stdio: 'pipe',\n    mergeOutAndError: true,\n    killOnExit: true,\n    printingStdout: options.printRawOutput,\n    printingStderr: options.printRawOutput,\n    verbose: argv.verbose,\n  });\n  const exitCode = ret.status ?? 1;\n  if (!options.printRawOutput) {\n    printPackageCommandOutput(command, exitCode, ret.stdout);\n  }\n\n  if (exitCode !== 0 && !options.allowFailure) {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}):`), command));\n    process.exit(exitCode);\n  }\n  return exitCode;\n}\n\n/**\n * Prints package command output for `wb verify`.\n *\n * `wb verify` is primarily consumed by AI coding agents, so successful noisy\n * commands are summarized while failure output remains available for diagnosis.\n *\n * @param command The executed command.\n * @param exitCode The command exit code.\n * @param output The merged stdout and stderr output from the command.\n */\nfunction printPackageCommandOutput(command: string, exitCode: number, output: string): void {\n  if (exitCode === 0 && (command === `${packageManager} install` || command === `${packageManager} gen-code`)) {\n    console.info(chalk.green('Succeeded.'));\n    return;\n  }\n\n  const trimmedOutput = output.trim();\n  if (trimmedOutput) {\n    process.stdout.write(trimmedOutput);\n    process.stdout.write('\\n');\n  }\n}\n\nfunction printCommand(command: string, cwd: string): void {\n  console.info('\\n' + chalk.cyan(chalk.bold('Command:'), command) + chalk.gray(` at ${cwd}`));\n}\n\nfunction startVerifyFullReporter(project: Project): {\n  fail: (error?: unknown) => void;\n  finish: () => void;\n  succeed: () => void;\n} {\n  const startedAt = Date.now();\n  const wbDirPath = path.join(project.dirPath, '.wb');\n  fs.mkdirSync(wbDirPath, { recursive: true });\n\n  const logFilePath = path.join(wbDirPath, 'verify-full.log');\n  const logFile = fs.openSync(logFilePath, 'w');\n  const originalStdoutWrite = process.stdout.write.bind(process.stdout);\n  const originalStderrWrite = process.stderr.write.bind(process.stderr);\n  let succeeded = false;\n  let finished = false;\n\n  process.stdout.write = teeWrite(process.stdout.fd, logFile) as typeof process.stdout.write;\n  process.stderr.write = teeWrite(process.stderr.fd, logFile) as typeof process.stderr.write;\n  console.info(chalk.cyan(chalk.bold('Full log:'), logFilePath));\n\n  const finish = (): void => {\n    if (finished) return;\n    finished = true;\n\n    process.stdout.write = originalStdoutWrite as typeof process.stdout.write;\n    process.stderr.write = originalStderrWrite as typeof process.stderr.write;\n\n    const elapsedTime = formatElapsedTime(Date.now() - startedAt);\n    const status = succeeded ? 'Succeeded' : 'Failed';\n    const summary = `${status} in ${elapsedTime}. Full log: ${logFilePath}\\n`;\n    const coloredSummary = succeeded ? chalk.green(summary) : chalk.red(summary);\n    originalStdoutWrite(coloredSummary);\n    fs.writeSync(logFile, summary);\n    fs.closeSync(logFile);\n  };\n\n  process.once('exit', finish);\n\n  return {\n    fail: (error) => {\n      succeeded = false;\n      if (error) {\n        console.error(error);\n      }\n    },\n    finish: () => {\n      process.removeListener('exit', finish);\n      finish();\n    },\n    succeed: () => {\n      succeeded = true;\n    },\n  };\n}\n\nfunction teeWrite(outputFile: number, logFile: number): typeof process.stdout.write {\n  return ((\n    chunk: Uint8Array | string,\n    encodingOrCallback?: BufferEncoding | ((error?: Error | null) => void),\n    callback?: (error?: Error | null) => void\n  ) => {\n    const buffer =\n      typeof chunk === 'string'\n        ? Buffer.from(chunk, typeof encodingOrCallback === 'string' ? encodingOrCallback : 'utf8')\n        : chunk;\n    fs.writeSync(logFile, buffer);\n    fs.writeSync(outputFile, buffer);\n    if (typeof encodingOrCallback === 'function') {\n      encodingOrCallback();\n    }\n    callback?.();\n    return true;\n  }) as typeof process.stdout.write;\n}\n\nfunction formatElapsedTime(milliseconds: number): string {\n  const seconds = Math.round(milliseconds / 1000);\n  const minutes = Math.floor(seconds / 60);\n  const remainingSeconds = seconds % 60;\n  if (minutes === 0) {\n    return `${remainingSeconds}s`;\n  }\n  return `${minutes}m ${remainingSeconds}s`;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables, treeKill } from '@willbooster/shared-lib-node/src';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.js';\nimport { concurrentlyCommand } from './commands/concurrently.js';\nimport { killPortIfNonCiCommand } from './commands/killPortIfNonCi.js';\nimport { lintCommand } from './commands/lint.js';\nimport { optimizeForDockerBuildCommand } from './commands/optimizeForDockerBuild.js';\nimport { prismaCommand } from './commands/prisma.js';\nimport { retryCommand } from './commands/retry.js';\nimport { setupCommand } from './commands/setup.js';\nimport { startCommand } from './commands/start.js';\nimport { testCommand } from './commands/test.js';\nimport { testOnCiCommand } from './commands/testOnCi.js';\nimport { treeKillCommand } from './commands/treeKill.js';\nimport { tcCommand, typeCheckCommand } from './commands/typecheck.js';\nimport { verifyCodeCommand } from './commands/verifyCode.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nawait yargs(hideBin(process.argv))\n  .scriptName('wb')\n  .options(sharedOptionsBuilder)\n  .middleware((argv) => {\n    const workingDir = argv['working-dir'];\n    if (workingDir) {\n      const dirPath = path.resolve(workingDir);\n      process.chdir(dirPath);\n    }\n\n    removeNpmAndYarnEnvironmentVariables(process.env);\n  })\n  .command(verifyCodeCommand)\n  .command(buildIfNeededCommand)\n  .command(concurrentlyCommand)\n  .command(killPortIfNonCiCommand)\n  .command(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(testOnCiCommand)\n  .command(treeKillCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n\nlet shuttingDown = false;\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => {\n    if (shuttingDown) return;\n\n    shuttingDown = true;\n    try {\n      treeKill(process.pid);\n    } catch (error) {\n      console.warn(`Failed to treeKill(${process.pid}) during shutdown:`, error);\n    }\n    process.exit();\n  });\n}\n"],"names":["yargsOptionsBuilderForEnv","env","description","type","default","verbose","alias","cachedEnvVars","Map","readEnvFile","filePath","cached","get","parsed","config","path","resolve","processEnv","quiet","set","isErrnoException","error","Error","treeKill","pid","signal","Number","isInteger","process","platform","runCommand","String","maxBuffer","timeout","isNoSuchProcessError","killTreeOnWindows","descendants","rootPid","stdout","childrenByParent","psOutput","line","split","matched","exec","childPid","parentPid","children","push","buildChildrenByParentMap","queue","index","length","collectDescendantPidsFromMap","collectDescendantPids","targetPids","toReversed","toChildrenFirstPids","targetPid","killIfNeeded","kill","command","args","options","execFileSync","encoding","stdio","stderr","Buffer","isBuffer","toString","extractStderr","CommandExecutionError","code","status","toExitCode","test","constructor","super","join","this","name","async","spawnAsync","Promise","reject","proc","spawn","setEncoding","stdoutPrinter","createRealtimePrinter","omitBlankLinesWhilePrinting","stderrPrinter","on","data","printingStdout","write","mergeOutAndError","printingStderr","stopped","stopProcess","console","info","warn","cleanupSignals","signalHandlers","removeKillOnExitHandlers","removeListener","handler","clear","killOnExit","handleSignal","listenerCount","removeAllListeners","flush","undefined","input","stdin","end","ANSI_ESCAPE_CODE_REGEXP","RegExp","fromCodePoint","stream","omitBlankLines","pending","lines","pop","isBlankLine","replaceAll","trim","t","s","i","e","n","entries","h","blocks","reset","finalized","block","start","lastByteIndex","padding","outputBits","blockCount","byteCount","outputBlocks","extraBytes","update","o","l","c","f","codePointAt","r","finalize","hex","a","u","d","b","k","y","x","B","p","C","z","I","g","w","A","P","E","j","m","q","v","D","F","G","H","J","K","L","M","N","O","Q","R","S","T","U","V","W","X","Y","Z","$","_","tt","st","it","et","ot","nt","ht","rt","lt","ct","ft","instance","from","message","stack","cause","stub","hydrate","Uint8Array","btoa","decode","create","encode","atob","Set","values","add","Date","toJSON","flags","source","URL","href","map","TextEncoder","TextDecoder","JSON","stringify","isNaN","isFinite","Array","isArray","fill","slice","Object","cacheDuration","POSITIVE_INFINITY","getCacheKey","kind","now","call","isCI","ciEnv","Project","_initProto","_applyDecs","memoizeOne","argv","pathByName","dirPath","loadEnv","_dirPath","isBunAvailable","hasBunToolVersion","usesBunPackageManager","hasBunLockfile","hasBunPackageManager","fs","readFileSync","rootDirPath","some","fileName","existsSync","packageManager","rootPackageJson","packageJson","startsWith","buildCommand","scripts","build","includes","dockerfile","findFile","hasDockerfile","hasSourceCode","dockerImageName","envVars","envPathAndLoadedEnvVarCountPairs","cwd","envPaths","envPath","cascade","cascadeEnv","cascadeNodeEnv","NODE_ENV","autoCascadeEnv","WB_ENV","includeRootEnv","rootPath","flatMap","filter","relative","envPathAndLoadedEnvVarNames","keys","key","value","checkEnv","missingKeys","expand","readEnvironmentVariables","count","parse","packageJsonPath","hasPrisma","getOwnDependencyVersion","hasDrizzle","databaseOrm","hasVitest","dependencies","vitest","devDependencies","hasOxlint","hasDependency","hasOxfmt","hasPrettier","hasPoetryLock","hasPubspecYaml","preferredLinter","hasOwnDependency","packageName","hasPlaywrightConfig","skipLaunchingServerForPlaywright","CI","configPath","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","find","getDependencyVersion","optionalDependencies","peerDependencies","findSelfProject","findDescendantProjects","rootAndSelfProjects","findRootAndSelfProjects","root","self","getAllDescendantProjects","thisProject","rootProject","workspaces","endsWith","projects","workspace","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","versions","bun","npm_execpath","runtimeWithArgs","packageManagerWithRun","buildIfNeededCommand","describe","projectPathForTesting","project","chalk","red","green","canSkip","cacheFilePath","contentHash","cacheDirectoryPath","promises","mkdir","recursive","hash","createHash","commitHash","child_process","execSync","environmentJson","ignoringEnvVarNames","has","toSorted","key1","key2","localeCompare","filteredFilePaths","spawnSync","replace","includePatterns","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","normalizedScript","normalizeScript","printStart","printable","silent","runnable","printFinishedAndExitIfNeeded","silentSuccess","shouldProcessSilentOutput","Boolean","processSilentOutput","configureEnv","output","onSignal","runWithSpawnInParallel","runAndWaitForReturnValue","printRawOutput","out","projectPackageManagerWithRun","newScript","blitz","printableScript","fixBunCommand","runnableScript","prefix","weak","gray","cyan","bold","printOptions","exit","newEnv","ci","forceColor","FORCE_COLOR","sharedOptionsBuilder","buildEnvReaderOptionArgs","optionName","getOptionValue","item","camelCaseOptionName","character","toUpperCase","concurrentlyCommand","builder","success","choices","commands","detached","interruptedSignal","firstResult","stopResult","stopping","forceKillPromises","results","waitForExitPromises","child","settled","settle","killOthers","killOthersOnFail","shouldStopOthers","terminateChildren","once","getExitCode","stopAll","stopOnSigint","stopOnSigterm","stopOnSigquit","all","result","runConcurrently","constants","signals","forceKillPids","signalPids","toChildPids","pids","deadline","every","isProcessGroupGone","sleep","Math","min","waitForForceKill","signaledPids","killProcessGroup","ms","setTimeout","killPortIfNonCiCommand","portEnv","PORT","port","killPortProcess","killPortIfNonCi","printBufferedOutput","hasWarningOutput","removeNoColorWarning","shouldPrintBufferedOutput","normalizedOutput","normalizeBufferedOutput","buildShellCommand","arg","shellEscapeArgument","oxlintExtensions","pythonExtensions","dartExtensions","oxfmtExtensions","prettierExtensions","prettierOnlyExtensions","ext","prettierFixtureIgnorePattern","lintCommand","fix","format","lint","files","lintTargets","getLintTargetFiles","lintFilePathsByProject","oxfmtFilePathsByProject","pythonFilePathsByProject","dartFilePathsByProject","prettierFilePaths","packageJsonFilePaths","prettierArgs","sortPackageJsonArgs","missingLintToolForExplicitFiles","file","fileKind","stat","isDirectory","getLintTargetFileKind","extension","extname","getExplicitPackageJsonPaths","lintPath","getExplicitLintTargets","pythonFilePaths","dartFilePaths","supportsLintingExtension","lintFilePaths","oxfmtFilePaths","buildPrettierOnlyDirectoryPattern","formatterPath","buildExplicitFormatterArgs","isPotentialLintTarget","selfDirPath","needsPrettier","projectPattern","buildPrettierArgs","lintPromises","lintRunOptions","printAllOutput","buildLintCommand","runLintCommand","buildOxfmtCommand","buildPoetryCommand","buildDartCommand","lintResults","printSilentLintOutputs","lintExitCodes","prettierResult","sortPackageJsonResult","runWithSpawnInParallelBuffered","then","printableResults","printCommandOutput","printCommandHeader","targets","shouldFormatExplicitPathWithPrettier","descendantProjects","owningProject","findOwningProject","prepareForRunningCommand","commandName","runtimeDevDependencies","optimizeForDockerBuildCommand","outside","deps","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","promotedDeps","version","promoteRuntimeDevDependencies","nameWordsToBeRemoved","removedDeps","word","removeUnnecessaryDevDependenciesForOutsideDockerBuild","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","removedScripts","content","private","publishConfig","prettier","FILE_SCHEMA","drizzleScripts","deploy","additionalOptions","migrate","_project","migrateDev","removeCommand","dbPath","DATABASE_PATH","dbUrl","DATABASE_URL","rawDbPath","getFileDatabaseUrlPath","absolutePath","isAbsolute","buildRemoveSqliteDbCommand","seed","scriptPath","studio","dbUrlOrPath","POSSIBLE_PRISMA_PATHS","schemaPath","getDatabaseDirPath","getPrismaBaseDir","prismaScripts","cleanUpLitestream","deployForce","removeDbCommand","listBackups","steps","cleanupCommand","baseDir","cleanUpSqliteDbIfNeeded","resetCommand","restore","outputPath","prisma","prismaCommand","aliases","yargs","parserConfiguration","cleanUpLitestreamCommand","createLitestreamConfigCommand","deployCommand","deployForceCommand","listBackupsCommand","migrateCommand","migrateDevCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","strict","allProjects","findDatabaseOrmProjects","prepareForRunningDatabaseOrmCommand","createLitestreamConfig","unknownOptions","extractUnknownOptions","orm","getDatabaseOrmScripts","restored","fullCommand","trimEnd","requiredEnvVars","CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID","CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME","CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID","CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY","missingEnvVars","retentionCheckInterval","litestreamConfig","writeFileSync","reason","filtered","ormProjectByProject","ormProject","knownOptions","sharedOptionKeys","sharedOptionAliases","option","allKnownOptions","kebabCaseKey","match","toLowerCase","passthroughArgs","retryCommand","retry","cmdAndArgs","lastStatus","yellow","setupCommand","dirents","readdir","withFileTypes","os","packages","isFile","promiseAll","playwright","setup","toDevNull","killed","killPortProcessImmediatelyAndOnExit","available","host","probePort","isPortAvailable","killPortContainerAndProcess","killFunc","filterArgs","containerIds","id","listDockerContainerIds","removeDockerContainers","stopDockerContainerByPort","checkAndKillPortProcess","rawPort","server","createServer","err","close","listen","dockerScripts","buildImage","stopAndStart","additionalArgs","stop","spawnSyncOnExit","BaseScripts","shouldWaitAndOpenApp","buildDocker","startDev","startDevProtected","waitAndOpenApp","startProduction","startProductionProtected","startTest","startDocker","normalizedDockerOptionsText","normalizedArgsText","ecosystemConfigPath","findEcosystemConfigPath","cmd","testE2EDev","testE2EProtected","testE2EProduction","testE2EDocker","testStart","waitApp","startCommand","forwardedPlaywrightArgs","playwrightArgs","playwrightCommand","bail","base","normalizedTargets","appendPlaywrightBailOption","rest","explicitTargetIndexes","findExplicitPlaywrightTargetIndexes","restWithoutExplicitTarget","buildPlaywrightCommand","testUnit","commandArgs","playwrightIndex","indexOf","isPlaywrightTestCommand","pendingValueMode","targetIndexes","offset","PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES","PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES","shortOption","PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES","blitzScripts","httpServerScripts","watch","testCommand","nextScripts","plainAppScripts","_1","_2","remixScripts","viteScripts","httpServerPackages","mode","dockerOptions","normalizeArgs","next","vite","e2e","argumentsBuilder","NO_COLOR","testTargets","shouldRunE2e","shouldRunUnit","hasE2eTargets","target","hasUnitTargets","shouldRunAllTests","resolveTestExecutionTargets","defaultUnitTargets","getDefaultUnitTargets","unitTargets","unitArgv","runTestCommand","unitTimeout","e2eTargets","e2eArgv","buildPlaywrightArgsForE2E","testOnDocker","WB_DOCKER","dedupeNoisyTestOutput","recentPrintedLines","recentPrintedLineSet","dedupedLines","lineStartIndex","lineEndIndex","iterateLines","normalizedLine","normalizeLineForSimilarity","printedLine","areLinesSimilar","pushRecentPrintedLine","lineSet","removedLine","shift","delete","maxLength","max","abs","distance","hasForwardedPlaywrightTargets","testOnCiCommand","testOnCi","treeKillCommand","positional","demandOption","typeCheckCommand","removedNextDir","buildTypeScriptTypeCheckCommands","nextDirPath","rmSync","force","exitCodes","finalExitCode","typeCheck","tcCommand","verifyCodeCommand","full","reporter","startedAt","wbDirPath","mkdirSync","logFilePath","logFile","openSync","originalStdoutWrite","bind","originalStderrWrite","succeeded","finished","teeWrite","fd","finish","elapsedTime","milliseconds","seconds","round","minutes","floor","remainingSeconds","formatElapsedTime","summary","coloredSummary","writeSync","closeSync","fail","succeed","startVerifyFullReporter","verifyCode","runProjectTest","verifyCodeFully","runPackageCommand","runInProcessCommand","allowFailure","printCommand","trimmedOutput","printPackageCommandOutput","outputFile","chunk","encodingOrCallback","callback","buffer","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","removeNpmAndYarnEnvironmentVariables","packageJsonDir","url","pathname","getVersion","help","shuttingDown"],"mappings":"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","x_google_ignoreList":[5,6,7,8,9]}
9
+ */const _=[..."0123456789abcdef"],B=[6,1536,393216,100663296],L=[0,8,16,24],F=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];const z=e=>{const t=[];for(const[n,r]of e.entries())t[n]=r;return t};class M{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(e,t,n){this.padding=t,this.outputBits=n,this.blockCount=1600-(e<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=n>>5,this.extraBytes=(31&n)>>3;for(let e=0;e<50;++e)this.s[e]=0}update(e){if(this.finalized)throw new Error("finalize already called");const t=this.blocks,n=this.byteCount,r=e.length,o=this.blockCount,s=this.s;let i,a,c=0;for(;c<r;){if(this.reset)for(this.reset=!1,t[0]=this.block,i=1;i<o+1;++i)t[i]=0;for(i=this.start;c<r&&i<n;++c)a=e.codePointAt(c)||0,a<128?t[i>>2]|=a<<L[3&i++]:a<2048?(t[i>>2]|=(192|a>>6)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]):a<55296||a>=57344?(t[i>>2]|=(224|a>>12)<<L[3&i++],t[i>>2]|=(128|a>>6&63)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]):(a=65536+((1023&a)<<10|1023&(e.codePointAt(++c)||0)),t[i>>2]|=(240|a>>18)<<L[3&i++],t[i>>2]|=(128|a>>12&63)<<L[3&i++],t[i>>2]|=(128|a>>6&63)<<L[3&i++],t[i>>2]|=(128|63&a)<<L[3&i++]);if(this.lastByteIndex=i,i>=n){for(this.start=i-n,this.block=t[o],i=0;i<o;++i)s[i]^=t[i];U(s),this.reset=!0}else this.start=i}return this}finalize(){if(this.finalized)return;this.finalized=!0;const e=this.blocks;let t=this.lastByteIndex;const n=this.blockCount,r=this.s;if(e[t>>2]|=this.padding[3&t],this.lastByteIndex===this.byteCount)for(e[0]=e[n],t=1;t<n+1;++t)e[t]=0;for(e[n-1]|=2147483648,t=0;t<n;++t)r[t]^=e[t];U(r)}hex(){this.finalize();const e=this.blockCount;let t=this.s;const n=this.outputBlocks,r=this.extraBytes;let o,s=0,i=0,a="";for(;i<n;){for(s=0;s<e&&i<n;++s,++i)o=t[s],a+=_[o>>4&15]+_[15&o]+_[o>>12&15]+_[o>>8&15]+_[o>>20&15]+_[o>>16&15]+_[o>>28&15]+_[o>>24&15];i%e===0&&(t=z(t),U(t),s=0)}return r&&(o=t[s],a+=_[o>>4&15]+_[15&o],r>1&&(a+=_[o>>12&15]+_[o>>8&15]),r>2&&(a+=_[o>>20&15]+_[o>>16&15])),a}}const U=function(e){let t,n,r,o,s,i,a,c,l,d,u,p,f,h,m,g,w,y,b,v,k,A,E,P,S,$,x,R,j,O,D,N,T,C,I,_,B,L,z,M,U,W,J,Y,V,q,G,K,H,Q,Z,X,ee,te,ne,re,oe,se,ie,ae,ce,le,de;for(r=0;r<48;r+=2)o=e[0]^e[10]^e[20]^e[30]^e[40],s=e[1]^e[11]^e[21]^e[31]^e[41],i=e[2]^e[12]^e[22]^e[32]^e[42],a=e[3]^e[13]^e[23]^e[33]^e[43],c=e[4]^e[14]^e[24]^e[34]^e[44],l=e[5]^e[15]^e[25]^e[35]^e[45],d=e[6]^e[16]^e[26]^e[36]^e[46],u=e[7]^e[17]^e[27]^e[37]^e[47],p=e[8]^e[18]^e[28]^e[38]^e[48],f=e[9]^e[19]^e[29]^e[39]^e[49],t=p^(i<<1|a>>>31),n=f^(a<<1|i>>>31),e[0]^=t,e[1]^=n,e[10]^=t,e[11]^=n,e[20]^=t,e[21]^=n,e[30]^=t,e[31]^=n,e[40]^=t,e[41]^=n,t=o^(c<<1|l>>>31),n=s^(l<<1|c>>>31),e[2]^=t,e[3]^=n,e[12]^=t,e[13]^=n,e[22]^=t,e[23]^=n,e[32]^=t,e[33]^=n,e[42]^=t,e[43]^=n,t=i^(d<<1|u>>>31),n=a^(u<<1|d>>>31),e[4]^=t,e[5]^=n,e[14]^=t,e[15]^=n,e[24]^=t,e[25]^=n,e[34]^=t,e[35]^=n,e[44]^=t,e[45]^=n,t=c^(p<<1|f>>>31),n=l^(f<<1|p>>>31),e[6]^=t,e[7]^=n,e[16]^=t,e[17]^=n,e[26]^=t,e[27]^=n,e[36]^=t,e[37]^=n,e[46]^=t,e[47]^=n,t=d^(o<<1|s>>>31),n=u^(s<<1|o>>>31),e[8]^=t,e[9]^=n,e[18]^=t,e[19]^=n,e[28]^=t,e[29]^=n,e[38]^=t,e[39]^=n,e[48]^=t,e[49]^=n,h=e[0],m=e[1],q=e[11]<<4|e[10]>>>28,G=e[10]<<4|e[11]>>>28,R=e[20]<<3|e[21]>>>29,j=e[21]<<3|e[20]>>>29,ae=e[31]<<9|e[30]>>>23,ce=e[30]<<9|e[31]>>>23,W=e[40]<<18|e[41]>>>14,J=e[41]<<18|e[40]>>>14,C=e[2]<<1|e[3]>>>31,I=e[3]<<1|e[2]>>>31,g=e[13]<<12|e[12]>>>20,w=e[12]<<12|e[13]>>>20,K=e[22]<<10|e[23]>>>22,H=e[23]<<10|e[22]>>>22,O=e[33]<<13|e[32]>>>19,D=e[32]<<13|e[33]>>>19,le=e[42]<<2|e[43]>>>30,de=e[43]<<2|e[42]>>>30,te=e[5]<<30|e[4]>>>2,ne=e[4]<<30|e[5]>>>2,_=e[14]<<6|e[15]>>>26,B=e[15]<<6|e[14]>>>26,y=e[25]<<11|e[24]>>>21,b=e[24]<<11|e[25]>>>21,Q=e[34]<<15|e[35]>>>17,Z=e[35]<<15|e[34]>>>17,N=e[45]<<29|e[44]>>>3,T=e[44]<<29|e[45]>>>3,P=e[6]<<28|e[7]>>>4,S=e[7]<<28|e[6]>>>4,re=e[17]<<23|e[16]>>>9,oe=e[16]<<23|e[17]>>>9,L=e[26]<<25|e[27]>>>7,z=e[27]<<25|e[26]>>>7,v=e[36]<<21|e[37]>>>11,k=e[37]<<21|e[36]>>>11,X=e[47]<<24|e[46]>>>8,ee=e[46]<<24|e[47]>>>8,Y=e[8]<<27|e[9]>>>5,V=e[9]<<27|e[8]>>>5,$=e[18]<<20|e[19]>>>12,x=e[19]<<20|e[18]>>>12,se=e[29]<<7|e[28]>>>25,ie=e[28]<<7|e[29]>>>25,M=e[38]<<8|e[39]>>>24,U=e[39]<<8|e[38]>>>24,A=e[48]<<14|e[49]>>>18,E=e[49]<<14|e[48]>>>18,e[0]=h^~g&y,e[1]=m^~w&b,e[10]=P^~$&R,e[11]=S^~x&j,e[20]=C^~_&L,e[21]=I^~B&z,e[30]=Y^~q&K,e[31]=V^~G&H,e[40]=te^~re&se,e[41]=ne^~oe&ie,e[2]=g^~y&v,e[3]=w^~b&k,e[12]=$^~R&O,e[13]=x^~j&D,e[22]=_^~L&M,e[23]=B^~z&U,e[32]=q^~K&Q,e[33]=G^~H&Z,e[42]=re^~se&ae,e[43]=oe^~ie&ce,e[4]=y^~v&A,e[5]=b^~k&E,e[14]=R^~O&N,e[15]=j^~D&T,e[24]=L^~M&W,e[25]=z^~U&J,e[34]=K^~Q&X,e[35]=H^~Z&ee,e[44]=se^~ae&le,e[45]=ie^~ce&de,e[6]=v^~A&h,e[7]=k^~E&m,e[16]=O^~N&P,e[17]=D^~T&S,e[26]=M^~W&C,e[27]=U^~J&I,e[36]=Q^~X&Y,e[37]=Z^~ee&V,e[46]=ae^~le&te,e[47]=ce^~de&ne,e[8]=A^~h&g,e[9]=E^~m&w,e[18]=N^~P&$,e[19]=T^~S&x,e[28]=W^~C&_,e[29]=J^~I&B,e[38]=X^~Y&q,e[39]=ee^~V&G,e[48]=le^~te&re,e[49]=de^~ne&oe,e[0]^=F[r],e[1]^=F[r+1]},W=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,r,o])=>{e.name=t,e.message=n,void 0===r?delete e.stack:e.stack=r,void 0!==o&&(e.cause=o)}},t={instance:Uint8Array,from:e=>[btoa(Y.decode(e))],create:([e])=>J.encode(atob(e))},n={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,r]of t)e.set(n,r)}},r={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},o={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},s={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},i={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,n,r,o,s,i].map(e=>[e.instance.name,e]))}(),J=new TextEncoder,Y=new TextDecoder("utf-8");function V(e,t=W){return JSON.stringify(K(e,t))}function q(e){if(void 0===e)return-1;if("number"==typeof e){if(Number.isNaN(e))return-3;if(!Number.isFinite(e))return e<0?-5:-4}return null}const G=[];function K(e,t=W){const n=q(e);if(null!==n)return n;const r=[],o=new Map;return function e(n){const s=q(n);if(null!==s)return s;let i=o.get(n);if(void 0!==i)return i;switch(i=r.length,typeof n){case"number":case"string":case"boolean":r[i]=n,o.set(n,i);break;case"bigint":r[i]=[-6,n.toString(16)],o.set(n,i);break;case"object":if(null===n)r[i]=n,o.set(n,i);else if(Array.isArray(n)){const t=function(e){if(G.length<e){const t=G.length;G.length=e,G.fill(-2,t,e)}return G.slice(0,e)}(n.length);r[i]=t,o.set(n,i);for(const[r,o]of n.entries())t[r]=e(o)}else{const[s,a]=function(e,t){const n=e.constructor;if("function"==typeof n){const r=n.name,o=t.get(r);if(void 0!==o)return[r,o.from(e)]}const r=Object.entries(e),o=r.length,s=Array.from({length:o+o});for(let e=0;e<o;e++){const t=r[e],n=e+e;s[n]=t[0],s[n+1]=t[1]}return["",s]}(n,t),c=a.length,l=Array.from({length:c+1});l[0]=s,r[i]=l,o.set(n,i);for(let t=0;t<c;t++)l[t+1]=e(a[t])}}return i}(e),r}function H(e,t){return function(e){return new M(512,B,512).update(e).hex()}(V([e,t]))}const Q=function({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:t=H}={}){return function(n,r){let o,s,i;return"getter"===r?.kind?function(){const r=t(this,[]),a=Date.now();return(i!==r||a-s>e)&&(i=r,o=n.call(this),s=a),o}:function(...a){const c=t(this,a),l=Date.now();return(i!==c||l-s>e)&&(i=c,o=r?n.call(this,...a):n(...a),s=l),o}}}({getCacheKey:H});function Z(e){return!!e&&"0"!==e&&"false"!==e}let X;class ee{static{[X]=function(e,t,n,r,o){var s,i,a,c,l,d,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,h=Object.create,m=[h(null),h(null)],g=t.length;function w(t,n,r){return function(o,s){n&&(s=o,o=e);for(var i=0;i<t.length;i++)s=t[i].apply(o,r?[s]:[]);return r?s:o}}function y(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function b(e,t,n,r,o,a,c,l,d,u,p){function h(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),b=t[3],v=!c,k=1===o,A=3===o,E=4===o,P=2===o;function S(t,n,r){return function(o,s){return n&&(s=o,o=e),r&&r(o),$[t].call(o,s)}}if(!v){var $={},x=[],R=A?"get":E||k?"set":"value";if(d?(u||k?$={get:C(function(){return b(this)},r,"get"),set:function(e){t[4](this,e)}}:$[R]=b,u||C($[R],r,P?"":R)):u||($=Object.getOwnPropertyDescriptor(e,r)),!u&&!d){if((i=m[+l][r])&&7!==(i^o))throw Error("Decorating two elements with the same name ("+$[R].name+") is not supported yet");m[+l][r]=o<3?1:o}}for(var j=e,O=g.length-1;O>=0;O-=n?2:1){var D=y(g[O],"A decorator","be",!0),N=n?g[O-1]:void 0,T={},I={kind:["field","accessor","method","getter","setter","class"][o],name:r,metadata:s,addInitializer:function(e,t){if(e.v)throw new TypeError("attempted to call addInitializer after decoration was finished");y(t,"An initializer","be",!0),a.push(t)}.bind(null,T)};if(v)i=D.call(N,j,I),T.v=1,y(i,"class decorators","return")&&(j=i);else if(I.static=l,I.private=d,i=I.access={has:d?p.bind():function(e){return r in e}},E||(i.get=d?P?function(e){return h(e),$.value}:S("get",0,h):function(e){return e[r]}),P||A||(i.set=d?S("set",0,h):function(e,t){e[r]=t}),j=D.call(N,k?{get:$.get,set:$.set}:$[R],I),T.v=1,k){if("object"==typeof j&&j)(i=y(j.get,"accessor.get"))&&($.get=i),(i=y(j.set,"accessor.set"))&&($.set=i),(i=y(j.init,"accessor.init"))&&x.unshift(i);else if(void 0!==j)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(j,(u?"field":"method")+" decorators","return")&&(u?x.unshift(j):$[R]=j)}return o<2&&c.push(w(x,l,1),w(a,l,0)),u||v||(d?k?c.splice(-1,0,S("get",l),S("set",l)):c.push(P?$[R]:y.call.bind($[R])):f(e,r,$)),j}function v(e){return f(e,p,{configurable:!0,enumerable:!0,value:s})}return s=h(null==s?null:s),l=[],d=function(e){e&&l.push(w(e))},u=function(t,r){for(var s=0;s<n.length;s++){var i=n[s],d=i[1],u=7&d;if((8&d)==t&&!u==r){var p=i[2],f=!!i[3],h=16&d;b(t?e:e.prototype,i,h,f?"#"+p:I(p),u,u<2?[]:t?c=c||[]:a=a||[],l,!!t,f,r,t&&f?function(t){return T(t)===e}:o)}}},u(8,0),u(0,0),u(8,1),u(0,1),d(a),d(c),i=l,g||v(e),{e:i,get c(){var n=[];return g&&[v(e=b(e,[t],r,e.name,5,n)),w(n,1)]}}}(this,[],[[Q,3,"isBunAvailable"],[Q,3,"usesBunPackageManager"],[Q,3,"buildCommand"],[Q,3,"rootDirPath"],[Q,3,"dockerfile"],[Q,3,"hasDockerfile"],[Q,3,"hasSourceCode"],[Q,3,"name"],[Q,3,"dockerImageName"],[Q,3,"env"],[Q,3,"packageJson"],[Q,3,"packageJsonPath"],[Q,3,"hasPrisma"],[Q,3,"hasDrizzle"],[Q,3,"databaseOrm"],[Q,3,"hasVitest"],[Q,3,"hasOxlint"],[Q,3,"hasOxfmt"],[Q,3,"hasPrettier"],[Q,3,"hasPoetryLock"],[Q,3,"hasPubspecYaml"],[Q,3,"preferredLinter"],[Q,3,"hasPlaywrightConfig"],[Q,3,"skipLaunchingServerForPlaywright"],[Q,3,"dockerPackageJson"],[Q,3,"binExists"],[Q,3,"rootPackageJson"]]).e}argv=void X(this);pathByName=new Map;constructor(e,n,r){this._dirPath=t.resolve(e),this.argv=n,this.loadEnv=r}get isBunAvailable(){return!!this.hasBunToolVersion()||this.usesBunPackageManager}get usesBunPackageManager(){return!!this.hasBunLockfile()||this.hasBunPackageManager()}hasBunToolVersion(){try{return/(^|\n)bun\s/.test(e.readFileSync(t.join(this.rootDirPath,".tool-versions"),"utf8"))}catch{return!1}}hasBunLockfile(){return["bun.lock","bun.lockb"].some(n=>e.existsSync(t.join(this.rootDirPath,n)))}hasBunPackageManager(){const e=this.rootPackageJson?.packageManager??this.packageJson.packageManager;return"string"==typeof e&&e.startsWith("bun@")}get buildCommand(){return this.packageJson.scripts?.build?.includes("buildIfNeeded")?"YARN run build":this.packageJson.scripts?.build?"YARN wb buildIfNeeded "+(this.argv.verbose?"--verbose":""):"echo 'No build script'"}get dirPath(){return this._dirPath}get rootDirPath(){return e.existsSync(t.join(this.dirPath,"..","..","package.json"))?t.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return e.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return e.existsSync(t.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){if(!this.loadEnv)return process.env;const[n,r]=function(n,r){let o=(n.env??[]).map(e=>t.resolve(r,e.toString()));const s=n.cascadeEnv??(n.cascadeNodeEnv?process.env.NODE_ENV||"development":n.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof s){if(0===o.length&&(o.push(t.join(r,".env")),n.includeRootEnv)){const n=t.resolve(r,"..","..");e.existsSync(t.join(n,"package.json"))&&o.push(t.join(n,".env"))}o=o.flatMap(e=>s?[`${e}.${s}.local`,`${e}.local`,`${e}.${s}`,e]:[`${e}.local`,e])}o=o.filter(t=>e.existsSync(t)).map(e=>t.relative(r,e)),n.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",o.join(", ")));const i=[],a={};for(const e of o){const o=[];for(const[n,s]of Object.entries(A(t.join(r,e))))n in a||n in process.env||(a[n]=s,o.push(n));i.push([e,o]),n.verbose&&o.length>0&&console.info(`Read ${o.length} environment variables from ${e}`)}if(n.verbose||console.info(`Read env files: ${i.map(([e,t])=>t.length>0?`${e} (${t.join(", ")})`:e).join(", ")||"nothing"}`),n.checkEnv){const e=Object.keys(A(t.join(r,n.checkEnv))).filter(e=>!(e in a)&&!(e in process.env));if(e.length>0)throw new Error(`Missing environment variables in [${o.join(", ")}]: [${e.join(", ")}]`)}return[p({parsed:a,processEnv:{}}).parsed??a,i]}(this.argv,this.dirPath);for(const[e,t]of r)console.info(`Loaded ${t} environment variables from ${e}`);return{...n,...process.env}}get packageJson(){return JSON.parse(e.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return t.join(this.dirPath,"package.json")}get hasPrisma(){return!!this.getOwnDependencyVersion("prisma")}get hasDrizzle(){return!!this.getOwnDependencyVersion("drizzle-orm")}get databaseOrm(){return this.hasPrisma?"prisma":this.hasDrizzle?"drizzle":void 0}get hasVitest(){return!!(this.packageJson.dependencies?.vitest??this.packageJson.devDependencies?.vitest)}get hasOxlint(){return this.hasDependency("oxlint")}get hasOxfmt(){return this.hasDependency("oxfmt")}get hasPrettier(){return this.hasDependency("prettier")}get hasPoetryLock(){return e.existsSync(t.join(this.dirPath,"poetry.lock"))||e.existsSync(t.join(this.rootDirPath,"poetry.lock"))}get hasPubspecYaml(){return e.existsSync(t.join(this.dirPath,"pubspec.yaml"))||e.existsSync(t.join(this.rootDirPath,"pubspec.yaml"))}get preferredLinter(){if(this.hasOxlint)return"oxlint"}hasOwnDependency(e){return!!this.getOwnDependencyVersion(e)}get hasPlaywrightConfig(){try{return!!this.findFile("playwright.config.ts")}catch{return!1}}get skipLaunchingServerForPlaywright(){if(Z(this.env.CI))return!1;try{const t=this.findFile("playwright.config.ts");return/\bwebServer\b/.test(e.readFileSync(t,"utf8"))}catch{return!1}}get dockerPackageJson(){return t.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(e.readFileSync(t.join(t.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let n=!1,r=this.dirPath;for(;;){const o=t.join(r,"node_modules",".bin");if(e.existsSync(o)&&(this.env.PATH=`${o}:${this.env.PATH}`,n=!0),e.existsSync(t.join(r,".git")))break;const s=t.dirname(r);if(r===s)break;r=s}return n}findFile(n){let r=this.pathByName.get(n);if(r)return r;if(r=[n,t.join("..","..",n)].map(e=>t.resolve(this.dirPath,e)).find(t=>e.existsSync(t)),!r)throw new Error(`File not found: ${n}`);return this.pathByName.set(n,r),r}hasDependency(e){return!!(this.getOwnDependencyVersion(e)??this.getDependencyVersion(this.rootPackageJson,e))}getOwnDependencyVersion(e){return this.getDependencyVersion(this.packageJson,e)}getDependencyVersion(e,t){if(e)return e.dependencies?.[t]??e.devDependencies?.[t]??e.optionalDependencies?.[t]??e.peerDependencies?.[t]}get rootPackageJson(){if(this.rootDirPath===this.dirPath)return this.packageJson;try{return JSON.parse(e.readFileSync(t.join(this.rootDirPath,"package.json"),"utf8"))}catch(e){return void console.error(`[wb] Failed to read or parse ${t.join(this.rootDirPath,"package.json")}`,e)}}}function te(n,r=!0,o){if(o??=process.cwd(),e.existsSync(t.join(o,"package.json")))return new ee(o,n,r)}async function ne(e,t=!0,n){const r=re(e,t,n);if(r)return{...r,descendants:r.root===r.self?await oe(e,r.root,t):[r.self]}}function re(n,r=!0,o){if(o??=process.cwd(),!e.existsSync(t.join(o,"package.json")))return;const s=new ee(o,n,r);let i=s;if(!s.packageJson.workspaces&&t.dirname(o).endsWith("/packages")){const s=t.resolve(o,"..","..");e.existsSync(t.join(s,"package.json"))&&(i=new ee(s,n,r))}return{root:i,self:s}}async function oe(n,r,o){const s=[r],i=r.packageJson.workspaces;if(!Array.isArray(i))return s;const a=[],c=[];for(const n of i.map(e=>t.join(r.dirPath,e)))e.existsSync(n)?c.push(n):a.push(n);c.push(...await d(a,{dot:!0,onlyDirectories:!0}));for(const r of c)e.existsSync(t.join(r,"package.json"))&&s.push(new ee(r,n,o));return s}const se=process.versions.bun||process.argv[0]?.endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),ie=se?"bun --bun run":"node",ae=se?"bun":"yarn",ce=se?"bun --bun run":"yarn",le={command:"buildIfNeeded",describe:"Build code if changes are detected",builder:{command:{description:"A build command (default: yarn|bun build)",type:"string",alias:"c"}},async handler(n){await async function(n,r){const s=te(n,!0,r);if(!s)return console.error(l.red("No project found.")),!0;const i=n.command??(s.packageJson.scripts?.build?se?"bun run build":"yarn build":void 0);if(!i)return console.info(l.green("Skip to build because no build command is defined.")),!1;if(n={...n,command:i},!e.existsSync(t.join(s.rootDirPath,".git")))return de(s,n),!0;const[a,d,u]=await async function(n,r){const s=t.resolve(n.dirPath,"node_modules",".cache","build"),i=t.resolve(s,"last-build");await e.promises.mkdir(s,{recursive:!0});const a=c("sha256"),l=o.execSync("git rev-parse HEAD",{cwd:n.dirPath}).toString().trim();a.update(l);const d=JSON.stringify(Object.entries(n.env).filter(([e])=>!ue.has(e)).toSorted(([e],[t])=>e.localeCompare(t)));a.update(d),await async function(e,t,n){return new Promise(r=>{const s=o.spawnSync("git",["status","--porcelain"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").filter(e=>e.length>0).map(e=>e.slice(2).trim()).map(t=>"test"===e.env.WB_ENV?t.replace(/packages\/wb\/test\/fixtures\/[^/]+\//,""):t).filter(e=>(pe.some(t=>e.includes(t))||fe.some(t=>e.endsWith(t)))&&!he.some(t=>e.includes(t)));t.verbose&&console.info(`Changed files: ${s.join(", ")}`);const i=o.spawn("git",["diff","--",...s],{cwd:e.rootDirPath});i.stdout.on("data",e=>{n.update(e),t.verbose&&(console.info("Data:",e),console.info("Hash:",n.copy().digest("hex")))}),i.on("close",()=>{r()})})}(n,r,a);const u=a.digest("hex"),p=await async function(e){try{return await e()}catch(e){if("object"==typeof e&&e&&"code"in e&&"ENOENT"===e.code)return;throw e}}(()=>e.promises.readFile(i,"utf8"));return[p===u,i,u]}(s,n);if(a)return console.info(l.green(`Skip to run '${n.command}' 💫`)),!1;if(!de(s,n))return;n.dryRun||await e.promises.writeFile(d,u,"utf8");return!0}(n)}};function de(e,t){if(console.info(l.green(`Run '${t.command}'`)),!t.dryRun){const n=o.spawnSync(t.command??"",{cwd:e.dirPath,env:e.env,shell:!0,stdio:"inherit"});if(0!==n.status)return process.exitCode=n.status??1,!1}return!0}const ue=new Set(["CI","PWDEBUG","TMPDIR"]);const pe=["src/","public/"],fe=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],he=["test/","tests/","__tests__/","test-fixtures/","test/fixtures/"];const me=new m,ge={exitIfFailed:!0};async function we(e,t,n,r=ge){const o=be(e,t);if(ve(o.printable,t,n.silent?"Command":"Start"),n.verbose&&ve(o.runnable,t,"Start (raw)",!0),n.dryRun)return ke(o.printable,0,r,{silentSuccess:n.silent}),0;const s=Boolean(n.silent&&r.processSilentOutput),i=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:n.silent?"pipe":"inherit",timeout:r.timeout,mergeOutAndError:s,killOnExit:!0,printingStdout:n.silent&&!s,printingStderr:n.silent&&!s,omitBlankLinesWhilePrinting:n.silent,verbose:n.verbose});if(s){const e=r.processSilentOutput?.(i.stdout).trim();e&&(process.stdout.write(e),process.stdout.write("\n"))}return r.onSignal?.(i.signal),ke(o.printable,i.status,r,{silentSuccess:n.silent}),i.status??1}function ye(e,t,n,r=ge){return me.runAndWaitForReturnValue(async()=>{const o=be(e,t);if(ve(o.printable,t,"Start (parallel)",!0),n.dryRun)return ve(o.printable,t,"Started (log)"),n.verbose&&ve(o.runnable,t,"Started (raw)",!0),ke(o.printable,0,r),0;const s=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose});r.onSignal?.(s.signal),ve(o.printable,t,"Started (log)"),n.verbose&&ve(o.runnable,t,"Started (raw)",!0);const i=s.stdout.trim();return i&&!r.printRawOutput&&(process.stdout.write(i),process.stdout.write("\n")),ke(o.printable,s.status,r),s.status??1})}function be(e,t){const n=t.usesBunPackageManager?"bun --bun run":"yarn";let r=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA generate ",t.packageJson.dependencies?.blitz?"PRISMA generate ":"PRISMA generate --no-hints ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN run ",t.usesBunPackageManager?`${n} `:"YARN run ").replaceAll("BUN ",t.usesBunPackageManager?`${n} `:"YARN ").replaceAll("YARN run ",t.usesBunPackageManager?`${n} `:"yarn run ");t.usesBunPackageManager&&(r=r.replaceAll("YARN build-ts run","bun --bun run").replaceAll("bun --bun run bun --bun run","bun --bun run").replaceAll("dist/index.js","src/index.ts")),r=r.trim();const o=Ee(r.replaceAll("YARN ",`${n} `)),s=Ee(r.replaceAll("YARN playwright ",`${n} playwright `).replaceAll("YARN ",!t.usesBunPackageManager&&t.binExists?"":`${n} `));return{printable:`${n} dotenv${t.env.WB_ENV?` -c=${t.env.WB_ENV||"development"}`:""} -- ${o}`,runnable:s}}function ve(e,t,n="Start",r=!1){console.info("\n"+(r?l.gray:l.cyan)(l.bold(`${n}:`),e)+l.gray(` at ${t.dirPath}`))}function ke(e,t,n,r={}){if(0===t){if(r.silentSuccess)return;console.info(l.green(l.bold("Finished:"),e))}else console.info(l.red(l.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1)}function Ae(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function Ee(e){return e.includes("next dev")||e.includes("playwright")||e.includes("prisma")||e.includes("test/e2e-additional")?e.replaceAll("bun --bun","bun"):e}const Pe={...v,"working-dir":{description:"A working directory",type:"string",alias:"w"},"dry-run":{description:"Whether to skip actual command execution",type:"boolean",alias:["dry","d"]}};function Se(e){const t=[];for(const n of Object.keys(v)){const r=$e(e,n);if(void 0!==r)if("boolean"!=typeof r)if("string"!=typeof r&&"number"!=typeof r){if(Array.isArray(r))for(const e of r)t.push(`--${n}=${e}`)}else t.push(`--${n}=${r}`);else t.push(r?`--${n}`:`--${n}=false`)}return t}function $e(e,t){const n=t.replaceAll(/-([a-z])/g,(e,t)=>t.toUpperCase()),r=e;return r[t]??r[n]}const xe={command:"concurrently <commands...>",describe:"Run commands concurrently",builder:{...Pe,"kill-others":{description:"Kill other commands when one command exits",type:"boolean"},"kill-others-on-fail":{description:"Kill other commands when one command fails",type:"boolean"},success:{description:"Define successful completion criteria",type:"string",choices:["all","first"],default:"all"},commands:{description:"Commands to run concurrently",type:"array"}},async handler(e){"win32"===process.platform&&(console.error(l.red("This command is not supported on Windows.")),process.exit(1));const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));const n=(e.commands??[]).map(String).filter(Boolean);0===n.length&&(console.error(l.red("No commands provided.")),process.exit(1));try{const r=await async function(e){const t=e.commands.map(t=>o.spawn(be(t,e.project).runnable,{cwd:e.project.dirPath,detached:!0,env:Ae(e.project.env,{ci:e.ci,forceColor:e.forceColor}),shell:!0,stdio:"inherit"}));let n,r,s,i=!1;const a=[],c=Array.from({length:t.length}),l=t.map((n,o)=>new Promise(l=>{let d=!1;const u=n=>{d||(d=!0,c[o]=n,r??=n,!i&&function(e,t){return"first"===t.success||t.killOthers||t.killOthersOnFail&&0!==e}(n,e)&&(s=n,i=!0,a.push(je(t,"SIGTERM"))),l())};n.once("error",e=>{console.error("Failed to start child process:",e),u(1)}),n.once("exit",(e,t)=>{u(Re(e??void 0,t??void 0))})})),d=e=>{n??=e,i||(i=!0,a.push(je(t,e)))},u=()=>{d("SIGINT")},p=()=>{d("SIGTERM")},f=()=>{d("SIGQUIT")};process.on("SIGINT",u),process.on("SIGTERM",p),process.on("SIGQUIT",f);try{await Promise.all(l),await Promise.all(a)}finally{process.removeListener("SIGINT",u),process.removeListener("SIGTERM",p),process.removeListener("SIGQUIT",f)}if(n)return Re(void 0,n);if("first"===e.success)return r??1;if(void 0!==s)return s;for(const e of c)if(void 0!==e&&0!==e)return e;return 0}({commands:n,project:t,killOthers:e.killOthers??!1,killOthersOnFail:e.killOthersOnFail??!1,success:e.success,ci:"boolean"==typeof e.ci?e.ci:void 0,forceColor:"boolean"==typeof e.forceColor?e.forceColor:void 0});process.exit(r)}catch(e){console.error(l.red(e instanceof Error?e.message:String(e))),process.exit(1)}}};function Re(e,t){return void 0!==e?e:t&&t in h.signals?128+h.signals[t]:1}async function je(e,t){const n=Oe(function(e){return e.flatMap(e=>void 0===e.pid?[]:[e.pid])}(e),t);0!==n.length&&await async function(e){const t=Date.now()+5e3;for(;Date.now()<t;){if(e.every(De))return!1;await Ne(Math.min(100,t-Date.now()))}return!0}(n)&&Oe(n,"SIGKILL")}function Oe(e,t){const n=[];for(const r of e)try{if(!Te(r,t))continue;n.push(r),P(r,t)}catch(e){console.warn("Failed to kill child process:",e)}return n}function De(e){try{return process.kill(-e,0),!1}catch(e){return!!Ce(e)}}async function Ne(e){await new Promise(t=>setTimeout(t,e))}function Te(e,t){try{return process.kill(-e,t),!0}catch(e){if(Ce(e))return!1;throw e}}function Ce(e){return"object"==typeof e&&null!==e&&"code"in e&&"ESRCH"===e.code}const Ie={command:"kill-port-if-non-ci",describe:"Kill the port specified by PORT environment variable if non-CI.",builder:{},async handler(e){await async function(e){const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));if(Z(t.env.CI))return void console.info(`Skip killing port due to CI: ${t.env.CI}`);const n=t.env.PORT,r=Number(n);(!Number.isInteger(r)||r<=0)&&(console.error(l.red(`PORT environment variable is invalid: ${n}`)),process.exit(1));console.info(`Killing the port: ${r}`);try{await g(r)}catch{}}(e)}};function _e(e,t){if(!function(e,t){return 0!==e||function(e){return/\bwarn(?:ing)?s?\b/i.test(e.replaceAll(/\b(?:0|no) warnings?\b/gi,""))}(Be(t))}(e,t))return;const n=function(e){return Be(e).trim()}(t);n&&(process.stdout.write(n),process.stdout.write("\n"))}function Be(e){return e.replaceAll(/\(node:\d+\) Warning: The 'NO_COLOR' env is ignored due to the 'FORCE_COLOR' env being set\.\n\(Use `node --trace-warnings \.\.\.` to show where the warning was created\)\n?/g,"")}function Le(e){return e.map(e=>Fe(e)).join(" ")}function Fe(e){return/^[\w./:=,@%+-]+$/u.test(e)?e:`'${e.replaceAll("'","'\"'\"'")}'`}const ze=new Set(["astro","cjs","cts","js","jsx","mjs","mts","svelte","ts","tsx","vue"]),Me=new Set(["py"]),Ue=new Set(["dart"]),We=new Set([...ze,"css","gql","graphql","hbs","htm","html","json","json5","jsonc","less","md","mdx","scss","toml","yaml","yml"]),Je=new Set(["cjs","css","cts","htm","html","java","js","json","json5","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),Ye=new Set([...Je].filter(e=>!We.has(e))),Ve="!**/test{-,/}fixtures/**",qe={command:"lint [files...]",describe:"Lint code",builder:{fix:{description:"Fix the linting errors",type:"boolean"},format:{description:"Format the code",type:"boolean"},quiet:{description:"Report errors only",type:"boolean"},silent:{description:"Print only failed or warning command output",type:"boolean"}},async handler(e){const t=await Ge(e);t&&process.exit(t)}};async function Ge(e){if("win32"===process.platform)return console.error(l.red("This command is not supported on Windows.")),1;const n=await ne(e,!1);if(!n)return console.error(l.red("No project found.")),1;const r=function(e){const t=new Set;for(const n of[...e.files??[],...e._.slice(1),...e["--"]??[]])t.add(String(n));return[...t]}(e),o=new Map,s=new Map,i=new Map,a=new Map,c=[],d=[];let u,p,f=!1;if(r.length>0){const h=await Promise.all(r.map(async e=>{const n=t.resolve(e),r=await async function(e){try{if((await w.stat(e)).isDirectory())return"directory"}catch{}return"other"}(n);return{fileKind:r,filePath:n}}));for(const{fileKind:r,filePath:u}of h){if(u.endsWith("/test/fixtures")||u.includes("/test/fixtures/")||u.endsWith("/test-fixtures")||u.includes("/test-fixtures/"))continue;const p=t.extname(u).slice(1);if(u.endsWith("/package.json"))d.push(u);else{d.push(...st(n.descendants,u,r));for(const{lintPath:t,project:d}of it(n.descendants,u,r)){if(d.hasPoetryLock&&("directory"===r||Me.has(p))){const e=i.get(d)??[];if(e.push(t),i.set(d,e),"directory"!==r)continue}if(d.hasPubspecYaml&&("directory"===r||Ue.has(p))){const e=a.get(d)??[];if(e.push(t),a.set(d,e),"directory"!==r)continue}if("directory"===r||ct(d,p)){const n=o.get(d)??[];if(n.push(t),o.set(d,n),e.format)if("directory"===r&&d.hasOxfmt){const e=s.get(d)??[];e.push(t),s.set(d,e),c.push(ot(t),Ve)}else for(const e of rt(d,t,r,p))if(d.hasOxfmt){const t=s.get(d)??[];t.push(e),s.set(d,t)}else c.push(e)}else if(e.format&&(Je.has(p)||We.has(p)))if(d.hasOxfmt&&We.has(p)){const e=s.get(d)??[];e.push(t),s.set(d,e)}else Je.has(p)&&c.push(t);else at(p)&&!d.preferredLinter&&(console.error(l.red(`No linter found for ${d.name}. Install Oxlint.`)),f=!0)}}}u=[...new Set(c)],p=[...new Set(d)]}else u=function(e,n){const r=new Set([`**/{.*/,}*.{${[...Ye].join(",")}}`,Ve]);for(const o of n){if(!lt(o))continue;const n=t.join(o.dirPath,"**/{.*/,}*.{"+[...Je].join(",")+"}");r.add(t.relative(e,n)||n)}return[...r]}(n.self.dirPath,n.descendants),p=n.descendants.map(e=>e.packageJsonPath);const h=[],m={exitIfFailed:!1,forceColor:!e.printAllOutput};if(r.length>0){for(const[t,n]of o){const r=Xe(t,e,n);r&&h.push(Ke(r,t,e,m))}if(e.format)for(const[t,n]of s)h.push(Ke(et(n),t,e,m));for(const[t,n]of i)h.push(Ke(tt(e,n),t,e,m));for(const[t,n]of a)h.push(Ke(nt(e,n),t,e,m))}else{for(const t of n.descendants){if(t.packageJson.workspaces&&!t.hasSourceCode)continue;const n=Xe(t,e);n&&h.push(Ke(n,t,e,m))}for(const t of n.descendants)t.hasPoetryLock&&h.push(Ke(tt(e),t,e,m)),t.hasPubspecYaml&&h.push(Ke(nt(e),t,e,m)),t.hasOxfmt&&e.format&&h.push(Ke(et(),t,e,m))}const g=await Promise.all(h);He(g,e);const y=g.map(e=>e.exitCode);if(f||y.some(e=>0!==e))return 1;if(e.format){if(u.length>0&&n.self.hasPrettier){const t=await Ke(Le(["YARN","prettier","--cache","--color","--no-error-on-unmatched-pattern","--write","--",...u]),n.self,e,m);He([t],e),y.push(t.exitCode)}if(p.length>0){const t=await Ke(Le(["YARN","sort-package-json","--",...p]),n.self,e,m);He([t],e),y.push(t.exitCode)}}return y.some(e=>0!==e)?1:0}function Ke(e,t,n,r){if(n.silent){const o=be(e,t);return function(e,t,n,r=ge){return me.runAndWaitForReturnValue(async()=>{const o=be(e,t);if(n.dryRun)return{exitCode:0,output:""};const s=await j(o.runnable,void 0,{cwd:t.dirPath,env:Ae(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose});return r.onSignal?.(s.signal),{exitCode:s.status??1,output:s.stdout}})}(e,t,n,r).then(e=>({...e,command:o.printable,cwd:t.dirPath}))}return ye(e,t,n,r).then(e=>({exitCode:e}))}function He(e,t){const n=t.silent&&!t.printAllOutput?e.filter(e=>0!==e.exitCode):e;if(0!==n.length)for(const e of n)"output"in e&&(t.printAllOutput?Qe(e):(t.silent&&Ze(e.command,e.cwd),_e(e.exitCode,e.output)))}function Qe(e){if(Ze(e.command,e.cwd),0===e.exitCode&&((t=e.command).includes(" oxfmt ")||t.includes(" sort-package-json ")))return void console.info(l.green("Succeeded."));var t;const n=e.output.trim();n&&(process.stdout.write(n),process.stdout.write("\n"))}function Ze(e,t){console.info("\n"+l.cyan(l.bold("Command:"),e)+l.gray(` at ${t}`))}function Xe(e,t,n){if("oxlint"===e.preferredLinter)return Le(["YARN","oxlint","--no-error-on-unmatched-pattern",...t.quiet?["--quiet"]:[],...t.fix?["--fix"]:[],...n??["."]])}function et(e){return Le(["YARN","oxfmt","--write","--no-error-on-unmatched-pattern",...e??["."],"!**/package.json"])}function tt(e,t){const n=t&&t.length>0?t:["."];return(e.fix||e.format?[Le(["poetry","run","isort","--profile","black","--filter-files",...n]),Le(["poetry","run","black",...n]),Le(["poetry","run","flake8",...e.quiet?["-q"]:[],...n])]:[Le(["poetry","run","flake8",...e.quiet?["-q"]:[],...n])]).join(" && ")}function nt(e,t){const n=t&&t.length>0?t:["."],r=[];return(e.fix||e.format)&&r.push(Le(["dart","format",...n])),r.push(Le(["dart","analyze",...n])),r.join(" && ")}function rt(e,t,n,r){return"directory"===n&&e.hasOxfmt?[t]:"directory"===n&&lt(e)?[t,Ve]:function(e,t){return e.hasOxfmt?We.has(t):!!lt(e)||Ye.has(t)}(e,r)?[t]:[]}function ot(e){return t.join(e,`**/{.*/,}*.{${[...Ye].join(",")}}`)}function st(e,n,r){return"directory"!==r?[]:e.filter(e=>e.packageJsonPath===t.join(n,"package.json")||e.packageJsonPath.startsWith(`${n}/`)).map(e=>e.packageJsonPath)}function it(e,t,n){if("directory"===n){const n=e.filter(e=>e.dirPath===t||e.dirPath.startsWith(`${t}/`));if(n.length>0)return n.map(e=>({lintPath:e.dirPath,project:e}))}const r=function(e,t){let n;for(const r of e)t!==r.dirPath&&!t.startsWith(`${r.dirPath}/`)||n&&!(r.dirPath.length>n.dirPath.length)||(n=r);return n}(e,t);return r?[{lintPath:t,project:r}]:[]}function at(e){return ze.has(e)||Me.has(e)||Ue.has(e)}function ct(e,t){return"oxlint"===e.preferredLinter&&ze.has(t)}function lt(e){return!e.hasOxfmt&&"oxlint"===e.preferredLinter}function*dt(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const ut=["@willbooster/wb","build-ts"],pt={command:"optimizeForDockerBuild",describe:"Optimize configuration when building a Docker image",builder:{outside:{description:"Whether the optimization is executed outside a docker container or not",type:"boolean",alias:"o"}},async handler(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1));for(const o of dt("optimizeForDockerBuild",r.descendants)){const r=o.packageJson,s=["dependencies","devDependencies"];for(const e of s){const t=r[e]??{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ft(n,r),ht(r),mt(r),n.dryRun)continue;const i=n.outside?t.join(o.dirPath,"dist"):o.dirPath;await e.promises.mkdir(i,{recursive:!0}),await e.promises.writeFile(t.join(i,"package.json"),JSON.stringify(r),"utf8")}n.dryRun||n.outside||(o.spawnSync(ae,["install"],{stdio:"inherit"}),console.info("Installed dependencies."))}};function ft(e,t){!function(e){const t=e.devDependencies??{},n=e.dependencies??{},r=[];for(const e of ut){const o=t[e];o&&(n[e]||(n[e]=o,r.push(e)),delete t[e])}r.length>0&&(e.dependencies=n);console.info("Promoted runtime devDependencies:",r.join(", ")||"none")}(t),e.outside?function(e){const t=e.devDependencies??{},n=["artillery","concurrently","conventional-changelog-conventionalcommits","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","railway","semantic-release","sort-package-json","wait-on","vitest"],r=[];for(const e of Object.keys(t))(n.some(t=>e.includes(t))||e.includes("willbooster")&&e.includes("config"))&&(delete t[e],r.push(e));console.info("Removed devDependencies:",r.join(", ")||"none")}(t):(delete t.devDependencies,console.info("Removed all devDependencies."))}function ht(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts??{},o=[];for(const[e,s]of Object.entries(r))(t.some(t=>e.startsWith(t))||n.some(e=>s.includes(e)||s.trim()===e.trim()))&&(delete r[e],o.push(e));console.info("Removed scripts:",o.join(", ")||"none")}function mt(e){delete e.private,delete e.publishConfig,delete e.prettier}const gt="file:";const wt=new class{deploy(e,t=""){return this.migrate(e,t)}migrate(e,t=""){return`YARN drizzle-kit migrate ${t}`}migrateDev(e,t=""){return`YARN drizzle-kit generate ${t}`}reset(e,n=""){const r=function(e){const n=e.env.DATABASE_PATH??function(e){const t=e.env.DATABASE_URL;if(!t?.startsWith(gt))return;const n=t.slice(5).replace(/[?#].*$/,"");if(!n)return;return n}(e);if(!n)return;const r=t.isAbsolute(n)?n:t.resolve(e.dirPath,n);return`rm -f "${r}" "${r}-wal" "${r}-shm"`}(e);return r?`${r} && ${this.migrate(e,n)} && ${this.seed(e)}`:"echo 'wb db reset supports Drizzle only when DATABASE_PATH or file: DATABASE_URL is set.' && exit 1"}seed(e,t){return t?`BUN build-ts run ${t}`:e.packageJson.scripts?.seed?"YARN run seed":"true"}studio(e,t,n=""){return t?"echo 'wb db studio for Drizzle does not support db-url-or-path.' && exit 1":`YARN drizzle-kit studio ${n}`}},yt="file:",bt=[{schemaPath:t.join("prisma","schema.prisma"),dbPath:"prisma"},{schemaPath:t.join("prisma","schema"),dbPath:t.join("prisma","schema")},{schemaPath:t.join("db","schema.prisma"),dbPath:"db"}];function vt(e){return e.packageJson.dependencies?.blitz?"db/mount":"prisma/mount"}function kt(n){return bt.find(({schemaPath:r})=>e.existsSync(t.resolve(n.dirPath,r)))?.dbPath}const At=new class{cleanUpLitestream(e){const t=vt(e);var n;return`${`if [ -f "${n=`${t}/prod.sqlite3`}" ]; then printf 'PRAGMA wal_checkpoint(TRUNCATE);' | PRISMA db execute --stdin --url "${yt}${n}"; fi && rm -f "${n}".* "${n}"-*`}; rm -Rf ${t}/.prod.sqlite3* || true`}deploy(e,t=""){return`PRISMA migrate deploy ${t}`}deployForce(e){const t=vt(e),n=`rm -Rf "${`${t}/prod.sqlite3`}"*`;return`${n}; PRISMA migrate reset --force --skip-seed && ${n}\n && litestream restore -config litestream.yml -o ${t}/prod.sqlite3 ${t}/prod.sqlite3 && ls -ahl ${t}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}listBackups(e){return`litestream ltx -config litestream.yml ${vt(e)}/prod.sqlite3`}migrate(e,t=""){return`PRISMA migrate deploy ${t} && PRISMA generate && ${this.seed(e)}`}migrateDev(e,t=""){return`PRISMA migrate dev ${t}`}reset(e,n=""){const r=[],o=function(e){const n=e.env.DATABASE_URL;if(!n?.startsWith(yt))return;const r=n.slice(5).replace(/[?#].*$/,"");if(!r)return;const o=kt(e),s=t.isAbsolute(r)?r:t.resolve(e.dirPath,o??".",r);return`rm -f "${s}" "${s}-wal" "${s}-shm"`}(e);o&&r.push(o);const s=["PRISMA migrate reset --force",n].filter(Boolean).join(" ");return r.push(s),e.packageJson.dependencies?.blitz&&r.push(this.seed(e)),r.filter(Boolean).join(" && ")}restore(e,t){return`rm -Rf ${t}*; litestream restore -config litestream.yml -o ${t} ${vt(e)}/prod.sqlite3`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?`BUN build-ts run ${t}`:e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}studio(e,n,r=""){let o="";if(n)try{new URL(n),o=`DATABASE_URL=${n} `}catch{const e=t.resolve(n);o=`DATABASE_URL=${yt}${e} `}else if(e.env.DATABASE_URL?.startsWith(yt)){const n=kt(e);if(n){const r=t.resolve(e.dirPath,n,e.env.DATABASE_URL.slice(5));o=`DATABASE_URL=${yt}${r} `}}return`${o}PRISMA studio ${r}`}},Et={},Pt={command:"prisma",aliases:["db"],describe:"Run database commands. Use '--' to stop wb option parsing and forward the remaining arguments to Prisma. Drizzle projects use drizzle-kit. Example: wb prisma migrate-dev -- --name init",builder:e=>e.parserConfiguration({"populate--":!0}).command(St).command($t).command(xt).command(Rt).command(jt).command(Ot).command(Dt).command(Nt).command(Tt).command(Ct).command(It).command(_t).demandCommand().strict(!1),handler(){}},St={command:"cleanup-litestream",describe:"Clean up temporal Litestream files",builder:Et,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma cleanup-litestream",t))await we(At.cleanUpLitestream(n),n,e)}},$t={command:"create-litestream-config",describe:"Create Litestream configuration file",builder:Et,async handler(e){const t=await Lt(e,"prisma");for(const{project:e}of zt("prisma create-litestream-config",t))Bt(e)}},xt={command:"deploy",describe:"Apply migration to DB without initializing it",builder:Et,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db deploy",t))await we(Ft(r).deploy(o,n),o,e)}},Rt={command:"deploy-force",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:Et,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma deploy-force",t))await we(At.deployForce(n),n,e)}},jt={command:"list-backups",describe:"List Litestream backups",builder:Et,async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma list-backups",t))await we(At.listBackups(n),n,e)}},Ot={command:"migrate",describe:"Apply migration to DB with initializing it",builder:Et,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db migrate",t))await we(Ft(r).migrate(o,n),o,e)}},Dt={command:"migrate-dev",describe:"Create a migration file",builder:Et,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db migrate-dev",t))await we(Ft(r).migrateDev(o,n),o,e)}},Nt={command:"reset",describe:"Reset DB",builder:Et,async handler(e){const t=await Lt(e),n=Mt(e);for(const{orm:r,project:o}of zt("db reset",t))await we(Ft(r).reset(o,n),o,e);if("test"!==process.env.WB_ENV){process.env.WB_ENV="test";for(const{orm:t,project:r}of zt("WB_ENV=test db reset",await Lt(e)))await we(Ft(t).reset(r,n),r,e)}}},Tt={command:"restore",describe:"Restore DB from Litestream's backup",builder:{...Et,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await Lt(e,"prisma");for(const{project:n}of zt("prisma restore",t)){const t=e.output??(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await we(At.restore(n,t),n,e)}}},Ct={command:"seed",describe:"Populate DB with seed data",builder:{...Et,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await Lt(e);for(const{orm:n,project:r}of zt("db seed",t))await we(Ft(n).seed(r,e.file),r,e)}},It={command:"studio [db-url-or-path]",describe:"Open database studio",builder:{...Et,"db-url-or-path":{description:"URL or path to the database",type:"string"},restored:{description:"Whether to open the default restored database (<db|prisma>/restored.sqlite3).",type:"boolean"}},async handler(e){if(e.restored&&e.dbUrlOrPath)throw new Error("You cannot specify both --restored and --db-url-or-path.");const t=await Lt(e),n=Mt(e,["db-url-or-path","restored"]);for(const{orm:r,project:o}of zt("db studio",t)){const t=e.restored?o.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await we(Ft(r).studio(o,t,n),o,e)}}},_t={command:"$0 <args..>",describe:"Pass the command and arguments to the detected ORM as is. Additional Prisma flags can also be forwarded after '--'.",builder:{args:{type:"array"}},async handler(e){const t=await Lt(e),n=[(e.args?.join(" ")??"").trimEnd(),Mt(e,["args"])].filter(Boolean).join(" ");for(const{orm:r,project:o}of zt(`db ${n}`,t)){const t="prisma"===r?`PRISMA ${n}`:`YARN drizzle-kit ${n}`;await we(t,o,e)}}};function Bt(t){const n=`${t.packageJson.dependencies?.blitz?"db":"prisma"}/mount/prod.sqlite3`,r={CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME:t.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY:t.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY},o=Object.entries(r).filter(([,e])=>!e).map(([e])=>e);if(o.length>0)throw new Error(`Missing environment variables for Litestream: ${o.join(", ")}`);const s="staging"===t.env.WB_ENV?"5m":"1h",i=`dbs:\n - path: ${n}\n busy-timeout: 5s\n checkpoint-interval: 1m\n replica:\n type: s3\n endpoint: https://${r.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n bucket: ${r.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n access-key-id: ${r.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n secret-access-key: ${r.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n snapshot-interval: 24h # Create a backup per day\n retention: 72h # Keep backups for 3 days\n retention-check-interval: ${s}\n sync-interval: 1m\n`,a="/etc/litestream.yml";try{e.writeFileSync(a,i),console.info(`Generated ${a}`)}catch(e){const t=e instanceof Error?e.message:String(e);throw new Error(`Failed to write ${a}: ${t}`,{cause:e})}}async function Lt(e,t){const n=await ne(e);n||(console.error(l.red("No project found.")),process.exit(1));const r=n.descendants.map(e=>e.databaseOrm?{project:e,orm:e.databaseOrm}:void 0).filter(e=>!(!e||t&&e.orm!==t));return 0===r.length&&(console.error(l.red(t?`No ${t} project found.`:"No supported database ORM project found.")),process.exit(1)),r}function Ft(e){return"prisma"===e?At:wt}function*zt(e,t){const n=new Map(t.map(e=>[e.project,e]));for(const r of dt(e,t.map(({project:e})=>e))){const e=n.get(r);if(!e)throw new Error(`Failed to detect database ORM for ${r.name}.`);yield e}}function Mt(e,t=[]){const n=[],r=Object.keys(Pe),o=Object.values(Pe).flatMap(e=>"alias"in e?Array.isArray(e.alias)?e.alias:[e.alias]:[]).map(String),s=new Set([...t,...r,...o,"--","_","$0"]);for(const[t,r]of Object.entries(e))if(!s.has(t)){const o=t.replaceAll(/[A-Z]/g,e=>`-${e.toLowerCase()}`);if(o!==t&&void 0!==e[o])continue;if("boolean"==typeof r&&r)n.push(`--${t}`);else if("string"==typeof r||"number"==typeof r)n.push(`--${t}`,String(r));else if(Array.isArray(r))for(const e of r)n.push(`--${t}`,String(e))}const i=Array.isArray(e["--"])?e["--"].map(String):[];return Le([...n,...i])}const Ut={command:"retry [command] [args...]",describe:"Retry the given command until it succeeds",builder:{retry:{description:"A maximum retry count",type:"number",alias:"r",default:3}},async handler(e){const t=te(e);t||(console.error(l.red("No project found.")),process.exit(1));const n=[e.command,...e.args??[],...e._.slice(1)].filter(Boolean);let r=0;for(let o=0;o<e.retry;o++)if(o>0&&console.info(`\n${l.yellow(`#${o} Retrying: ${n.join(" ")}`)}`),r=await we(n.join(" "),t,e,{exitIfFailed:!1,onSignal:e=>{e&&process.exit(1)}}),0===r)return;process.exit(r)}},Wt={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await ne(e,!1,t);n||(console.error(l.red("No project found.")),process.exit(1));for(const t of dt("setup",n.descendants)){const r=await w.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===f.platform()){const n=["pstree"];await ye(`brew install ${n.join(" ")}`,t,e)}r.some(e=>e.isFile()&&e.name.includes("-version"))&&await we("asdf install",t,e,{exitIfFailed:!1})}if(r.some(e=>e.isFile()&&"pyproject.toml"===e.name)){await ye("poetry config virtualenvs.in-project true",t,e);const[,n]=o.execSync("asdf current python").toString().trim().split(/\s+/);await ye(`poetry env use ${n}`,t,e),await me.promiseAll(),await we("poetry run pip install --upgrade pip",t,e),await we("poetry install --ansi",t,e)}t!==n.root&&n.root.packageJson.scripts?.["gen-code"]||!t.packageJson.scripts?.["gen-code"]||await we(`${ce} gen-code`,t,e)}const r=n.descendants.find(e=>e.packageJson.devDependencies?.playwright);r&&await we(`${ce} playwright install --with-deps`,r,e)}(e)}};function Jt(e){return e.silent?" > /dev/null":""}const Yt=new Set;async function Vt(e,t){const n=await async function(e){for(const t of["127.0.0.1","::"]){if(!await Kt(t,e))return!1}return!0}(e);n||await qt(e,t);const r=async()=>{Yt.has(e)||(Yt.add(e),await qt(e,t))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,r)}async function qt(e,t){await async function(e,t){await async function(e,t){try{const n=await async function(e,t){const{stdout:n}=await j("docker",["ps","-q",...e],{cwd:t.dirPath,env:t.env});return n.split(/\s+/).map(e=>e.trim()).filter(Boolean)}(e,t);if(0===n.length)return;await j("docker",["rm","-f",...n],{cwd:t.dirPath,env:t.env})}catch{}}(["--filter",`publish=${e}`],t)}(e,t);try{await g(e)}catch{}}async function Gt(e,t){const n=Number(e);if(!n)throw new Error(`The given port (${n}) is invalid.`);return await Vt(n,t),n}async function Kt(e,t){return new Promise(n=>{const r=y();r.once("error",e=>{"EADDRINUSE"!==e.code?"EAFNOSUPPORT"!==e.code?n(!1):n(!0):n(!1)}),r.once("listening",()=>{r.close(()=>{n(!0)})}),r.listen(t,e)})}const Ht=new class{buildImage(e,n){const r=e.dockerPackageJson.scripts?.["docker/build/prepare"]?"YARN run docker/build/prepare && ":"";return`cd ${t.dirname(e.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${e.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n --build-arg WB_ENV=${e.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t="",n=""){return`${this.stop(e)} && ${this.start(e,t,n)}`}start(e,t="",n=""){!function(e,t){const n=()=>{if(Yt.has(e))return;Yt.add(e),ve(e,t);const{status:n}=a(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});ke(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e);return`docker run --rm ${n.includes("/bin/bash")?"-it ":""}--publish ${e.env.PORT}:8080 --name ${e.dockerImageName} ${t} ${e.dockerImageName} ${n}`}stop(e){return`true $(docker rm -f $(docker container ls -q -f name=${e.dockerImageName}) 2> /dev/null)`}stopAll(){return"true $(docker rm -f $(docker ps -q) 2> /dev/null)"}};class Qt{constructor(e){this.shouldWaitAndOpenApp=e}buildDocker(e,t){return Ht.buildImage(e,t)}async startDev(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",this.startDevProtected(e,t),this.waitAndOpenApp(e)]):this.startDevProtected(e,t)}async startProduction(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",this.startProductionProtected(e,t),this.waitAndOpenApp(e)]):this.startProductionProtected(e,t)}async startTest(e,t){return await Gt(e.env.PORT,e),this.startProductionProtected(e,t)}async startDocker(e,t){return await Gt(e.env.PORT,e),this.shouldWaitAndOpenApp?`${this.buildDocker(e,"development")}\n && ${Le(["YARN","wb","concurrently",...Se(t),"--kill-others-on-fail",Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??""),this.waitAndOpenApp(e)])}`:`${this.buildDocker(e,"development")}\n && ${Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProductionProtected(e,t){const n=function(e){try{return e.findFile("ecosystem.config.cjs")}catch{return}}(e),r=void 0===n?[("YARN wb buildIfNeeded "+(t.verbose?"--verbose":"")).trim(),`${e.isBunAvailable?"bun":"node"} dist/index.js ${t.normalizedArgsText??""}`.trim()]:[e.buildCommand,`pm2-runtime start --no-autorestart ${n}`];return[...[...e.hasPrisma?[At.migrate(e)]:[],...e.hasDrizzle?[wt.migrate(e)]:[]].flatMap(e=>e.split("&&")),...r].filter(Boolean).map(e=>`${e} ${Jt(t)}`.trim()).join(" && ")}testE2EDev(e,t,n){return this.testE2EProtected(e,t,this.startDevProtected(e,t),n)}testE2EProduction(e,t,n){return this.testE2EProtected(e,t,this.startProductionProtected(e,t),n)}testE2EDocker(e,t,n){return this.testE2EProtected(e,t,Ht.stopAndStart(e),n)}async testStart(e,t){return await Gt(e.env.PORT,e),`${n="NODE_ENV",r="",`${n}=${Fe(r)}`} ${Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",this.startDevProtected(e,t),this.waitApp(e)])}`;var n,r}async testE2EProtected(e,t,n,{forwardedPlaywrightArgs:r=[],playwrightArgs:o=["test","test/e2e/"]}){const s=await Gt(e.env.PORT,e),i=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",a=function(e,t,n,r=[]){const o=["BUN","playwright"],s=t?.map(String);if("test"!==e[0]||!s?.length)return Zt([...o,...e,...r],n);const i=e.slice(1),a=Xt(i),c=0===a.length?i:i.filter((e,t)=>!a.includes(t));return Zt([...o,"test",...s,...c,...r],n)}(o,t.targets,t.bail,r);return e.skipLaunchingServerForPlaywright?`${a}${i}`:Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",`${n} && exit 1`,`wait-on -t 600000 -i 2000 http-get://127.0.0.1:${s}\n && ${a}${i}`])}testUnit(e,t){const n=t.targets?.map(String);return e.hasVitest?Le(["YARN","vitest","run",...n?.length?n:["test/unit/"],"--color","--passWithNoTests","--allowOnly","--watch=false",...t.bail?["--bail=1"]:[]]):e.isBunAvailable?Le(["bun","test",...n?.length?n:["test/unit/"],...t.bail?["--bail"]:[]]):'echo "No tests."'}waitApp(e){const t=e.env.PORT;return`wait-on -t 10000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${t}`}waitAndOpenApp(e){const t=e.env.PORT;return`${this.waitApp(e)} || wait-on http-get://127.0.0.1:${t} && open-cli http://\${HOST:-localhost}:${t}`}}function Zt(e,t){const n=e.indexOf("playwright"),r=-1!==n&&"test"===e[n+1];return t&&r?e.some(e=>"--max-failures"===e||e.startsWith("--max-failures="))?Le(e):Le([...e,"--max-failures=1"]):Le(e)}function Xt(e){let t;const n=[];for(const[r,o]of e.entries()){if(t){if("required"===t||!o.startsWith("-")){t=void 0;continue}t=void 0}if("--"===o)return[...n,...e.slice(r+1).map((e,t)=>r+1+t)];if(o.startsWith("--")){if(o.includes("="))continue;en.has(o)?t="required":tn.has(o)&&(t="optional")}else{if(o.startsWith("-")&&"-"!==o){const e=o.slice(0,2);2===o.length&&nn.has(e)&&(t="required");continue}n.push(r)}}return n}const en=new Set(["--browser","--config","--grep","--grep-invert","--global-timeout","--max-failures","--output","--project","--repeat-each","--reporter","--retries","--shard","--test-list","--test-list-invert","--timeout","--trace","--tsconfig","--ui-host","--ui-port","--ui-title","--workers"]),tn=new Set(["--only-changed","--update-snapshots","--update-source-method"]),nn=new Set(["-c","-g","-j"]);const rn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`blitz dev ${t.normalizedArgsText??""}`}};const on=new class extends Qt{constructor(){super(!1)}startDevProtected(e,t){return`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`}async testE2EProtected(e,t,n,r={}){if(e.hasPlaywrightConfig)return super.testE2EProtected(e,t,n,r);const o=await Gt(e.env.PORT,e),s=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",i=t.targets?.map(String),a=i?.length?i:["test/e2e/"],c=this.testUnit(e,{...t,targets:a});return Le(["YARN","wb","concurrently",...Se(t),"--kill-others","--success","first",`${n} && exit 1`,`wait-on -t 600000 -i 2000 http-get://127.0.0.1:${o} && ${c}${s}`])}};const sn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`next dev --turbopack ${t.normalizedArgsText??""}`}};const an=new class extends Qt{constructor(){super(!1)}startDevProtected(e,t){throw new Error("This method should not be called.")}startDev(e,t){return Promise.resolve(`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`)}startProduction(e,t){return Promise.resolve(`${e.buildCommand} && ${ie} dist/index.js ${t.normalizedArgsText??""} | tee server.log`)}startTest(){return Promise.resolve("echo 'do nothing.'")}startDocker(e,t){return Promise.resolve(`${this.buildDocker(e,"development")} && ${Ht.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`)}testE2EDev(){return Promise.resolve("echo 'do nothing.'")}testE2EProduction(){return Promise.resolve("echo 'do nothing.'")}testE2EDocker(){return Promise.resolve("echo 'do nothing.'")}testStart(){return Promise.resolve("echo 'do nothing.'")}};const cn=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`remix dev ${t.normalizedArgsText??""}`}};const ln=new class extends Qt{constructor(){super(!0)}startDevProtected(e,t){return`YARN vite dev ${t.normalizedArgsText??""}`.trim()}startProductionProtected(e,t){return`${e.buildCommand} && YARN vite preview ${t.normalizedArgsText??""}`.trim()}},dn=["express","fastify","elysia","hono"],un={watch:{description:"Whether to watch files",type:"boolean"},args:{description:"Arguments for core command",type:"array",alias:"a",default:[]},"docker-options":{description:'Arguments for "docker run"',type:"array",default:[]},mode:{description:"Start mode: dev[elopment] (default) | staging | docker | docker-debug | test",type:"string",alias:"m"}},pn={command:"start [args..]",describe:"Start app. Use '--' to stop wb option parsing and forward the remaining arguments to the underlying app command. Example: wb start -- --host 0.0.0.0",builder:e=>e.parserConfiguration({"populate--":!0}).options(un),async handler(e){!function(e){e.normalizedArgsText=[...e.args??[],...e._?.slice(1)??[],...e["--"]??[]].map(e=>Fe(String(e))).join(" "),e.normalizedDockerOptionsText=(e.dockerOptions??[]).map(e=>Fe(String(e))).join(" ")}(e);const t=await ne(e);t||(console.error(l.red("No project found.")),process.exit(1));for(const n of t.descendants){const t=n.packageJson.dependencies??{},r=n.packageJson.devDependencies??{};let o;if(t.blitz)o=rn;else if(t.next)o=sn;else if(r["@remix-run/dev"])o=cn;else if(r.vite)o=ln;else if(dn.some(e=>t[e])&&!t["firebase-functions"]||n.hasDockerfile&&/EXPOSE\s+8080/.test(n.dockerfile))o=on;else{if(!t["build-ts"]&&!r["build-ts"])continue;o=an}switch(console.info(`Running "start" for ${n.name} ...`),e.mode??"dev"){case"dev":case"development":process.env.WB_ENV||="development",await we(await o.startDev(n,e),n,e);break;case"staging":process.env.WB_ENV||="staging",await we(await o.startProduction(n,e),n,e);break;case"docker":process.env.WB_ENV||="staging",await we(await o.startDocker(n,e),n,e);break;case"docker-debug":process.env.WB_ENV||="staging",e.normalizedArgsText="'/bin/bash'",await we(await o.startDocker(n,e),n,e);break;case"test":{process.env.WB_ENV||="test";const t=await o.startTest(n,e);await we(t,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}},fn=new RegExp(`${String.fromCodePoint(27)}\\[[0-?]*[ -/]*[@-~]`,"g"),hn={e2e:{description:"How to run E2E tests",type:"string",choices:["headless","headless-dev","headed","headed-dev","docker","docker-debug","debug","generate","trace"],default:"headless"},silent:{description:"Reduce redundant outputs",type:"boolean"},bail:{description:"Stop tests after the first failure",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"}},mn={array:!0,description:"Unit or E2E test target paths",type:"string"},gn={command:"test [targets...]",describe:"Test project. If you pass no arguments, it will run all tests. Use '--' to stop wb option parsing and forward the remaining flags to Playwright. Example: wb test -- --grep 'uploaded image asset'",builder:e=>e.parserConfiguration({"populate--":!0}).options(hn).positional("targets",mn),async handler(e){await wn(e)}};async function wn(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1)),process.env.FORCE_COLOR||="3",delete process.env.NO_COLOR,process.env.WB_ENV||="test";const o=n.targets??[],s=n["--"]??[],{shouldRunE2e:i,shouldRunUnit:a}=function(e,t=[]){const n=e.some(e=>e.includes("/e2e")),r=e.some(e=>e.includes("/unit")),o=0===e.length&&0===t.length;return{shouldRunUnit:o||r,shouldRunE2e:o||n||t.length>0}}(o,s);for(const c of r.descendants){const r=c.packageJson.dependencies??{},l=c.packageJson.devDependencies??{};let d;d=r.blitz?rn:r.next?sn:l["@remix-run/dev"]?cn:l.vite?ln:dn.some(e=>r[e])&&!r["firebase-functions"]?on:an,console.info(`Running "test" for ${c.name} ...`);const u=yn(c);if(a&&!1!==u){const e=o.filter(e=>e.includes("/unit")),t=e.length>0?e:u.length>0?u:void 0,r={...n,targets:t};await vn(d.testUnit(c,r),c,n,{timeout:n.unitTimeout})}if(!i||!e.existsSync(t.join(c.dirPath,"test","e2e")))continue;const p=o.filter(e=>e.includes("/e2e")),f={...n,targets:p.length>0?p:void 0};switch(n.e2e){case"headless":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s),forwardedPlaywrightArgs:s}),c,n);continue;case"headless-dev":await vn(await d.testE2EDev(c,f,{playwrightArgs:Sn(p,s),forwardedPlaywrightArgs:s}),c,n);continue;case"docker":await bn(c,f,d,Sn(p,s),s);continue;case"docker-debug":await bn(c,f,d,Sn(p,s,["--debug"]),s);continue}if(r.blitz||r.next||l["@remix-run/dev"]||l.vite)switch(n.e2e){case"headed":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s,["--headed"]),forwardedPlaywrightArgs:s}),c,n);break;case"headed-dev":await vn(await d.testE2EDev(c,f,{playwrightArgs:Sn(p,s,["--headed"]),forwardedPlaywrightArgs:s}),c,n);break;case"debug":await vn(await d.testE2EProduction(c,f,{playwrightArgs:Sn(p,s,["--debug"]),forwardedPlaywrightArgs:s}),c,n);break;case"generate":await vn(await d.testE2EProduction(c,f,{playwrightArgs:["codegen",`http://localhost:${c.env.PORT}`]}),c,n);break;case"trace":await vn("BUN playwright show-trace",c,n)}}}function yn(n){return e.existsSync(t.join(n.dirPath,"test","unit"))?[]:!(!n.hasVitest||!e.existsSync(t.join(n.dirPath,"test")))&&(e.existsSync(t.join(n.dirPath,"test","e2e"))?["test","--exclude","test/e2e/**"]:["test"])}async function bn(e,t,n,r,o){e.env.WB_DOCKER||="1",await we(`${n.buildDocker(e,"test")}${Jt(t)}`,e,t),process.exitCode=await vn(await n.testE2EDocker(e,t,{playwrightArgs:r,forwardedPlaywrightArgs:o}),e,t,{exitIfFailed:!1}),await we(Ht.stop(e),e,t)}function vn(e,t,n,r={}){return we(e,t,n,{...r,processSilentOutput:kn})}function kn(e){const t=[],n=new Set,r=[];for(const o of function*(e){let t=0;for(;t<=e.length;){const n=e.indexOf("\n",t);if(-1===n)return void(yield e.slice(t));yield e.slice(t,n),t=n+1}}(e)){const e=En(o);n.has(e)||(t.some(t=>Pn(t,e))||(An(t,n,e),r.push(o)))}return r.join("\n")}function An(e,t,n){if(e.push(n),t.add(n),e.length<=200)return;const r=e.shift();void 0!==r&&t.delete(r)}function En(e){return e.replaceAll(fn,"").trim().replaceAll(/^(?:\[[^\]]+\]\s*)+/g,"").replaceAll(/\(node:\d+\)/g,"(node:<number>)").replaceAll(/\b\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?Z?\b/g,"<timestamp>").replaceAll(/([?&]cache=)\d+/g,"$1<number>")}function Pn(e,t){const n=Math.max(e.length,t.length);return 0===n||!(Math.abs(e.length-t.length)>.05*n)&&b(e,t)/n<=.05}function Sn(e,t=[],n=[]){const r=Xt(t).length>0;return["test",...e.length>0||r?[]:["test/e2e/"],...n]}const $n={command:"test-on-ci",describe:"Test project on CI with no options.",builder:{silent:{description:"Reduce redundant outputs",type:"boolean"}},async handler(n){await async function(n){const r=await ne(n);r||(console.error(l.red("No project found.")),process.exit(1));process.env.CI||="1",process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";for(const o of r.descendants){const r=o.packageJson.dependencies??{},s=o.packageJson.devDependencies??{};let i;i=r.blitz?rn:r.next?sn:s["@remix-run/dev"]?cn:s.vite?ln:dn.some(e=>r[e])&&!r["firebase-functions"]?on:an,console.info(`Running "test-on-ci" for ${o.name} ...`);const a=o.hasDockerfile;if(a&&await ye(Ht.stopAll(),o,n),e.existsSync(t.join(o.dirPath,"test","unit"))&&await ye(i.testUnit(o,n).replaceAll(" --allowOnly",""),o,n),e.existsSync(t.join(o.dirPath,"test","e2e"))){await ye(await i.testStart(o,n),o,n),await me.promiseAll(),a&&(o.env.WB_DOCKER||="1",await we(`${i.buildDocker(o,"test")}${Jt(n)}`,o,n));const e=a?await i.testE2EDocker(o,n,{}):await i.testE2EProduction(o,n,{});process.exitCode=await we(e.replaceAll(" --allowOnly",""),o,n,{exitIfFailed:!1}),a&&await we(Ht.stop(o),o,n)}}}(n)}};const xn={command:"tree-kill <pid> [signal]",describe:"Kill the given process and all descendants",builder:e=>e.positional("pid",{description:"The process ID to kill.",type:"number",demandOption:!0}).option("signal",{description:"Signal to send to the process tree.",type:"string",default:"SIGTERM"}),handler(e){try{const t=e.signal;if(!(t in h.signals))throw new Error(`Invalid signal: ${t}`);P(e.pid,t)}catch(e){console.error(e instanceof Error?e.message:String(e)),process.exit(1)}}},Rn={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(n){process.exit(await async function(n){const r=await ne(n,!1);if(!r)return console.error(l.red("No project found.")),1;let o=!1;const s=r.descendants.map(async s=>{const i=[];for(s.packageJson.workspaces&&!s.hasSourceCode||i.push(...function(e){if(e.hasOwnDependency("@typescript/native-preview"))return["BUN tsgo --noEmit"];if(e.hasOwnDependency("typescript"))return["BUN tsc --noEmit"];return[]}(s)),!s.packageJson.workspaces&&s.hasOwnDependency("pyright")&&i.push("YARN pyright");i.length>0;){const a=await ye(i.join(" && "),s,n,{ci:r.descendants.length>1,exitIfFailed:!1,forceColor:!0}),c=t.join(s.dirPath,".next");if(!a||!e.existsSync(c))return a;e.rmSync(c,{force:!0,recursive:!0}),console.info(l.yellow("Removed `.next` directory. We will re-try type checking.")),o=!0}}),i=await Promise.all(s);let a=0;for(const[e,t]of i.entries())if(t){(r.descendants[e]?.packageJson.dependencies??{}).blitz&&console.info(l.yellow('Please try "yarn gen-code" if you face unknown type errors.')),a=t}a||console.info(l.green(o?"-----\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.":"No type errors found."));return a}(n))}};const jn={...Rn,command:"tc"},On={command:"verify",describe:"Verify project code",builder:{full:{type:"boolean",default:!1,describe:"Run tests after verifying project code"}},async handler(n){const r=re(n,!1);r||(console.error(l.red("No project found.")),process.exit(1)),await(n.full?async function(n,r){const o=function(n){const r=Date.now(),o=t.join(n.dirPath,".wb");e.mkdirSync(o,{recursive:!0});const s=t.join(o,"verify-full.log"),i=e.openSync(s,"w"),a=process.stdout.write.bind(process.stdout),c=process.stderr.write.bind(process.stderr);let d=!1,u=!1;process.stdout.write=Cn(process.stdout.fd,i),process.stderr.write=Cn(process.stderr.fd,i),console.info(l.cyan(l.bold("Full log:"),s));const p=()=>{if(u)return;u=!0,process.stdout.write=a,process.stderr.write=c;const t=function(e){const t=Math.round(e/1e3),n=Math.floor(t/60),r=t%60;if(0===n)return`${r}s`;return`${n}m ${r}s`}(Date.now()-r),n=`${d?"Succeeded":"Failed"} in ${t}. Full log: ${s}\n`,o=d?l.green(n):l.red(n);a(o),e.writeSync(i,n),e.closeSync(i)};return process.once("exit",p),{fail:e=>{d=!1,e&&console.error(e)},finish:()=>{process.removeListener("exit",p),p()},succeed:()=>{d=!0}}}(n);try{await Dn(n,r),await async function(e,t){await wn({...t,_:["test"],e2e:"headless",silent:!0})}(0,r),o.succeed()}catch(e){throw o.fail(e),e}finally{o.finish()}}(r.self,n):Dn(r.self,n))}};async function Dn(e,t){await Tn(`${ae} install`,e,t),e.packageJson.scripts?.["gen-code"]&&await Tn(`${ae} gen-code`,e,t),await Nn("format",()=>Ge({...t,_:["lint"],format:!0,printAllOutput:!0,silent:!0}),{allowFailure:!0,silent:!0}),await Nn("lint-fix",()=>Ge({...t,_:["lint"],fix:!0,printAllOutput:!0,quiet:!0,silent:!0}),{silent:!0})}async function Nn(e,t,n={}){n.silent||console.info("\n"+l.cyan(l.bold("Start:"),e));const r=await t()??0;return 0===r||n.allowFailure?n.silent||console.info(l.green(l.bold("Finished:"),e)):(console.info(l.red(l.bold(`Failed (exit code ${r}):`),e)),process.exit(r)),r}async function Tn(e,t,n,r={}){if(function(e,t){console.info("\n"+l.cyan(l.bold("Command:"),e)+l.gray(` at ${t}`))}(e,t.dirPath),n.dryRun)return 0;const o=await j(e,void 0,{cwd:t.dirPath,env:Ae(t.env,{forceColor:!1}),shell:!0,stdio:"pipe",mergeOutAndError:!0,killOnExit:!0,printingStdout:r.printRawOutput,printingStderr:r.printRawOutput,verbose:n.verbose}),s=o.status??1;return r.printRawOutput||function(e,t,n){if(0===t&&(e===`${ae} install`||e===`${ae} gen-code`))return void console.info(l.green("Succeeded."));const r=n.trim();r&&(process.stdout.write(r),process.stdout.write("\n"))}(e,s,o.stdout),0===s||r.allowFailure||(console.info(l.red(l.bold(`Failed (exit code ${s}):`),e)),process.exit(s)),s}function Cn(t,n){return(r,o,s)=>{const i="string"==typeof r?Buffer.from(r,"string"==typeof o?o:"utf8"):r;return e.writeSync(n,i),e.writeSync(t,i),"function"==typeof o&&o(),s?.(),!0}}await n(r(process.argv)).scriptName("wb").options(Pe).middleware(e=>{const n=e["working-dir"];if(n){const e=t.resolve(n);process.chdir(e)}!function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const t of Object.keys(e)){const n=t.toUpperCase();(n.startsWith("NPM_")||n.startsWith("YARN_")||n.startsWith("BERRY_")||"PROJECT_CWD"===n||"INIT_CWD"===n)&&delete e[t]}}(process.env)}).command(On).command(le).command(xe).command(Ie).command(qe).command(pt).command(Pt).command(Ut).command(Wt).command(pn).command(gn).command($n).command(xn).command(Rn).command(jn).demandCommand().strict().version(function(){let n=t.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(t.join(n,"package.json"));)n=t.dirname(n);return JSON.parse(e.readFileSync(t.join(n,"package.json"),"utf8")).version}()).help().argv;let In=!1;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,()=>{if(!In){In=!0;try{P(process.pid)}catch(e){console.warn(`Failed to treeKill(${process.pid}) during shutdown:`,e)}process.exit()}});
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../../shared-lib-node/src/env.ts","../../shared-lib-node/src/errno.ts","../../shared-lib-node/src/treeKill.ts","../../shared-lib-node/src/processTree.ts","../../shared-lib-node/src/spawn.ts","../../../node_modules/at-decorators/dist/hash.js","../../../node_modules/at-decorators/dist/oson/constructors.js","../../../node_modules/at-decorators/dist/oson/stringify.js","../../../node_modules/at-decorators/dist/getCacheKey.js","../../../node_modules/at-decorators/dist/memoizeOne.js","../src/utils/ci.ts","../src/project.ts","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/utils/promisePool.ts","../src/scripts/run.ts","../src/sharedOptionsBuilder.ts","../src/commands/concurrently.ts","../src/commands/killPortIfNonCi.ts","../src/utils/output.ts","../src/utils/shell.ts","../src/commands/lint.ts","../src/commands/commandUtils.ts","../src/commands/optimizeForDockerBuild.ts","../src/scripts/drizzleScripts.ts","../src/scripts/prismaScripts.ts","../src/commands/prisma.ts","../src/commands/retry.ts","../src/commands/setup.ts","../src/scripts/builder.ts","../src/utils/process.ts","../src/utils/port.ts","../src/scripts/dockerScripts.ts","../src/scripts/execution/baseScripts.ts","../src/scripts/execution/blitzScripts.ts","../src/scripts/execution/httpServerScripts.ts","../src/scripts/execution/nextScripts.ts","../src/scripts/execution/plainAppScripts.ts","../src/scripts/execution/remixScripts.ts","../src/scripts/execution/viteScripts.ts","../src/commands/httpServerPackages.ts","../src/commands/start.ts","../src/commands/test.ts","../src/commands/testOnCi.ts","../src/commands/treeKill.ts","../src/commands/typecheck.ts","../src/commands/verifyCode.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\nimport { expand } from 'dotenv-expand';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const yargsOptionsBuilderForEnv = {\n  env: {\n    description: '.env files to be loaded.',\n    type: 'array',\n  },\n  'cascade-env': {\n    description:\n      'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n    type: 'string',\n  },\n  'cascade-node-env': {\n    description: 'Same with --cascade-env=<NODE_ENV || \"development\">. Preferred over `auto-cascade-env`.',\n    type: 'boolean',\n  },\n  'auto-cascade-env': {\n    description: 'Same with --cascade-env=<WB_ENV || NODE_ENV || \"development\">.',\n    type: 'boolean',\n    default: true,\n  },\n  'include-root-env': {\n    description: 'Include .env files in root directory if the project is in a monorepo and --env option is not used.',\n    type: 'boolean',\n    default: true,\n  },\n  'check-env': {\n    description: 'Check whether the keys of the loaded .env files are same with the given .env file.',\n    type: 'string',\n    default: '.env.example',\n  },\n  verbose: {\n    description: 'Whether to show verbose information',\n    type: 'boolean',\n    alias: 'v',\n  },\n} as const;\n\nexport type EnvReaderOptions = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof yargsOptionsBuilderForEnv>>>;\n\n/**\n * This function reads environment variables from `.env` files.\n * Note it does not assign them in `process.env`.\n * @return [envVars, [envPaths, envVarNames][]]\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): [Record<string, string>, [string, string[]][]] {\n  let envPaths = (argv.env ?? []).map((envPath) => path.resolve(cwd, envPath.toString()));\n  const cascade =\n    argv.cascadeEnv ??\n    (argv.cascadeNodeEnv\n      ? process.env.NODE_ENV || 'development'\n      : argv.autoCascadeEnv\n        ? process.env.WB_ENV || process.env.NODE_ENV || 'development'\n        : undefined);\n  if (typeof cascade === 'string') {\n    if (envPaths.length === 0) {\n      envPaths.push(path.join(cwd, '.env'));\n      if (argv.includeRootEnv) {\n        const rootPath = path.resolve(cwd, '..', '..');\n        if (fs.existsSync(path.join(rootPath, 'package.json'))) {\n          envPaths.push(path.join(rootPath, '.env'));\n        }\n      }\n    }\n    envPaths = envPaths.flatMap((envPath) =>\n      cascade\n        ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n        : [`${envPath}.local`, envPath]\n    );\n  }\n  envPaths = envPaths.filter((envPath) => fs.existsSync(envPath)).map((envPath) => path.relative(cwd, envPath));\n  if (argv.verbose) {\n    console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`);\n    console.info('Reading env files:', envPaths.join(', '));\n  }\n\n  const envPathAndLoadedEnvVarNames: [string, string[]][] = [];\n  const envVars: Record<string, string> = {};\n  for (const envPath of envPaths) {\n    const keys: string[] = [];\n    for (const [key, value] of Object.entries(readEnvFile(path.join(cwd, envPath)))) {\n      if (!(key in envVars) && !(key in process.env)) {\n        envVars[key] = value;\n        keys.push(key);\n      }\n    }\n    envPathAndLoadedEnvVarNames.push([envPath, keys]);\n    if (argv.verbose && keys.length > 0) {\n      console.info(`Read ${keys.length} environment variables from ${envPath}`);\n    }\n  }\n  if (!argv.verbose) {\n    console.info(\n      `Read env files: ${envPathAndLoadedEnvVarNames.map(([envPath, keys]) => (keys.length > 0 ? `${envPath} (${keys.join(', ')})` : envPath)).join(', ') || 'nothing'}`\n    );\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv)));\n    const missingKeys = exampleKeys.filter((key) => !(key in envVars) && !(key in process.env));\n    if (missingKeys.length > 0) {\n      throw new Error(`Missing environment variables in [${envPaths.join(', ')}]: [${missingKeys.join(', ')}]`);\n    }\n  }\n  return [expand({ parsed: envVars, processEnv: {} }).parsed ?? envVars, envPathAndLoadedEnvVarNames];\n}\n\n/**\n * This function read environment variables from `.env` files and assign them in `process.env`.\n * */\nexport function readAndApplyEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): Record<string, string | undefined> {\n  const [envVars] = readEnvironmentVariables(argv, cwd);\n  for (const [key, value] of Object.entries(envVars)) {\n    if (!(key in process.env)) {\n      process.env[key] = value;\n    }\n  }\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string): Record<string, string> {\n  const cached = cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {}, quiet: true }).parsed ?? {};\n  cachedEnvVars.set(filePath, parsed);\n  return parsed;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n  // Remove npm & yarn environment variables from process.env\n  if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n    envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n      // Temporary directory in macOS\n      .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n      // Temporary directories in Linux\n      .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n      .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n  }\n  for (const key of Object.keys(envVars)) {\n    const upperKey = key.toUpperCase();\n    if (\n      upperKey.startsWith('NPM_') ||\n      upperKey.startsWith('YARN_') ||\n      upperKey.startsWith('BERRY_') ||\n      upperKey === 'PROJECT_CWD' ||\n      upperKey === 'INIT_CWD'\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete envVars[key];\n    }\n  }\n}\n","export function isErrnoException(error: unknown): error is NodeJS.ErrnoException {\n  return error instanceof Error && 'code' in error;\n}\n","import { execFileSync } from 'node:child_process';\n\nimport { isErrnoException } from './errno.js';\nimport { buildChildrenByParentMap, collectDescendantPids as collectDescendantPidsFromMap } from './processTree.js';\n\nexport function treeKill(pid: number, signal: NodeJS.Signals = 'SIGTERM'): void {\n  if (!Number.isInteger(pid) || pid <= 0) {\n    throw new Error(`Invalid pid: ${pid}`);\n  }\n\n  if (process.platform === 'win32') {\n    killTreeOnWindows(pid);\n    return;\n  }\n\n  const descendants = collectDescendantPids(pid);\n  const targetPids = toChildrenFirstPids(pid, descendants);\n  for (const targetPid of targetPids) {\n    killIfNeeded(targetPid, signal);\n  }\n}\n\nfunction killIfNeeded(pid: number, signal: NodeJS.Signals): void {\n  try {\n    process.kill(pid, signal);\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return;\n    }\n    throw error;\n  }\n}\n\nfunction killTreeOnWindows(pid: number): void {\n  try {\n    runCommand('taskkill', ['/PID', String(pid), '/T', '/F'], {\n      maxBuffer: 1024 * 1024,\n      timeout: 2000,\n    });\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return;\n    }\n    throw error;\n  }\n}\n\nfunction collectDescendantPids(rootPid: number): number[] {\n  const { stdout } = runCommand(\n    'ps',\n    ['-Ao', 'pid=,ppid='],\n    // Keep command bounded so watch-mode kill loops cannot hang this path.\n    { maxBuffer: 1024 * 1024, timeout: 2000 }\n  );\n  const childrenByParent = buildChildrenByParentMap(stdout);\n  return collectDescendantPidsFromMap(rootPid, childrenByParent);\n}\n\nfunction toChildrenFirstPids(pid: number, descendants: readonly number[]): number[] {\n  const targetPids = descendants.toReversed();\n  targetPids.push(pid);\n  return targetPids;\n}\n\nfunction runCommand(\n  command: string,\n  args: readonly string[],\n  options?: { timeout: number; maxBuffer: number }\n): { stdout: string; stderr: string } {\n  try {\n    const stdout = execFileSync(command, [...args], {\n      encoding: 'utf8',\n      maxBuffer: options?.maxBuffer,\n      timeout: options?.timeout,\n      stdio: ['ignore', 'pipe', 'pipe'],\n    });\n    return { stdout, stderr: '' };\n  } catch (error) {\n    const stderr = extractStderr(error);\n    throw new CommandExecutionError(command, args, stderr, toExitCode(error));\n  }\n}\n\nfunction isNoSuchProcessError(error: unknown): boolean {\n  if (isErrnoException(error) && error.code === 'ESRCH') {\n    return true;\n  }\n\n  if (error instanceof CommandExecutionError) {\n    return /no such process|not found|not recognized|there is no running instance/i.test(error.stderr);\n  }\n  return false;\n}\n\nfunction toExitCode(error: unknown): number | string | undefined {\n  if (isErrnoException(error)) {\n    return error.code;\n  }\n  if (typeof error === 'object' && error !== null && 'status' in error) {\n    const status = (error as { status: unknown }).status;\n    if (typeof status === 'number') {\n      return status;\n    }\n  }\n  return undefined;\n}\n\nfunction extractStderr(error: unknown): string {\n  if (typeof error !== 'object' || error === null || !('stderr' in error)) {\n    return '';\n  }\n\n  const stderr = (error as Record<'stderr', unknown>).stderr;\n  if (typeof stderr === 'string') {\n    return stderr;\n  }\n  if (Buffer.isBuffer(stderr)) {\n    return stderr.toString('utf8');\n  }\n  return '';\n}\n\nclass CommandExecutionError extends Error {\n  readonly stderr: string;\n  readonly code: number | string | undefined;\n\n  constructor(command: string, args: readonly string[], stderr: string, code: number | string | undefined) {\n    super(`Command failed: ${command} ${args.join(' ')}`);\n    this.name = 'CommandExecutionError';\n    this.stderr = stderr;\n    this.code = code;\n  }\n}\n","export function buildChildrenByParentMap(psOutput: string): Map<number, number[]> {\n  const childrenByParent = new Map<number, number[]>();\n  for (const line of psOutput.split('\\n')) {\n    const matched = /^\\s*(\\d+)\\s+(\\d+)\\s*$/.exec(line);\n    if (!matched) {\n      continue;\n    }\n\n    const childPid = Number(matched[1]);\n    const parentPid = Number(matched[2]);\n    const children = childrenByParent.get(parentPid);\n    if (children) {\n      children.push(childPid);\n    } else {\n      childrenByParent.set(parentPid, [childPid]);\n    }\n  }\n  return childrenByParent;\n}\n\nexport function collectDescendantPids(rootPid: number, childrenByParent: Map<number, number[]>): number[] {\n  const descendants: number[] = [];\n  const queue = [...(childrenByParent.get(rootPid) ?? [])];\n  let index = 0;\n  while (index < queue.length) {\n    const pid = queue[index] as number;\n    index += 1;\n    descendants.push(pid);\n    queue.push(...(childrenByParent.get(pid) ?? []));\n  }\n  return descendants;\n}\n","import type {\n  SpawnOptions,\n  SpawnOptionsWithoutStdio,\n  SpawnOptionsWithStdioTuple,\n  SpawnSyncReturns,\n  StdioNull,\n  StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport { treeKill } from './treeKill.js';\n\n/**\n * Return type for spawnAsync function, based on SpawnSyncReturns but without output and error properties\n */\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\n/**\n * Options for spawnAsync function, extending various Node.js spawn options with additional functionality\n */\nexport type SpawnAsyncOptions = (\n  | SpawnOptionsWithoutStdio\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n  | SpawnOptions\n) & {\n  /** Input string to write to the spawned process's stdin */\n  input?: string;\n  /** If true, stderr output will be merged into stdout */\n  mergeOutAndError?: boolean;\n  /** If true, the spawned process will be killed when the parent process exits */\n  killOnExit?: boolean;\n  /** If true, enables verbose logging of process operations */\n  verbose?: boolean;\n  /** If true, stdout data will be printed to console as it's received */\n  printingStdout?: boolean;\n  /** If true, stderr data will be printed to console as it's received */\n  printingStderr?: boolean;\n  /** If true, blank-only lines are skipped while printing stdout/stderr in realtime */\n  omitBlankLinesWhilePrinting?: boolean;\n};\n\n/**\n * Spawns a child process asynchronously and returns a promise that resolves with the process results\n *\n * This function provides a Promise-based wrapper around Node.js's spawn function with additional features:\n * - Automatic encoding of stdout/stderr as UTF-8\n * - Option to merge stderr into stdout\n * - Option to automatically kill the process on parent exit\n * - Option to provide input via stdin\n * - Verbose logging capability\n *\n * @param command - The command to run\n * @param args - List of string arguments\n * @param options - Configuration options for the spawned process\n * @returns Promise that resolves with the process results including pid, stdout, stderr, status, and signal\n * @throws Will reject the promise if the process fails to spawn or encounters an error\n *\n * @example\n * ```typescript\n * const result = await spawnAsync('ls', ['-la'], { verbose: true });\n * console.log(result.stdout);\n * ```\n */\nexport async function spawnAsync(\n  command: string,\n  args?: readonly string[],\n  options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n  return new Promise((resolve, reject) => {\n    try {\n      const proc = spawn(command, args ?? [], options ?? {});\n      // `setEncoding` is undefined in Bun\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stdout?.setEncoding?.('utf8');\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      const stdoutPrinter = createRealtimePrinter(process.stdout, options?.omitBlankLinesWhilePrinting);\n      const stderrPrinter = createRealtimePrinter(process.stderr, options?.omitBlankLinesWhilePrinting);\n      proc.stdout?.on('data', (data: string) => {\n        stdout += data;\n        if (options?.printingStdout) {\n          stdoutPrinter.write(data);\n        }\n      });\n      proc.stderr?.on('data', (data: string) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += data;\n        }\n        if (options?.printingStderr) {\n          stderrPrinter.write(data);\n        }\n      });\n\n      let stopped = false;\n      const stopProcess = (): void => {\n        if (stopped || !proc.pid) return;\n\n        stopped = true;\n        if (options?.verbose) {\n          console.info(`treeKill(${proc.pid})`);\n        }\n        try {\n          treeKill(proc.pid);\n        } catch (error) {\n          if (options?.verbose) {\n            console.warn(`Failed to treeKill(${proc.pid})`, error);\n          }\n        }\n      };\n      const cleanupSignals: NodeJS.Signals[] =\n        process.platform === 'win32' ? ['SIGINT', 'SIGTERM'] : ['SIGINT', 'SIGTERM', 'SIGQUIT'];\n      const signalHandlers = new Map<NodeJS.Signals, () => void>();\n      const removeKillOnExitHandlers = (): void => {\n        process.removeListener('beforeExit', stopProcess);\n        for (const [signal, handler] of signalHandlers) {\n          process.removeListener(signal, handler);\n        }\n        signalHandlers.clear();\n      };\n      if (options?.killOnExit) {\n        process.on('beforeExit', stopProcess);\n        for (const signal of cleanupSignals) {\n          const handleSignal = (): void => {\n            stopProcess();\n            removeKillOnExitHandlers();\n            if (process.listenerCount(signal) === 0) {\n              process.kill(process.pid, signal);\n            }\n          };\n          signalHandlers.set(signal, handleSignal);\n          process.on(signal, handleSignal);\n        }\n      }\n\n      proc.on('error', (error) => {\n        removeKillOnExitHandlers();\n        proc.removeAllListeners('close');\n        reject(error);\n      });\n      proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n        removeKillOnExitHandlers();\n        stdoutPrinter.flush();\n        stderrPrinter.flush();\n        if (proc.pid === undefined) {\n          reject(new Error('Process has no pid.'));\n        } else {\n          resolve({\n            pid: proc.pid,\n            stdout,\n            stderr,\n            status: code,\n            signal,\n          });\n        }\n      });\n\n      if (options?.input) {\n        proc.stdin?.write(options.input);\n        proc.stdin?.end();\n      }\n    } catch (error) {\n      // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n      reject(error);\n    }\n  });\n}\n\nconst ANSI_ESCAPE_CODE_REGEXP = new RegExp(`${String.fromCodePoint(27)}\\\\[[0-?]*[ -/]*[@-~]`, 'g');\n\nfunction createRealtimePrinter(\n  stream: NodeJS.WriteStream,\n  omitBlankLines = false\n): { write: (data: string) => void; flush: () => void } {\n  if (!omitBlankLines) {\n    return {\n      write: (data) => stream.write(data),\n      flush: () => {},\n    };\n  }\n\n  let pending = '';\n  return {\n    write: (data) => {\n      pending += data;\n      const lines = pending.split(/\\r?\\n/);\n      pending = lines.pop() ?? '';\n      for (const line of lines) {\n        if (!isBlankLine(line)) {\n          stream.write(`${line}\\n`);\n        }\n      }\n    },\n    flush: () => {\n      if (!isBlankLine(pending)) {\n        stream.write(pending);\n      }\n      pending = '';\n    },\n  };\n}\n\nfunction isBlankLine(line: string): boolean {\n  return line.replaceAll(ANSI_ESCAPE_CODE_REGEXP, '').trim().length === 0;\n}\n","/**\n * [js-sha3]{@link https://github.com/emn178/js-sha3}\n *\n * @version 0.9.3\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2015-2023\n * @license MIT\n */\nconst t=[...\"0123456789abcdef\"],s=[6,1536,393216,100663296],i=[0,8,16,24],e=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];function o(t){return new h(512,s,512).update(t).hex()}const n=t=>{const s=[];for(const[i,e]of t.entries())s[i]=e;return s};class h{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(t,s,i){this.padding=s,this.outputBits=i,this.blockCount=1600-(t<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=i>>5,this.extraBytes=(31&i)>>3;for(let t=0;t<50;++t)this.s[t]=0}update(t){if(this.finalized)throw new Error(\"finalize already called\");const s=this.blocks,e=this.byteCount,o=t.length,n=this.blockCount,h=this.s;let l,c,f=0;for(;f<o;){if(this.reset)for(this.reset=!1,s[0]=this.block,l=1;l<n+1;++l)s[l]=0;for(l=this.start;f<o&&l<e;++f)c=t.codePointAt(f)||0,c<128?s[l>>2]|=c<<i[3&l++]:c<2048?(s[l>>2]|=(192|c>>6)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):c<55296||c>=57344?(s[l>>2]|=(224|c>>12)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):(c=65536+((1023&c)<<10|1023&(t.codePointAt(++f)||0)),s[l>>2]|=(240|c>>18)<<i[3&l++],s[l>>2]|=(128|c>>12&63)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]);if(this.lastByteIndex=l,l>=e){for(this.start=l-e,this.block=s[n],l=0;l<n;++l)h[l]^=s[l];r(h),this.reset=!0}else this.start=l}return this}finalize(){if(this.finalized)return;this.finalized=!0;const t=this.blocks;let s=this.lastByteIndex;const i=this.blockCount,e=this.s;if(t[s>>2]|=this.padding[3&s],this.lastByteIndex===this.byteCount)for(t[0]=t[i],s=1;s<i+1;++s)t[s]=0;for(t[i-1]|=2147483648,s=0;s<i;++s)e[s]^=t[s];r(e)}hex(){this.finalize();const s=this.blockCount;let i=this.s;const e=this.outputBlocks,o=this.extraBytes;let h,l=0,c=0,f=\"\";for(;c<e;){for(l=0;l<s&&c<e;++l,++c)h=i[l],f+=t[h>>4&15]+t[15&h]+t[h>>12&15]+t[h>>8&15]+t[h>>20&15]+t[h>>16&15]+t[h>>28&15]+t[h>>24&15];c%s===0&&(i=n(i),r(i),l=0)}return o&&(h=i[l],f+=t[h>>4&15]+t[15&h],o>1&&(f+=t[h>>12&15]+t[h>>8&15]),o>2&&(f+=t[h>>20&15]+t[h>>16&15])),f}}const r=function(t){let s,i,o,n,h,r,l,c,f,a,u,d,b,k,y,x,B,p,C,z,I,g,w,A,P,E,j,m,q,v,D,F,G,H,J,K,L,M,N,O,Q,R,S,T,U,V,W,X,Y,Z,$,_,tt,st,it,et,ot,nt,ht,rt,lt,ct,ft;for(o=0;o<48;o+=2)n=t[0]^t[10]^t[20]^t[30]^t[40],h=t[1]^t[11]^t[21]^t[31]^t[41],r=t[2]^t[12]^t[22]^t[32]^t[42],l=t[3]^t[13]^t[23]^t[33]^t[43],c=t[4]^t[14]^t[24]^t[34]^t[44],f=t[5]^t[15]^t[25]^t[35]^t[45],a=t[6]^t[16]^t[26]^t[36]^t[46],u=t[7]^t[17]^t[27]^t[37]^t[47],d=t[8]^t[18]^t[28]^t[38]^t[48],b=t[9]^t[19]^t[29]^t[39]^t[49],s=d^(r<<1|l>>>31),i=b^(l<<1|r>>>31),t[0]^=s,t[1]^=i,t[10]^=s,t[11]^=i,t[20]^=s,t[21]^=i,t[30]^=s,t[31]^=i,t[40]^=s,t[41]^=i,s=n^(c<<1|f>>>31),i=h^(f<<1|c>>>31),t[2]^=s,t[3]^=i,t[12]^=s,t[13]^=i,t[22]^=s,t[23]^=i,t[32]^=s,t[33]^=i,t[42]^=s,t[43]^=i,s=r^(a<<1|u>>>31),i=l^(u<<1|a>>>31),t[4]^=s,t[5]^=i,t[14]^=s,t[15]^=i,t[24]^=s,t[25]^=i,t[34]^=s,t[35]^=i,t[44]^=s,t[45]^=i,s=c^(d<<1|b>>>31),i=f^(b<<1|d>>>31),t[6]^=s,t[7]^=i,t[16]^=s,t[17]^=i,t[26]^=s,t[27]^=i,t[36]^=s,t[37]^=i,t[46]^=s,t[47]^=i,s=a^(n<<1|h>>>31),i=u^(h<<1|n>>>31),t[8]^=s,t[9]^=i,t[18]^=s,t[19]^=i,t[28]^=s,t[29]^=i,t[38]^=s,t[39]^=i,t[48]^=s,t[49]^=i,k=t[0],y=t[1],V=t[11]<<4|t[10]>>>28,W=t[10]<<4|t[11]>>>28,m=t[20]<<3|t[21]>>>29,q=t[21]<<3|t[20]>>>29,rt=t[31]<<9|t[30]>>>23,lt=t[30]<<9|t[31]>>>23,R=t[40]<<18|t[41]>>>14,S=t[41]<<18|t[40]>>>14,H=t[2]<<1|t[3]>>>31,J=t[3]<<1|t[2]>>>31,x=t[13]<<12|t[12]>>>20,B=t[12]<<12|t[13]>>>20,X=t[22]<<10|t[23]>>>22,Y=t[23]<<10|t[22]>>>22,v=t[33]<<13|t[32]>>>19,D=t[32]<<13|t[33]>>>19,ct=t[42]<<2|t[43]>>>30,ft=t[43]<<2|t[42]>>>30,st=t[5]<<30|t[4]>>>2,it=t[4]<<30|t[5]>>>2,K=t[14]<<6|t[15]>>>26,L=t[15]<<6|t[14]>>>26,p=t[25]<<11|t[24]>>>21,C=t[24]<<11|t[25]>>>21,Z=t[34]<<15|t[35]>>>17,$=t[35]<<15|t[34]>>>17,F=t[45]<<29|t[44]>>>3,G=t[44]<<29|t[45]>>>3,A=t[6]<<28|t[7]>>>4,P=t[7]<<28|t[6]>>>4,et=t[17]<<23|t[16]>>>9,ot=t[16]<<23|t[17]>>>9,M=t[26]<<25|t[27]>>>7,N=t[27]<<25|t[26]>>>7,z=t[36]<<21|t[37]>>>11,I=t[37]<<21|t[36]>>>11,_=t[47]<<24|t[46]>>>8,tt=t[46]<<24|t[47]>>>8,T=t[8]<<27|t[9]>>>5,U=t[9]<<27|t[8]>>>5,E=t[18]<<20|t[19]>>>12,j=t[19]<<20|t[18]>>>12,nt=t[29]<<7|t[28]>>>25,ht=t[28]<<7|t[29]>>>25,O=t[38]<<8|t[39]>>>24,Q=t[39]<<8|t[38]>>>24,g=t[48]<<14|t[49]>>>18,w=t[49]<<14|t[48]>>>18,t[0]=k^~x&p,t[1]=y^~B&C,t[10]=A^~E&m,t[11]=P^~j&q,t[20]=H^~K&M,t[21]=J^~L&N,t[30]=T^~V&X,t[31]=U^~W&Y,t[40]=st^~et&nt,t[41]=it^~ot&ht,t[2]=x^~p&z,t[3]=B^~C&I,t[12]=E^~m&v,t[13]=j^~q&D,t[22]=K^~M&O,t[23]=L^~N&Q,t[32]=V^~X&Z,t[33]=W^~Y&$,t[42]=et^~nt&rt,t[43]=ot^~ht&lt,t[4]=p^~z&g,t[5]=C^~I&w,t[14]=m^~v&F,t[15]=q^~D&G,t[24]=M^~O&R,t[25]=N^~Q&S,t[34]=X^~Z&_,t[35]=Y^~$&tt,t[44]=nt^~rt&ct,t[45]=ht^~lt&ft,t[6]=z^~g&k,t[7]=I^~w&y,t[16]=v^~F&A,t[17]=D^~G&P,t[26]=O^~R&H,t[27]=Q^~S&J,t[36]=Z^~_&T,t[37]=$^~tt&U,t[46]=rt^~ct&st,t[47]=lt^~ft&it,t[8]=g^~k&x,t[9]=w^~y&B,t[18]=F^~A&E,t[19]=G^~P&j,t[28]=R^~H&K,t[29]=S^~J&L,t[38]=_^~T&V,t[39]=tt^~U&W,t[48]=ct^~st&et,t[49]=ft^~it&ot,t[0]^=e[o],t[1]^=e[o+1]};export{o as sha3_512};\n//# sourceMappingURL=hash.js.map\n","const e=\"\",t=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,a,s])=>{e.name=t,e.message=n,void 0===a?delete e.stack:e.stack=a,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(a.decode(e))],create:([e])=>n.encode(atob(e))},s={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,a]of t)e.set(n,a)}},o={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},r={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},c={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},d={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,s,o,r,c,d].map(e=>[e.instance.name,e]))}(),n=new TextEncoder,a=new TextDecoder(\"utf-8\");export{t as GLOBAL_CONSTRUCTOR_MAP,e as PLAIN_OBJECT_LABEL};\n//# sourceMappingURL=constructors.js.map\n","import{GLOBAL_CONSTRUCTOR_MAP as t,PLAIN_OBJECT_LABEL as n}from\"./constructors.js\";const e=-1,r=-2,o=-3,i=-4,s=-5,c=-6;function f(n,e=t){return JSON.stringify(a(n,e))}function u(t){if(void 0===t)return-1;if(\"number\"==typeof t){if(Number.isNaN(t))return-3;if(!Number.isFinite(t))return t<0?-5:-4}return null}const l=[];function a(e,r=t){const o=u(e);if(null!==o)return o;const i=[],s=new Map;return function t(e){const o=u(e);if(null!==o)return o;let c=s.get(e);if(void 0!==c)return c;switch(c=i.length,typeof e){case\"number\":case\"string\":case\"boolean\":i[c]=e,s.set(e,c);break;case\"bigint\":i[c]=[-6,e.toString(16)],s.set(e,c);break;case\"object\":if(null===e)i[c]=e,s.set(e,c);else if(Array.isArray(e)){const n=function(t){if(l.length<t){const n=l.length;l.length=t,l.fill(-2,n,t)}return l.slice(0,t)}(e.length);i[c]=n,s.set(e,c);for(const[r,o]of e.entries())n[r]=t(o)}else{const[o,f]=function(t,e){const r=t.constructor;if(\"function\"==typeof r){const n=r.name,o=e.get(n);if(void 0!==o)return[n,o.from(t)]}const o=Object.entries(t),i=o.length,s=Array.from({length:i+i});for(let t=0;t<i;t++){const n=o[t],e=t+t;s[e]=n[0],s[e+1]=n[1]}return[n,s]}(e,r),u=f.length,l=Array.from({length:u+1});l[0]=o,i[c]=l,s.set(e,c);for(let n=0;n<u;n++)l[n+1]=t(f[n])}}return c}(e),i}export{r as ARRAY_HOLE_INDEX,c as BIG_INT_LABEL,o as NAN_INDEX,s as NEG_INF_INDEX,i as POS_INF_INDEX,e as UNDEFINED_INDEX,a as listify,f as stringify};\n//# sourceMappingURL=stringify.js.map\n","import{sha3_512 as r}from\"./hash.js\";import{stringify as n}from\"./oson/stringify.js\";function o(o,t){return r(n([o,t]))}function t(r,o){return n([r,o])}function i(){return\"\"}export{i as getCacheKeyOfEmptyString,o as getCacheKeyOfHash,t as getCacheKeyOfStringified};\n//# sourceMappingURL=getCacheKey.js.map\n","import{getCacheKeyOfHash as t,getCacheKeyOfEmptyString as e}from\"./getCacheKey.js\";const n=r({getCacheKey:t}),c=r({getCacheKey:e});function r({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:n=t}={}){return function(t,c){let r,o,i;return\"getter\"===c?.kind?function(){const c=n(this,[]),a=Date.now();return(i!==c||a-o>e)&&(i=c,r=t.call(this),o=a),r}:function(...a){const u=n(this,a),h=Date.now();return(i!==u||h-o>e)&&(i=u,r=c?t.call(this,...a):t(...a),o=h),r}}}export{n as memoizeOne,r as memoizeOneFactory,c as memoizeOneWithEmptyHash};\n//# sourceMappingURL=memoizeOne.js.map\n","export function isCI(ciEnv: string | undefined): boolean {\n  return !!ciEnv && ciEnv !== '0' && ciEnv !== 'false';\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport { readEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport { memoizeOne } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nimport { isCI } from './utils/ci.js';\n\nexport type DatabaseOrm = 'prisma' | 'drizzle';\n\nexport class Project {\n  private readonly argv: EnvReaderOptions;\n  private readonly loadEnv: boolean;\n  private readonly pathByName = new Map<string, string>();\n\n  private readonly _dirPath: string;\n\n  constructor(dirPath: string, argv: EnvReaderOptions, loadEnv: boolean) {\n    this._dirPath = path.resolve(dirPath);\n    this.argv = argv;\n    this.loadEnv = loadEnv;\n  }\n\n  @memoizeOne\n  get isBunAvailable(): boolean {\n    if (this.hasBunToolVersion()) return true;\n    return this.usesBunPackageManager;\n  }\n\n  @memoizeOne\n  get usesBunPackageManager(): boolean {\n    if (this.hasBunLockfile()) return true;\n    return this.hasBunPackageManager();\n  }\n\n  private hasBunToolVersion(): boolean {\n    try {\n      return /(^|\\n)bun\\s/.test(fs.readFileSync(path.join(this.rootDirPath, '.tool-versions'), 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  private hasBunLockfile(): boolean {\n    // Some repositories rely on the lockfile or packageManager field instead of mise.\n    // Docker optimization must follow the target project, not the runtime that launched wb.\n    return ['bun.lock', 'bun.lockb'].some((fileName) => fs.existsSync(path.join(this.rootDirPath, fileName)));\n  }\n\n  private hasBunPackageManager(): boolean {\n    const packageManager = this.rootPackageJson?.packageManager ?? this.packageJson.packageManager;\n    return typeof packageManager === 'string' && packageManager.startsWith('bun@');\n  }\n\n  @memoizeOne\n  get buildCommand(): string {\n    return this.packageJson.scripts?.build?.includes('buildIfNeeded')\n      ? 'YARN run build'\n      : this.packageJson.scripts?.build\n        ? `YARN wb buildIfNeeded ${this.argv.verbose ? '--verbose' : ''}`\n        : \"echo 'No build script'\";\n  }\n\n  get dirPath(): string {\n    return this._dirPath;\n  }\n\n  @memoizeOne\n  get rootDirPath(): string {\n    return fs.existsSync(path.join(this.dirPath, '..', '..', 'package.json'))\n      ? path.resolve(this.dirPath, '..', '..')\n      : this.dirPath;\n  }\n\n  @memoizeOne\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoizeOne\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoizeOne\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoizeOne\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoizeOne\n  get env(): Record<string, string | undefined> {\n    if (!this.loadEnv) return process.env;\n\n    const [envVars, envPathAndLoadedEnvVarCountPairs] = readEnvironmentVariables(this.argv, this.dirPath);\n    for (const [envPath, count] of envPathAndLoadedEnvVarCountPairs) {\n      console.info(`Loaded ${count} environment variables from ${envPath}`);\n    }\n    return { ...envVars, ...process.env };\n  }\n\n  @memoizeOne\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8')) as PackageJson;\n  }\n\n  @memoizeOne\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoizeOne\n  get hasPrisma(): boolean {\n    return !!this.getOwnDependencyVersion('prisma');\n  }\n\n  @memoizeOne\n  get hasDrizzle(): boolean {\n    return !!this.getOwnDependencyVersion('drizzle-orm');\n  }\n\n  @memoizeOne\n  get databaseOrm(): DatabaseOrm | undefined {\n    if (this.hasPrisma) return 'prisma';\n    if (this.hasDrizzle) return 'drizzle';\n    return;\n  }\n\n  @memoizeOne\n  get hasVitest(): boolean {\n    return !!(this.packageJson.dependencies?.vitest ?? this.packageJson.devDependencies?.vitest);\n  }\n\n  @memoizeOne\n  get hasOxlint(): boolean {\n    return this.hasDependency('oxlint');\n  }\n\n  @memoizeOne\n  get hasOxfmt(): boolean {\n    return this.hasDependency('oxfmt');\n  }\n\n  @memoizeOne\n  get hasPrettier(): boolean {\n    return this.hasDependency('prettier');\n  }\n\n  @memoizeOne\n  get hasPoetryLock(): boolean {\n    return (\n      fs.existsSync(path.join(this.dirPath, 'poetry.lock')) || fs.existsSync(path.join(this.rootDirPath, 'poetry.lock'))\n    );\n  }\n\n  @memoizeOne\n  get hasPubspecYaml(): boolean {\n    return (\n      fs.existsSync(path.join(this.dirPath, 'pubspec.yaml')) ||\n      fs.existsSync(path.join(this.rootDirPath, 'pubspec.yaml'))\n    );\n  }\n\n  @memoizeOne\n  get preferredLinter(): 'oxlint' | undefined {\n    if (this.hasOxlint) return 'oxlint';\n    return;\n  }\n\n  hasOwnDependency(packageName: string): boolean {\n    return !!this.getOwnDependencyVersion(packageName);\n  }\n\n  @memoizeOne\n  get hasPlaywrightConfig(): boolean {\n    try {\n      return !!this.findFile('playwright.config.ts');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get skipLaunchingServerForPlaywright(): boolean {\n    if (isCI(this.env.CI)) return false;\n    try {\n      const configPath = this.findFile('playwright.config.ts');\n      return /\\bwebServer\\b/.test(fs.readFileSync(configPath, 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : (JSON.parse(\n          fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8')\n        ) as PackageJson);\n  }\n\n  @memoizeOne\n  get binExists(): boolean {\n    let binFound = false;\n    let currentPath = this.dirPath;\n    for (;;) {\n      const binPath = path.join(currentPath, 'node_modules', '.bin');\n      if (fs.existsSync(binPath)) {\n        this.env.PATH = `${binPath}:${this.env.PATH}`;\n        binFound = true;\n      }\n\n      if (fs.existsSync(path.join(currentPath, '.git'))) {\n        break;\n      }\n      const parentPath = path.dirname(currentPath);\n      if (currentPath === parentPath) {\n        break;\n      }\n      currentPath = parentPath;\n    }\n    return binFound;\n  }\n\n  findFile(fileName: string): string {\n    let filePath = this.pathByName.get(fileName);\n    if (filePath) return filePath;\n\n    filePath = [fileName, path.join('..', '..', fileName)]\n      .map((p) => path.resolve(this.dirPath, p))\n      .find((p) => fs.existsSync(p));\n    if (!filePath) {\n      throw new Error(`File not found: ${fileName}`);\n    }\n    this.pathByName.set(fileName, filePath);\n    return filePath;\n  }\n\n  private hasDependency(packageName: string): boolean {\n    return !!(\n      this.getOwnDependencyVersion(packageName) ?? this.getDependencyVersion(this.rootPackageJson, packageName)\n    );\n  }\n\n  private getOwnDependencyVersion(packageName: string): string | undefined {\n    return this.getDependencyVersion(this.packageJson, packageName);\n  }\n\n  private getDependencyVersion(packageJson: PackageJson | undefined, packageName: string): string | undefined {\n    if (!packageJson) return;\n\n    return (\n      packageJson.dependencies?.[packageName] ??\n      packageJson.devDependencies?.[packageName] ??\n      packageJson.optionalDependencies?.[packageName] ??\n      packageJson.peerDependencies?.[packageName]\n    );\n  }\n\n  @memoizeOne\n  private get rootPackageJson(): PackageJson | undefined {\n    if (this.rootDirPath === this.dirPath) return this.packageJson;\n\n    try {\n      return JSON.parse(fs.readFileSync(path.join(this.rootDirPath, 'package.json'), 'utf8')) as PackageJson;\n    } catch (error) {\n      console.error(`[wb] Failed to read or parse ${path.join(this.rootDirPath, 'package.json')}`, error);\n      return;\n    }\n  }\n}\n\nexport interface FoundProjects {\n  root: Project;\n  self: Project;\n  descendants: Project[];\n}\n\nexport function findSelfProject(argv: EnvReaderOptions, loadEnv = true, dirPath?: string): Project | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  return new Project(dirPath, argv, loadEnv);\n}\n\nexport async function findDescendantProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Promise<FoundProjects | undefined> {\n  const rootAndSelfProjects = findRootAndSelfProjects(argv, loadEnv, dirPath);\n  if (!rootAndSelfProjects) return;\n\n  return {\n    ...rootAndSelfProjects,\n    descendants:\n      rootAndSelfProjects.root === rootAndSelfProjects.self\n        ? await getAllDescendantProjects(argv, rootAndSelfProjects.root, loadEnv)\n        : [rootAndSelfProjects.self],\n  };\n}\n\nexport function findRootAndSelfProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Omit<FoundProjects, 'descendants'> | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  const thisProject = new Project(dirPath, argv, loadEnv);\n  let rootProject = thisProject;\n  if (!thisProject.packageJson.workspaces && path.dirname(dirPath).endsWith('/packages')) {\n    const rootDirPath = path.resolve(dirPath, '..', '..');\n    if (fs.existsSync(path.join(rootDirPath, 'package.json'))) {\n      rootProject = new Project(rootDirPath, argv, loadEnv);\n    }\n  }\n  return { root: rootProject, self: thisProject };\n}\n\nasync function getAllDescendantProjects(\n  argv: EnvReaderOptions,\n  rootProject: Project,\n  loadEnv: boolean\n): Promise<Project[]> {\n  const projects = [rootProject];\n\n  const workspace = rootProject.packageJson.workspaces;\n  if (!Array.isArray(workspace)) return projects;\n\n  const globPattern: string[] = [];\n  const packageDirs: string[] = [];\n  for (const workspacePath of workspace.map((ws: string) => path.join(rootProject.dirPath, ws))) {\n    if (fs.existsSync(workspacePath)) {\n      packageDirs.push(workspacePath);\n    } else {\n      globPattern.push(workspacePath);\n    }\n  }\n  packageDirs.push(...(await globby(globPattern, { dot: true, onlyDirectories: true })));\n  for (const subPackageDirPath of packageDirs) {\n    if (!fs.existsSync(path.join(subPackageDirPath, 'package.json'))) continue;\n\n    projects.push(new Project(subPackageDirPath, argv, loadEnv));\n  }\n  return projects;\n}\n","export const isRunningOnBun =\n  // Detect `bun --bun run wb ...`. cf. https://bun.sh/guides/util/detect-bun\n  process.versions.bun ||\n  // Detect `bun run wb ...`.\n  process.argv[0]?.endsWith('/bun') ||\n  process.env.npm_execpath?.endsWith('/bun');\n\nexport const runtimeWithArgs = isRunningOnBun ? 'bun --bun run' : 'node';\nexport const packageManager = isRunningOnBun ? 'bun' : 'yarn';\nexport const packageManagerWithRun = isRunningOnBun ? 'bun --bun run' : 'yarn';\n","import child_process from 'node:child_process';\nimport type { BinaryLike, Hash } from 'node:crypto';\nimport { createHash } from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport { ignoreEnoentAsync } from '@willbooster/shared-lib/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  command: {\n    description: 'A build command (default: yarn|bun build)',\n    type: 'string',\n    alias: 'c',\n  },\n} as const;\n\nexport const buildIfNeededCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'buildIfNeeded',\n  describe: 'Build code if changes are detected',\n  builder,\n  async handler(argv) {\n    await buildIfNeeded(argv);\n  },\n};\n\nexport async function buildIfNeeded(\n  // Test code requires Partial<...>\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>>>,\n  projectPathForTesting?: string\n): Promise<boolean | undefined> {\n  const project = findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\n\n  const buildCommand =\n    argv.command ??\n    (project.packageJson.scripts?.build ? (isRunningOnBun ? 'bun run build' : 'yarn build') : undefined);\n  if (!buildCommand) {\n    console.info(chalk.green('Skip to build because no build command is defined.'));\n    return false;\n  }\n  argv = { ...argv, command: buildCommand };\n\n  if (!fs.existsSync(path.join(project.rootDirPath, '.git'))) {\n    build(project, argv);\n    return true;\n  }\n\n  const [canSkip, cacheFilePath, contentHash] = await canSkipBuild(project, argv);\n  if (canSkip) {\n    console.info(chalk.green(`Skip to run '${argv.command}' 💫`));\n    return false;\n  }\n\n  if (!build(project, argv)) return;\n\n  if (!argv.dryRun) {\n    await fs.promises.writeFile(cacheFilePath, contentHash, 'utf8');\n  }\n  return true;\n}\n\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  console.info(chalk.green(`Run '${argv.command}'`));\n  if (!argv.dryRun) {\n    const ret = child_process.spawnSync(argv.command ?? '', {\n      cwd: project.dirPath,\n      env: project.env,\n      shell: true,\n      stdio: 'inherit',\n    });\n    if (ret.status !== 0) {\n      process.exitCode = ret.status ?? 1;\n      return false;\n    }\n  }\n  return true;\n}\n\nconst ignoringEnvVarNames = new Set(['CI', 'PWDEBUG', 'TMPDIR']);\n\nexport async function canSkipBuild(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>\n): Promise<[boolean, string, string]> {\n  const cacheDirectoryPath = path.resolve(project.dirPath, 'node_modules', '.cache', 'build');\n  const cacheFilePath = path.resolve(cacheDirectoryPath, 'last-build');\n  await fs.promises.mkdir(cacheDirectoryPath, { recursive: true });\n\n  const hash = createHash('sha256');\n\n  const commitHash = child_process.execSync('git rev-parse HEAD', { cwd: project.dirPath }).toString().trim();\n  hash.update(commitHash);\n\n  const environmentJson = JSON.stringify(\n    Object.entries(project.env)\n      .filter(([key]) => !ignoringEnvVarNames.has(key))\n      .toSorted(([key1], [key2]) => key1.localeCompare(key2))\n  );\n  hash.update(environmentJson);\n\n  await updateHashWithDiffResult(project, argv, hash);\n  const contentHash = hash.digest('hex');\n\n  const cachedContentHash = await ignoreEnoentAsync(() => fs.promises.readFile(cacheFilePath, 'utf8'));\n  return [cachedContentHash === contentHash, cacheFilePath, contentHash];\n}\n\nconst includePatterns = ['src/', 'public/'];\nconst includeSuffix = [\n  '.js',\n  '.cjs',\n  '.mjs',\n  '.jsx',\n  '.ts',\n  '.cts',\n  '.mts',\n  '.tsx',\n  '.json',\n  '.browserslistrc',\n  // Because some build commands affected by changes in `package.json`\n  'package.json',\n  'yarn.lock',\n];\nconst excludePatterns = ['test/', 'tests/', '__tests__/', 'test-fixtures/', 'test/fixtures/'];\n\nasync function updateHashWithDiffResult(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  hash: Hash\n): Promise<void> {\n  return new Promise((resolve) => {\n    const ret = child_process.spawnSync('git', ['status', '--porcelain'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const lines = ret.stdout\n      .trim()\n      .split('\\n')\n      .filter((line) => line.length > 0);\n    const filePaths = lines\n      .map((line) => line.slice(2).trim())\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/wb\\/test\\/fixtures\\/[^/]+\\//, '') : filePath\n      );\n    const filteredFilePaths = filePaths.filter(\n      (filePath) =>\n        (includePatterns.some((pattern) => filePath.includes(pattern)) ||\n          includeSuffix.some((suffix) => filePath.endsWith(suffix))) &&\n        !excludePatterns.some((pattern) => filePath.includes(pattern))\n    );\n    if (argv.verbose) {\n      console.info(`Changed files: ${filteredFilePaths.join(', ')}`);\n    }\n\n    // 'git diff --' works only on rootDirPath\n    const proc = child_process.spawn('git', ['diff', '--', ...filteredFilePaths], { cwd: project.rootDirPath });\n    proc.stdout.on('data', (data: BinaryLike) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info('Data:', data);\n        console.info('Hash:', hash.copy().digest('hex'));\n      }\n    });\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n","import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n  if (obj instanceof Error) return obj;\n  if (typeof obj === 'string') return new Error(obj);\n  try {\n    return new Error(JSON.stringify(obj));\n  } catch {\n    return new Error(String(obj));\n  }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport interface RetryOptions {\n  beforeRetry?: (error: unknown) => Promise<void>;\n  handleError?: (error: unknown) => Promise<void>;\n  /**\n   * The maximum number of total attempts, including the initial attempt.\n   * For example, `retryCount: 3` runs the function at most 3 times: 1 initial attempt and up to 2 retries.\n   */\n  retryCount?: number;\n  retryLogger?: (message: string) => void;\n  shouldRetry?: (error: unknown) => boolean;\n  sleepMilliseconds?: number;\n  updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of total attempts, including the initial attempt.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n  func: (failedCount: number) => T | Promise<T>,\n  {\n    beforeRetry,\n    handleError,\n    retryCount = 3,\n    retryLogger,\n    shouldRetry,\n    sleepMilliseconds = 0,\n    updateSleepMilliseconds,\n  }: RetryOptions = {}\n): Promise<T> {\n  let failedCount = 0;\n  for (;;) {\n    try {\n      return await func(failedCount);\n    } catch (error) {\n      await handleError?.(error);\n      failedCount++;\n      if (failedCount >= retryCount) {\n        throw error;\n      }\n      if (shouldRetry && !shouldRetry(error)) {\n        throw error;\n      }\n      if (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      if (updateSleepMilliseconds) {\n        sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n","import { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\n  onSignal?: (signal: NodeJS.Signals | null) => void;\n  forceColor?: boolean;\n  processSilentOutput?: (output: string) => string;\n  printRawOutput?: boolean;\n  timeout?: number;\n}\n\nconst defaultOptions: Options = {\n  exitIfFailed: true,\n};\n\nexport interface BufferedRunResult {\n  exitCode: number;\n  output: string;\n}\n\nexport async function runWithSpawn(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>> & { silent?: boolean },\n  opts: Options = defaultOptions\n): Promise<number> {\n  const normalizedScript = normalizeScript(script, project);\n  printStart(normalizedScript.printable, project, argv.silent ? 'Command' : 'Start');\n  if (argv.verbose) {\n    printStart(normalizedScript.runnable, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts, { silentSuccess: argv.silent });\n    return 0;\n  }\n\n  const shouldProcessSilentOutput = Boolean(argv.silent && opts.processSilentOutput);\n  const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, opts),\n    shell: true,\n    stdio: argv.silent ? 'pipe' : 'inherit',\n    timeout: opts.timeout,\n    mergeOutAndError: shouldProcessSilentOutput,\n    killOnExit: true,\n    printingStdout: argv.silent && !shouldProcessSilentOutput,\n    printingStderr: argv.silent && !shouldProcessSilentOutput,\n    omitBlankLinesWhilePrinting: argv.silent,\n    verbose: argv.verbose,\n  });\n  if (shouldProcessSilentOutput) {\n    const output = opts.processSilentOutput?.(ret.stdout).trim();\n    if (output) {\n      process.stdout.write(output);\n      process.stdout.write('\\n');\n    }\n  }\n  opts.onSignal?.(ret.signal);\n  printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts, { silentSuccess: argv.silent });\n  return ret.status ?? 1;\n}\n\nexport function runWithSpawnInParallel(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    printStart(normalizedScript.printable, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(normalizedScript.printable, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      printingStdout: opts.printRawOutput,\n      printingStderr: opts.printRawOutput,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    printStart(normalizedScript.printable, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n    }\n    const out = ret.stdout.trim();\n    if (out && !opts.printRawOutput) {\n      process.stdout.write(out);\n      process.stdout.write('\\n');\n    }\n    printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n    return ret.status ?? 1;\n  });\n}\n\nexport function runWithSpawnInParallelBuffered(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<BufferedRunResult> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    if (argv.dryRun) {\n      return {\n        exitCode: 0,\n        output: '',\n      };\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      printingStdout: opts.printRawOutput,\n      printingStderr: opts.printRawOutput,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    return {\n      exitCode: ret.status ?? 1,\n      output: ret.stdout,\n    };\n  });\n}\n\n/**\n * Replace capitalized commands (e.g., YARN, PRISMA, BUN) with suitable commands.\n */\nexport function normalizeScript(script: string, project: Project): { printable: string; runnable: string } {\n  const projectPackageManagerWithRun = project.usesBunPackageManager ? 'bun --bun run' : 'yarn';\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\n    .replaceAll(\n      'PRISMA generate ',\n      project.packageJson.dependencies?.blitz ? 'PRISMA generate ' : 'PRISMA generate --no-hints '\n    )\n    .replaceAll('PRISMA ', project.packageJson.dependencies?.blitz ? 'YARN blitz prisma ' : 'YARN prisma ')\n    .replaceAll('BUN run ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'YARN run ')\n    .replaceAll('BUN ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'YARN ')\n    // Avoid replacing `YARN run` with `run` by replacing `YARN` with `(yarn|bun --bun) run`.\n    .replaceAll('YARN run ', project.usesBunPackageManager ? `${projectPackageManagerWithRun} ` : 'yarn run ');\n  if (project.usesBunPackageManager) {\n    newScript = newScript\n      .replaceAll('YARN build-ts run', 'bun --bun run')\n      .replaceAll('bun --bun run bun --bun run', 'bun --bun run')\n      // Because bun can run src/index.ts directly.\n      .replaceAll('dist/index.js', 'src/index.ts');\n  }\n  newScript = newScript.trim();\n  const printableScript = fixBunCommand(newScript.replaceAll('YARN ', `${projectPackageManagerWithRun} `));\n  const runnableScript = fixBunCommand(\n    newScript\n      // Keep Playwright as a package-manager command instead of resolving it through node_modules/.bin.\n      .replaceAll('YARN playwright ', `${projectPackageManagerWithRun} playwright `)\n      .replaceAll(\n        'YARN ',\n        !project.usesBunPackageManager && project.binExists ? '' : `${projectPackageManagerWithRun} `\n      )\n  );\n  // Add cascade option when WB_ENV is defined\n  const cascadeOption = project.env.WB_ENV ? ` -c=${project.env.WB_ENV || 'development'}` : '';\n  return {\n    printable: `${projectPackageManagerWithRun} dotenv${cascadeOption} -- ${printableScript}`,\n    runnable: runnableScript,\n  };\n}\n\nexport function printStart(normalizedScript: string, project: Project, prefix = 'Start', weak = false): void {\n  console.info(\n    '\\n' +\n      (weak ? chalk.gray : chalk.cyan)(chalk.bold(`${prefix}:`), normalizedScript) +\n      chalk.gray(` at ${project.dirPath}`)\n  );\n}\n\nexport function printFinishedAndExitIfNeeded(\n  script: string,\n  exitCode: number | null,\n  opts: Omit<Options, 'timeout'>,\n  printOptions: { silentSuccess?: boolean } = {}\n): void {\n  if (exitCode === 0) {\n    if (printOptions.silentSuccess) return;\n    console.info(chalk.green(chalk.bold('Finished:'), script));\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}): `), script));\n    if (opts.exitIfFailed !== false) {\n      process.exit(exitCode ?? 1);\n    }\n  }\n}\n\nexport function configureEnv(\n  env: Record<string, string | undefined>,\n  opts: Options\n): Record<string, string | undefined> {\n  const newEnv = { ...env };\n  if (opts.ci) {\n    newEnv.CI = '1';\n  }\n  if (opts.forceColor) {\n    newEnv.FORCE_COLOR = '3';\n  }\n  return newEnv;\n}\n\nfunction fixBunCommand(command: string): string {\n  // cf. https://github.com/oven-sh/bun/issues/14359\n  return command.includes('next dev') ||\n    // cf. https://github.com/oven-sh/bun/issues/8222\n    command.includes('playwright') ||\n    // \"bun --bun prisma generate\" doesn't work\n    command.includes('prisma') ||\n    command.includes('test/e2e-additional')\n    ? command.replaceAll('bun --bun', 'bun')\n    : command;\n}\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node/src';\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  // This option is for debugging mainly.\n  'working-dir': {\n    description: 'A working directory',\n    type: 'string',\n    alias: 'w',\n  },\n  'dry-run': {\n    description: 'Whether to skip actual command execution',\n    type: 'boolean',\n    alias: ['dry', 'd'],\n  },\n} as const;\n\nexport function buildEnvReaderOptionArgs(argv: EnvReaderOptions): string[] {\n  const args: string[] = [];\n  for (const optionName of Object.keys(yargsOptionsBuilderForEnv)) {\n    const value = getOptionValue(argv, optionName);\n    if (value === undefined) continue;\n\n    if (typeof value === 'boolean') {\n      args.push(value ? `--${optionName}` : `--${optionName}=false`);\n      continue;\n    }\n    if (typeof value === 'string' || typeof value === 'number') {\n      args.push(`--${optionName}=${value}`);\n      continue;\n    }\n    if (Array.isArray(value)) {\n      for (const item of value) {\n        args.push(`--${optionName}=${item}`);\n      }\n    }\n  }\n  return args;\n}\n\nfunction getOptionValue(argv: EnvReaderOptions, optionName: string): unknown {\n  const camelCaseOptionName = optionName.replaceAll(/-([a-z])/g, (_, character: string) => character.toUpperCase());\n  const options = argv as Record<string, unknown>;\n  return options[optionName] ?? options[camelCaseOptionName];\n}\n","import child_process from 'node:child_process';\nimport { constants } from 'node:os';\n\nimport { treeKill } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject, type Project } from '../project.js';\nimport { configureEnv, normalizeScript } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst FORCE_KILL_DELAY_MS = 5000;\n\nconst builder = {\n  'kill-others': {\n    description: 'Kill other commands when one command exits',\n    type: 'boolean',\n  },\n  'kill-others-on-fail': {\n    description: 'Kill other commands when one command fails',\n    type: 'boolean',\n  },\n  success: {\n    description: 'Define successful completion criteria',\n    type: 'string',\n    choices: ['all', 'first'],\n    default: 'all',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  commands: {\n    description: 'Commands to run concurrently',\n    type: 'array',\n  },\n} as const;\n\ninterface RunConcurrentlyOptions {\n  commands: string[];\n  project: Project;\n  killOthers: boolean;\n  killOthersOnFail: boolean;\n  success: 'all' | 'first';\n  ci?: boolean;\n  forceColor?: boolean;\n}\n\nexport const concurrentlyCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof argumentsBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'concurrently <commands...>',\n  describe: 'Run commands concurrently',\n  builder: { ...sharedOptionsBuilder, ...builder, ...argumentsBuilder },\n  async handler(argv) {\n    if (process.platform === 'win32') {\n      console.error(chalk.red('This command is not supported on Windows.'));\n      process.exit(1);\n    }\n\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const commands = (argv.commands ?? []).map(String).filter(Boolean);\n    if (commands.length === 0) {\n      console.error(chalk.red('No commands provided.'));\n      process.exit(1);\n    }\n\n    try {\n      const exitCode = await runConcurrently({\n        commands,\n        project,\n        killOthers: argv.killOthers ?? false,\n        killOthersOnFail: argv.killOthersOnFail ?? false,\n        success: argv.success,\n        ci: typeof argv.ci === 'boolean' ? argv.ci : undefined,\n        forceColor: typeof argv.forceColor === 'boolean' ? argv.forceColor : undefined,\n      });\n      process.exit(exitCode);\n    } catch (error) {\n      console.error(chalk.red(error instanceof Error ? error.message : String(error)));\n      process.exit(1);\n    }\n  },\n};\n\nexport async function runConcurrently(options: RunConcurrentlyOptions): Promise<number> {\n  const children = options.commands.map((command) =>\n    child_process.spawn(normalizeScript(command, options.project).runnable, {\n      cwd: options.project.dirPath,\n      detached: true,\n      env: configureEnv(options.project.env, { ci: options.ci, forceColor: options.forceColor }),\n      shell: true,\n      stdio: 'inherit',\n    })\n  );\n\n  let stopping = false;\n  let interruptedSignal: NodeJS.Signals | undefined;\n  let firstResult: number | undefined;\n  let stopResult: number | undefined;\n  const forceKillPromises: Promise<void>[] = [];\n  const results = Array.from<number | undefined>({ length: children.length });\n  const waitForExitPromises = children.map((child, index) => {\n    return new Promise<void>((resolve) => {\n      let settled = false;\n      const settle = (exitCode: number): void => {\n        if (settled) return;\n\n        settled = true;\n        results[index] = exitCode;\n        firstResult ??= exitCode;\n\n        if (!stopping && shouldStopOthers(exitCode, options)) {\n          stopResult = exitCode;\n          stopping = true;\n          forceKillPromises.push(terminateChildren(children, 'SIGTERM'));\n        }\n        resolve();\n      };\n\n      child.once('error', (error) => {\n        console.error('Failed to start child process:', error);\n        settle(1);\n      });\n      child.once('exit', (code, signal) => {\n        settle(getExitCode(code ?? undefined, signal ?? undefined));\n      });\n    });\n  });\n\n  const stopAll = (signal: NodeJS.Signals): void => {\n    interruptedSignal ??= signal;\n    if (stopping) return;\n\n    stopping = true;\n    forceKillPromises.push(terminateChildren(children, signal));\n  };\n  const stopOnSigint = (): void => {\n    stopAll('SIGINT');\n  };\n  const stopOnSigterm = (): void => {\n    stopAll('SIGTERM');\n  };\n  const stopOnSigquit = (): void => {\n    stopAll('SIGQUIT');\n  };\n  process.on('SIGINT', stopOnSigint);\n  process.on('SIGTERM', stopOnSigterm);\n  process.on('SIGQUIT', stopOnSigquit);\n  try {\n    await Promise.all(waitForExitPromises);\n    await Promise.all(forceKillPromises);\n  } finally {\n    process.removeListener('SIGINT', stopOnSigint);\n    process.removeListener('SIGTERM', stopOnSigterm);\n    process.removeListener('SIGQUIT', stopOnSigquit);\n  }\n\n  if (interruptedSignal) {\n    return getExitCode(undefined, interruptedSignal);\n  }\n\n  if (options.success === 'first') {\n    return firstResult ?? 1;\n  }\n  if (stopResult !== undefined) {\n    return stopResult;\n  }\n  for (const result of results) {\n    if (result !== undefined && result !== 0) {\n      return result;\n    }\n  }\n  return 0;\n}\n\nfunction getExitCode(code: number | undefined, signal: NodeJS.Signals | undefined): number {\n  if (code !== undefined) {\n    return code;\n  }\n  if (signal && signal in constants.signals) {\n    return 128 + constants.signals[signal];\n  }\n  return 1;\n}\n\nfunction shouldStopOthers(\n  exitCode: number,\n  options: Pick<RunConcurrentlyOptions, 'killOthers' | 'killOthersOnFail' | 'success'>\n): boolean {\n  return options.success === 'first' || options.killOthers || (options.killOthersOnFail && exitCode !== 0);\n}\n\nasync function terminateChildren(children: child_process.ChildProcess[], signal: NodeJS.Signals): Promise<void> {\n  const forceKillPids = signalPids(toChildPids(children), signal);\n  if (forceKillPids.length === 0) return;\n\n  if (await waitForForceKill(forceKillPids)) {\n    signalPids(forceKillPids, 'SIGKILL');\n  }\n}\n\nfunction toChildPids(children: child_process.ChildProcess[]): number[] {\n  return children.flatMap((child) => (child.pid === undefined ? [] : [child.pid]));\n}\n\nfunction signalPids(pids: readonly number[], signal: NodeJS.Signals): number[] {\n  const signaledPids: number[] = [];\n  for (const pid of pids) {\n    try {\n      if (!killProcessGroup(pid, signal)) continue;\n\n      signaledPids.push(pid);\n      treeKill(pid, signal);\n    } catch (error) {\n      console.warn('Failed to kill child process:', error);\n    }\n  }\n  return signaledPids;\n}\n\nasync function waitForForceKill(pids: readonly number[]): Promise<boolean> {\n  const deadline = Date.now() + FORCE_KILL_DELAY_MS;\n  while (Date.now() < deadline) {\n    if (pids.every(isProcessGroupGone)) return false;\n\n    await sleep(Math.min(100, deadline - Date.now()));\n  }\n  return true;\n}\n\nfunction isProcessGroupGone(pid: number): boolean {\n  try {\n    process.kill(-pid, 0);\n    return false;\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return true;\n    }\n    return false;\n  }\n}\n\nasync function sleep(ms: number): Promise<void> {\n  await new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nfunction killProcessGroup(pid: number, signal: NodeJS.Signals): boolean {\n  try {\n    process.kill(-pid, signal);\n    return true;\n  } catch (error) {\n    if (isNoSuchProcessError(error)) {\n      return false;\n    }\n    throw error;\n  }\n}\n\nfunction isNoSuchProcessError(error: unknown): boolean {\n  return typeof error === 'object' && error !== null && 'code' in error && error.code === 'ESRCH';\n}\n","import chalk from 'chalk';\nimport killPortProcess from 'kill-port';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isCI } from '../utils/ci.js';\n\nconst killPortIfNonCiBuilder = {} as const;\n\nexport const killPortIfNonCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'kill-port-if-non-ci',\n  describe: 'Kill the port specified by PORT environment variable if non-CI.',\n  builder: killPortIfNonCiBuilder,\n  async handler(argv) {\n    await killPortIfNonCi(argv);\n  },\n};\n\nexport async function killPortIfNonCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const project = findSelfProject(argv);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (isCI(project.env.CI)) {\n    console.info(`Skip killing port due to CI: ${project.env.CI}`);\n    return;\n  }\n\n  const portEnv = project.env.PORT;\n  const port = Number(portEnv);\n  if (!Number.isInteger(port) || port <= 0) {\n    console.error(chalk.red(`PORT environment variable is invalid: ${portEnv}`));\n    process.exit(1);\n  }\n\n  console.info(`Killing the port: ${port}`);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n","export function printBufferedOutput(exitCode: number, output: string): void {\n  if (!shouldPrintBufferedOutput(exitCode, output)) return;\n\n  const normalizedOutput = normalizeBufferedOutput(output);\n  if (normalizedOutput) {\n    process.stdout.write(normalizedOutput);\n    process.stdout.write('\\n');\n  }\n}\n\nexport function shouldPrintBufferedOutput(exitCode: number, output: string): boolean {\n  return exitCode !== 0 || hasWarningOutput(removeNoColorWarning(output));\n}\n\nexport function normalizeBufferedOutput(output: string): string {\n  return removeNoColorWarning(output).trim();\n}\n\nfunction hasWarningOutput(output: string): boolean {\n  return /\\bwarn(?:ing)?s?\\b/i.test(output.replaceAll(/\\b(?:0|no) warnings?\\b/gi, ''));\n}\n\nfunction removeNoColorWarning(output: string): string {\n  return output.replaceAll(\n    /\\(node:\\d+\\) Warning: The 'NO_COLOR' env is ignored due to the 'FORCE_COLOR' env being set\\.\\n\\(Use `node --trace-warnings \\.\\.\\.` to show where the warning was created\\)\\n?/g,\n    ''\n  );\n}\n","export function buildShellCommand(args: string[]): string {\n  return args.map((arg) => shellEscapeArgument(arg)).join(' ');\n}\n\nexport function buildShellEnvironmentAssignment(name: string, value: string): string {\n  return `${name}=${shellEscapeArgument(value)}`;\n}\n\nexport function shellEscapeArgument(arg: string): string {\n  return /^[\\w./:=,@%+-]+$/u.test(arg) ? arg : `'${arg.replaceAll(\"'\", `'\"'\"'`)}'`;\n}\n","import fs from 'node:fs/promises';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { BufferedRunResult } from '../scripts/run.js';\nimport { normalizeScript, runWithSpawnInParallel, runWithSpawnInParallelBuffered } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { printBufferedOutput } from '../utils/output.js';\nimport { buildShellCommand } from '../utils/shell.js';\n\nconst builder = {\n  fix: {\n    description: 'Fix the linting errors',\n    type: 'boolean',\n  },\n  format: {\n    description: 'Format the code',\n    type: 'boolean',\n  },\n  quiet: {\n    description: 'Report errors only',\n    type: 'boolean',\n  },\n  silent: {\n    description: 'Print only failed or warning command output',\n    type: 'boolean',\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  files: {\n    description: 'File and directory paths to lint',\n    type: 'array',\n  },\n} as const;\n\nexport type LintCommandOptions = InferredOptionTypes<\n  typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder\n>;\nexport type LintCommandArgv = ArgumentsCamelCase<LintCommandOptions> & {\n  '--'?: unknown[];\n  _: unknown[];\n  printAllOutput?: boolean;\n};\n\nconst oxlintExtensions = new Set(['astro', 'cjs', 'cts', 'js', 'jsx', 'mjs', 'mts', 'svelte', 'ts', 'tsx', 'vue']);\nconst pythonExtensions = new Set(['py']);\nconst dartExtensions = new Set(['dart']);\nconst oxfmtExtensions = new Set([\n  ...oxlintExtensions,\n  'css',\n  'gql',\n  'graphql',\n  'hbs',\n  'htm',\n  'html',\n  'json',\n  'json5',\n  'jsonc',\n  'less',\n  'md',\n  'mdx',\n  'scss',\n  'toml',\n  'yaml',\n  'yml',\n]);\nconst prettierExtensions = new Set([\n  'cjs',\n  'css',\n  'cts',\n  'htm',\n  'html',\n  'java',\n  'js',\n  'json',\n  'json5',\n  'jsonc',\n  'jsx',\n  'md',\n  'mjs',\n  'mts',\n  'scss',\n  'ts',\n  'tsx',\n  'vue',\n  'yaml',\n  'yml',\n]);\nconst prettierOnlyExtensions = new Set([...prettierExtensions].filter((ext) => !oxfmtExtensions.has(ext)));\nconst prettierFixtureIgnorePattern = '!**/test{-,/}fixtures/**';\n\ntype BufferedLintRunResult = BufferedRunResult & { command: string; cwd: string };\ntype LintRunResult = BufferedLintRunResult | { exitCode: number };\n\nexport const lintCommand: CommandModule<unknown, LintCommandOptions> = {\n  command: 'lint [files...]',\n  describe: 'Lint code',\n  builder,\n  async handler(argv) {\n    const exitCode = await lint(argv as LintCommandArgv);\n    if (exitCode) process.exit(exitCode);\n  },\n};\n\nexport async function lint(argv: LintCommandArgv): Promise<number> {\n  if (process.platform === 'win32') {\n    console.error(chalk.red('This command is not supported on Windows.'));\n    return 1;\n  }\n\n  const projects = await findDescendantProjects(argv, false);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    return 1;\n  }\n\n  const files = getLintTargetFiles(argv);\n  const lintFilePathsByProject = new Map<Project, string[]>();\n  const oxfmtFilePathsByProject = new Map<Project, string[]>();\n  const pythonFilePathsByProject = new Map<Project, string[]>();\n  const dartFilePathsByProject = new Map<Project, string[]>();\n  const prettierFilePaths: string[] = [];\n  const packageJsonFilePaths: string[] = [];\n  let missingLintToolForExplicitFiles = false;\n  let prettierArgs: string[];\n  let sortPackageJsonArgs: string[];\n  if (files.length > 0) {\n    const lintTargets = await Promise.all(\n      files.map(async (file) => {\n        const filePath = path.resolve(file);\n        const fileKind = await getLintTargetFileKind(filePath);\n        return { fileKind, filePath };\n      })\n    );\n    for (const { fileKind, filePath } of lintTargets) {\n      if (\n        filePath.endsWith('/test/fixtures') ||\n        filePath.includes('/test/fixtures/') ||\n        filePath.endsWith('/test-fixtures') ||\n        filePath.includes('/test-fixtures/')\n      ) {\n        continue;\n      }\n\n      const extension = path.extname(filePath).slice(1);\n      if (filePath.endsWith('/package.json')) {\n        packageJsonFilePaths.push(filePath);\n        continue;\n      }\n      packageJsonFilePaths.push(...getExplicitPackageJsonPaths(projects.descendants, filePath, fileKind));\n\n      for (const { lintPath, project } of getExplicitLintTargets(projects.descendants, filePath, fileKind)) {\n        if (project.hasPoetryLock && (fileKind === 'directory' || pythonExtensions.has(extension))) {\n          const pythonFilePaths = pythonFilePathsByProject.get(project) ?? [];\n          pythonFilePaths.push(lintPath);\n          pythonFilePathsByProject.set(project, pythonFilePaths);\n          if (fileKind !== 'directory') continue;\n        }\n        if (project.hasPubspecYaml && (fileKind === 'directory' || dartExtensions.has(extension))) {\n          const dartFilePaths = dartFilePathsByProject.get(project) ?? [];\n          dartFilePaths.push(lintPath);\n          dartFilePathsByProject.set(project, dartFilePaths);\n          if (fileKind !== 'directory') continue;\n        }\n        if (fileKind === 'directory' || supportsLintingExtension(project, extension)) {\n          const lintFilePaths = lintFilePathsByProject.get(project) ?? [];\n          lintFilePaths.push(lintPath);\n          lintFilePathsByProject.set(project, lintFilePaths);\n          if (argv.format) {\n            if (fileKind === 'directory' && project.hasOxfmt) {\n              const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n              oxfmtFilePaths.push(lintPath);\n              oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n              prettierFilePaths.push(buildPrettierOnlyDirectoryPattern(lintPath), prettierFixtureIgnorePattern);\n            } else {\n              for (const formatterPath of buildExplicitFormatterArgs(project, lintPath, fileKind, extension)) {\n                if (project.hasOxfmt) {\n                  const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n                  oxfmtFilePaths.push(formatterPath);\n                  oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n                } else {\n                  prettierFilePaths.push(formatterPath);\n                }\n              }\n            }\n          }\n        } else if (argv.format && (prettierExtensions.has(extension) || oxfmtExtensions.has(extension))) {\n          if (project.hasOxfmt && oxfmtExtensions.has(extension)) {\n            const oxfmtFilePaths = oxfmtFilePathsByProject.get(project) ?? [];\n            oxfmtFilePaths.push(lintPath);\n            oxfmtFilePathsByProject.set(project, oxfmtFilePaths);\n          } else if (prettierExtensions.has(extension)) {\n            prettierFilePaths.push(lintPath);\n          }\n        } else if (isPotentialLintTarget(extension) && !project.preferredLinter) {\n          console.error(chalk.red(`No linter found for ${project.name}. Install Oxlint.`));\n          missingLintToolForExplicitFiles = true;\n        }\n      }\n    }\n    prettierArgs = [...new Set(prettierFilePaths)];\n    sortPackageJsonArgs = [...new Set(packageJsonFilePaths)];\n  } else {\n    prettierArgs = buildPrettierArgs(projects.self.dirPath, projects.descendants);\n    sortPackageJsonArgs = projects.descendants.map((p) => p.packageJsonPath);\n  }\n\n  const lintPromises: Promise<LintRunResult>[] = [];\n  const lintRunOptions = { exitIfFailed: false, forceColor: !argv.printAllOutput } as const;\n  if (files.length > 0) {\n    for (const [project, lintFilePaths] of lintFilePathsByProject) {\n      const lintCommand = buildLintCommand(project, argv, lintFilePaths);\n      if (!lintCommand) continue;\n\n      lintPromises.push(runLintCommand(lintCommand, project, argv, lintRunOptions));\n    }\n    if (argv.format) {\n      for (const [project, oxfmtFilePaths] of oxfmtFilePathsByProject) {\n        lintPromises.push(runLintCommand(buildOxfmtCommand(oxfmtFilePaths), project, argv, lintRunOptions));\n      }\n    }\n    for (const [project, pythonFilePaths] of pythonFilePathsByProject) {\n      lintPromises.push(runLintCommand(buildPoetryCommand(argv, pythonFilePaths), project, argv, lintRunOptions));\n    }\n    for (const [project, dartFilePaths] of dartFilePathsByProject) {\n      lintPromises.push(runLintCommand(buildDartCommand(argv, dartFilePaths), project, argv, lintRunOptions));\n    }\n  } else {\n    for (const project of projects.descendants) {\n      if (project.packageJson.workspaces && !project.hasSourceCode) continue;\n\n      const lintCommand = buildLintCommand(project, argv);\n      if (!lintCommand) continue;\n\n      lintPromises.push(runLintCommand(lintCommand, project, argv, lintRunOptions));\n    }\n    for (const project of projects.descendants) {\n      if (project.hasPoetryLock) {\n        lintPromises.push(runLintCommand(buildPoetryCommand(argv), project, argv, lintRunOptions));\n      }\n      if (project.hasPubspecYaml) {\n        lintPromises.push(runLintCommand(buildDartCommand(argv), project, argv, lintRunOptions));\n      }\n      if (project.hasOxfmt && argv.format) {\n        lintPromises.push(runLintCommand(buildOxfmtCommand(), project, argv, lintRunOptions));\n      }\n    }\n  }\n  const lintResults = await Promise.all(lintPromises);\n  printSilentLintOutputs(lintResults, argv);\n  const lintExitCodes = lintResults.map((result) => result.exitCode);\n\n  if (missingLintToolForExplicitFiles || lintExitCodes.some((exitCode) => exitCode !== 0)) {\n    return 1;\n  }\n\n  if (argv.format) {\n    if (prettierArgs.length > 0 && projects.self.hasPrettier) {\n      const prettierResult = await runLintCommand(\n        buildShellCommand([\n          'YARN',\n          'prettier',\n          '--cache',\n          '--color',\n          '--no-error-on-unmatched-pattern',\n          '--write',\n          '--',\n          ...prettierArgs,\n        ]),\n        projects.self,\n        argv,\n        lintRunOptions\n      );\n      printSilentLintOutputs([prettierResult], argv);\n      lintExitCodes.push(prettierResult.exitCode);\n    }\n    if (sortPackageJsonArgs.length > 0) {\n      const sortPackageJsonResult = await runLintCommand(\n        buildShellCommand(['YARN', 'sort-package-json', '--', ...sortPackageJsonArgs]),\n        projects.self,\n        argv,\n        lintRunOptions\n      );\n      printSilentLintOutputs([sortPackageJsonResult], argv);\n      lintExitCodes.push(sortPackageJsonResult.exitCode);\n    }\n  }\n\n  return lintExitCodes.some((exitCode) => exitCode !== 0) ? 1 : 0;\n}\n\nfunction runLintCommand(\n  command: string,\n  project: Project,\n  argv: LintCommandArgv,\n  options: Parameters<typeof runWithSpawnInParallel>[3]\n): Promise<LintRunResult> {\n  if (argv.silent) {\n    const normalizedScript = normalizeScript(command, project);\n    return runWithSpawnInParallelBuffered(command, project, argv, options).then((result) => ({\n      ...result,\n      command: normalizedScript.printable,\n      cwd: project.dirPath,\n    }));\n  }\n  return runWithSpawnInParallel(command, project, argv, options).then((exitCode) => ({ exitCode }));\n}\n\nfunction printSilentLintOutputs(\n  results: LintRunResult[],\n  argv: Pick<LintCommandArgv, 'printAllOutput' | 'silent'>\n): void {\n  const printableResults =\n    argv.silent && !argv.printAllOutput ? results.filter((result) => result.exitCode !== 0) : results;\n  if (printableResults.length === 0) return;\n\n  for (const result of printableResults) {\n    if (!('output' in result)) continue;\n\n    if (argv.printAllOutput) {\n      printCommandOutput(result);\n    } else {\n      if (argv.silent) {\n        printCommandHeader(result.command, result.cwd);\n      }\n      printBufferedOutput(result.exitCode, result.output);\n    }\n  }\n}\n\nfunction printCommandOutput(result: BufferedLintRunResult): void {\n  printCommandHeader(result.command, result.cwd);\n\n  if (result.exitCode === 0 && shouldSuppressSuccessfulVerifyOutput(result.command)) {\n    console.info(chalk.green('Succeeded.'));\n    return;\n  }\n\n  const output = result.output.trim();\n  if (output) {\n    process.stdout.write(output);\n    process.stdout.write('\\n');\n  }\n}\n\nfunction printCommandHeader(command: string, cwd: string): void {\n  console.info('\\n' + chalk.cyan(chalk.bold('Command:'), command) + chalk.gray(` at ${cwd}`));\n}\n\nfunction shouldSuppressSuccessfulVerifyOutput(command: string): boolean {\n  return command.includes(' oxfmt ') || command.includes(' sort-package-json ');\n}\n\nexport function buildLintCommand(\n  project: Pick<Project, 'preferredLinter'>,\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string | undefined {\n  if (project.preferredLinter === 'oxlint') {\n    return buildShellCommand([\n      'YARN',\n      'oxlint',\n      '--no-error-on-unmatched-pattern',\n      ...(argv.quiet ? ['--quiet'] : []),\n      ...(argv.fix ? ['--fix'] : []),\n      ...(files ?? ['.']),\n    ]);\n  }\n  return;\n}\n\nexport function buildOxfmtCommand(files?: string[]): string {\n  return buildShellCommand([\n    'YARN',\n    'oxfmt',\n    '--write',\n    '--no-error-on-unmatched-pattern',\n    ...(files ?? ['.']),\n    '!**/package.json',\n  ]);\n}\n\nexport function buildPoetryCommand(\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string {\n  const targets = files && files.length > 0 ? files : ['.'];\n  const commands =\n    argv.fix || argv.format\n      ? [\n          buildShellCommand(['poetry', 'run', 'isort', '--profile', 'black', '--filter-files', ...targets]),\n          buildShellCommand(['poetry', 'run', 'black', ...targets]),\n          buildShellCommand(['poetry', 'run', 'flake8', ...(argv.quiet ? ['-q'] : []), ...targets]),\n        ]\n      : [buildShellCommand(['poetry', 'run', 'flake8', ...(argv.quiet ? ['-q'] : []), ...targets])];\n  return commands.join(' && ');\n}\n\nexport function buildDartCommand(\n  argv: Pick<LintCommandOptions, 'fix' | 'format'> & Partial<Pick<LintCommandOptions, 'quiet'>>,\n  files?: string[]\n): string {\n  const targets = files && files.length > 0 ? files : ['.'];\n  const commands: string[] = [];\n  if (argv.fix || argv.format) {\n    commands.push(buildShellCommand(['dart', 'format', ...targets]));\n  }\n  commands.push(buildShellCommand(['dart', 'analyze', ...targets]));\n  return commands.join(' && ');\n}\n\nexport function buildPrettierArgs(\n  selfDirPath: string,\n  projects: Pick<Project, 'dirPath' | 'preferredLinter' | 'hasOxfmt'>[]\n): string[] {\n  const args = new Set<string>([`**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}`, prettierFixtureIgnorePattern]);\n  for (const project of projects) {\n    if (!needsPrettier(project)) continue;\n\n    const projectPattern = path.join(project.dirPath, '**/{.*/,}*.{' + [...prettierExtensions].join(',') + '}');\n    args.add(path.relative(selfDirPath, projectPattern) || projectPattern);\n  }\n  return [...args];\n}\n\nfunction findOwningProject(projects: Project[], filePath: string): Project | undefined {\n  let owningProject: Project | undefined;\n  for (const project of projects) {\n    if (\n      (filePath === project.dirPath || filePath.startsWith(`${project.dirPath}/`)) &&\n      (!owningProject || project.dirPath.length > owningProject.dirPath.length)\n    ) {\n      owningProject = project;\n    }\n  }\n  return owningProject;\n}\n\nexport function getLintTargetFiles(argv: Pick<LintCommandArgv, '--' | '_' | 'files'>): string[] {\n  const lintTargets = new Set<string>();\n  for (const value of [...(argv.files ?? []), ...argv._.slice(1), ...(argv['--'] ?? [])]) {\n    lintTargets.add(String(value));\n  }\n  return [...lintTargets];\n}\n\nexport async function getLintTargetFileKind(filePath: string): Promise<'directory' | 'other'> {\n  try {\n    const stats = await fs.stat(filePath);\n    if (stats.isDirectory()) return 'directory';\n  } catch {\n    // Missing paths are handled by the downstream tools.\n  }\n\n  return 'other';\n}\n\nexport function shouldFormatExplicitPathWithPrettier(\n  project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>,\n  extension: string\n): boolean {\n  if (project.hasOxfmt) return oxfmtExtensions.has(extension);\n  if (needsPrettier(project)) return true;\n  return prettierOnlyExtensions.has(extension);\n}\n\nexport function buildExplicitFormatterArgs(\n  project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>,\n  filePath: string,\n  fileKind: 'directory' | 'other',\n  extension: string\n): string[] {\n  if (fileKind === 'directory' && project.hasOxfmt) {\n    return [filePath];\n  }\n  if (fileKind === 'directory' && needsPrettier(project)) {\n    return [filePath, prettierFixtureIgnorePattern];\n  }\n  if (shouldFormatExplicitPathWithPrettier(project, extension)) {\n    return [filePath];\n  }\n  return [];\n}\n\nfunction buildPrettierOnlyDirectoryPattern(filePath: string): string {\n  return path.join(filePath, `**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}`);\n}\n\nexport function getExplicitPackageJsonPaths(\n  projects: Pick<Project, 'dirPath' | 'packageJsonPath'>[],\n  filePath: string,\n  fileKind: 'directory' | 'other'\n): string[] {\n  if (fileKind !== 'directory') return [];\n  return projects\n    .filter(\n      (project) =>\n        project.packageJsonPath === path.join(filePath, 'package.json') ||\n        project.packageJsonPath.startsWith(`${filePath}/`)\n    )\n    .map((project) => project.packageJsonPath);\n}\n\nexport function getExplicitLintTargets(\n  projects: Project[],\n  filePath: string,\n  fileKind: 'directory' | 'other'\n): { lintPath: string; project: Project }[] {\n  if (fileKind === 'directory') {\n    const descendantProjects = projects.filter(\n      (project) => project.dirPath === filePath || project.dirPath.startsWith(`${filePath}/`)\n    );\n    if (descendantProjects.length > 0) {\n      return descendantProjects.map((project) => ({ lintPath: project.dirPath, project }));\n    }\n  }\n\n  const project = findOwningProject(projects, filePath);\n  return project ? [{ lintPath: filePath, project }] : [];\n}\n\nfunction isPotentialLintTarget(extension: string): boolean {\n  return oxlintExtensions.has(extension) || pythonExtensions.has(extension) || dartExtensions.has(extension);\n}\n\nfunction supportsLintingExtension(project: Pick<Project, 'preferredLinter'>, extension: string): boolean {\n  if (project.preferredLinter === 'oxlint') return oxlintExtensions.has(extension);\n  return false;\n}\n\nfunction needsPrettier(project: Pick<Project, 'preferredLinter' | 'hasOxfmt'>): boolean {\n  return !project.hasOxfmt && project.preferredLinter === 'oxlint';\n}\n","import type { Project } from '../project.js';\n\nexport function* prepareForRunningCommand(commandName: string, projects: Project[]): Generator<Project, void, unknown> {\n  for (const project of projects) {\n    console.info(`Running \"${commandName}\" for ${project.name} ...`);\n\n    yield project;\n  }\n}\n","import child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\n// These tools are declared as devDependencies in source repos, but optimized Docker\n// package.json files still need them for in-image codegen/build steps.\nconst runtimeDevDependencies = ['@willbooster/wb', 'build-ts'];\n\nconst builder = {\n  outside: {\n    description: 'Whether the optimization is executed outside a docker container or not',\n    type: 'boolean',\n    alias: 'o',\n  },\n} as const;\n\nexport const optimizeForDockerBuildCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'optimizeForDockerBuild',\n  describe: 'Optimize configuration when building a Docker image',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of prepareForRunningCommand('optimizeForDockerBuild', projects.descendants)) {\n      const packageJson: PackageJson = project.packageJson;\n      const keys = ['dependencies', 'devDependencies'] as const;\n      for (const key of keys) {\n        const deps = packageJson[key] ?? {};\n        for (const [name, value] of Object.entries(deps)) {\n          if (value?.startsWith('git@github.com:')) {\n            // Docker builds cannot access private SSH URLs unless credentials are forwarded.\n            // The Dockerfile copies those workspace packages into the image instead.\n            deps[name] = `./${name}`;\n          }\n        }\n      }\n\n      optimizeDevDependencies(argv, packageJson);\n\n      optimizeScripts(packageJson);\n\n      optimizeRootProps(packageJson);\n\n      if (argv.dryRun) continue;\n\n      const distDirPath = argv.outside ? path.join(project.dirPath, 'dist') : project.dirPath;\n      await fs.promises.mkdir(distDirPath, { recursive: true });\n      await fs.promises.writeFile(path.join(distDirPath, 'package.json'), JSON.stringify(packageJson), 'utf8');\n    }\n    if (!argv.dryRun && !argv.outside) {\n      child_process.spawnSync(packageManager, ['install'], {\n        stdio: 'inherit',\n      });\n      console.info('Installed dependencies.');\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  promoteRuntimeDevDependencies(packageJson);\n  if (argv.outside) {\n    // Outside optimization writes dist/package.json before Docker builds the app.\n    // Keep build-time packages for that later in-image build and remove only known non-build tooling.\n    removeUnnecessaryDevDependenciesForOutsideDockerBuild(packageJson);\n    return;\n  }\n\n  // Inside Docker, codegen/build has already finished, so production install should not see dev tooling.\n  delete packageJson.devDependencies;\n  console.info('Removed all devDependencies.');\n}\n\nfunction removeUnnecessaryDevDependenciesForOutsideDockerBuild(packageJson: PackageJson): void {\n  const devDeps = packageJson.devDependencies ?? {};\n  // In --outside mode, Docker still runs codegen/build before a second in-image optimization.\n  // Remove only tooling that is not needed for that build phase.\n  const nameWordsToBeRemoved = [\n    'artillery',\n    'concurrently',\n    'conventional-changelog-conventionalcommits',\n    'husky',\n    'imagemin',\n    'jest',\n    'kill-port',\n    'lint-staged',\n    'open-cli',\n    'playwright',\n    'prettier',\n    'pinst',\n    'railway',\n    'semantic-release',\n    'sort-package-json',\n    'wait-on',\n    'vitest',\n  ];\n  const removedDeps: string[] = [];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      // Shared config packages are needed only for lint/format/test commands, not Docker builds.\n      (name.includes('willbooster') && name.includes('config'))\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete devDeps[name];\n      removedDeps.push(name);\n    }\n  }\n  console.info('Removed devDependencies:', removedDeps.join(', ') || 'none');\n}\n\nfunction promoteRuntimeDevDependencies(packageJson: PackageJson): void {\n  const devDeps = packageJson.devDependencies ?? {};\n  const dependencies = packageJson.dependencies ?? {};\n  const promotedDeps: string[] = [];\n  for (const name of runtimeDevDependencies) {\n    const version = devDeps[name];\n    if (!version) continue;\n    if (!dependencies[name]) {\n      dependencies[name] = version;\n      promotedDeps.push(name);\n    }\n    delete devDeps[name];\n  }\n  if (promotedDeps.length > 0) {\n    packageJson.dependencies = dependencies;\n  }\n  console.info('Promoted runtime devDependencies:', promotedDeps.join(', ') || 'none');\n}\n\nfunction optimizeScripts(packageJson: PackageJson): void {\n  const nameWordsOfUnnecessaryScripts = ['check', 'deploy', 'format', 'lint', 'start', 'test'];\n  const contentWordsOfUnnecessaryScripts = ['pinst ', 'husky '];\n  const scripts = (packageJson.scripts ?? {}) as Record<string, string>;\n  const removedScripts: string[] = [];\n  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.startsWith(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete scripts[name];\n      removedScripts.push(name);\n    }\n  }\n  console.info('Removed scripts:', removedScripts.join(', ') || 'none');\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\n\nconst FILE_SCHEMA = 'file:';\n\nclass DrizzleScripts {\n  deploy(project: Project, additionalOptions = ''): string {\n    return this.migrate(project, additionalOptions);\n  }\n\n  migrate(_project: Project, additionalOptions = ''): string {\n    return `YARN drizzle-kit migrate ${additionalOptions}`;\n  }\n\n  migrateDev(_project: Project, additionalOptions = ''): string {\n    return `YARN drizzle-kit generate ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    const removeCommand = buildRemoveSqliteDbCommand(project);\n    if (!removeCommand) {\n      return \"echo 'wb db reset supports Drizzle only when DATABASE_PATH or file: DATABASE_URL is set.' && exit 1\";\n    }\n\n    return `${removeCommand} && ${this.migrate(project, additionalOptions)} && ${this.seed(project)}`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if (project.packageJson.scripts?.seed) return 'YARN run seed';\n    return 'true';\n  }\n\n  studio(_project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    if (dbUrlOrPath) {\n      return \"echo 'wb db studio for Drizzle does not support db-url-or-path.' && exit 1\";\n    }\n\n    return `YARN drizzle-kit studio ${additionalOptions}`;\n  }\n}\n\nfunction buildRemoveSqliteDbCommand(project: Project): string | undefined {\n  const dbPath = project.env.DATABASE_PATH ?? getFileDatabaseUrlPath(project);\n  if (!dbPath) return;\n\n  const absolutePath = path.isAbsolute(dbPath) ? dbPath : path.resolve(project.dirPath, dbPath);\n  return `rm -f \"${absolutePath}\" \"${absolutePath}-wal\" \"${absolutePath}-shm\"`;\n}\n\nfunction getFileDatabaseUrlPath(project: Project): string | undefined {\n  const dbUrl = project.env.DATABASE_URL;\n  if (!dbUrl?.startsWith(FILE_SCHEMA)) return;\n\n  const rawDbPath = dbUrl.slice(FILE_SCHEMA.length).replace(/[?#].*$/, '');\n  if (!rawDbPath) return;\n\n  return rawDbPath;\n}\n\nexport const drizzleScripts = new DrizzleScripts();\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { Project } from '../project.js';\n\nconst FILE_SCHEMA = 'file:';\n\nconst POSSIBLE_PRISMA_PATHS = [\n  { schemaPath: path.join('prisma', 'schema.prisma'), dbPath: 'prisma' },\n  { schemaPath: path.join('prisma', 'schema'), dbPath: path.join('prisma', 'schema') },\n  { schemaPath: path.join('db', 'schema.prisma'), dbPath: 'db' },\n];\n\n/**\n * A collection of scripts for executing Prisma commands.\n * Note that `PRISMA` is replaced with `YARN prisma` or `YARN blitz prisma`\n * and `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PrismaScripts {\n  cleanUpLitestream(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    const cleanUpCommand = buildWalCheckpointAndRemoveSqliteSidecarFilesCommand(`${dirPath}/prod.sqlite3`);\n    // Cleanup existing artifacts to avoid issues with Litestream replication.\n    // Note that don't merge multiple rm commands into one, because if one fails, the subsequent ones won't run.\n    return `${cleanUpCommand}; rm -Rf ${dirPath}/.prod.sqlite3* || true`;\n  }\n\n  deploy(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions}`;\n  }\n\n  deployForce(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    const removeDbCommand = buildRemoveSqliteDbCommand(`${dirPath}/prod.sqlite3`);\n    // `prisma migrate reset` can fail depending on the state of the existing database, so we remove it first.\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `${removeDbCommand}; PRISMA migrate reset --force --skip-seed && ${removeDbCommand}\n      && litestream restore -config litestream.yml -o ${dirPath}/prod.sqlite3 ${dirPath}/prod.sqlite3 && ls -ahl ${dirPath}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  listBackups(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `litestream ltx -config litestream.yml ${dirPath}/prod.sqlite3`;\n  }\n\n  migrate(project: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions} && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate dev ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    const steps: string[] = [];\n    const cleanupCommand = cleanUpSqliteDbIfNeeded(project);\n    if (cleanupCommand) steps.push(cleanupCommand);\n    const resetCommand = ['PRISMA migrate reset --force', additionalOptions].filter(Boolean).join(' ');\n    steps.push(resetCommand);\n    if (project.packageJson.dependencies?.blitz) {\n      // Blitz does not trigger seed automatically, so we need to run it manually.\n      steps.push(this.seed(project));\n    }\n    return steps.filter(Boolean).join(' && ');\n  }\n\n  restore(project: Project, outputPath: string): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `rm -Rf ${outputPath}*; litestream restore -config litestream.yml -o ${outputPath} ${dirPath}/prod.sqlite3`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.blitz) return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if ((project.packageJson.prisma as Record<string, string> | undefined)?.seed) return `YARN prisma db seed`;\n    return `if [ -e \"prisma/seeds.ts\" ]; then BUN build-ts run prisma/seeds.ts; fi`;\n  }\n\n  studio(project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    let prefix = '';\n    // Deal with Prisma issue: https://github.com/prisma/studio/issues/1273\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    } else if (project.env.DATABASE_URL?.startsWith(FILE_SCHEMA)) {\n      const baseDir = getPrismaBaseDir(project);\n      if (baseDir) {\n        const absolutePath = path.resolve(project.dirPath, baseDir, project.env.DATABASE_URL.slice(FILE_SCHEMA.length));\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    }\n    return `${prefix}PRISMA studio ${additionalOptions}`;\n  }\n}\n\nfunction getDatabaseDirPath(project: Project): string {\n  return project.packageJson.dependencies?.blitz ? 'db/mount' : 'prisma/mount';\n}\n\nfunction getPrismaBaseDir(project: Project): string | undefined {\n  return POSSIBLE_PRISMA_PATHS.find(({ schemaPath }) => fs.existsSync(path.resolve(project.dirPath, schemaPath)))\n    ?.dbPath;\n}\n\nfunction buildRemoveSqliteDbCommand(dbPath: string): string {\n  return `rm -Rf \"${dbPath}\"*`;\n}\n\nfunction buildWalCheckpointAndRemoveSqliteSidecarFilesCommand(dbPath: string): string {\n  return `if [ -f \"${dbPath}\" ]; then printf 'PRAGMA wal_checkpoint(TRUNCATE);' | PRISMA db execute --stdin --url \"${FILE_SCHEMA}${dbPath}\"; fi && rm -f \"${dbPath}\".* \"${dbPath}\"-*`;\n}\n\nexport function cleanUpSqliteDbIfNeeded(project: Project): string | undefined {\n  const dbUrl = project.env.DATABASE_URL;\n  if (!dbUrl?.startsWith(FILE_SCHEMA)) return;\n\n  const rawDbPath = dbUrl.slice(FILE_SCHEMA.length).replace(/[?#].*$/, '');\n  if (!rawDbPath) return;\n\n  const baseDir = getPrismaBaseDir(project);\n  const absolutePath = path.isAbsolute(rawDbPath)\n    ? rawDbPath\n    : path.resolve(project.dirPath, baseDir ?? '.', rawDbPath);\n\n  return `rm -f \"${absolutePath}\" \"${absolutePath}-wal\" \"${absolutePath}-shm\"`;\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import fs from 'node:fs';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { DatabaseOrm, Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport { drizzleScripts } from '../scripts/drizzleScripts.js';\nimport { prismaScripts } from '../scripts/prismaScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { buildShellCommand } from '../utils/shell.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const prismaCommand: CommandModule = {\n  command: 'prisma',\n  aliases: ['db'],\n  describe:\n    \"Run database commands. Use '--' to stop wb option parsing and forward the remaining arguments to Prisma. Drizzle projects use drizzle-kit. Example: wb prisma migrate-dev -- --name init\",\n  builder: (yargs) => {\n    return yargs\n      .parserConfiguration({ 'populate--': true })\n      .command(cleanUpLitestreamCommand)\n      .command(createLitestreamConfigCommand)\n      .command(deployCommand)\n      .command(deployForceCommand)\n      .command(listBackupsCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand()\n      .strict(false); // Allow unknown options to be passed through\n  },\n  handler() {\n    // Do nothing\n  },\n};\n\nconst cleanUpLitestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'cleanup-litestream',\n  describe: 'Clean up temporal Litestream files',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma cleanup-litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.cleanUpLitestream(project), project, argv);\n    }\n  },\n};\n\nconst createLitestreamConfigCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'create-litestream-config',\n  describe: 'Create Litestream configuration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma create-litestream-config', allProjects)) {\n      createLitestreamConfig(project);\n    }\n  },\n};\n\nconst deployCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy',\n  describe: 'Apply migration to DB without initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db deploy', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).deploy(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy-force',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma deploy-force', allProjects)) {\n      await runWithSpawn(prismaScripts.deployForce(project), project, argv);\n    }\n  },\n};\n\nconst listBackupsCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'list-backups',\n  describe: 'List Litestream backups',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma list-backups', allProjects)) {\n      await runWithSpawn(prismaScripts.listBackups(project), project, argv);\n    }\n  },\n};\n\nconst migrateCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate',\n  describe: 'Apply migration to DB with initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db migrate', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).migrate(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst migrateDevCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate-dev',\n  describe: 'Create a migration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db migrate-dev', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).migrateDev(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst resetCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'reset',\n  describe: 'Reset DB',\n  builder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db reset', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).reset(project, unknownOptions), project, argv);\n    }\n    // Force to reset test database\n    if (process.env.WB_ENV !== 'test') {\n      process.env.WB_ENV = 'test';\n      for (const { orm, project } of prepareForRunningDatabaseOrmCommand(\n        'WB_ENV=test db reset',\n        await findDatabaseOrmProjects(argv)\n      )) {\n        await runWithSpawn(getDatabaseOrmScripts(orm).reset(project, unknownOptions), project, argv);\n      }\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...builder,\n  output: {\n    description: 'Output path of the restored database. Defaults to \"<db|prisma>/restored.sqlite3\".',\n    type: 'string',\n  },\n} as const;\n\nconst restoreCommand: CommandModule<unknown, InferredOptionTypes<typeof restoreBuilder>> = {\n  command: 'restore',\n  describe: \"Restore DB from Litestream's backup\",\n  builder: restoreBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv, 'prisma');\n    for (const { project } of prepareForRunningDatabaseOrmCommand('prisma restore', allProjects)) {\n      const output =\n        argv.output ?? (project.packageJson.dependencies?.blitz ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, output), project, argv);\n    }\n  },\n};\n\nconst seedBuilder = {\n  ...builder,\n  file: {\n    alias: 'f',\n    description: 'Path of the seed script.',\n    type: 'string',\n  },\n} as const;\n\nconst seedCommand: CommandModule<unknown, InferredOptionTypes<typeof seedBuilder>> = {\n  command: 'seed',\n  describe: 'Populate DB with seed data',\n  builder: seedBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db seed', allProjects)) {\n      await runWithSpawn(getDatabaseOrmScripts(orm).seed(project, argv.file), project, argv);\n    }\n  },\n};\n\nconst studioBuilder = {\n  ...builder,\n  'db-url-or-path': {\n    description: 'URL or path to the database',\n    type: 'string',\n  },\n  restored: {\n    description: 'Whether to open the default restored database (<db|prisma>/restored.sqlite3).',\n    type: 'boolean',\n  },\n} as const;\n\nconst studioCommand: CommandModule<unknown, InferredOptionTypes<typeof studioBuilder>> = {\n  command: 'studio [db-url-or-path]',\n  describe: 'Open database studio',\n  builder: studioBuilder,\n  async handler(argv) {\n    if (argv.restored && argv.dbUrlOrPath) {\n      throw new Error('You cannot specify both --restored and --db-url-or-path.');\n    }\n\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv, ['db-url-or-path', 'restored']);\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand('db studio', allProjects)) {\n      const dbUrlOrPath = argv.restored\n        ? project.packageJson.dependencies?.blitz\n          ? 'db/restored.sqlite3'\n          : 'prisma/restored.sqlite3'\n        : argv.dbUrlOrPath?.toString();\n      await runWithSpawn(getDatabaseOrmScripts(orm).studio(project, dbUrlOrPath, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst defaultCommandBuilder = { args: { type: 'array' } } as const;\n\nconst defaultCommand: CommandModule<unknown, InferredOptionTypes<typeof defaultCommandBuilder>> = {\n  command: '$0 <args..>',\n  describe:\n    \"Pass the command and arguments to the detected ORM as is. Additional Prisma flags can also be forwarded after '--'.\",\n  builder: defaultCommandBuilder,\n  async handler(argv) {\n    const allProjects = await findDatabaseOrmProjects(argv);\n    const script = (argv.args?.join(' ') ?? '').trimEnd();\n    const unknownOptions = extractUnknownOptions(argv, ['args']);\n    const fullCommand = [script, unknownOptions].filter(Boolean).join(' ');\n    for (const { orm, project } of prepareForRunningDatabaseOrmCommand(`db ${fullCommand}`, allProjects)) {\n      const command = orm === 'prisma' ? `PRISMA ${fullCommand}` : `YARN drizzle-kit ${fullCommand}`;\n      await runWithSpawn(command, project, argv);\n    }\n  },\n};\n\nfunction createLitestreamConfig(project: Project): void {\n  const dirName = project.packageJson.dependencies?.blitz ? 'db' : 'prisma';\n  const dbPath = `${dirName}/mount/prod.sqlite3`;\n  const requiredEnvVars = {\n    CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,\n    CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME: project.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,\n    CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,\n    CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY: project.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY,\n  } as const;\n  const missingEnvVars = Object.entries(requiredEnvVars)\n    .filter(([, value]) => !value)\n    .map(([key]) => key);\n  if (missingEnvVars.length > 0) {\n    throw new Error(`Missing environment variables for Litestream: ${missingEnvVars.join(', ')}`);\n  }\n\n  const retentionCheckInterval = project.env.WB_ENV === 'staging' ? '5m' : '1h';\n  const litestreamConfig = `dbs:\n  - path: ${dbPath}\n    busy-timeout: 5s\n    checkpoint-interval: 1m\n    replica:\n      type: s3\n      endpoint: https://${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n      bucket: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n      access-key-id: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n      secret-access-key: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n      snapshot-interval: 24h  # Create a backup per day\n      retention: 72h          # Keep backups for 3 days\n      retention-check-interval: ${retentionCheckInterval}\n      sync-interval: 1m\n`;\n\n  const configPath = '/etc/litestream.yml';\n  try {\n    fs.writeFileSync(configPath, litestreamConfig);\n    console.info(`Generated ${configPath}`);\n  } catch (error) {\n    const reason = error instanceof Error ? error.message : String(error);\n    throw new Error(`Failed to write ${configPath}: ${reason}`, {\n      cause: error,\n    });\n  }\n}\n\ninterface DatabaseOrmProject {\n  project: Project;\n  orm: DatabaseOrm;\n}\n\nasync function findDatabaseOrmProjects(argv: EnvReaderOptions, orm?: DatabaseOrm): Promise<DatabaseOrmProject[]> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  const filtered = projects.descendants\n    .map((project) => (project.databaseOrm ? { project, orm: project.databaseOrm } : undefined))\n    .filter((project): project is DatabaseOrmProject => !!project && (!orm || project.orm === orm));\n  if (filtered.length === 0) {\n    console.error(chalk.red(orm ? `No ${orm} project found.` : 'No supported database ORM project found.'));\n    process.exit(1);\n  }\n  return filtered;\n}\n\nfunction getDatabaseOrmScripts(orm: DatabaseOrm): typeof prismaScripts | typeof drizzleScripts {\n  return orm === 'prisma' ? prismaScripts : drizzleScripts;\n}\n\nfunction* prepareForRunningDatabaseOrmCommand(\n  commandName: string,\n  projects: DatabaseOrmProject[]\n): Generator<DatabaseOrmProject, void, unknown> {\n  const ormProjectByProject = new Map(projects.map((project) => [project.project, project]));\n  for (const project of prepareForRunningCommand(\n    commandName,\n    projects.map(({ project }) => project)\n  )) {\n    const ormProject = ormProjectByProject.get(project);\n    if (!ormProject) throw new Error(`Failed to detect database ORM for ${project.name}.`);\n\n    yield ormProject;\n  }\n}\n\n/**\n * Extract unknown options from argv to pass to ORM commands.\n */\nexport function extractUnknownOptions(argv: Record<string, unknown>, knownOptions: string[] = []): string {\n  const unknownOptions: string[] = [];\n\n  // Build list of known options from shared options builders\n  const sharedOptionKeys = Object.keys(sharedOptionsBuilder);\n  const sharedOptionAliases = Object.values(sharedOptionsBuilder)\n    .flatMap((option) => {\n      if ('alias' in option) {\n        return Array.isArray(option.alias) ? option.alias : [option.alias];\n      }\n      return [];\n    })\n    .map(String);\n\n  const allKnownOptions = new Set([\n    ...knownOptions,\n    ...sharedOptionKeys,\n    ...sharedOptionAliases,\n    // Internal yargs properties\n    '--',\n    '_',\n    '$0',\n  ]);\n\n  for (const [key, value] of Object.entries(argv)) {\n    if (!allKnownOptions.has(key)) {\n      // Skip camelCase versions of kebab-case options to avoid duplication\n      // If we have both 'create-only' and 'createOnly', prefer the kebab-case version\n      const kebabCaseKey = key.replaceAll(/[A-Z]/g, (match) => `-${match.toLowerCase()}`);\n      if (kebabCaseKey !== key && argv[kebabCaseKey] !== undefined) {\n        continue; // Skip camelCase version if kebab-case exists\n      }\n\n      // Handle boolean flags\n      if (typeof value === 'boolean' && value) {\n        unknownOptions.push(`--${key}`);\n      }\n      // Handle string/number values\n      else if (typeof value === 'string' || typeof value === 'number') {\n        unknownOptions.push(`--${key}`, String(value));\n      }\n      // Handle arrays\n      else if (Array.isArray(value)) {\n        for (const item of value) {\n          unknownOptions.push(`--${key}`, String(item));\n        }\n      }\n    }\n  }\n\n  const passthroughArgs = Array.isArray(argv['--']) ? argv['--'].map(String) : [];\n  return buildShellCommand([...unknownOptions, ...passthroughArgs]);\n}\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  retry: {\n    description: 'A maximum retry count',\n    type: 'number',\n    alias: 'r',\n    default: 3,\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  command: {\n    description: 'A command to retry',\n    type: 'string',\n  },\n  args: {\n    description: 'Arguments for the command',\n    type: 'array',\n  },\n} as const;\n\nexport const retryCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'retry [command] [args...]',\n  describe: 'Retry the given command until it succeeds',\n  builder,\n  async handler(argv) {\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const cmdAndArgs = [argv.command, ...(argv.args ?? []), ...argv._.slice(1)].filter(Boolean);\n    let lastStatus = 0;\n    for (let i = 0; i < argv.retry; i++) {\n      if (i > 0) {\n        console.info(`\\n${chalk.yellow(`#${i} Retrying: ${cmdAndArgs.join(' ')}`)}`);\n      }\n      // TODO: should we add single quotes around each argument?\n      lastStatus = await runWithSpawn(cmdAndArgs.join(' '), project, argv, {\n        exitIfFailed: false,\n        onSignal: (signal) => {\n          if (signal) {\n            process.exit(1);\n          }\n        },\n      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","import child_process from 'node:child_process';\nimport fs from 'node:fs/promises';\nimport os from 'node:os';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { packageManagerWithRun } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const setupCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'setup',\n  describe: 'Setup development environment. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    await setup(argv);\n  },\n};\n\n// Test code requires Partial<...>\nexport async function setup(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  projectPathForTesting?: string\n): Promise<void> {\n  const projects = await findDescendantProjects(argv, false, projectPathForTesting);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  for (const project of prepareForRunningCommand('setup', projects.descendants)) {\n    const dirents = await fs.readdir(project.dirPath, { withFileTypes: true });\n    if (project === projects.root) {\n      if (os.platform() === 'darwin') {\n        const packages = ['pstree'];\n        await runWithSpawnInParallel(`brew install ${packages.join(' ')}`, project, argv);\n      }\n\n      if (dirents.some((d) => d.isFile() && d.name.includes('-version'))) {\n        await runWithSpawn('asdf install', project, argv, { exitIfFailed: false });\n      }\n    }\n\n    if (dirents.some((d) => d.isFile() && d.name === 'pyproject.toml')) {\n      await runWithSpawnInParallel('poetry config virtualenvs.in-project true', project, argv);\n      const [, version] = child_process.execSync('asdf current python').toString().trim().split(/\\s+/);\n      await runWithSpawnInParallel(`poetry env use ${version}`, project, argv);\n      await promisePool.promiseAll();\n      await runWithSpawn('poetry run pip install --upgrade pip', project, argv);\n      await runWithSpawn('poetry install --ansi', project, argv);\n    }\n\n    if (\n      (project === projects.root || !projects.root.packageJson.scripts?.['gen-code']) &&\n      project.packageJson.scripts?.['gen-code']\n    ) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\n  }\n\n  const project = projects.descendants.find((p) => p.packageJson.devDependencies?.playwright);\n  if (project) {\n    await runWithSpawn(`${packageManagerWithRun} playwright install --with-deps`, project, argv);\n  }\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport { shellEscapeArgument } from '../utils/shell.js';\n\nexport const scriptOptionsBuilder = {\n  watch: {\n    description: 'Whether to watch files',\n    type: 'boolean',\n  },\n  args: {\n    description: 'Arguments for core command',\n    type: 'array',\n    alias: 'a',\n    default: [],\n  },\n  'docker-options': {\n    description: 'Arguments for \"docker run\"',\n    type: 'array',\n    default: [],\n  },\n} as const;\n\nexport type ScriptArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & {\n  '--'?: string[];\n  normalizedArgsText?: string;\n  normalizedDockerOptionsText?: string;\n  silent?: boolean;\n  verbose?: boolean;\n};\n\nexport function normalizeArgs(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & { '--'?: string[] }\n): void {\n  (argv as ScriptArgv).normalizedArgsText = [...(argv.args ?? []), ...(argv._?.slice(1) ?? []), ...(argv['--'] ?? [])]\n    .map((arg) => shellEscapeArgument(String(arg)))\n    .join(' ');\n  (argv as ScriptArgv).normalizedDockerOptionsText = (argv.dockerOptions ?? [])\n    .map((arg) => shellEscapeArgument(String(arg)))\n    .join(' ');\n}\n\nexport function toDevNull(argv: unknown): string {\n  return (argv as { silent: boolean }).silent ? ` > /dev/null` : '';\n}\n","import { spawnSync } from 'node:child_process';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nimport { isPortAvailable } from './port.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number, project: Project): Promise<void> {\n  const available = await isPortAvailable(port);\n  if (!available) {\n    await killPortContainerAndProcess(port, project);\n  }\n\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortContainerAndProcess(port, project);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortContainerAndProcess(port: number, project: Project): Promise<void> {\n  // We should stop Docker containers first because `kill-port` may fail to stop Docker containers.\n  await stopDockerContainerByPort(port, project);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function stopDockerContainerByImageName(imageName: string, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `name=${imageName}`], project);\n}\n\nexport async function stopDockerContainerByPort(port: number, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `publish=${port}`], project);\n}\n\nasync function removeDockerContainers(filterArgs: string[], project: Project): Promise<void> {\n  try {\n    const containerIds = await listDockerContainerIds(filterArgs, project);\n    if (containerIds.length === 0) return;\n\n    await spawnAsync('docker', ['rm', '-f', ...containerIds], {\n      cwd: project.dirPath,\n      env: project.env,\n    });\n  } catch {\n    // do nothing\n  }\n}\n\nasync function listDockerContainerIds(filterArgs: string[], project: Project): Promise<string[]> {\n  const { stdout } = await spawnAsync('docker', ['ps', '-q', ...filterArgs], {\n    cwd: project.dirPath,\n    env: project.env,\n  });\n  return stdout\n    .split(/\\s+/)\n    .map((id) => id.trim())\n    .filter(Boolean);\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = (): void => {\n    if (killed.has(script)) return;\n\n    killed.add(script);\n    printStart(script, project);\n    const { status } = spawnSync(script, { cwd: project.dirPath, shell: true, stdio: 'inherit' });\n    printFinishedAndExitIfNeeded(script, status, {});\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n","import { createServer } from 'node:net';\n\nimport type { Project } from '../project.js';\n\nimport { killPortProcessImmediatelyAndOnExit } from './process.js';\n\n/**\n * Checks the given port and kills any process using it.\n * Note wb always requires PORT environment variable.\n */\nexport async function checkAndKillPortProcess(rawPort: unknown, project: Project): Promise<number> {\n  const port = Number(rawPort);\n  if (!port) throw new Error(`The given port (${port}) is invalid.`);\n\n  await killPortProcessImmediatelyAndOnExit(port, project);\n  return port;\n}\n\n/**\n * Checks if a port is available.\n * @param port - The port number to check\n * @returns A promise that resolves to true if the port is available, false otherwise\n */\nexport async function isPortAvailable(port: number): Promise<boolean> {\n  // Check both stacks to catch processes bound only on IPv6 or IPv4.\n  for (const host of ['127.0.0.1', '::']) {\n    const available = await probePort(host, port);\n    if (!available) return false;\n  }\n  return true;\n}\n\nasync function probePort(host: string, port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = createServer();\n\n    server.once('error', (err: NodeJS.ErrnoException) => {\n      if (err.code === 'EADDRINUSE') {\n        resolve(false);\n        return;\n      }\n      if (err.code === 'EAFNOSUPPORT') {\n        resolve(true);\n        return;\n      }\n      resolve(false);\n    });\n\n    server.once('listening', () => {\n      server.close(() => {\n        resolve(true);\n      });\n    });\n\n    server.listen(port, host);\n  });\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\nimport { spawnSyncOnExit } from '../utils/process.js';\n\n/**\n * A collection of scripts for executing Docker commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass DockerScripts {\n  buildImage(project: Project, version: string): string {\n    // e.g. coding-booster uses `\"docker/build/prepare\": \"touch drill-users.csv\",`\n    const prefix = project.dockerPackageJson.scripts?.['docker/build/prepare']\n      ? 'YARN run docker/build/prepare && '\n      : '';\n    return `cd ${path.dirname(project.findFile('Dockerfile'))}\n    && ${prefix}YARN wb optimizeForDockerBuild --outside\n    && YARN wb retry -- docker build -t ${project.dockerImageName}\n        --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n\n  stopAndStart(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${this.start(project, additionalOptions, additionalArgs)}`;\n  }\n\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    const allocateTty = additionalArgs.includes('/bin/bash');\n    return `docker run --rm ${allocateTty ? '-it ' : ''}--publish ${project.env.PORT}:8080 --name ${project.dockerImageName} ${additionalOptions} ${project.dockerImageName} ${additionalArgs}`;\n  }\n\n  stop(project: Project): string {\n    return `true $(docker rm -f $(docker container ls -q -f name=${project.dockerImageName}) 2> /dev/null)`;\n  }\n\n  stopAll(): string {\n    return `true $(docker rm -f $(docker ps -q) 2> /dev/null)`;\n  }\n}\n\nexport const dockerScripts = new DockerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { buildEnvReaderOptionArgs } from '../../sharedOptionsBuilder.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport { buildShellCommand, buildShellEnvironmentAssignment } from '../../utils/shell.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { toDevNull } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\nimport { drizzleScripts } from '../drizzleScripts.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nexport interface TestE2EOptions {\n  /** '--e2e generate' calls 'codegen http://localhost:8080' */\n  playwrightArgs?: string[];\n  /** Raw Playwright args forwarded after `wb test -- ...` */\n  forwardedPlaywrightArgs?: string[];\n}\n\n/**\n * A collection of scripts for executing an app.\n * Note that YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nexport abstract class BaseScripts {\n  private readonly shouldWaitAndOpenApp: boolean;\n  protected constructor(shouldWaitAndOpenApp: boolean) {\n    this.shouldWaitAndOpenApp = shouldWaitAndOpenApp;\n  }\n\n  buildDocker(project: Project, version: string): string {\n    return dockerScripts.buildImage(project, version);\n  }\n\n  // ------------ START: start commands ------------\n  async startDev(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startDevProtected(project, argv);\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others-on-fail',\n      this.startDevProtected(project, argv),\n      this.waitAndOpenApp(project),\n    ]);\n  }\n  async startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startProductionProtected(project, argv);\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others-on-fail',\n      this.startProductionProtected(project, argv),\n      this.waitAndOpenApp(project),\n    ]);\n  }\n  async startTest(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    return this.startProductionProtected(project, argv);\n  }\n  async startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) {\n      return `${this.buildDocker(project, 'development')}\n      && ${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}`;\n    }\n\n    return `${this.buildDocker(project, 'development')}\n      && ${buildShellCommand([\n        'YARN',\n        'wb',\n        'concurrently',\n        ...buildEnvReaderOptionArgs(argv),\n        '--kill-others-on-fail',\n        dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? ''),\n        this.waitAndOpenApp(project),\n      ])}`;\n  }\n\n  protected abstract startDevProtected(_: Project, argv: ScriptArgv): string;\n  protected startProductionProtected(project: Project, argv: ScriptArgv): string {\n    const ecosystemConfigPath = findEcosystemConfigPath(project);\n    const commands =\n      ecosystemConfigPath === undefined\n        ? [\n            `YARN wb buildIfNeeded ${argv.verbose ? '--verbose' : ''}`.trim(),\n            `${project.isBunAvailable ? 'bun' : 'node'} dist/index.js ${argv.normalizedArgsText ?? ''}`.trim(),\n          ]\n        : [project.buildCommand, `pm2-runtime start --no-autorestart ${ecosystemConfigPath}`];\n\n    const migrationCommands = [\n      ...(project.hasPrisma ? [prismaScripts.migrate(project)] : []),\n      ...(project.hasDrizzle ? [drizzleScripts.migrate(project)] : []),\n    ];\n    return [...migrationCommands.flatMap((cmd) => cmd.split('&&')), ...commands]\n      .filter(Boolean)\n      .map((cmd) => `${cmd} ${toDevNull(argv)}`.trim())\n      .join(' && ');\n  }\n  // ------------ END: start commands ------------\n\n  // ------------ START: test (e2e) commands ------------\n  testE2EDev(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startDevProtected(project, argv), options);\n  }\n  testE2EProduction(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startProductionProtected(project, argv), options);\n  }\n  testE2EDocker(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, dockerScripts.stopAndStart(project), options);\n  }\n  async testStart(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    // Use empty NODE_ENV to avoid \"production\" mode in some frameworks like Blitz.js.\n    return `${buildShellEnvironmentAssignment('NODE_ENV', '')} ${buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      this.startDevProtected(project, argv),\n      this.waitApp(project),\n    ])}`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    { forwardedPlaywrightArgs = [], playwrightArgs = ['test', 'test/e2e/'] }: TestE2EOptions\n  ): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const playwrightCommand = buildPlaywrightCommand(playwrightArgs, argv.targets, argv.bail, forwardedPlaywrightArgs);\n    if (project.skipLaunchingServerForPlaywright) {\n      return `${playwrightCommand}${suffix}`;\n    }\n\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      `${startCommand} && exit 1`,\n      `wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && ${playwrightCommand}${suffix}`,\n    ]);\n  }\n  // ------------ END: test (e2e) commands ------------\n\n  testUnit(project: Project, argv: TestArgv): string {\n    const targets = argv.targets?.map(String);\n    if (project.hasVitest) {\n      // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n      return buildShellCommand([\n        'YARN',\n        'vitest',\n        'run',\n        ...(targets?.length ? targets : ['test/unit/']),\n        '--color',\n        '--passWithNoTests',\n        '--allowOnly',\n        '--watch=false',\n        ...(argv.bail ? ['--bail=1'] : []),\n      ]);\n    } else if (project.isBunAvailable) {\n      return buildShellCommand([\n        'bun',\n        'test',\n        ...(targets?.length ? targets : ['test/unit/']),\n        ...(argv.bail ? ['--bail'] : []),\n      ]);\n    }\n    return 'echo \"No tests.\"';\n  }\n\n  protected waitApp(project: Project): string {\n    const port = project.env.PORT;\n    return `wait-on -t 10000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 500 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${port}`;\n  }\n\n  protected waitAndOpenApp(project: Project): string {\n    const port = project.env.PORT;\n    return `${this.waitApp(\n      project\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n\nfunction findEcosystemConfigPath(project: Project): string | undefined {\n  try {\n    return project.findFile('ecosystem.config.cjs');\n  } catch {\n    return;\n  }\n}\n\nfunction buildPlaywrightCommand(\n  playwrightArgs: string[],\n  targets: TestArgv['targets'],\n  bail?: boolean,\n  forwardedPlaywrightArgs: string[] = []\n): string {\n  const base = ['BUN', 'playwright'];\n  const normalizedTargets = targets?.map(String);\n  if (playwrightArgs[0] !== 'test' || !normalizedTargets?.length) {\n    return appendPlaywrightBailOption([...base, ...playwrightArgs, ...forwardedPlaywrightArgs], bail);\n  }\n\n  const rest = playwrightArgs.slice(1);\n  const explicitTargetIndexes = findExplicitPlaywrightTargetIndexes(rest);\n  const restWithoutExplicitTarget =\n    explicitTargetIndexes.length === 0 ? rest : rest.filter((_, index) => !explicitTargetIndexes.includes(index));\n  return appendPlaywrightBailOption(\n    [...base, 'test', ...normalizedTargets, ...restWithoutExplicitTarget, ...forwardedPlaywrightArgs],\n    bail\n  );\n}\n\nfunction appendPlaywrightBailOption(commandArgs: string[], bail?: boolean): string {\n  const playwrightIndex = commandArgs.indexOf('playwright');\n  const isPlaywrightTestCommand = playwrightIndex !== -1 && commandArgs[playwrightIndex + 1] === 'test';\n  if (!bail || !isPlaywrightTestCommand) {\n    return buildShellCommand(commandArgs);\n  }\n  if (commandArgs.some((arg) => arg === '--max-failures' || arg.startsWith('--max-failures='))) {\n    return buildShellCommand(commandArgs);\n  }\n  return buildShellCommand([...commandArgs, '--max-failures=1']);\n}\n\nexport function findExplicitPlaywrightTargetIndexes(args: string[]): number[] {\n  let pendingValueMode: 'optional' | 'required' | undefined;\n  const targetIndexes: number[] = [];\n\n  for (const [index, arg] of args.entries()) {\n    if (pendingValueMode) {\n      if (pendingValueMode === 'required' || !arg.startsWith('-')) {\n        pendingValueMode = undefined;\n        continue;\n      }\n      pendingValueMode = undefined;\n    }\n\n    if (arg === '--') {\n      return [...targetIndexes, ...args.slice(index + 1).map((_, offset) => index + 1 + offset)];\n    }\n    if (arg.startsWith('--')) {\n      if (arg.includes('=')) continue;\n      if (PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES.has(arg)) {\n        pendingValueMode = 'required';\n      } else if (PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES.has(arg)) {\n        pendingValueMode = 'optional';\n      }\n      continue;\n    }\n    if (arg.startsWith('-') && arg !== '-') {\n      const shortOption = arg.slice(0, 2);\n      if (arg.length === 2 && PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES.has(shortOption)) {\n        pendingValueMode = 'required';\n      }\n      continue;\n    }\n    targetIndexes.push(index);\n  }\n\n  return targetIndexes;\n}\n\nconst PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES = new Set([\n  '--browser',\n  '--config',\n  '--grep',\n  '--grep-invert',\n  '--global-timeout',\n  '--max-failures',\n  '--output',\n  '--project',\n  '--repeat-each',\n  '--reporter',\n  '--retries',\n  '--shard',\n  '--test-list',\n  '--test-list-invert',\n  '--timeout',\n  '--trace',\n  '--tsconfig',\n  '--ui-host',\n  '--ui-port',\n  '--ui-title',\n  '--workers',\n]);\n\nconst PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES = new Set([\n  '--only-changed',\n  '--update-snapshots',\n  '--update-source-method',\n]);\n\nconst PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES = new Set(['-c', '-g', '-j']);\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Blitz.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass BlitzScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `blitz dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { buildEnvReaderOptionArgs } from '../../sharedOptionsBuilder.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport { buildShellCommand } from '../../utils/shell.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts, type TestE2EOptions } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass HttpServerScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    options: TestE2EOptions = {}\n  ): Promise<string> {\n    if (project.hasPlaywrightConfig) {\n      return super.testE2EProtected(project, argv, startCommand, options);\n    }\n\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const targets = argv.targets?.map(String);\n    const normalizedTargets = targets?.length ? targets : ['test/e2e/'];\n    const testCommand = this.testUnit(project, { ...argv, targets: normalizedTargets });\n    return buildShellCommand([\n      'YARN',\n      'wb',\n      'concurrently',\n      ...buildEnvReaderOptionArgs(argv),\n      '--kill-others',\n      '--success',\n      'first',\n      `${startCommand} && exit 1`,\n      `wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port} && ${testCommand}${suffix}`,\n    ]);\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Next.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass NextScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `next dev --turbopack ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.js';\nimport { SERVER_LOG_FILE } from '../../utils/log.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PlainAppScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected startDevProtected(_1: Project, _2: ScriptArgv): string {\n    throw new Error('This method should not be called.');\n  }\n\n  override startDev(_: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`\n    );\n  }\n  override startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${project.buildCommand} && ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''} | tee ${SERVER_LOG_FILE}`\n    );\n  }\n  override startTest(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${this.buildDocker(project, 'development')} && ${dockerScripts.stopAndStart(\n        project,\n        argv.normalizedDockerOptionsText ?? '',\n        argv.normalizedArgsText ?? ''\n      )}`\n    );\n  }\n\n  override testE2EDev(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EProduction(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EDocker(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testStart(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Remix commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass RemixScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `remix dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Vite-based apps with Playwright e2e tests.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass ViteScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN vite dev ${argv.normalizedArgsText ?? ''}`.trim();\n  }\n\n  protected override startProductionProtected(project: Project, argv: ScriptArgv): string {\n    return `${project.buildCommand} && YARN vite preview ${argv.normalizedArgsText ?? ''}`.trim();\n  }\n}\n\nexport const viteScripts = new ViteScripts();\n","export const httpServerPackages = ['express', 'fastify', 'elysia', 'hono'];\n","import chalk from 'chalk';\nimport type { Argv, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { normalizeArgs, scriptOptionsBuilder } from '../scripts/builder.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug | test',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const startCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'start [args..]',\n  describe:\n    \"Start app. Use '--' to stop wb option parsing and forward the remaining arguments to the underlying app command. Example: wb start -- --host 0.0.0.0\",\n  builder: (yargs: Argv<unknown>) =>\n    yargs.parserConfiguration({ 'populate--': true }).options(builder) as Argv<\n      InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>\n    >,\n  async handler(argv) {\n    normalizeArgs(argv);\n\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of projects.descendants) {\n      const deps = project.packageJson.dependencies ?? {};\n      const devDeps = project.packageJson.devDependencies ?? {};\n      let scripts: BaseScripts;\n      if (deps.blitz) {\n        scripts = blitzScripts;\n      } else if (deps.next) {\n        scripts = nextScripts;\n      } else if (devDeps['@remix-run/dev']) {\n        scripts = remixScripts;\n      } else if (devDeps.vite) {\n        scripts = viteScripts;\n      } else if (\n        (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) ||\n        (project.hasDockerfile && /EXPOSE\\s+8080/.test(project.dockerfile))\n      ) {\n        scripts = httpServerScripts;\n      } else if (deps['build-ts'] || devDeps['build-ts']) {\n        scripts = plainAppScripts;\n      } else {\n        continue;\n      }\n      console.info(`Running \"start\" for ${project.name} ...`);\n\n      switch (argv.mode ?? 'dev') {\n        case 'dev':\n        case 'development': {\n          process.env.WB_ENV ||= 'development';\n          await runWithSpawn(await scripts.startDev(project, argv), project, argv);\n          break;\n        }\n        case 'staging': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startProduction(project, argv), project, argv);\n          break;\n        }\n        case 'docker': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          process.env.WB_ENV ||= 'staging';\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'test': {\n          process.env.WB_ENV ||= 'test';\n          const script = await scripts.startTest(project, argv);\n          await runWithSpawn(script, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport { distance } from 'fastest-levenshtein';\nimport type { Argv, ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { scriptOptionsBuilder } from '../scripts/builder.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { findExplicitPlaywrightTargetIndexes } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst ANSI_ESCAPE_CODE_REGEXP = new RegExp(`${String.fromCodePoint(27)}\\\\[[0-?]*[ -/]*[@-~]`, 'g');\nconst SIMILAR_TEST_OUTPUT_LOOKBACK_LINE_COUNT = 200;\nconst SIMILAR_TEST_OUTPUT_DISTANCE_RATIO = 0.05;\n\nconst builder = {\n  e2e: {\n    description: 'How to run E2E tests',\n    type: 'string',\n    choices: [\n      'headless',\n      'headless-dev',\n      'headed',\n      'headed-dev',\n      'docker',\n      'docker-debug',\n      'debug',\n      'generate',\n      'trace',\n    ],\n    default: 'headless',\n  },\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n  bail: {\n    description: 'Stop tests after the first failure',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  targets: {\n    array: true,\n    description: 'Unit or E2E test target paths',\n    type: 'string',\n  },\n} as const;\n\ntype TestCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>;\n\nexport type TestArgv = Partial<\n  ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder & typeof argumentsBuilder>>\n>;\n\nexport type TestCommandArgv = ArgumentsCamelCase<TestCommandOptions> & { '--'?: string[] };\n\nexport const testCommand: CommandModule<unknown, TestCommandOptions> = {\n  command: 'test [targets...]',\n  describe:\n    \"Test project. If you pass no arguments, it will run all tests. Use '--' to stop wb option parsing and forward the remaining flags to Playwright. Example: wb test -- --grep 'uploaded image asset'\",\n  builder: (yargs: Argv<unknown>): Argv<TestCommandOptions> =>\n    yargs\n      .parserConfiguration({ 'populate--': true })\n      .options(builder)\n      .positional('targets', argumentsBuilder.targets) as Argv<TestCommandOptions>,\n  async handler(argv) {\n    await test(argv as TestCommandArgv);\n  },\n};\n\nexport async function test(argv: TestCommandArgv): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.FORCE_COLOR ||= '3';\n  delete process.env.NO_COLOR;\n  process.env.WB_ENV ||= 'test';\n\n  // Get test targets from positional arguments\n  const testTargets = (argv.targets ?? []) as string[];\n  const forwardedPlaywrightArgs = argv['--'] ?? [];\n  const { shouldRunE2e, shouldRunUnit } = resolveTestExecutionTargets(testTargets, forwardedPlaywrightArgs);\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (devDeps.vite) {\n      scripts = viteScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    // Run unit tests if needed\n    const defaultUnitTargets = getDefaultUnitTargets(project);\n    if (shouldRunUnit && defaultUnitTargets !== false) {\n      const unitTargets = testTargets.filter((target) => target.includes('/unit'));\n      const targets =\n        unitTargets.length > 0 ? unitTargets : defaultUnitTargets.length > 0 ? defaultUnitTargets : undefined;\n      const unitArgv = { ...argv, targets };\n      await runTestCommand(scripts.testUnit(project, unitArgv), project, argv, { timeout: argv.unitTimeout });\n    }\n    // Skip e2e tests if not needed or no e2e directory exists\n    if (!shouldRunE2e || !fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      continue;\n    }\n\n    // Get e2e targets for this project\n    const e2eTargets = testTargets.filter((target) => target.includes('/e2e'));\n    const e2eArgv = { ...argv, targets: e2eTargets.length > 0 ? e2eTargets : undefined };\n\n    switch (argv.e2e) {\n      case 'headless': {\n        await runTestCommand(\n          await scripts.testE2EProduction(project, e2eArgv, {\n            playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n            forwardedPlaywrightArgs,\n          }),\n          project,\n          argv\n        );\n        continue;\n      }\n      case 'headless-dev': {\n        await runTestCommand(\n          await scripts.testE2EDev(project, e2eArgv, {\n            playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n            forwardedPlaywrightArgs,\n          }),\n          project,\n          argv\n        );\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(\n          project,\n          e2eArgv,\n          scripts,\n          buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs),\n          forwardedPlaywrightArgs\n        );\n        continue;\n      }\n      case 'docker-debug': {\n        await testOnDocker(\n          project,\n          e2eArgv,\n          scripts,\n          buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--debug']),\n          forwardedPlaywrightArgs\n        );\n        continue;\n      }\n    }\n    if (deps.blitz || deps.next || devDeps['@remix-run/dev'] || devDeps.vite) {\n      switch (argv.e2e) {\n        case 'headed': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--headed']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'headed-dev': {\n          await runTestCommand(\n            await scripts.testE2EDev(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--headed']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'debug': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: buildPlaywrightArgsForE2E(e2eTargets, forwardedPlaywrightArgs, ['--debug']),\n              forwardedPlaywrightArgs,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'generate': {\n          await runTestCommand(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: ['codegen', `http://localhost:${project.env.PORT}`],\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'trace': {\n          await runTestCommand(`BUN playwright show-trace`, project, argv);\n          break;\n        }\n      }\n    }\n  }\n}\n\nfunction getDefaultUnitTargets(project: Project): string[] | false {\n  if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n    return [];\n  }\n  if (project.hasVitest && fs.existsSync(path.join(project.dirPath, 'test'))) {\n    return fs.existsSync(path.join(project.dirPath, 'test', 'e2e')) ? ['test', '--exclude', 'test/e2e/**'] : ['test'];\n  }\n  return false;\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof argumentsBuilder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string[],\n  forwardedPlaywrightArgs?: string[]\n): Promise<void> {\n  project.env.WB_DOCKER ||= '1';\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n  process.exitCode = await runTestCommand(\n    await scripts.testE2EDocker(project, argv, {\n      playwrightArgs,\n      forwardedPlaywrightArgs,\n    }),\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n\nfunction runTestCommand(\n  script: string,\n  project: Project,\n  argv: Parameters<typeof runWithSpawn>[2],\n  options: Parameters<typeof runWithSpawn>[3] = {}\n): Promise<number> {\n  return runWithSpawn(script, project, argv, {\n    ...options,\n    processSilentOutput: dedupeNoisyTestOutput,\n  });\n}\n\nfunction dedupeNoisyTestOutput(output: string): string {\n  const recentPrintedLines: string[] = [];\n  const recentPrintedLineSet = new Set<string>();\n  const dedupedLines: string[] = [];\n  for (const line of iterateLines(output)) {\n    const normalizedLine = normalizeLineForSimilarity(line);\n    if (recentPrintedLineSet.has(normalizedLine)) continue;\n    if (recentPrintedLines.some((printedLine) => areLinesSimilar(printedLine, normalizedLine))) continue;\n\n    pushRecentPrintedLine(recentPrintedLines, recentPrintedLineSet, normalizedLine);\n    dedupedLines.push(line);\n  }\n  return dedupedLines.join('\\n');\n}\n\nfunction* iterateLines(output: string): Generator<string> {\n  let lineStartIndex = 0;\n  while (lineStartIndex <= output.length) {\n    const lineEndIndex = output.indexOf('\\n', lineStartIndex);\n    if (lineEndIndex === -1) {\n      yield output.slice(lineStartIndex);\n      return;\n    }\n\n    yield output.slice(lineStartIndex, lineEndIndex);\n    lineStartIndex = lineEndIndex + 1;\n  }\n}\n\nfunction pushRecentPrintedLine(lines: string[], lineSet: Set<string>, line: string): void {\n  lines.push(line);\n  lineSet.add(line);\n  if (lines.length <= SIMILAR_TEST_OUTPUT_LOOKBACK_LINE_COUNT) return;\n\n  const removedLine = lines.shift();\n  if (removedLine !== undefined) {\n    lineSet.delete(removedLine);\n  }\n}\n\nfunction normalizeLineForSimilarity(line: string): string {\n  return line\n    .replaceAll(ANSI_ESCAPE_CODE_REGEXP, '')\n    .trim()\n    .replaceAll(/^(?:\\[[^\\]]+\\]\\s*)+/g, '')\n    .replaceAll(/\\(node:\\d+\\)/g, '(node:<number>)')\n    .replaceAll(/\\b\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d+)?Z?\\b/g, '<timestamp>')\n    .replaceAll(/([?&]cache=)\\d+/g, '$1<number>');\n}\n\nfunction areLinesSimilar(a: string, b: string): boolean {\n  const maxLength = Math.max(a.length, b.length);\n  if (maxLength === 0) return true;\n  if (Math.abs(a.length - b.length) > maxLength * SIMILAR_TEST_OUTPUT_DISTANCE_RATIO) return false;\n\n  return distance(a, b) / maxLength <= SIMILAR_TEST_OUTPUT_DISTANCE_RATIO;\n}\n\nexport function buildPlaywrightArgsForE2E(\n  e2eTargets: string[],\n  forwardedPlaywrightArgs: string[] = [],\n  additionalArgs: string[] = []\n): string[] {\n  const hasForwardedPlaywrightTargets = findExplicitPlaywrightTargetIndexes(forwardedPlaywrightArgs).length > 0;\n  return ['test', ...(e2eTargets.length > 0 || hasForwardedPlaywrightTargets ? [] : ['test/e2e/']), ...additionalArgs];\n}\n\nexport function resolveTestExecutionTargets(\n  testTargets: string[],\n  forwardedPlaywrightArgs: string[] = []\n): { shouldRunUnit: boolean; shouldRunE2e: boolean } {\n  const hasE2eTargets = testTargets.some((target) => target.includes('/e2e'));\n  const hasUnitTargets = testTargets.some((target) => target.includes('/unit'));\n  const shouldRunAllTests = testTargets.length === 0 && forwardedPlaywrightArgs.length === 0;\n\n  return {\n    shouldRunUnit: shouldRunAllTests || hasUnitTargets,\n    shouldRunE2e: shouldRunAllTests || hasE2eTargets || forwardedPlaywrightArgs.length > 0,\n  };\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { viteScripts } from '../scripts/execution/viteScripts.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst testOnCiBuilder = {\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n} as const;\nexport const testOnCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'test-on-ci',\n  describe: 'Test project on CI with no options.',\n  builder: testOnCiBuilder,\n  async handler(argv) {\n    await testOnCi(argv);\n  },\n};\n\nexport async function testOnCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.CI ||= '1';\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (devDeps.vite) {\n      scripts = viteScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test-on-ci\" for ${project.name} ...`);\n\n    const hasDockerfile = project.hasDockerfile;\n    if (hasDockerfile) {\n      await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n    }\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      // CI mode disallows `only` to avoid including debug tests\n      await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv);\n    }\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      // Confirm dev server startup for consistency across projects with E2E tests.\n      await runWithSpawnInParallel(await scripts.testStart(project, argv), project, argv);\n      await promisePool.promiseAll();\n      if (hasDockerfile) {\n        project.env.WB_DOCKER ||= '1';\n        await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n      }\n      const script = hasDockerfile\n        ? await scripts.testE2EDocker(project, argv, {})\n        : await scripts.testE2EProduction(project, argv, {});\n      process.exitCode = await runWithSpawn(\n        // CI mode disallows `only` to avoid including debug tests\n        script.replaceAll(' --allowOnly', ''),\n        project,\n        argv,\n        {\n          exitIfFailed: false,\n        }\n      );\n      if (hasDockerfile) {\n        await runWithSpawn(dockerScripts.stop(project), project, argv);\n      }\n    }\n  }\n}\n","import { constants } from 'node:os';\n\nimport { treeKill } from '@willbooster/shared-lib-node/src';\nimport type { Argv, CommandModule } from 'yargs';\n\ninterface TreeKillCommandArgs {\n  pid: number;\n  signal: string;\n}\n\nconst builder = (yargs: Argv): Argv<TreeKillCommandArgs> =>\n  yargs\n    .positional('pid', {\n      description: 'The process ID to kill.',\n      type: 'number',\n      demandOption: true,\n    })\n    .option('signal', {\n      description: 'Signal to send to the process tree.',\n      type: 'string',\n      default: 'SIGTERM',\n    }) as Argv<TreeKillCommandArgs>;\n\nexport const treeKillCommand: CommandModule<object, TreeKillCommandArgs> = {\n  command: 'tree-kill <pid> [signal]',\n  describe: 'Kill the given process and all descendants',\n  builder,\n  handler(argv) {\n    try {\n      const signal = argv.signal as NodeJS.Signals;\n      if (!(signal in constants.signals)) {\n        throw new Error(`Invalid signal: ${signal}`);\n      }\n      treeKill(argv.pid, signal);\n    } catch (error) {\n      console.error(error instanceof Error ? error.message : String(error));\n      process.exit(1);\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport type { Project } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {} as const;\n\ntype TypeCheckCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>;\nexport type TypeCheckCommandArgv = ArgumentsCamelCase<TypeCheckCommandOptions>;\n\nexport const typeCheckCommand: CommandModule<unknown, TypeCheckCommandOptions> = {\n  command: 'typecheck',\n  describe: 'Run type checking. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    process.exit(await typeCheck(argv));\n  },\n};\n\nexport async function typeCheck(argv: TypeCheckCommandArgv): Promise<number> {\n  const projects = await findDescendantProjects(argv, false);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    return 1;\n  }\n\n  let removedNextDir = false as boolean;\n  const promises = projects.descendants.map(async (project) => {\n    const commands: string[] = [];\n    if (!project.packageJson.workspaces || project.hasSourceCode) {\n      commands.push(...buildTypeScriptTypeCheckCommands(project));\n    }\n    if (!project.packageJson.workspaces && project.hasOwnDependency('pyright')) {\n      commands.push('YARN pyright');\n    }\n    while (commands.length > 0) {\n      const exitCode = await runWithSpawnInParallel(commands.join(' && '), project, argv, {\n        // Disable interactive mode\n        ci: projects.descendants.length > 1,\n        exitIfFailed: false,\n        forceColor: true,\n      });\n\n      // Re-try type checking after removing `.next` directory\n      const nextDirPath = path.join(project.dirPath, '.next');\n      if (exitCode && fs.existsSync(nextDirPath)) {\n        fs.rmSync(nextDirPath, { force: true, recursive: true });\n        console.info(chalk.yellow('Removed `.next` directory. We will re-try type checking.'));\n        removedNextDir = true;\n        continue;\n      }\n\n      return exitCode;\n    }\n  });\n  const exitCodes = await Promise.all(promises);\n  let finalExitCode = 0;\n  for (const [i, exitCode] of exitCodes.entries()) {\n    if (exitCode) {\n      const deps = projects.descendants[i]?.packageJson.dependencies ?? {};\n      if (deps.blitz) {\n        console.info(chalk.yellow('Please try \"yarn gen-code\" if you face unknown type errors.'));\n      }\n      finalExitCode = exitCode;\n    }\n  }\n  if (!finalExitCode)\n    console.info(\n      chalk.green(\n        removedNextDir\n          ? '-----\\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.'\n          : 'No type errors found.'\n      )\n    );\n  return finalExitCode;\n}\n\nfunction buildTypeScriptTypeCheckCommands(project: Project): string[] {\n  if (project.hasOwnDependency('@typescript/native-preview')) {\n    return ['BUN tsgo --noEmit'];\n  }\n  if (project.hasOwnDependency('typescript')) {\n    return ['BUN tsc --noEmit'];\n  }\n  return [];\n}\n\nexport const tcCommand: CommandModule<unknown, TypeCheckCommandOptions> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findRootAndSelfProjects } from '../project.js';\nimport { configureEnv } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { lint, type LintCommandArgv } from './lint.js';\nimport { test, type TestCommandArgv } from './test.js';\n\nconst builder = {\n  full: {\n    type: 'boolean',\n    default: false,\n    describe: 'Run tests after verifying project code',\n  },\n} as const;\n\ntype VerifyCodeCommandOptions = InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>;\ntype VerifyCodeCommandArgv = ArgumentsCamelCase<VerifyCodeCommandOptions>;\n\nexport const verifyCodeCommand: CommandModule<unknown, VerifyCodeCommandOptions> = {\n  command: 'verify',\n  describe: 'Verify project code',\n  builder,\n  async handler(argv) {\n    const projects = findRootAndSelfProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    await (argv.full ? verifyCodeFully(projects.self, argv) : verifyCode(projects.self, argv));\n  },\n};\n\nasync function verifyCodeFully(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  const reporter = startVerifyFullReporter(project);\n  try {\n    await verifyCode(project, argv);\n    await runProjectTest(project, argv);\n    reporter.succeed();\n  } catch (error) {\n    reporter.fail(error);\n    throw error;\n  } finally {\n    reporter.finish();\n  }\n}\n\nasync function verifyCode(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  await runPackageCommand(`${packageManager} install`, project, argv);\n  if (project.packageJson.scripts?.['gen-code']) {\n    await runPackageCommand(`${packageManager} gen-code`, project, argv);\n  }\n  await runInProcessCommand(\n    'format',\n    () =>\n      lint({\n        ...argv,\n        _: ['lint'],\n        format: true,\n        printAllOutput: true,\n        silent: true,\n      } as unknown as LintCommandArgv),\n    {\n      allowFailure: true,\n      silent: true,\n    }\n  );\n  await runInProcessCommand(\n    'lint-fix',\n    () =>\n      lint({\n        ...argv,\n        _: ['lint'],\n        fix: true,\n        printAllOutput: true,\n        quiet: true,\n        silent: true,\n      } as unknown as LintCommandArgv),\n    { silent: true }\n  );\n}\n\nasync function runProjectTest(project: Project, argv: VerifyCodeCommandArgv): Promise<void> {\n  await test({ ...argv, _: ['test'], e2e: 'headless', silent: true } as unknown as TestCommandArgv);\n}\n\nasync function runInProcessCommand(\n  commandName: string,\n  command: () => Promise<number | undefined>,\n  options: { allowFailure?: boolean; silent?: boolean } = {}\n): Promise<number> {\n  if (!options.silent) {\n    console.info('\\n' + chalk.cyan(chalk.bold('Start:'), commandName));\n  }\n  const exitCode = (await command()) ?? 0;\n  if (exitCode === 0 || options.allowFailure) {\n    if (!options.silent) {\n      console.info(chalk.green(chalk.bold('Finished:'), commandName));\n    }\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}):`), commandName));\n    process.exit(exitCode);\n  }\n  return exitCode;\n}\n\nasync function runPackageCommand(\n  command: string,\n  project: Project,\n  argv: VerifyCodeCommandArgv,\n  options: { allowFailure?: boolean; printRawOutput?: boolean } = {}\n): Promise<number> {\n  printCommand(command, project.dirPath);\n  if (argv.dryRun) {\n    return 0;\n  }\n\n  const ret = await spawnAsync(command, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, { forceColor: false }),\n    shell: true,\n    stdio: 'pipe',\n    mergeOutAndError: true,\n    killOnExit: true,\n    printingStdout: options.printRawOutput,\n    printingStderr: options.printRawOutput,\n    verbose: argv.verbose,\n  });\n  const exitCode = ret.status ?? 1;\n  if (!options.printRawOutput) {\n    printPackageCommandOutput(command, exitCode, ret.stdout);\n  }\n\n  if (exitCode !== 0 && !options.allowFailure) {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}):`), command));\n    process.exit(exitCode);\n  }\n  return exitCode;\n}\n\n/**\n * Prints package command output for `wb verify`.\n *\n * `wb verify` is primarily consumed by AI coding agents, so successful noisy\n * commands are summarized while failure output remains available for diagnosis.\n *\n * @param command The executed command.\n * @param exitCode The command exit code.\n * @param output The merged stdout and stderr output from the command.\n */\nfunction printPackageCommandOutput(command: string, exitCode: number, output: string): void {\n  if (exitCode === 0 && (command === `${packageManager} install` || command === `${packageManager} gen-code`)) {\n    console.info(chalk.green('Succeeded.'));\n    return;\n  }\n\n  const trimmedOutput = output.trim();\n  if (trimmedOutput) {\n    process.stdout.write(trimmedOutput);\n    process.stdout.write('\\n');\n  }\n}\n\nfunction printCommand(command: string, cwd: string): void {\n  console.info('\\n' + chalk.cyan(chalk.bold('Command:'), command) + chalk.gray(` at ${cwd}`));\n}\n\nfunction startVerifyFullReporter(project: Project): {\n  fail: (error?: unknown) => void;\n  finish: () => void;\n  succeed: () => void;\n} {\n  const startedAt = Date.now();\n  const wbDirPath = path.join(project.dirPath, '.wb');\n  fs.mkdirSync(wbDirPath, { recursive: true });\n\n  const logFilePath = path.join(wbDirPath, 'verify-full.log');\n  const logFile = fs.openSync(logFilePath, 'w');\n  const originalStdoutWrite = process.stdout.write.bind(process.stdout);\n  const originalStderrWrite = process.stderr.write.bind(process.stderr);\n  let succeeded = false;\n  let finished = false;\n\n  process.stdout.write = teeWrite(process.stdout.fd, logFile) as typeof process.stdout.write;\n  process.stderr.write = teeWrite(process.stderr.fd, logFile) as typeof process.stderr.write;\n  console.info(chalk.cyan(chalk.bold('Full log:'), logFilePath));\n\n  const finish = (): void => {\n    if (finished) return;\n    finished = true;\n\n    process.stdout.write = originalStdoutWrite as typeof process.stdout.write;\n    process.stderr.write = originalStderrWrite as typeof process.stderr.write;\n\n    const elapsedTime = formatElapsedTime(Date.now() - startedAt);\n    const status = succeeded ? 'Succeeded' : 'Failed';\n    const summary = `${status} in ${elapsedTime}. Full log: ${logFilePath}\\n`;\n    const coloredSummary = succeeded ? chalk.green(summary) : chalk.red(summary);\n    originalStdoutWrite(coloredSummary);\n    fs.writeSync(logFile, summary);\n    fs.closeSync(logFile);\n  };\n\n  process.once('exit', finish);\n\n  return {\n    fail: (error) => {\n      succeeded = false;\n      if (error) {\n        console.error(error);\n      }\n    },\n    finish: () => {\n      process.removeListener('exit', finish);\n      finish();\n    },\n    succeed: () => {\n      succeeded = true;\n    },\n  };\n}\n\nfunction teeWrite(outputFile: number, logFile: number): typeof process.stdout.write {\n  return ((\n    chunk: Uint8Array | string,\n    encodingOrCallback?: BufferEncoding | ((error?: Error | null) => void),\n    callback?: (error?: Error | null) => void\n  ) => {\n    const buffer =\n      typeof chunk === 'string'\n        ? Buffer.from(chunk, typeof encodingOrCallback === 'string' ? encodingOrCallback : 'utf8')\n        : chunk;\n    fs.writeSync(logFile, buffer);\n    fs.writeSync(outputFile, buffer);\n    if (typeof encodingOrCallback === 'function') {\n      encodingOrCallback();\n    }\n    callback?.();\n    return true;\n  }) as typeof process.stdout.write;\n}\n\nfunction formatElapsedTime(milliseconds: number): string {\n  const seconds = Math.round(milliseconds / 1000);\n  const minutes = Math.floor(seconds / 60);\n  const remainingSeconds = seconds % 60;\n  if (minutes === 0) {\n    return `${remainingSeconds}s`;\n  }\n  return `${minutes}m ${remainingSeconds}s`;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables, treeKill } from '@willbooster/shared-lib-node/src';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.js';\nimport { concurrentlyCommand } from './commands/concurrently.js';\nimport { killPortIfNonCiCommand } from './commands/killPortIfNonCi.js';\nimport { lintCommand } from './commands/lint.js';\nimport { optimizeForDockerBuildCommand } from './commands/optimizeForDockerBuild.js';\nimport { prismaCommand } from './commands/prisma.js';\nimport { retryCommand } from './commands/retry.js';\nimport { setupCommand } from './commands/setup.js';\nimport { startCommand } from './commands/start.js';\nimport { testCommand } from './commands/test.js';\nimport { testOnCiCommand } from './commands/testOnCi.js';\nimport { treeKillCommand } from './commands/treeKill.js';\nimport { tcCommand, typeCheckCommand } from './commands/typecheck.js';\nimport { verifyCodeCommand } from './commands/verifyCode.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nawait yargs(hideBin(process.argv))\n  .scriptName('wb')\n  .options(sharedOptionsBuilder)\n  .middleware((argv) => {\n    const workingDir = argv['working-dir'];\n    if (workingDir) {\n      const dirPath = path.resolve(workingDir);\n      process.chdir(dirPath);\n    }\n\n    removeNpmAndYarnEnvironmentVariables(process.env);\n  })\n  .command(verifyCodeCommand)\n  .command(buildIfNeededCommand)\n  .command(concurrentlyCommand)\n  .command(killPortIfNonCiCommand)\n  .command(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(testOnCiCommand)\n  .command(treeKillCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n\nlet shuttingDown = false;\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => {\n    if (shuttingDown) return;\n\n    shuttingDown = true;\n    try {\n      treeKill(process.pid);\n    } catch (error) {\n      console.warn(`Failed to treeKill(${process.pid}) during shutdown:`, error);\n    }\n    process.exit();\n  });\n}\n"],"names":["yargsOptionsBuilderForEnv","env","description","type","default","verbose","alias","cachedEnvVars","Map","readEnvFile","filePath","cached","get","parsed","config","path","resolve","processEnv","quiet","set","isErrnoException","error","Error","treeKill","pid","signal","Number","isInteger","process","platform","runCommand","String","maxBuffer","timeout","isNoSuchProcessError","killTreeOnWindows","descendants","rootPid","stdout","childrenByParent","psOutput","line","split","matched","exec","childPid","parentPid","children","push","buildChildrenByParentMap","queue","index","length","collectDescendantPidsFromMap","collectDescendantPids","targetPids","toReversed","toChildrenFirstPids","targetPid","killIfNeeded","kill","command","args","options","execFileSync","encoding","stdio","stderr","Buffer","isBuffer","toString","extractStderr","CommandExecutionError","code","status","toExitCode","test","constructor","super","join","this","name","async","spawnAsync","Promise","reject","proc","spawn","setEncoding","stdoutPrinter","createRealtimePrinter","omitBlankLinesWhilePrinting","stderrPrinter","on","data","printingStdout","write","mergeOutAndError","printingStderr","stopped","stopProcess","console","info","warn","cleanupSignals","signalHandlers","removeKillOnExitHandlers","removeListener","handler","clear","killOnExit","handleSignal","listenerCount","removeAllListeners","flush","undefined","input","stdin","end","ANSI_ESCAPE_CODE_REGEXP","RegExp","fromCodePoint","stream","omitBlankLines","pending","lines","pop","isBlankLine","replaceAll","trim","t","s","i","e","n","entries","h","blocks","reset","finalized","block","start","lastByteIndex","padding","outputBits","blockCount","byteCount","outputBlocks","extraBytes","update","o","l","c","f","codePointAt","r","finalize","hex","a","u","d","b","k","y","x","B","p","C","z","I","g","w","A","P","E","j","m","q","v","D","F","G","H","J","K","L","M","N","O","Q","R","S","T","U","V","W","X","Y","Z","$","_","tt","st","it","et","ot","nt","ht","rt","lt","ct","ft","instance","from","message","stack","cause","stub","hydrate","Uint8Array","btoa","decode","create","encode","atob","Set","values","add","Date","toJSON","flags","source","URL","href","map","TextEncoder","TextDecoder","JSON","stringify","isNaN","isFinite","Array","isArray","fill","slice","Object","cacheDuration","POSITIVE_INFINITY","getCacheKey","kind","now","call","isCI","ciEnv","Project","_initProto","_applyDecs","memoizeOne","argv","pathByName","dirPath","loadEnv","_dirPath","isBunAvailable","hasBunToolVersion","usesBunPackageManager","hasBunLockfile","hasBunPackageManager","fs","readFileSync","rootDirPath","some","fileName","existsSync","packageManager","rootPackageJson","packageJson","startsWith","buildCommand","scripts","build","includes","dockerfile","findFile","hasDockerfile","hasSourceCode","dockerImageName","envVars","envPathAndLoadedEnvVarCountPairs","cwd","envPaths","envPath","cascade","cascadeEnv","cascadeNodeEnv","NODE_ENV","autoCascadeEnv","WB_ENV","includeRootEnv","rootPath","flatMap","filter","relative","envPathAndLoadedEnvVarNames","keys","key","value","checkEnv","missingKeys","expand","readEnvironmentVariables","count","parse","packageJsonPath","hasPrisma","getOwnDependencyVersion","hasDrizzle","databaseOrm","hasVitest","dependencies","vitest","devDependencies","hasOxlint","hasDependency","hasOxfmt","hasPrettier","hasPoetryLock","hasPubspecYaml","preferredLinter","hasOwnDependency","packageName","hasPlaywrightConfig","skipLaunchingServerForPlaywright","CI","configPath","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","find","getDependencyVersion","optionalDependencies","peerDependencies","findSelfProject","findDescendantProjects","rootAndSelfProjects","findRootAndSelfProjects","root","self","getAllDescendantProjects","thisProject","rootProject","workspaces","endsWith","projects","workspace","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","versions","bun","npm_execpath","runtimeWithArgs","packageManagerWithRun","buildIfNeededCommand","describe","projectPathForTesting","project","chalk","red","green","canSkip","cacheFilePath","contentHash","cacheDirectoryPath","promises","mkdir","recursive","hash","createHash","commitHash","child_process","execSync","environmentJson","ignoringEnvVarNames","has","toSorted","key1","key2","localeCompare","filteredFilePaths","spawnSync","replace","includePatterns","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","normalizedScript","normalizeScript","printStart","printable","silent","runnable","printFinishedAndExitIfNeeded","silentSuccess","shouldProcessSilentOutput","Boolean","processSilentOutput","configureEnv","output","onSignal","runWithSpawnInParallel","runAndWaitForReturnValue","printRawOutput","out","projectPackageManagerWithRun","newScript","blitz","printableScript","fixBunCommand","runnableScript","prefix","weak","gray","cyan","bold","printOptions","exit","newEnv","ci","forceColor","FORCE_COLOR","sharedOptionsBuilder","buildEnvReaderOptionArgs","optionName","getOptionValue","item","camelCaseOptionName","character","toUpperCase","concurrentlyCommand","builder","success","choices","commands","detached","interruptedSignal","firstResult","stopResult","stopping","forceKillPromises","results","waitForExitPromises","child","settled","settle","killOthers","killOthersOnFail","shouldStopOthers","terminateChildren","once","getExitCode","stopAll","stopOnSigint","stopOnSigterm","stopOnSigquit","all","result","runConcurrently","constants","signals","forceKillPids","signalPids","toChildPids","pids","deadline","every","isProcessGroupGone","sleep","Math","min","waitForForceKill","signaledPids","killProcessGroup","ms","setTimeout","killPortIfNonCiCommand","portEnv","PORT","port","killPortProcess","killPortIfNonCi","printBufferedOutput","hasWarningOutput","removeNoColorWarning","shouldPrintBufferedOutput","normalizedOutput","normalizeBufferedOutput","buildShellCommand","arg","shellEscapeArgument","oxlintExtensions","pythonExtensions","dartExtensions","oxfmtExtensions","prettierExtensions","prettierOnlyExtensions","ext","prettierFixtureIgnorePattern","lintCommand","fix","format","lint","files","lintTargets","getLintTargetFiles","lintFilePathsByProject","oxfmtFilePathsByProject","pythonFilePathsByProject","dartFilePathsByProject","prettierFilePaths","packageJsonFilePaths","prettierArgs","sortPackageJsonArgs","missingLintToolForExplicitFiles","file","fileKind","stat","isDirectory","getLintTargetFileKind","extension","extname","getExplicitPackageJsonPaths","lintPath","getExplicitLintTargets","pythonFilePaths","dartFilePaths","supportsLintingExtension","lintFilePaths","oxfmtFilePaths","buildPrettierOnlyDirectoryPattern","formatterPath","buildExplicitFormatterArgs","isPotentialLintTarget","selfDirPath","needsPrettier","projectPattern","buildPrettierArgs","lintPromises","lintRunOptions","printAllOutput","buildLintCommand","runLintCommand","buildOxfmtCommand","buildPoetryCommand","buildDartCommand","lintResults","printSilentLintOutputs","lintExitCodes","prettierResult","sortPackageJsonResult","runWithSpawnInParallelBuffered","then","printableResults","printCommandOutput","printCommandHeader","targets","shouldFormatExplicitPathWithPrettier","descendantProjects","owningProject","findOwningProject","prepareForRunningCommand","commandName","runtimeDevDependencies","optimizeForDockerBuildCommand","outside","deps","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","promotedDeps","version","promoteRuntimeDevDependencies","nameWordsToBeRemoved","removedDeps","word","removeUnnecessaryDevDependenciesForOutsideDockerBuild","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","removedScripts","content","private","publishConfig","prettier","FILE_SCHEMA","drizzleScripts","deploy","additionalOptions","migrate","_project","migrateDev","removeCommand","dbPath","DATABASE_PATH","dbUrl","DATABASE_URL","rawDbPath","getFileDatabaseUrlPath","absolutePath","isAbsolute","buildRemoveSqliteDbCommand","seed","scriptPath","studio","dbUrlOrPath","POSSIBLE_PRISMA_PATHS","schemaPath","getDatabaseDirPath","getPrismaBaseDir","prismaScripts","cleanUpLitestream","deployForce","removeDbCommand","listBackups","steps","cleanupCommand","baseDir","cleanUpSqliteDbIfNeeded","resetCommand","restore","outputPath","prisma","prismaCommand","aliases","yargs","parserConfiguration","cleanUpLitestreamCommand","createLitestreamConfigCommand","deployCommand","deployForceCommand","listBackupsCommand","migrateCommand","migrateDevCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","strict","allProjects","findDatabaseOrmProjects","prepareForRunningDatabaseOrmCommand","createLitestreamConfig","unknownOptions","extractUnknownOptions","orm","getDatabaseOrmScripts","restored","fullCommand","trimEnd","requiredEnvVars","CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID","CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME","CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID","CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY","missingEnvVars","retentionCheckInterval","litestreamConfig","writeFileSync","reason","filtered","ormProjectByProject","ormProject","knownOptions","sharedOptionKeys","sharedOptionAliases","option","allKnownOptions","kebabCaseKey","match","toLowerCase","passthroughArgs","retryCommand","retry","cmdAndArgs","lastStatus","yellow","setupCommand","dirents","readdir","withFileTypes","os","packages","isFile","promiseAll","playwright","setup","toDevNull","killed","killPortProcessImmediatelyAndOnExit","available","host","probePort","isPortAvailable","killPortContainerAndProcess","killFunc","filterArgs","containerIds","id","listDockerContainerIds","removeDockerContainers","stopDockerContainerByPort","checkAndKillPortProcess","rawPort","server","createServer","err","close","listen","dockerScripts","buildImage","stopAndStart","additionalArgs","stop","spawnSyncOnExit","BaseScripts","shouldWaitAndOpenApp","buildDocker","startDev","startDevProtected","waitAndOpenApp","startProduction","startProductionProtected","startTest","startDocker","normalizedDockerOptionsText","normalizedArgsText","ecosystemConfigPath","findEcosystemConfigPath","cmd","testE2EDev","testE2EProtected","testE2EProduction","testE2EDocker","testStart","waitApp","startCommand","forwardedPlaywrightArgs","playwrightArgs","playwrightCommand","bail","base","normalizedTargets","appendPlaywrightBailOption","rest","explicitTargetIndexes","findExplicitPlaywrightTargetIndexes","restWithoutExplicitTarget","buildPlaywrightCommand","testUnit","commandArgs","playwrightIndex","indexOf","isPlaywrightTestCommand","pendingValueMode","targetIndexes","offset","PLAYWRIGHT_TEST_OPTIONS_WITH_REQUIRED_VALUES","PLAYWRIGHT_TEST_OPTIONS_WITH_OPTIONAL_VALUES","shortOption","PLAYWRIGHT_TEST_SHORT_OPTIONS_WITH_REQUIRED_VALUES","blitzScripts","httpServerScripts","watch","testCommand","nextScripts","plainAppScripts","_1","_2","remixScripts","viteScripts","httpServerPackages","mode","dockerOptions","normalizeArgs","next","vite","e2e","argumentsBuilder","array","positional","NO_COLOR","testTargets","shouldRunE2e","shouldRunUnit","hasE2eTargets","target","hasUnitTargets","shouldRunAllTests","resolveTestExecutionTargets","defaultUnitTargets","getDefaultUnitTargets","unitTargets","unitArgv","runTestCommand","unitTimeout","e2eTargets","e2eArgv","buildPlaywrightArgsForE2E","testOnDocker","WB_DOCKER","dedupeNoisyTestOutput","recentPrintedLines","recentPrintedLineSet","dedupedLines","lineStartIndex","lineEndIndex","iterateLines","normalizedLine","normalizeLineForSimilarity","printedLine","areLinesSimilar","pushRecentPrintedLine","lineSet","removedLine","shift","delete","maxLength","max","abs","distance","hasForwardedPlaywrightTargets","testOnCiCommand","testOnCi","treeKillCommand","demandOption","typeCheckCommand","removedNextDir","buildTypeScriptTypeCheckCommands","nextDirPath","rmSync","force","exitCodes","finalExitCode","typeCheck","tcCommand","verifyCodeCommand","full","reporter","startedAt","wbDirPath","mkdirSync","logFilePath","logFile","openSync","originalStdoutWrite","bind","originalStderrWrite","succeeded","finished","teeWrite","fd","finish","elapsedTime","milliseconds","seconds","round","minutes","floor","remainingSeconds","formatElapsedTime","summary","coloredSummary","writeSync","closeSync","fail","succeed","startVerifyFullReporter","verifyCode","runProjectTest","verifyCodeFully","runPackageCommand","runInProcessCommand","allowFailure","printCommand","trimmedOutput","printPackageCommandOutput","outputFile","chunk","encodingOrCallback","callback","buffer","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","removeNpmAndYarnEnvironmentVariables","packageJsonDir","url","pathname","getVersion","help","shuttingDown"],"mappings":"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","x_google_ignoreList":[5,6,7,8,9]}