bunup 0.1.24 → 0.1.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/cli.mjs CHANGED
@@ -1,10 +1,10 @@
1
1
  #!/usr/bin/env bun
2
2
  // @bun
3
- import Y from"fs";import Xt from"path";import{isMainThread as Lt,parentPort as I,Worker as Ft,workerData as Ut}from"node:worker_threads";class O extends Error{constructor(t){super(t);this.name="BunupError"}}class w extends O{constructor(t){super(t);this.name="BunupBuildError"}}class g extends O{constructor(t){super(t);this.name="BunupDTSBuildError"}}class h extends O{constructor(t){super(t);this.name="BunupCLIError"}}class D extends O{constructor(t){super(t);this.name="BunupWatchError"}}var u=(t)=>{if(t instanceof Error)return t.message;return String(t)},Rt=(t,r)=>{let n=u(t),s=r?`[${r}] `:"",e="ERROR";if(t instanceof w)e="BUILD ERROR";else if(t instanceof g)e="DTS ERROR";else if(t instanceof h)e="CLI ERROR";else if(t instanceof D)e="WATCH ERROR";else if(t instanceof O)e="BUNUP ERROR";if(console.error(`\x1B[31m[${e}]\x1B[0m ${s}${n}`),t instanceof Error&&t.stack)console.error("\x1B[2m"+t.stack.split(`
3
+ import Q from"fs";import Vt from"path";import{isMainThread as Zt}from"worker_threads";import{isMainThread as qt,parentPort as W,Worker as Gt,workerData as Xt}from"node:worker_threads";class R extends Error{constructor(t){super(t);this.name="BunupError"}}class $ extends R{constructor(t){super(t);this.name="BunupBuildError"}}class g extends R{constructor(t){super(t);this.name="BunupDTSBuildError"}}class h extends R{constructor(t){super(t);this.name="BunupCLIError"}}class B extends R{constructor(t){super(t);this.name="BunupWatchError"}}var p=(t)=>{if(t instanceof Error)return t.message;return String(t)},St=(t,n)=>{let r=p(t),e=n?`[${n}] `:"",s="ERROR";if(t instanceof $)s="BUILD ERROR";else if(t instanceof g)s="DTS ERROR";else if(t instanceof h)s="CLI ERROR";else if(t instanceof B)s="WATCH ERROR";else if(t instanceof R)s="BUNUP ERROR";if(console.error(`\x1B[31m[${s}]\x1B[0m ${e}${r}`),t instanceof Error&&t.stack)console.error("\x1B[2m"+t.stack.split(`
4
4
  `).slice(1).join(`
5
- `)+"\x1B[0m")},K=(t,r)=>{Rt(t,r),process.exit(1)};var f={MAX_LABEL_LENGTH:5,colors:{cli:"183",info:"240",warn:"221",error:"203",progress:{ESM:"214",CJS:"114",IIFE:"105",DTS:"75"},default:"255"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(t,r,n){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length));return`\x1B[38;5;${t}m[${r}]\x1B[0m ${s}${n}`},cli(t){let r=this.labels.cli;console.log(this.formatMessage(this.colors.cli,r,t))},info(t){console.log(`\x1B[38;5;${this.colors.info}m${t}\x1B[0m`)},warn(t){let r=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,r,t))},error(t){let r=this.labels.error;console.error(this.formatMessage(this.colors.error,r,t))},progress(t,r){let n=String(t),s=this.colors.default;for(let[e,o]of Object.entries(this.colors.progress))if(n.includes(e)){s=o;break}console.log(this.formatMessage(s,n,r))}};function Q(t,r){return`${r?`${r.replace(/-/g,"_")}_`:""}${t}`.toUpperCase()}function F(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function V(t=8){return Math.random().toString(36).substring(2,2+t)}function Z(t,r){switch(t){case"esm":return".mjs";case"cjs":return T(r)?".cjs":".js";case"iife":return".global.js"}}function z(t,r){switch(t){case"esm":return".d.mts";case"cjs":return T(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function T(t){return t==="module"}function k(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function tt(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function rt(t,r){return t===void 0?r==="esm":t}import Dt from"node:fs";import St from"oxc-transform";import A from"node:path";function U(t){let r=A.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?A.resolve(r,t.data.compilerOptions.baseUrl):r}function nt(t){let r=new Map,n=t.data?.compilerOptions?.paths;if(!n)return r;let s=U(t);for(let[e,o]of Object.entries(n))if(Array.isArray(o)&&o.length){let i=e.replace(/\*/g,"(.*)"),a=o[0].replace(/\*/g,"$1");r.set(`^${i}$`,A.join(s,a))}return r}function et(t,r,n){for(let[s,e]of r){let o=new RegExp(s),i=t.match(o);if(i)return e.replace("$1",i[1]||"")}return n?A.join(n,t):null}function st(t,r){if(r===void 0)return"";let n=t.slice(0,r).split(`
6
- `),s=n.length,e=n[n.length-1].length+1;return` (${s}:${e})`}function ot(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var v=new Set;async function it(t){let r=new Map;return await Promise.all([...t].map(async(n)=>{try{let s=n.replace(/\.tsx?$/,".d.ts"),e=await Dt.promises.readFile(n,"utf8"),{code:o,errors:i}=St.isolatedDeclaration(n,e);if(i.forEach((a)=>{let l=a.labels[0],c=l?st(e,l.start):"",x=`${n.split("/").slice(-3).join("/")}${c}: ${ot(a.message)}`;if(!v.has(x))v.add(x)}),o)r.set(s,o)}catch(s){f.warn(`Failed to generate declaration for ${n}: ${u(s)}`)}})),r}import ht from"node:fs";import H from"node:path";import{loadTsConfig as bt}from"load-tsconfig";function at(t){try{return bt(".",t)}catch(r){return f.warn(`Failed to load tsconfig: ${u(r)}`),{path:t,data:{},files:[]}}}import C from"node:path";import{rollup as kt}from"rollup";import At from"rollup-plugin-dts";import _ from"typescript";function lt(t){return t.map((r)=>typeof r==="string"?new RegExp(`^${F(r)}($|\\/|\\\\)`):r)}function M(t,r){return lt(t.external||[]).concat(tt(r).map((n)=>new RegExp(`^${F(n)}($|\\/|\\\\)`)))}function j(t){return lt(t.noExternal||[])}import N from"node:fs";import ft from"node:path";var P={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0};function ct(t,r){return{outdir:`${r}/${t.outDir}`,minify:Tt(t),target:t.target,splitting:t.splitting}}function Tt(t){let{minify:r,minifyWhitespace:n,minifyIdentifiers:s,minifySyntax:e}=t,o=r===!0;return{whitespace:n??o,identifiers:s??o,syntax:e??o}}async function ut(t){let r=[];for(let n of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let s=ft.join(t,`bunup.config${n}`);try{if(!N.existsSync(s))continue;let e;if(n===".json"||n===".jsonc"){let o=N.readFileSync(s,"utf8");e=JSON.parse(o)}else{let o=await import(`file://${s}`);if(e=o.default||o,!e)f.warn(`No default export found in ${s}`),e={}}if(Array.isArray(e))for(let o of e)r.push({options:{...P,...o},rootDir:t});else r.push({options:{...P,...e},rootDir:t});break}catch(e){throw new w(`Failed to load config from ${s}: ${u(e)}`)}if(r.length>0)break}return r}function W(t){let r=ft.join(t,"package.json");try{if(!N.existsSync(r))return null;let n=N.readFileSync(r,"utf8");return JSON.parse(n)}catch(n){return f.warn(`Failed to load package.json at ${r}: ${u(n)}`),null}}async function pt(t,r,n,s,e){let a=`\x00virtual:${t.replace(/\.tsx?$/,".d.ts")}`,l=e.data?.compilerOptions,c={name:"bunup:virtual-dts",resolveId(d,E){if(d.startsWith("\x00virtual:"))return d;if(!E?.startsWith("\x00virtual:")||!d.startsWith("."))return null;let y=E.slice(9),B=C.resolve(C.dirname(y),d);if(d==="."){let R=C.join(C.dirname(y),"index.d.ts");if(r.has(R))return`\x00virtual:${R}`;B=C.dirname(y)}if(r.has(B))return`\x00virtual:${B}`;let J=`${B}.d.ts`;if(r.has(J))return`\x00virtual:${J}`;if(d.startsWith(".")){let R=C.join(B,"index.d.ts");if(r.has(R))return`\x00virtual:${R}`}return null},load(d){return d.startsWith("\x00virtual:")?r.get(d.slice(9))||null:null}},m=W(s),p=M(n,m),x=j(n),b;try{b=await kt({input:a,onwarn(E,y){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(E.code??""))return;y(E)},plugins:[c,At({tsconfig:e.path,compilerOptions:{...l?_.parseJsonConfigFileContent({compilerOptions:l},_.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:_.ScriptTarget.ESNext}})],external:(E)=>p.some((y)=>y.test(E))&&!x.some((y)=>y.test(E))});let{output:d}=await b.generate({});if(!d[0]?.code)throw new g("Generated bundle is empty");return d[0].code}catch(d){throw new g(`DTS bundling failed: ${u(d)}`)}finally{if(b)await b.close()}}import gt from"node:fs";import mt from"node:path";var Mt=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,jt=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function dt(t,r){let n=new Set([t]),s=[t],e=nt(r),o=U(r);while(s.length){let i=s.pop();if(!i)continue;try{let a=await gt.promises.readFile(i,"utf8"),l=Nt(a);for(let c of l){let m=c.startsWith(".")?mt.resolve(mt.dirname(i),c):et(c,e,o);if(!m)continue;let p=Wt(m);if(p&&!n.has(p))n.add(p),s.push(p)}}catch(a){f.warn(`Error processing ${i}: ${u(a)}`)}}return n}function Nt(t){let r=new Set;for(let n of[Mt,jt]){let s;while((s=n.exec(t))!==null)r.add(s[2])}return Array.from(r)}function Wt(t){let r=["",".ts",".tsx","/index.ts","/index.tsx"];for(let n of r){let s=`${t}${n}`;if(gt.existsSync(s)&&(s.endsWith(".ts")||s.endsWith(".tsx")))return s}return null}async function xt(t,r,n){let{absoluteRootDir:s,absoluteEntry:e}=It(t,r),o=at(n.preferredTsconfigPath),i=await dt(e,o),a=await it(i);return pt(e,a,n,s,o)}function It(t,r){let n=H.resolve(t),s=H.resolve(n,r);if(!ht.existsSync(n))throw new g(`Root directory does not exist: ${n}`);if(!ht.existsSync(s))throw new g(`Entry file does not exist: ${s}`);if(!s.endsWith(".ts"))throw new g(`Entry file must be a TypeScript file (.ts): ${s}`);if(H.relative(n,s).startsWith(".."))throw new g(`Entry file must be within rootDir: ${s}`);return{absoluteRootDir:n,absoluteEntry:s}}async function wt(t,r,n,s,e){return new Promise((o,i)=>{let a={rootDir:t,entries:r,formats:n,options:s,packageType:e},l=new Ft(new URL("./dtsWorker.js",import.meta.url),{workerData:a});l.on("message",(c)=>{if(c.success)o();else i(new g(c.error||"Unknown DTS worker error"))}),l.on("error",i),l.on("exit",(c)=>{if(c!==0)i(new g(`DTS worker stopped with exit code ${c}`))})})}if(!Lt&&I){let{rootDir:t,entries:r,formats:n,options:s,packageType:e}=Ut,o=performance.now();f.progress("DTS","Bundling types");try{let i=r.map(async(a)=>{let l=await xt(t,a.path,s);return Promise.all(n.map(async(c)=>{let m=z(c,e),p=`${s.outDir}/${a.name}${m}`,x=`${t}/${p}`;await Bun.write(x,l),f.progress("DTS",p)}))});Promise.all(i).then(()=>{let a=performance.now()-o;I?.postMessage({success:!0});let l=k(a);if(f.progress("DTS",`Bundled types in ${l}`),v.size>0)console.log(`
7
- `),v.forEach((c)=>{f.warn(c)}),f.info(`
5
+ `)+"\x1B[0m")},Z=(t,n)=>{St(t,n),process.exit(1)};var f={MAX_LABEL_LENGTH:5,colors:{cli:"183",info:"240",warn:"221",error:"203",progress:{ESM:"214",CJS:"114",IIFE:"105",DTS:"75"},default:"255"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(t,n,r){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));return`\x1B[38;5;${t}m[${n}]\x1B[0m ${e}${r}`},cli(t){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,t))},info(t){console.log(`\x1B[38;5;${this.colors.info}m${t}\x1B[0m`)},warn(t){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,t))},error(t){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,t))},progress(t,n){let r=String(t),e=this.colors.default;for(let[s,i]of Object.entries(this.colors.progress))if(r.includes(s)){e=i;break}console.log(this.formatMessage(e,r,n))}};function k(t,n){return`${n?`${n.replace(/-/g,"_")}_`:""}${t}`.toUpperCase()}function T(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function z(t=8){return Math.random().toString(36).substring(2,2+t)}function D(t,n){switch(t){case"esm":return".mjs";case"cjs":return N(n)?".cjs":".js";case"iife":return".global.js"}}function tt(t,n){switch(t){case"esm":return".d.mts";case"cjs":return N(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function N(t){return t==="module"}function I(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function nt(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function rt(t,n){return t===void 0?n==="esm":t}import{loadTsConfig as bt}from"load-tsconfig";function et(t){try{return bt(".",t)}catch(n){return f.warn(`Failed to load tsconfig: ${p(n)}`),{path:t,data:{},files:[]}}}import P from"node:path";import{rollup as At}from"rollup";import Nt from"rollup-plugin-dts";import U from"typescript";function st(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${T(n)}($|\\/|\\\\)`):n)}function j(t,n){return st(t.external||[]).concat(nt(n).map((r)=>new RegExp(`^${T(r)}($|\\/|\\\\)`)))}function L(t){return st(t.noExternal||[])}import M from"node:fs";import ot from"node:path";var O={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0};function it(t,n){return{outdir:`${n}/${t.outDir}`,minify:Bt(t),target:t.target,splitting:t.splitting}}function Bt(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:s}=t,i=n===!0;return{whitespace:r??i,identifiers:e??i,syntax:s??i}}async function at(t){let n=[];for(let r of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let e=ot.join(t,`bunup.config${r}`);try{if(!M.existsSync(e))continue;let s;if(r===".json"||r===".jsonc"){let i=M.readFileSync(e,"utf8");s=JSON.parse(i)}else{let i=await import(`file://${e}`);if(s=i.default||i,!s)f.warn(`No default export found in ${e}`),s={}}if(Array.isArray(s))for(let i of s)n.push({options:{...O,...i},rootDir:t});else n.push({options:{...O,...s},rootDir:t});break}catch(s){throw new $(`Failed to load config from ${e}: ${p(s)}`)}if(n.length>0)break}return n}function F(t){let n=ot.join(t,"package.json");try{if(!M.existsSync(n))return null;let r=M.readFileSync(n,"utf8");return JSON.parse(r)}catch(r){return f.warn(`Failed to load package.json at ${n}: ${p(r)}`),null}}var It=()=>{return global.allFilesUsedToBundleDts||C||new Set};async function lt(t,n,r,e,s){let a=`\x00virtual:${t.replace(/\.tsx?$/,".d.ts")}`,c=s.data?.compilerOptions,l={name:"bunup:virtual-dts",resolveId(d,y){if(d.startsWith("\x00virtual:"))return d;if(!y?.startsWith("\x00virtual:")||!d.startsWith("."))return null;let x=y.slice(9),S=P.resolve(P.dirname(x),d);if(d==="."){let b=P.join(P.dirname(x),"index.d.ts");if(n.has(b))return`\x00virtual:${b}`;S=P.dirname(x)}if(n.has(S))return`\x00virtual:${S}`;let V=`${S}.d.ts`;if(n.has(V))return`\x00virtual:${V}`;if(d.startsWith(".")){let b=P.join(S,"index.d.ts");if(n.has(b))return`\x00virtual:${b}`}return null},load(d){if(d.startsWith("\x00virtual:")){let y=d.slice(9),x=n.get(y);if(x)return It().add(y),x}return null}},m=F(e),u=j(r,m),E=L(r),v;try{v=await At({input:a,onwarn(y,x){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(y.code??""))return;x(y)},plugins:[l,Nt({tsconfig:s.path,compilerOptions:{...c?U.parseJsonConfigFileContent({compilerOptions:c},U.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:U.ScriptTarget.ESNext}})],external:(y)=>u.some((x)=>x.test(y))&&!E.some((x)=>x.test(y))});let{output:d}=await v.generate({});if(!d[0]?.code)throw new g("Generated bundle is empty");return d[0].code}catch(d){throw new g(`DTS bundling failed: ${p(d)}`)}finally{if(v)await v.close()}}import pt from"node:fs";import ut from"node:path";import H from"node:path";function q(t){let n=H.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?H.resolve(n,t.data.compilerOptions.baseUrl):n}function ct(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=q(t);for(let[s,i]of Object.entries(r))if(Array.isArray(i)&&i.length){let o=s.replace(/\*/g,"(.*)"),a=i[0].replace(/\*/g,"$1");n.set(`^${o}$`,H.join(e,a))}return n}function ft(t,n,r){for(let[e,s]of n){let i=new RegExp(e),o=t.match(i);if(o)return s.replace("$1",o[1]||"")}return r?H.join(r,t):null}var jt=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Lt=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function mt(t,n){let r=new Set([t]),e=[t],s=ct(n),i=q(n);while(e.length){let o=e.pop();if(!o)continue;try{let a=await pt.promises.readFile(o,"utf8"),c=Mt(a);for(let l of c){let m=l.startsWith(".")?ut.resolve(ut.dirname(o),l):ft(l,s,i);if(!m)continue;let u=Ft(m);if(u&&!r.has(u))r.add(u),e.push(u)}}catch(a){f.warn(`Error processing ${o}: ${p(a)}`)}}return r}function Mt(t){let n=new Set;for(let r of[jt,Lt]){let e;while((e=r.exec(t))!==null)n.add(e[2])}return Array.from(n)}function Ft(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(pt.existsSync(e)&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}import Ht from"node:fs";import{isolatedDeclaration as Wt}from"oxc-transform";async function gt(t){let n=new Map;return await Promise.all([...t].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts"),s=await Ht.promises.readFile(r,"utf8"),{code:i}=Wt(r,s);if(i)n.set(e,i)}catch(e){f.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),n}import X from"node:fs";import G from"node:path";import{isolatedDeclaration as _t}from"oxc-transform";function dt(t,n){let r=G.resolve(t),e=G.resolve(r,n);if(!X.existsSync(r))throw new g(`Root directory does not exist: ${r}`);if(!X.existsSync(e))throw new g(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new g(`Entry file must be a TypeScript file (.ts): ${e}`);if(G.relative(r,e).startsWith(".."))throw new g(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function xt(t){if(t.size===0)return;let n=!1;if(console.log(`
6
+ `),await Promise.all([...t].map(async(r)=>{try{let e=r.replace(/\.d\.ts$/,".ts"),s=await X.promises.readFile(e,"utf8"),{errors:i}=_t(e,s);i.forEach((o)=>{let a=o.labels[0],c=a?Tt(s,a.start):"",u=`${e.split("/").slice(-3).join("/")}${c}: ${Ut(o.message)}`;f.warn(u),n=!0})}catch{}})),n)f.info(`
8
7
  You may have noticed some TypeScript warnings above related to missing type annotations. This is because Bunup uses TypeScript's "isolatedDeclarations" approach for generating declaration files. This modern approach requires explicit type annotations on exports for better, more accurate type declarations. Other bundlers might not show these warnings because they use different, potentially less precise methods. Adding the suggested type annotations will not only silence these warnings but also improve the quality of your published type definitions, making your library more reliable for consumers.
9
- `),v.clear()}).catch((a)=>{I?.postMessage({success:!1,error:u(a)})})}catch(i){I?.postMessage({success:!1,error:u(i)})}}function _t(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function S(t){let r=[],n=new Set;function s(e,o){if(n.has(e)){let i=V();r.push({name:`${e}_${i}`,path:o})}else r.push({name:e,path:o}),n.add(e)}if(Array.isArray(t))for(let e of t){let o=_t(e);s(o,e)}else Object.entries(t).forEach(([e,o])=>{s(e,o)});return r}function yt(t,r){return`[dir]/${t}${r}`}function Et(t,r){return{name:"bunup:external-plugin",setup(n){n.onResolve({filter:/.*/},(s)=>{let e=s.path;if(t.some((i)=>i.test(e))&&!r.some((i)=>i.test(e)))return{path:e,external:!0};return null})}}}async function L(t,r){if(!t.entry||t.entry.length===0||!t.outDir)throw new w("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let n=performance.now();f.cli("Build started");let s=W(r),e=s?.type,o=M(t,s),i=j(t),a=[Et(o,i)],l=S(t.entry),c=t.format.flatMap((m)=>l.map((p)=>Ht(t,r,p,m,e,a)));try{await Promise.all(c);let m=performance.now()-n,p=k(m);f.cli(`\uD83D\uDCE6 Build success in ${p}`)}catch{throw new w("Build process encountered errors")}if(t.dts){let m=t.format.filter((x)=>{if(x==="iife"&&!T(e)&&t.format.includes("cjs"))return!1;return!0}),p=t.dts===!0?l:S(t.dts.entry);try{await wt(r,p,m,t,e)}catch(x){throw new g(`DTS build process encountered errors: ${u(x)}`)}}}async function Ht(t,r,n,s,e,o){let i=Z(s,e),a=ct(t,r),l=await Bun.build({...a,entrypoints:[`${r}/${n.path}`],format:s,naming:{entry:yt(n.name,i)},splitting:rt(t.splitting,s),plugins:o,throw:!1});if(!l.success)throw l.logs.forEach((c)=>{if(c.level==="error")f.error(c.message);else if(c.level==="warning")f.warn(c.message);else if(c.level==="info")f.info(c.message)}),new w(`Build failed for ${n} (${s})`);f.progress(Q(s,t.name),`${t.outDir}/${n.name}${i}`)}function $(t){return(r,n)=>{n[t]=r===!0?!0:r==="true"}}function q(t){return(r,n)=>{if(typeof r==="string")n[t]=r;else throw new h(`Option --${t} requires a string value`)}}function $t(t){return(r,n)=>{if(typeof r==="string")n[t]=r.split(",");else throw new h(`Option --${t} requires a string value`)}}var qt={name:{flags:["n","name"],handler:q("name")},format:{flags:["f","format"],handler:(t,r)=>{if(typeof t==="string")r.format=t.split(",");else throw new h("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:q("outDir")},minify:{flags:["m","minify"],handler:$("minify")},watch:{flags:["w","watch"],handler:$("watch")},dts:{flags:["d","dts"],handler:$("dts")},external:{flags:["e","external"],handler:$t("external")},target:{flags:["t","target"],handler:q("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:$("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:$("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:$("minifySyntax")},clean:{flags:["c","clean"],handler:$("clean")},splitting:{flags:["s","splitting"],handler:$("splitting")},noExternal:{flags:["ne","no-external"],handler:$t("noExternal")}},G={};for(let t of Object.values(qt))if(t)for(let r of t.flags)G[r]=t.handler;function Ot(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function vt(t){let r={},n={},s=0;while(s<t.length){let e=t[s];if(e.startsWith("--")){let o,i;if(e.includes("=")){let[a,l]=e.slice(2).split("=",2);o=a,i=l}else{o=e.slice(2);let a=t[s+1];if(i=a&&!a.startsWith("-")?a:!0,typeof i==="string")s++}if(o==="entry")if(typeof i==="string"){let a=Ot(i);if(n[a])f.warn(`Duplicate entry name '${a}' derived from '${i}'. Overwriting previous entry.`);n[a]=i}else throw new h("Option --entry requires a string value");else if(o.startsWith("entry.")){let a=o.slice(6);if(typeof i==="string"){if(n[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);n[a]=i}else throw new h(`Option --entry.${a} requires a string value`)}else{let a=G[o];if(a)a(i,r);else throw new h(`Unknown option: --${o}`)}}else if(e.startsWith("-")){let o=e.slice(1),i=t[s+1],a=i&&!i.startsWith("-")?i:!0;if(typeof a==="string")s++;let l=G[o];if(l)l(a,r);else throw new h(`Unknown option: -${o}`)}else{let o=Ot(e);if(n[o])f.warn(`Duplicate entry name '${o}' derived from positional argument '${e}'. Overwriting previous entry.`);n[o]=e}s++}if(Object.keys(n).length>0)r.entry=n;return r}(()=>{if(typeof Bun==="undefined")throw new h(`Bunup requires Bun to run.
10
- To install Bun, visit https://bun.sh/docs/installation`)})();import X from"node:path";import Gt from"chokidar";async function Pt(t,r){let n=new Set;S(t.entry).forEach((l)=>{let c=X.resolve(r,l.path),m=X.dirname(c);n.add(m)});let e=Gt.watch(Array.from(n),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,t.outDir]}),o=null,i=!1,a=async(l)=>{if(i)return;i=!0;try{await L({...t,entry:[l],clean:!1},r)}catch(c){throw new D(`Build failed: ${u(c)}`)}finally{i=!1}};e.on("change",(l)=>{let c=X.relative(r,l);if(f.cli(`File changed: ${c}`),o)clearTimeout(o);o=setTimeout(()=>a(c),300)}),e.on("error",(l)=>{throw new D(`Watcher error: ${u(l)}`)})}async function Yt(t=Bun.argv.slice(2)){let r=vt(t),n=await ut(process.cwd()),s=process.cwd();if(r.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(n.length===0){let e={...P,...r};if(e.clean)Bt(s,e.outDir);await Ct(e,s)}else{for(let{options:e,rootDir:o}of n)if(e.clean)Bt(o,e.outDir);await Promise.all(n.map(async({options:e,rootDir:o})=>{let i={...P,...e,...r};await Ct(i,o)}))}if(!r.watch)process.exit(0)}async function Ct(t,r){if(t.watch)await Pt(t,r);else await L(t,r)}function Bt(t,r){let n=Xt.join(t,r);if(Y.existsSync(n))try{Y.rmSync(n,{recursive:!0,force:!0})}catch(s){throw new w(`Failed to clean output directory: ${s}`)}Y.mkdirSync(n,{recursive:!0})}Yt().catch((t)=>K(t));export{Yt as main};
8
+ `)}function Tt(t,n){if(n===void 0)return"";let r=t.slice(0,n).split(`
9
+ `),e=r.length,s=r[r.length-1].length+1;return` (${e}:${s})`}function Ut(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function ht(t,n,r){let{absoluteRootDir:e,absoluteEntry:s}=dt(t,n),i=et(r.preferredTsconfigPath),o=await mt(s,i),a=await gt(o);return lt(s,a,r,e,i)}async function yt(t,n,r,e,s){return new Promise((i,o)=>{let a={rootDir:t,entries:n,formats:r,options:e,packageType:s},c=new Gt(new URL("./dtsWorker.js",import.meta.url),{workerData:a});c.on("message",async(l)=>{if(l.success){let m=I(l.timeMs);if(f.progress("DTS",`Bundled types in ${m}`),l.filesUsed)l.filesUsed.forEach((u)=>C.add(u));i()}else o(new g(l.error||"Unknown DTS worker error"))}),c.on("error",o),c.on("exit",(l)=>{if(l!==0)o(new g(`DTS worker stopped with exit code ${l}`))})})}if(!qt&&W){let{rootDir:t,entries:n,formats:r,options:e,packageType:s}=Xt,i=performance.now(),o=new Set;global.allFilesUsedToBundleDts=o,f.progress("DTS","Bundling types");try{(async()=>{try{await Promise.all(n.map(async(c)=>{let l=await ht(t,c.path,e);await Promise.all(r.map(async(m)=>{let u=tt(m,s),E=`${e.outDir}/${c.name}${u}`,v=`${t}/${E}`;await Bun.write(v,l),f.progress("DTS",E)}))}));let a=performance.now()-i;W?.postMessage({success:!0,timeMs:a,filesUsed:[...o]})}catch(a){W?.postMessage({success:!1,error:p(a)})}})()}catch(a){W?.postMessage({success:!1,error:p(a)})}}function Yt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function A(t){let n=[],r=new Set;function e(s,i){if(r.has(s)){let o=z();n.push({name:`${s}_${o}`,path:i})}else n.push({name:s,path:i}),r.add(s)}if(Array.isArray(t))for(let s of t){let i=Yt(s);e(i,s)}else Object.entries(t).forEach(([s,i])=>{e(s,i)});return n}function $t(t,n){return`[dir]/${t}${n}`}function wt(t,n){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let s=e.path;if(t.some((o)=>o.test(s))&&!n.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}async function _(t,n){if(!t.entry||t.entry.length===0||!t.outDir)throw new $("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let r=performance.now();f.cli("Build started");let e=F(n),s=e?.type,i=j(t,e),o=L(t),a=[wt(i,o)],c=A(t.entry),l=t.format.flatMap((m)=>c.map((u)=>{return Jt(t,n,u,m,s,a)}));try{await Promise.all(l);let m=performance.now()-r,u=I(m);f.cli(`\uD83D\uDCE6 Build success in ${u}`)}catch{throw new $("Build process encountered errors")}if(t.dts){let m=t.format.filter((E)=>{if(E==="iife"&&!N(s)&&t.format.includes("cjs"))return!1;return!0}),u=t.dts===!0?c:A(t.dts.entry);try{await yt(n,u,m,t,s)}catch(E){throw new g("DTS build process encountered errors")}}}async function Jt(t,n,r,e,s,i){let o=D(e,s),a=it(t,n),c=await Bun.build({...a,entrypoints:[`${n}/${r.path}`],format:e,naming:{entry:$t(r.name,o)},splitting:rt(t.splitting,e),plugins:i,throw:!1});if(!c.success)throw c.logs.forEach((l)=>{if(l.level==="error")f.error(l.message);else if(l.level==="warning")f.warn(l.message);else if(l.level==="info")f.info(l.message)}),new $(`Build failed for ${r} (${e})`);f.progress(k(e,t.name),`${t.outDir}/${r.name}${o}`)}function w(t){return(n,r)=>{r[t]=n===!0?!0:n==="true"}}function Y(t){return(n,r)=>{if(typeof n==="string")r[t]=n;else throw new h(`Option --${t} requires a string value`)}}function Et(t){return(n,r)=>{if(typeof n==="string")r[t]=n.split(",");else throw new h(`Option --${t} requires a string value`)}}var Kt={name:{flags:["n","name"],handler:Y("name")},format:{flags:["f","format"],handler:(t,n)=>{if(typeof t==="string")n.format=t.split(",");else throw new h("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:Y("outDir")},minify:{flags:["m","minify"],handler:w("minify")},watch:{flags:["w","watch"],handler:w("watch")},dts:{flags:["d","dts"],handler:w("dts")},external:{flags:["e","external"],handler:Et("external")},target:{flags:["t","target"],handler:Y("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:w("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:w("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:w("minifySyntax")},clean:{flags:["c","clean"],handler:w("clean")},splitting:{flags:["s","splitting"],handler:w("splitting")},noExternal:{flags:["ne","no-external"],handler:Et("noExternal")}},J={};for(let t of Object.values(Kt))if(t)for(let n of t.flags)J[n]=t.handler;function Ct(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function vt(t){let n={},r={},e=0;while(e<t.length){let s=t[e];if(s.startsWith("--")){let i,o;if(s.includes("=")){let[a,c]=s.slice(2).split("=",2);i=a,o=c}else{i=s.slice(2);let a=t[e+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")e++}if(i==="entry")if(typeof o==="string"){let a=Ct(o);if(r[a])f.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);r[a]=o}else throw new h("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(r[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);r[a]=o}else throw new h(`Option --entry.${a} requires a string value`)}else{let a=J[i];if(a)a(o,n);else throw new h(`Unknown option: --${i}`)}}else if(s.startsWith("-")){let i=s.slice(1),o=t[e+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")e++;let c=J[i];if(c)c(a,n);else throw new h(`Unknown option: -${i}`)}else{let i=Ct(s);if(r[i])f.warn(`Duplicate entry name '${i}' derived from positional argument '${s}'. Overwriting previous entry.`);r[i]=s}e++}if(Object.keys(r).length>0)n.entry=r;return n}(()=>{if(typeof Bun==="undefined")throw new h(`Bunup requires Bun to run.
10
+ To install Bun, visit https://bun.sh/docs/installation`)})();import K from"node:path";import Qt from"chokidar";async function Rt(t,n){let r=new Set;A(t.entry).forEach((c)=>{let l=K.resolve(n,c.path),m=K.dirname(l);r.add(m)});let s=Qt.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,t.outDir]}),i=null,o=!1,a=async(c)=>{if(o)return;o=!0;try{await _({...t,entry:[c],clean:!1},n)}catch(l){throw new B(`Build failed: ${p(l)}`)}finally{o=!1}};s.on("change",(c)=>{let l=K.relative(n,c);if(f.cli(`File changed: ${l}`),i)clearTimeout(i);i=setTimeout(()=>a(l),300)}),s.on("error",(c)=>{throw new B(`Watcher error: ${p(c)}`)})}var C=new Set;async function kt(t=Bun.argv.slice(2)){let n=vt(t),r=await at(process.cwd()),e=process.cwd();if(n.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(r.length===0){let s={...O,...n};if(s.clean)Pt(e,s.outDir);await Ot(s,e)}else{for(let{options:s,rootDir:i}of r)if(s.clean)Pt(i,s.outDir);await Promise.all(r.map(async({options:s,rootDir:i})=>{let o={...O,...s,...n};await Ot(o,i)}))}if(C.size>0)await xt(C),C.clear();if(!n.watch)process.exit(0)}async function Ot(t,n){if(t.watch)await Rt(t,n);else await _(t,n)}function Pt(t,n){let r=Vt.join(t,n);if(Q.existsSync(r))try{Q.rmSync(r,{recursive:!0,force:!0})}catch(e){throw new $(`Failed to clean output directory: ${e}`)}Q.mkdirSync(r,{recursive:!0})}if(Zt)kt().catch((t)=>Z(t));export{kt as main,C as allFilesUsedToBundleDts};
@@ -1,5 +1,8 @@
1
- var mt=require("node:module");var ct=Object.create;var{getPrototypeOf:pt,defineProperty:T,getOwnPropertyNames:j,getOwnPropertyDescriptor:ut}=Object,I=Object.prototype.hasOwnProperty;var g=(t,r,e)=>{e=t!=null?ct(pt(t)):{};let o=r||!t||!t.__esModule?T(e,"default",{value:t,enumerable:!0}):e;for(let s of j(t))if(!I.call(o,s))T(o,s,{get:()=>t[s],enumerable:!0});return o},F=new WeakMap,ft=(t)=>{var r=F.get(t),e;if(r)return r;if(r=T({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")j(t).map((o)=>!I.call(r,o)&&T(r,o,{get:()=>t[o],enumerable:!(e=ut(t,o))||e.enumerable}));return F.set(t,r),r};var gt=(t,r)=>{for(var e in r)T(t,e,{get:r[e],enumerable:!0,configurable:!0,set:(o)=>r[e]=()=>o})};var Pt={};gt(Pt,{runDtsInWorker:()=>yt});module.exports=ft(Pt);var d=require("node:worker_threads");class W extends Error{constructor(t){super(t);this.name="BunupError"}}class m extends W{constructor(t){super(t);this.name="BunupDTSBuildError"}}var f=(t)=>{if(t instanceof Error)return t.message;return String(t)};var u={MAX_LABEL_LENGTH:5,colors:{cli:"183",info:"240",warn:"221",error:"203",progress:{ESM:"214",CJS:"114",IIFE:"105",DTS:"75"},default:"255"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(t,r,e){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length));return`\x1B[38;5;${t}m[${r}]\x1B[0m ${o}${e}`},cli(t){let r=this.labels.cli;console.log(this.formatMessage(this.colors.cli,r,t))},info(t){console.log(`\x1B[38;5;${this.colors.info}m${t}\x1B[0m`)},warn(t){let r=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,r,t))},error(t){let r=this.labels.error;console.error(this.formatMessage(this.colors.error,r,t))},progress(t,r){let e=String(t),o=this.colors.default;for(let[s,a]of Object.entries(this.colors.progress))if(e.includes(s)){o=a;break}console.log(this.formatMessage(o,e,r))}};function O(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function U(t,r){switch(t){case"esm":return".d.mts";case"cjs":return dt(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function dt(t){return t==="module"}function _(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function G(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}var q=g(require("node:fs")),z=g(require("oxc-transform"));var C=g(require("node:path"));function S(t){let r=C.default.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?C.default.resolve(r,t.data.compilerOptions.baseUrl):r}function J(t){let r=new Map,e=t.data?.compilerOptions?.paths;if(!e)return r;let o=S(t);for(let[s,a]of Object.entries(e))if(Array.isArray(a)&&a.length){let n=s.replace(/\*/g,"(.*)"),i=a[0].replace(/\*/g,"$1");r.set(`^${n}$`,C.default.join(o,i))}return r}function X(t,r,e){for(let[o,s]of r){let a=new RegExp(o),n=t.match(a);if(n)return s.replace("$1",n[1]||"")}return e?C.default.join(e,t):null}function Y(t,r){if(r===void 0)return"";let e=t.slice(0,r).split(`
2
- `),o=e.length,s=e[e.length-1].length+1;return` (${o}:${s})`}function H(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var P=new Set;async function K(t){let r=new Map;return await Promise.all([...t].map(async(e)=>{try{let o=e.replace(/\.tsx?$/,".d.ts"),s=await q.default.promises.readFile(e,"utf8"),{code:a,errors:n}=z.default.isolatedDeclaration(e,s);if(n.forEach((i)=>{let c=i.labels[0],l=c?Y(s,c.start):"",y=`${e.split("/").slice(-3).join("/")}${l}: ${H(i.message)}`;if(!P.has(y))P.add(y)}),a)r.set(o,a)}catch(o){u.warn(`Failed to generate declaration for ${e}: ${f(o)}`)}})),r}var A=g(require("node:fs")),B=g(require("node:path"));var Q=require("load-tsconfig");function V(t){try{return Q.loadTsConfig(".",t)}catch(r){return u.warn(`Failed to load tsconfig: ${f(r)}`),{path:t,data:{},files:[]}}}var $=g(require("node:path")),st=require("rollup"),nt=g(require("rollup-plugin-dts")),v=g(require("typescript"));function Z(t){return t.map((r)=>typeof r==="string"?new RegExp(`^${O(r)}($|\\/|\\\\)`):r)}function tt(t,r){return Z(t.external||[]).concat(G(r).map((e)=>new RegExp(`^${O(e)}($|\\/|\\\\)`)))}function rt(t){return Z(t.noExternal||[])}var M=g(require("node:fs")),et=g(require("node:path"));function ot(t){let r=et.default.join(t,"package.json");try{if(!M.default.existsSync(r))return null;let e=M.default.readFileSync(r,"utf8");return JSON.parse(e)}catch(e){return u.warn(`Failed to load package.json at ${r}: ${f(e)}`),null}}async function it(t,r,e,o,s){let i=`\x00virtual:${t.replace(/\.tsx?$/,".d.ts")}`,c=s.data?.compilerOptions,l={name:"bunup:virtual-dts",resolveId(p,E){if(p.startsWith("\x00virtual:"))return p;if(!E?.startsWith("\x00virtual:")||!p.startsWith("."))return null;let x=E.slice(9),D=$.default.resolve($.default.dirname(x),p);if(p==="."){let R=$.default.join($.default.dirname(x),"index.d.ts");if(r.has(R))return`\x00virtual:${R}`;D=$.default.dirname(x)}if(r.has(D))return`\x00virtual:${D}`;let L=`${D}.d.ts`;if(r.has(L))return`\x00virtual:${L}`;if(p.startsWith(".")){let R=$.default.join(D,"index.d.ts");if(r.has(R))return`\x00virtual:${R}`}return null},load(p){return p.startsWith("\x00virtual:")?r.get(p.slice(9))||null:null}},w=ot(o),h=tt(e,w),y=rt(e),b;try{b=await st.rollup({input:i,onwarn(E,x){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(E.code??""))return;x(E)},plugins:[l,nt.default({tsconfig:s.path,compilerOptions:{...c?v.default.parseJsonConfigFileContent({compilerOptions:c},v.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:v.default.ScriptTarget.ESNext}})],external:(E)=>h.some((x)=>x.test(E))&&!y.some((x)=>x.test(E))});let{output:p}=await b.generate({});if(!p[0]?.code)throw new m("Generated bundle is empty");return p[0].code}catch(p){throw new m(`DTS bundling failed: ${f(p)}`)}finally{if(b)await b.close()}}var N=g(require("node:fs")),k=g(require("node:path"));var ht=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,xt=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function at(t,r){let e=new Set([t]),o=[t],s=J(r),a=S(r);while(o.length){let n=o.pop();if(!n)continue;try{let i=await N.default.promises.readFile(n,"utf8"),c=Et(i);for(let l of c){let w=l.startsWith(".")?k.default.resolve(k.default.dirname(n),l):X(l,s,a);if(!w)continue;let h=wt(w);if(h&&!e.has(h))e.add(h),o.push(h)}}catch(i){u.warn(`Error processing ${n}: ${f(i)}`)}}return e}function Et(t){let r=new Set;for(let e of[ht,xt]){let o;while((o=e.exec(t))!==null)r.add(o[2])}return Array.from(r)}function wt(t){let r=["",".ts",".tsx","/index.ts","/index.tsx"];for(let e of r){let o=`${t}${e}`;if(N.default.existsSync(o)&&(o.endsWith(".ts")||o.endsWith(".tsx")))return o}return null}async function lt(t,r,e){let{absoluteRootDir:o,absoluteEntry:s}=$t(t,r),a=V(e.preferredTsconfigPath),n=await at(s,a),i=await K(n);return it(s,i,e,o,a)}function $t(t,r){let e=B.default.resolve(t),o=B.default.resolve(e,r);if(!A.default.existsSync(e))throw new m(`Root directory does not exist: ${e}`);if(!A.default.existsSync(o))throw new m(`Entry file does not exist: ${o}`);if(!o.endsWith(".ts"))throw new m(`Entry file must be a TypeScript file (.ts): ${o}`);if(B.default.relative(e,o).startsWith(".."))throw new m(`Entry file must be within rootDir: ${o}`);return{absoluteRootDir:e,absoluteEntry:o}}async function yt(t,r,e,o,s){return new Promise((a,n)=>{let i={rootDir:t,entries:r,formats:e,options:o,packageType:s},c=new d.Worker(new URL("./dtsWorker.js",import.meta.url),{workerData:i});c.on("message",(l)=>{if(l.success)a();else n(new m(l.error||"Unknown DTS worker error"))}),c.on("error",n),c.on("exit",(l)=>{if(l!==0)n(new m(`DTS worker stopped with exit code ${l}`))})})}if(!d.isMainThread&&d.parentPort){let{rootDir:t,entries:r,formats:e,options:o,packageType:s}=d.workerData,a=performance.now();u.progress("DTS","Bundling types");try{let n=r.map(async(i)=>{let c=await lt(t,i.path,o);return Promise.all(e.map(async(l)=>{let w=U(l,s),h=`${o.outDir}/${i.name}${w}`,y=`${t}/${h}`;await Bun.write(y,c),u.progress("DTS",h)}))});Promise.all(n).then(()=>{let i=performance.now()-a;d.parentPort?.postMessage({success:!0});let c=_(i);if(u.progress("DTS",`Bundled types in ${c}`),P.size>0)console.log(`
3
- `),P.forEach((l)=>{u.warn(l)}),u.info(`
1
+ var Jt=require("node:module");var Ut=Object.create;var{getPrototypeOf:qt,defineProperty:N,getOwnPropertyNames:et,getOwnPropertyDescriptor:Gt}=Object,st=Object.prototype.hasOwnProperty;var g=(t,n,r)=>{r=t!=null?Ut(qt(t)):{};let e=n||!t||!t.__esModule?N(r,"default",{value:t,enumerable:!0}):r;for(let s of et(t))if(!st.call(e,s))N(e,s,{get:()=>t[s],enumerable:!0});return e},rt=new WeakMap,Xt=(t)=>{var n=rt.get(t),r;if(n)return n;if(n=N({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")et(t).map((e)=>!st.call(n,e)&&N(n,e,{get:()=>t[e],enumerable:!(r=Gt(t,e))||r.enumerable}));return rt.set(t,n),n};var Yt=(t,n)=>{for(var r in n)N(t,r,{get:n[r],enumerable:!0,configurable:!0,set:(e)=>n[r]=()=>e})};var an={};Yt(an,{runDtsInWorker:()=>V});module.exports=Xt(an);var w=require("node:worker_threads");var Y=g(require("node:fs")),St=g(require("node:path")),bt=require("node:worker_threads");class S extends Error{constructor(t){super(t);this.name="BunupError"}}class E extends S{constructor(t){super(t);this.name="BunupBuildError"}}class d extends S{constructor(t){super(t);this.name="BunupDTSBuildError"}}class y extends S{constructor(t){super(t);this.name="BunupCLIError"}}class I extends S{constructor(t){super(t);this.name="BunupWatchError"}}var p=(t)=>{if(t instanceof Error)return t.message;return String(t)},Kt=(t,n)=>{let r=p(t),e=n?`[${n}] `:"",s="ERROR";if(t instanceof E)s="BUILD ERROR";else if(t instanceof d)s="DTS ERROR";else if(t instanceof y)s="CLI ERROR";else if(t instanceof I)s="WATCH ERROR";else if(t instanceof S)s="BUNUP ERROR";if(console.error(`\x1B[31m[${s}]\x1B[0m ${e}${r}`),t instanceof Error&&t.stack)console.error("\x1B[2m"+t.stack.split(`
2
+ `).slice(1).join(`
3
+ `)+"\x1B[0m")},it=(t,n)=>{Kt(t,n),process.exit(1)};function K(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ot(t=8){return Math.random().toString(36).substring(2,2+t)}function at(t,n){switch(t){case"esm":return".mjs";case"cjs":return F(n)?".cjs":".js";case"iife":return".global.js"}}function lt(t,n){switch(t){case"esm":return".d.mts";case"cjs":return F(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function F(t){return t==="module"}function H(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function ct(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function ft(t,n){return t===void 0?n==="esm":t}function Qt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function j(t){let n=[],r=new Set;function e(s,i){if(r.has(s)){let o=ot();n.push({name:`${s}_${o}`,path:i})}else n.push({name:s,path:i}),r.add(s)}if(Array.isArray(t))for(let s of t){let i=Qt(s);e(i,s)}else Object.entries(t).forEach(([s,i])=>{e(s,i)});return n}function ut(t,n){return`[dir]/${t}${n}`}function pt(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${K(n)}($|\\/|\\\\)`):n)}function W(t,n){return pt(t.external||[]).concat(ct(n).map((r)=>new RegExp(`^${K(r)}($|\\/|\\\\)`)))}function _(t){return pt(t.noExternal||[])}var L=g(require("node:fs")),Q=g(require("node:path"));var f={MAX_LABEL_LENGTH:5,colors:{cli:"183",info:"240",warn:"221",error:"203",progress:{ESM:"214",CJS:"114",IIFE:"105",DTS:"75"},default:"255"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(t,n,r){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));return`\x1B[38;5;${t}m[${n}]\x1B[0m ${e}${r}`},cli(t){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,t))},info(t){console.log(`\x1B[38;5;${this.colors.info}m${t}\x1B[0m`)},warn(t){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,t))},error(t){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,t))},progress(t,n){let r=String(t),e=this.colors.default;for(let[s,i]of Object.entries(this.colors.progress))if(r.includes(s)){e=i;break}console.log(this.formatMessage(e,r,n))}};function mt(t,n){return`${n?`${n.replace(/-/g,"_")}_`:""}${t}`.toUpperCase()}var b={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0};function gt(t,n){return{outdir:`${n}/${t.outDir}`,minify:Vt(t),target:t.target,splitting:t.splitting}}function Vt(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:s}=t,i=n===!0;return{whitespace:r??i,identifiers:e??i,syntax:s??i}}async function dt(t){let n=[];for(let r of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let e=Q.default.join(t,`bunup.config${r}`);try{if(!L.default.existsSync(e))continue;let s;if(r===".json"||r===".jsonc"){let i=L.default.readFileSync(e,"utf8");s=JSON.parse(i)}else{let i=await import(`file://${e}`);if(s=i.default||i,!s)f.warn(`No default export found in ${e}`),s={}}if(Array.isArray(s))for(let i of s)n.push({options:{...b,...i},rootDir:t});else n.push({options:{...b,...s},rootDir:t});break}catch(s){throw new E(`Failed to load config from ${e}: ${p(s)}`)}if(n.length>0)break}return n}function T(t){let n=Q.default.join(t,"package.json");try{if(!L.default.existsSync(n))return null;let r=L.default.readFileSync(n,"utf8");return JSON.parse(r)}catch(r){return f.warn(`Failed to load package.json at ${n}: ${p(r)}`),null}}function xt(t,n){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let s=e.path;if(t.some((o)=>o.test(s))&&!n.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}async function U(t,n){if(!t.entry||t.entry.length===0||!t.outDir)throw new E("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let r=performance.now();f.cli("Build started");let e=T(n),s=e?.type,i=W(t,e),o=_(t),a=[xt(i,o)],c=j(t.entry),l=t.format.flatMap((m)=>c.map((u)=>{return Zt(t,n,u,m,s,a)}));try{await Promise.all(l);let m=performance.now()-r,u=H(m);f.cli(`\uD83D\uDCE6 Build success in ${u}`)}catch{throw new E("Build process encountered errors")}if(t.dts){let m=t.format.filter((v)=>{if(v==="iife"&&!F(s)&&t.format.includes("cjs"))return!1;return!0}),u=t.dts===!0?c:j(t.dts.entry);try{await V(n,u,m,t,s)}catch(v){throw new d("DTS build process encountered errors")}}}async function Zt(t,n,r,e,s,i){let o=at(e,s),a=gt(t,n),c=await Bun.build({...a,entrypoints:[`${n}/${r.path}`],format:e,naming:{entry:ut(r.name,o)},splitting:ft(t.splitting,e),plugins:i,throw:!1});if(!c.success)throw c.logs.forEach((l)=>{if(l.level==="error")f.error(l.message);else if(l.level==="warning")f.warn(l.message);else if(l.level==="info")f.info(l.message)}),new E(`Build failed for ${r} (${e})`);f.progress(mt(e,t.name),`${t.outDir}/${r.name}${o}`)}function C(t){return(n,r)=>{r[t]=n===!0?!0:n==="true"}}function Z(t){return(n,r)=>{if(typeof n==="string")r[t]=n;else throw new y(`Option --${t} requires a string value`)}}function ht(t){return(n,r)=>{if(typeof n==="string")r[t]=n.split(",");else throw new y(`Option --${t} requires a string value`)}}var kt={name:{flags:["n","name"],handler:Z("name")},format:{flags:["f","format"],handler:(t,n)=>{if(typeof t==="string")n.format=t.split(",");else throw new y("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:Z("outDir")},minify:{flags:["m","minify"],handler:C("minify")},watch:{flags:["w","watch"],handler:C("watch")},dts:{flags:["d","dts"],handler:C("dts")},external:{flags:["e","external"],handler:ht("external")},target:{flags:["t","target"],handler:Z("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:C("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:C("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:C("minifySyntax")},clean:{flags:["c","clean"],handler:C("clean")},splitting:{flags:["s","splitting"],handler:C("splitting")},noExternal:{flags:["ne","no-external"],handler:ht("noExternal")}},k={};for(let t of Object.values(kt))if(t)for(let n of t.flags)k[n]=t.handler;function yt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function $t(t){let n={},r={},e=0;while(e<t.length){let s=t[e];if(s.startsWith("--")){let i,o;if(s.includes("=")){let[a,c]=s.slice(2).split("=",2);i=a,o=c}else{i=s.slice(2);let a=t[e+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")e++}if(i==="entry")if(typeof o==="string"){let a=yt(o);if(r[a])f.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);r[a]=o}else throw new y("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(r[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);r[a]=o}else throw new y(`Option --entry.${a} requires a string value`)}else{let a=k[i];if(a)a(o,n);else throw new y(`Unknown option: --${i}`)}}else if(s.startsWith("-")){let i=s.slice(1),o=t[e+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")e++;let c=k[i];if(c)c(a,n);else throw new y(`Unknown option: -${i}`)}else{let i=yt(s);if(r[i])f.warn(`Duplicate entry name '${i}' derived from positional argument '${s}'. Overwriting previous entry.`);r[i]=s}e++}if(Object.keys(r).length>0)n.entry=r;return n}(()=>{if(typeof Bun==="undefined")throw new y(`Bunup requires Bun to run.
4
+ To install Bun, visit https://bun.sh/docs/installation`)})();var G=g(require("node:fs")),q=g(require("node:path")),wt=require("oxc-transform");function Et(t,n){let r=q.default.resolve(t),e=q.default.resolve(r,n);if(!G.default.existsSync(r))throw new d(`Root directory does not exist: ${r}`);if(!G.default.existsSync(e))throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(q.default.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function Ct(t){if(t.size===0)return;let n=!1;if(console.log(`
5
+ `),await Promise.all([...t].map(async(r)=>{try{let e=r.replace(/\.d\.ts$/,".ts"),s=await G.default.promises.readFile(e,"utf8"),{errors:i}=wt.isolatedDeclaration(e,s);i.forEach((o)=>{let a=o.labels[0],c=a?zt(s,a.start):"",u=`${e.split("/").slice(-3).join("/")}${c}: ${Dt(o.message)}`;f.warn(u),n=!0})}catch{}})),n)f.info(`
4
6
  You may have noticed some TypeScript warnings above related to missing type annotations. This is because Bunup uses TypeScript's "isolatedDeclarations" approach for generating declaration files. This modern approach requires explicit type annotations on exports for better, more accurate type declarations. Other bundlers might not show these warnings because they use different, potentially less precise methods. Adding the suggested type annotations will not only silence these warnings but also improve the quality of your published type definitions, making your library more reliable for consumers.
5
- `),P.clear()}).catch((i)=>{d.parentPort?.postMessage({success:!1,error:f(i)})})}catch(n){d.parentPort?.postMessage({success:!1,error:f(n)})}}
7
+ `)}function zt(t,n){if(n===void 0)return"";let r=t.slice(0,n).split(`
8
+ `),e=r.length,s=r[r.length-1].length+1;return` (${e}:${s})`}function Dt(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var X=g(require("node:path")),vt=g(require("chokidar"));async function Rt(t,n){let r=new Set;j(t.entry).forEach((c)=>{let l=X.default.resolve(n,c.path),m=X.default.dirname(l);r.add(m)});let s=vt.default.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,t.outDir]}),i=null,o=!1,a=async(c)=>{if(o)return;o=!0;try{await U({...t,entry:[c],clean:!1},n)}catch(l){throw new I(`Build failed: ${p(l)}`)}finally{o=!1}};s.on("change",(c)=>{let l=X.default.relative(n,c);if(f.cli(`File changed: ${l}`),i)clearTimeout(i);i=setTimeout(()=>a(l),300)}),s.on("error",(c)=>{throw new I(`Watcher error: ${p(c)}`)})}var R=new Set;async function tn(t=Bun.argv.slice(2)){let n=$t(t),r=await dt(process.cwd()),e=process.cwd();if(n.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(r.length===0){let s={...b,...n};if(s.clean)Pt(e,s.outDir);await Ot(s,e)}else{for(let{options:s,rootDir:i}of r)if(s.clean)Pt(i,s.outDir);await Promise.all(r.map(async({options:s,rootDir:i})=>{let o={...b,...s,...n};await Ot(o,i)}))}if(R.size>0)await Ct(R),R.clear();if(!n.watch)process.exit(0)}async function Ot(t,n){if(t.watch)await Rt(t,n);else await U(t,n)}function Pt(t,n){let r=St.default.join(t,n);if(Y.default.existsSync(r))try{Y.default.rmSync(r,{recursive:!0,force:!0})}catch(e){throw new E(`Failed to clean output directory: ${e}`)}Y.default.mkdirSync(r,{recursive:!0})}if(bt.isMainThread)tn().catch((t)=>it(t));var Bt=require("load-tsconfig");function At(t){try{return Bt.loadTsConfig(".",t)}catch(n){return f.warn(`Failed to load tsconfig: ${p(n)}`),{path:t,data:{},files:[]}}}var O=g(require("node:path")),Nt=require("rollup"),It=g(require("rollup-plugin-dts")),J=g(require("typescript"));var nn=()=>{return global.allFilesUsedToBundleDts||R||new Set};async function jt(t,n,r,e,s){let a=`\x00virtual:${t.replace(/\.tsx?$/,".d.ts")}`,c=s.data?.compilerOptions,l={name:"bunup:virtual-dts",resolveId(x,$){if(x.startsWith("\x00virtual:"))return x;if(!$?.startsWith("\x00virtual:")||!x.startsWith("."))return null;let h=$.slice(9),B=O.default.resolve(O.default.dirname(h),x);if(x==="."){let A=O.default.join(O.default.dirname(h),"index.d.ts");if(n.has(A))return`\x00virtual:${A}`;B=O.default.dirname(h)}if(n.has(B))return`\x00virtual:${B}`;let nt=`${B}.d.ts`;if(n.has(nt))return`\x00virtual:${nt}`;if(x.startsWith(".")){let A=O.default.join(B,"index.d.ts");if(n.has(A))return`\x00virtual:${A}`}return null},load(x){if(x.startsWith("\x00virtual:")){let $=x.slice(9),h=n.get($);if(h)return nn().add($),h}return null}},m=T(e),u=W(r,m),v=_(r),P;try{P=await Nt.rollup({input:a,onwarn($,h){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes($.code??""))return;h($)},plugins:[l,It.default({tsconfig:s.path,compilerOptions:{...c?J.default.parseJsonConfigFileContent({compilerOptions:c},J.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:J.default.ScriptTarget.ESNext}})],external:($)=>u.some((h)=>h.test($))&&!v.some((h)=>h.test($))});let{output:x}=await P.generate({});if(!x[0]?.code)throw new d("Generated bundle is empty");return x[0].code}catch(x){throw new d(`DTS bundling failed: ${p(x)}`)}finally{if(P)await P.close()}}var tt=g(require("node:fs")),D=g(require("node:path"));var M=g(require("node:path"));function z(t){let n=M.default.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?M.default.resolve(n,t.data.compilerOptions.baseUrl):n}function Lt(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=z(t);for(let[s,i]of Object.entries(r))if(Array.isArray(i)&&i.length){let o=s.replace(/\*/g,"(.*)"),a=i[0].replace(/\*/g,"$1");n.set(`^${o}$`,M.default.join(e,a))}return n}function Mt(t,n,r){for(let[e,s]of n){let i=new RegExp(e),o=t.match(i);if(o)return s.replace("$1",o[1]||"")}return r?M.default.join(r,t):null}var rn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,en=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function Ft(t,n){let r=new Set([t]),e=[t],s=Lt(n),i=z(n);while(e.length){let o=e.pop();if(!o)continue;try{let a=await tt.default.promises.readFile(o,"utf8"),c=sn(a);for(let l of c){let m=l.startsWith(".")?D.default.resolve(D.default.dirname(o),l):Mt(l,s,i);if(!m)continue;let u=on(m);if(u&&!r.has(u))r.add(u),e.push(u)}}catch(a){f.warn(`Error processing ${o}: ${p(a)}`)}}return r}function sn(t){let n=new Set;for(let r of[rn,en]){let e;while((e=r.exec(t))!==null)n.add(e[2])}return Array.from(n)}function on(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(tt.default.existsSync(e)&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}var Ht=g(require("node:fs")),Wt=require("oxc-transform");async function _t(t){let n=new Map;return await Promise.all([...t].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts"),s=await Ht.default.promises.readFile(r,"utf8"),{code:i}=Wt.isolatedDeclaration(r,s);if(i)n.set(e,i)}catch(e){f.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),n}async function Tt(t,n,r){let{absoluteRootDir:e,absoluteEntry:s}=Et(t,n),i=At(r.preferredTsconfigPath),o=await Ft(s,i),a=await _t(o);return jt(s,a,r,e,i)}async function V(t,n,r,e,s){return new Promise((i,o)=>{let a={rootDir:t,entries:n,formats:r,options:e,packageType:s},c=new w.Worker(new URL("./dtsWorker.js",import.meta.url),{workerData:a});c.on("message",async(l)=>{if(l.success){let m=H(l.timeMs);if(f.progress("DTS",`Bundled types in ${m}`),l.filesUsed)l.filesUsed.forEach((u)=>R.add(u));i()}else o(new d(l.error||"Unknown DTS worker error"))}),c.on("error",o),c.on("exit",(l)=>{if(l!==0)o(new d(`DTS worker stopped with exit code ${l}`))})})}if(!w.isMainThread&&w.parentPort){let{rootDir:t,entries:n,formats:r,options:e,packageType:s}=w.workerData,i=performance.now(),o=new Set;global.allFilesUsedToBundleDts=o,f.progress("DTS","Bundling types");try{(async()=>{try{await Promise.all(n.map(async(c)=>{let l=await Tt(t,c.path,e);await Promise.all(r.map(async(m)=>{let u=lt(m,s),v=`${e.outDir}/${c.name}${u}`,P=`${t}/${v}`;await Bun.write(P,l),f.progress("DTS",v)}))}));let a=performance.now()-i;w.parentPort?.postMessage({success:!0,timeMs:a,filesUsed:[...o]})}catch(a){w.parentPort?.postMessage({success:!1,error:p(a)})}})()}catch(a){w.parentPort?.postMessage({success:!1,error:p(a)})}}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bunup",
3
- "version": "0.1.24",
3
+ "version": "0.1.26",
4
4
  "description": "A extremely fast, zero-config bundler for TypeScript & JavaScript, powered by Bun.",
5
5
  "main": "./build/index.js",
6
6
  "types": "./build/index.d.ts",
@@ -18,7 +18,7 @@
18
18
  "@types/bun": "^1.2.5",
19
19
  "@typescript-eslint/eslint-plugin": "^7.3.1",
20
20
  "bumpp": "^10.1.0",
21
- "bunup": "^0.1.23",
21
+ "bunup": "^0.1.25",
22
22
  "eslint": "^8.57.0",
23
23
  "husky": "^9.1.6",
24
24
  "prettier": "^3.2.5",