bunup 0.4.73 → 0.4.74

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/dist/cli.mjs CHANGED
@@ -1,23 +1,23 @@
1
1
  #!/usr/bin/env bun
2
2
  // @bun
3
- var ye=Object.create;var{getPrototypeOf:Be,defineProperty:en,getOwnPropertyNames:Oe}=Object;var $e=Object.prototype.hasOwnProperty;var E=(n,e,r)=>{r=n!=null?ye(Be(n)):{};let t=e||!n||!n.__esModule?en(r,"default",{value:n,enumerable:!0}):r;for(let i of Oe(n))if(!$e.call(t,i))en(t,i,{get:()=>n[i],enumerable:!0});return t};var Se=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports);var Le=(n,e)=>{for(var r in e)en(n,r,{get:e[r],enumerable:!0,configurable:!0,set:(t)=>e[r]=()=>t})};var d=(n,e)=>()=>(n&&(e=n(n=0)),e);var ke=import.meta.require;var j=Se((dr,rn)=>{var D=process||{},Bn=D.argv||[],W=D.env||{},Re=!(!!W.NO_COLOR||Bn.includes("--no-color"))&&(!!W.FORCE_COLOR||Bn.includes("--color")||D.platform==="win32"||(D.stdout||{}).isTTY&&W.TERM!=="dumb"||!!W.CI),Te=(n,e,r=n)=>(t)=>{let i=""+t,s=i.indexOf(e,n.length);return~s?n+Me(i,e,r,s)+e:n+i+e},Me=(n,e,r,t)=>{let i="",s=0;do i+=n.substring(s,t)+r,s=t+e.length,t=n.indexOf(e,s);while(~t);return i+n.substring(s)},On=(n=Re)=>{let e=n?Te:()=>String;return{isColorSupported:n,reset:e("\x1B[0m","\x1B[0m"),bold:e("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:e("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:e("\x1B[3m","\x1B[23m"),underline:e("\x1B[4m","\x1B[24m"),inverse:e("\x1B[7m","\x1B[27m"),hidden:e("\x1B[8m","\x1B[28m"),strikethrough:e("\x1B[9m","\x1B[29m"),black:e("\x1B[30m","\x1B[39m"),red:e("\x1B[31m","\x1B[39m"),green:e("\x1B[32m","\x1B[39m"),yellow:e("\x1B[33m","\x1B[39m"),blue:e("\x1B[34m","\x1B[39m"),magenta:e("\x1B[35m","\x1B[39m"),cyan:e("\x1B[36m","\x1B[39m"),white:e("\x1B[37m","\x1B[39m"),gray:e("\x1B[90m","\x1B[39m"),bgBlack:e("\x1B[40m","\x1B[49m"),bgRed:e("\x1B[41m","\x1B[49m"),bgGreen:e("\x1B[42m","\x1B[49m"),bgYellow:e("\x1B[43m","\x1B[49m"),bgBlue:e("\x1B[44m","\x1B[49m"),bgMagenta:e("\x1B[45m","\x1B[49m"),bgCyan:e("\x1B[46m","\x1B[49m"),bgWhite:e("\x1B[47m","\x1B[49m"),blackBright:e("\x1B[90m","\x1B[39m"),redBright:e("\x1B[91m","\x1B[39m"),greenBright:e("\x1B[92m","\x1B[39m"),yellowBright:e("\x1B[93m","\x1B[39m"),blueBright:e("\x1B[94m","\x1B[39m"),magentaBright:e("\x1B[95m","\x1B[39m"),cyanBright:e("\x1B[96m","\x1B[39m"),whiteBright:e("\x1B[97m","\x1B[39m"),bgBlackBright:e("\x1B[100m","\x1B[49m"),bgRedBright:e("\x1B[101m","\x1B[49m"),bgGreenBright:e("\x1B[102m","\x1B[49m"),bgYellowBright:e("\x1B[103m","\x1B[49m"),bgBlueBright:e("\x1B[104m","\x1B[49m"),bgMagentaBright:e("\x1B[105m","\x1B[49m"),bgCyanBright:e("\x1B[106m","\x1B[49m"),bgWhiteBright:e("\x1B[107m","\x1B[49m")}};rn.exports=On();rn.exports.createColors=On});function q(n){Sn=n??!1}class I{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;cliColor=f.default.blue;mutedColor=f.default.dim;infoColor=f.default.cyan;warnColor=f.default.yellow;errorColor=f.default.red;sizeColor=f.default.green;defaultColor=f.default.white;progressFgColorMap={ESM:f.default.yellow,CJS:f.default.green,IIFE:f.default.magenta,DTS:f.default.blue};progressBgColorMap={ESM:f.default.bgYellow,CJS:f.default.bgGreen,IIFE:f.default.bgMagenta,DTS:f.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!I.instance)I.instance=new I;return I.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(n){if(!n?.once)return!0;if(this.loggedOnceMessages.has(n.once))return!1;return this.loggedOnceMessages.add(n.once),!0}formatMessage({fgColor:n,bgColor:e,label:r,message:t,size:i,identifier:s,muted:o}){let a=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length)),c=o?this.mutedColor(t):t;if(i){let[l,...g]=c.split(" "),x=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-l.length)),M=s?` ${e(f.default.black(` ${s} `))}`:"";return`${n(r)} ${a}${l}${x} ${this.sizeColor(i)} ${g.join(" ")}${M}`}let u=s?` ${e(f.default.black(` ${s} `))}`:"";return`${n(r)} ${a}${c}${u}`}output(n,e={},r=console.log){if(Sn||!this.shouldLog(e))return;if(e.verticalSpace)r("");if(r(n),e.verticalSpace)r("")}cli(n,e={}){let r=this.formatMessage({fgColor:this.cliColor,bgColor:f.default.bgBlue,label:this.labels.cli,message:n,identifier:e.identifier,muted:e.muted});this.output(r,e)}info(n,e={}){let r=this.formatMessage({fgColor:this.infoColor,bgColor:f.default.bgCyan,label:this.labels.info,message:n,identifier:e.identifier,muted:e.muted});this.output(r,e)}warn(n,e={}){let r=this.formatMessage({fgColor:this.warnColor,bgColor:f.default.bgYellow,label:this.labels.warn,message:n,identifier:e.identifier,muted:e.muted});this.output(r,e,console.warn)}error(n,e={}){let r=this.formatMessage({fgColor:this.errorColor,bgColor:f.default.bgRed,label:this.labels.error,message:n,identifier:e.identifier,muted:e.muted});this.output(r,e,console.error)}getProgressFgColor(n){for(let[e,r]of Object.entries(this.progressFgColorMap))if(n.includes(e))return r;return this.defaultColor}getProgressBgColor(n){for(let[e,r]of Object.entries(this.progressBgColorMap))if(n.includes(e))return r;return f.default.bgWhite}progress(n,e,r,t){let i,s,o={};if(typeof r==="string")i=r,s=t;else if(r)i=r.size,s=r.identifier,o=r;let a=this.getProgressFgColor(n),c=this.getProgressBgColor(n),u=this.formatMessage({fgColor:a,bgColor:c,label:n,message:e,size:i,identifier:s,muted:o.muted});this.output(u,o)}}var f,Sn=!1,m;var $=d(()=>{f=E(j(),1);m=I.getInstance()});function tn(n){return n instanceof F}var p,k,R,h,C,G,F,w=(n)=>{if(n instanceof Error)return n.message;return String(n)},Ae,sn=(n,e)=>{let r=w(n),t=e?`[${e}] `:"",i=tn(n),s="ERROR";if(n instanceof R)s="BUILD ERROR";else if(n instanceof h)s="DTS ERROR";else if(n instanceof C)s="CLI ERROR";else if(n instanceof G)s="WATCH ERROR";else if(i)s="ISOLATED DECL ERROR";else if(n instanceof k)s="BUNUP ERROR";let o=Ae.find((a)=>a.pattern.test(r)&&(a.errorType===s||!a.errorType));if(!o)console.error(`${p.default.red(s)} ${t}${i?p.default.dim(r):r}`);if(o)console.log(`
4
- `),o.logSolution(r),console.log(`
5
- `);else if(!i)console.error(p.default.dim(p.default.white("If you think this is a bug, please open an issue at: ")+p.default.cyan("https://github.com/arshad-yaseen/bunup/issues/new")))},Ln=(n,e)=>{sn(n,e),process.exit(1)};var y=d(()=>{p=E(j(),1);$();k=class k extends Error{constructor(n){super(n);this.name="BunupError"}};R=class R extends k{constructor(n){super(n);this.name="BunupBuildError"}};h=class h extends k{constructor(n){super(n);this.name="BunupDTSBuildError"}};C=class C extends k{constructor(n){super(n);this.name="BunupCLIError"}};G=class G extends k{constructor(n){super(n);this.name="BunupWatchError"}};F=class F extends k{constructor(n){super(n);this.name="BunupIsolatedDeclError"}};Ae=[{pattern:/Could not resolve: "bun"/i,errorType:"BUILD ERROR",logSolution:()=>{m.error(p.default.white("You're trying to build a project that uses Bun. ")+p.default.white("Please set the target option to ")+p.default.cyan("`bun`")+p.default.white(`.
6
- `)+p.default.white("Example: ")+p.default.green("`bunup --target bun`")+p.default.white(" or in config: ")+p.default.green("{ target: 'bun' }"))}}]});import kn from"fs/promises";import Ee from"path";function Rn(n,e,r){return Array.isArray(n)?n.map((t)=>({...t,[e]:r})):{...n,[e]:r}}function Tn(n){return Array.isArray(n)?n:[n]}function Mn(n,e){switch(n){case"esm":return A(e)?".js":".mjs";case"cjs":return A(e)?".cjs":".js";case"iife":return".global.js"}}function In(n,e){switch(n){case"esm":return A(e)?".d.ts":".d.mts";case"cjs":return A(e)?".d.cts":".d.ts";case"iife":return".d.ts"}}function on(n){return n==="node"||n==="bun"}function A(n){return n==="module"}function K(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function An(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function an(n){if(n===0)return"0 B";let e=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${e[r]}`;return`${(n/1024**r).toFixed(2)} ${e[r]}`}function T(n,e=3){return n.split("/").slice(-e).join("/")}async function En(n,e){let r=Ee.join(n,e);try{await kn.rm(r,{recursive:!0,force:!0})}catch(t){throw new R(`Failed to clean output directory: ${t}`)}await kn.mkdir(r,{recursive:!0})}function Q(n){return[".ts",".mts",".cts",".tsx"].some((e)=>n.endsWith(e))}var B=d(()=>{y()});import{basename as je,dirname as _e,extname as ve}from"path";function Z(n){let e=je(n),r=ve(e);return r?e.slice(0,-r.length):e}function _(n){if(typeof n==="string")return[{fullEntryPath:n,name:Z(n)}];if(typeof n==="object"&&!Array.isArray(n))return Object.entries(n).map(([t,i])=>({fullEntryPath:i,name:t}));let e=[],r=new Set;for(let t of n){let i=Z(t);if(!r.has(i)){e.push({fullEntryPath:t,name:i}),r.add(i);continue}let o=_e(t).split("/").filter((c)=>c!=="."&&c!=="");if(o.length===0){let c=1,u;do u=`${i}_${c++}`;while(r.has(u));e.push({fullEntryPath:t,name:u}),r.add(u);continue}let a=!1;for(let c=1;c<=o.length&&!a;c++){let l=`${o.slice(-c).join("/")}/${i}`;if(!r.has(l))e.push({fullEntryPath:t,name:l}),r.add(l),a=!0}if(!a){let c=1,u;do u=`${o.join("/")}/${i}_${c++}`;while(r.has(u));e.push({fullEntryPath:t,name:u}),r.add(u)}}return e}function jn(n){return n.filter((e)=>Q(e.fullEntryPath))}function _n(n,e){return`[dir]/${n}${e}`}var X=d(()=>{B()});import De from"path";import{loadConfig as Hn}from"coffi";async function Wn(n,e,r){return Array.isArray(n)&&"root"in n[0]?n.filter((t)=>r?r.includes(t.name):!0).map((t)=>({rootDir:De.resolve(e,t.root),options:Rn(t.config,"name",t.name)})):[{rootDir:e,options:n}]}async function Dn(n){let{config:e,filepath:r}=await Hn({name:"package",cwd:n,extensions:[".json"]});return{packageJson:e,path:r}}async function Yn(n,e){let{config:r,filepath:t}=await Hn({name:"tsconfig",cwd:n,extensions:[".json"],preferredPath:e});return{tsconfig:r,path:t}}var un=d(()=>{B()});function Ye(n){return An(n).map((e)=>new RegExp(`^${e}($|\\/|\\\\)`))}function qn(n,e){return typeof e==="string"?e===n:e.test(n)}function z(n,e,r){let i=Ye(r).some((o)=>o.test(n))||e.external?.some((o)=>qn(n,o)),s=e.noExternal?.some((o)=>qn(n,o));return i&&!s}var ln=d(()=>{B()});import{resolveTsImportPath as qe}from"ts-import-resolver";var U="\x00dts:",Gn=(n,e,r)=>{return{name:"bunup:virtual-dts",async resolveId(t,i){if(mn(t))return t;if(!i||!mn(i))return null;let s=e.tsconfig?qe({path:t,importer:v(i),tsconfig:e.tsconfig,rootDir:r}):null;if(!s)return null;let o=L(s);if(n.has(o))return J(o);return null},load(t){if(t.startsWith(U)){let i=v(t),s=n.get(i);if(s)return s}return null}}};var gn=d(()=>{H()});function Fn(n){return n.endsWith(".d.ts")||n.endsWith(".d.mts")||n.endsWith(".d.cts")}function Kn(n){return fn.test(n)&&!Fn(n)}function L(n){if(Fn(n))return n;if(n.endsWith(".mts"))return`${n.slice(0,-4)}.d.mts`;if(n.endsWith(".cts"))return`${n.slice(0,-4)}.d.cts`;if(fn.test(n))return n.replace(fn,".d.ts");return`${n}.d.ts`}function mn(n){return n.startsWith(U)}function v(n){return n.replace(U,"")}function J(n){return`${U}${n}`}function Qn(n,e){if(e===void 0)return"";let r=n.slice(0,e).split(`
7
- `),t=r.length,i=r[r.length-1].length+1;return` (${t}:${i})`}function Zn(n,e,r,t){if(typeof t==="boolean"&&t)return!1;if(Array.isArray(t)){for(let i of t)if(typeof i==="string"&&n===i)return!1;else if(i instanceof RegExp&&i.test(n))return!1}return z(n,e,r)}var fn;var H=d(()=>{ln();gn();fn=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/});import Xn from"path";import{ResolverFactory as Ge}from"oxc-resolver";function Vn(n,e){return{name:"bunup:types-resolve",buildStart(){dn||=new Ge({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...n.path&&{tsconfig:{configFile:n.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(r,t){if(e===!1)return;if(r==="bun")return;let i=t?v(t):void 0;if(/\0/.test(r))return;if(Array.isArray(e)){if(!e.some((c)=>typeof c==="string"?c===r:c.test(r)))return}let s=i?Xn.dirname(i):process.cwd(),{path:o}=await dn.async(s,r);if(!o)return;if(Kn(o)){let a=L(o);try{let{path:c}=await dn.async(Xn.dirname(o),a);if(c)return c}catch(c){}return}return o}}}var dn;var Nn=d(()=>{H()});import{build as Fe}from"rolldown";import{dts as Ke}from"rolldown-plugin-dts";async function zn(n,e,r,t,i,s){let o=L(n),a=J(o),c=typeof r.dts==="object"&&"resolve"in r.dts?r.dts.resolve:void 0;try{let{output:u}=await Fe({input:a,output:{dir:r.outDir},write:!1,...i.path&&{resolve:{tsconfigFilename:i.path}},onwarn(l,g){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(l.code??""))return;g(l)},plugins:[Gn(e,i,s),c&&Vn(i,c),Ke({dtsInput:!0,emitDtsOnly:!0})],external:(l)=>Zn(l,r,t,c)});if(!u[0]?.code)return m.warn(`Generated empty declaration file for entry "${n}"`,{muted:!0}),"";return u[0].code}catch(u){throw new h(`DTS bundling failed for entry "${n}": ${w(u)}`)}}var Jn=d(()=>{y();$();Nn();H();gn()});import{resolveTsImportPath as Qe}from"ts-import-resolver";function nr(n){let e=new Set,r=[Ze,Xe,Ve,Ne,ze,Je,Pe];for(let t of r){let i=n.matchAll(t);for(let s of i)if(s[1])e.add(s[1])}return e}async function Pn(n,e,r){let t=new Set([n]),i=[n];while(i.length){let s=i.pop();if(!s)continue;try{let o=await Bun.file(s).text(),a=nr(o);for(let c of a){let u=e.tsconfig?Qe({path:c,importer:s,tsconfig:e.tsconfig,rootDir:r}):null;if(!u)continue;if(!t.has(u))t.add(u),i.push(u)}}catch(o){m.warn(`Error processing ${s}: ${w(o)}`)}}return t}var Ze,Xe,Ve,Ne,ze,Je,Pe;var ne=d(()=>{y();$();Ze=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Xe=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Ve=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ne=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,ze=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Je=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,Pe=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g});import{isolatedDeclaration as er}from"oxc-transform";async function ee(n,e){let r=!1,t=new Map;if(await Promise.all([...n].map(async(i)=>{try{let s=L(i);if(!await Bun.file(i).exists())return;let a=await Bun.file(i).text(),{code:c,errors:u}=er(i,a);if(c)t.set(s,c);for(let l of u){if(!r&&!e)console.log(`
8
- `);let g=l.labels[0],x=g?Qn(a,g.start):"",S=`${T(i)}${x}: ${rr(l.message)}`;m[e?"warn":"error"](S),r=!0}}catch(s){m.warn(`Failed to generate declaration for ${i}: ${w(s)}`)}})),r&&!e)throw console.log(`
9
- `),new F(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${pn.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${pn.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return t}function rr(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var pn;var re=d(()=>{pn=E(j(),1);y();$();B();H()});import te from"fs/promises";import bn from"path";async function ie(n,e){let r=bn.resolve(n),t=bn.resolve(r,e);if(!await te.exists(r))throw new h(`Root directory does not exist: ${r}`);if(!await Bun.file(t).exists())throw new h(`Entry file does not exist: ${t}`);if(!Q(t))throw new h(`Entry file must be a TypeScript file: ${t}`);if(bn.relative(r,t).startsWith(".."))throw new h(`Entry file must be within rootDir: ${t}`);return{absoluteRootDir:r,absoluteEntry:t}}var se=d(()=>{y();B()});async function oe(n,e,r,t,i){let{absoluteEntry:s}=await ie(n,e),o=await Pn(s,t,n),a=await ee(o,r.watch);return zn(s,a,r,i,t,n)}var ae=d(()=>{Jn();ne();re();se()});function P(n){return{...tr,...n}}function ce(n){let{minify:e,minifyWhitespace:r,minifyIdentifiers:t,minifySyntax:i}=n,s=e===!0;return{whitespace:r??s,identifiers:t??s,syntax:i??s}}function ue(n,e){return e==="cjs"?n:void 0}function le(n,e,r,t){return{...typeof r==="object"&&Object.keys(r).reduce((i,s)=>{let o=JSON.stringify(r[s]);return i[`process.env.${s}`]=o,i[`import.meta.env.${s}`]=o,i},{}),...n,...t==="cjs"&&(e===!0||typeof e==="object"&&e.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function me(n,e){return n===void 0?e==="esm":n}function ge(n){return typeof n==="string"?n:void 0}var tr;var xn=d(()=>{tr={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0}});function fe(n,e){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(t)=>{let i=t.path;if(z(i,n,e))return{path:i,external:!0};return null})}}}var de=d(()=>{ln()});function pe({format:n,target:e,shims:r}){let i=sr(r).map((s)=>hn[s]).filter((s)=>s.appliesTo(n,e));if(i.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(s){s.onLoad({filter:ir},async({path:o})=>{let a=await Bun.file(o).text(),c=i.filter((x)=>x.isNeededInFile(a));if(c.length===0)return;let{shebangLine:u,codeContent:l}=or(a),g=c.map((x)=>x.generateCode()).join("");return{contents:u+g+l}})}}}function sr(n){if(n===!0)return Object.keys(hn);if(!n)return[];return Object.entries(n).filter(([e,r])=>r&&(e in hn)).map(([e])=>e)}function or(n){if(!n.startsWith("#!"))return{shebangLine:"",codeContent:n};let e=n.indexOf(`
10
- `);return e===-1?{shebangLine:"",codeContent:n}:{shebangLine:n.slice(0,e+1),codeContent:n.slice(e+1)}}var ir,hn;var be=d(()=>{B();ir=/\.(js|ts|jsx|tsx|mts|cts)$/,hn={dirnameFilename:{appliesTo:(n,e)=>n==="esm"&&on(e),isNeededInFile:(n)=>/\b__dirname\b/.test(n)||/\b__filename\b/.test(n),generateCode:()=>`import { fileURLToPath } from 'url';
3
+ var kr=Object.create;var{getPrototypeOf:Sr,defineProperty:on,getOwnPropertyNames:Tr}=Object;var $r=Object.prototype.hasOwnProperty;var E=(n,r,t)=>{t=n!=null?kr(Sr(n)):{};let e=r||!n||!n.__esModule?on(t,"default",{value:n,enumerable:!0}):t;for(let i of Tr(n))if(!$r.call(e,i))on(e,i,{get:()=>n[i],enumerable:!0});return e};var Lr=(n,r)=>()=>(r||n((r={exports:{}}).exports,r),r.exports);var Rr=(n,r)=>{for(var t in r)on(n,t,{get:r[t],enumerable:!0,configurable:!0,set:(e)=>r[t]=()=>e})};var d=(n,r)=>()=>(n&&(r=n(n=0)),r);var Ir=import.meta.require;var v=Lr((be,sn)=>{var F=process||{},On=F.argv||[],q=F.env||{},Mr=!(!!q.NO_COLOR||On.includes("--no-color"))&&(!!q.FORCE_COLOR||On.includes("--color")||F.platform==="win32"||(F.stdout||{}).isTTY&&q.TERM!=="dumb"||!!q.CI),Ar=(n,r,t=n)=>(e)=>{let i=""+e,o=i.indexOf(r,n.length);return~o?n+jr(i,r,t,o)+r:n+i+r},jr=(n,r,t,e)=>{let i="",o=0;do i+=n.substring(o,e)+t,o=e+r.length,e=n.indexOf(r,o);while(~e);return i+n.substring(o)},kn=(n=Mr)=>{let r=n?Ar:()=>String;return{isColorSupported:n,reset:r("\x1B[0m","\x1B[0m"),bold:r("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:r("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:r("\x1B[3m","\x1B[23m"),underline:r("\x1B[4m","\x1B[24m"),inverse:r("\x1B[7m","\x1B[27m"),hidden:r("\x1B[8m","\x1B[28m"),strikethrough:r("\x1B[9m","\x1B[29m"),black:r("\x1B[30m","\x1B[39m"),red:r("\x1B[31m","\x1B[39m"),green:r("\x1B[32m","\x1B[39m"),yellow:r("\x1B[33m","\x1B[39m"),blue:r("\x1B[34m","\x1B[39m"),magenta:r("\x1B[35m","\x1B[39m"),cyan:r("\x1B[36m","\x1B[39m"),white:r("\x1B[37m","\x1B[39m"),gray:r("\x1B[90m","\x1B[39m"),bgBlack:r("\x1B[40m","\x1B[49m"),bgRed:r("\x1B[41m","\x1B[49m"),bgGreen:r("\x1B[42m","\x1B[49m"),bgYellow:r("\x1B[43m","\x1B[49m"),bgBlue:r("\x1B[44m","\x1B[49m"),bgMagenta:r("\x1B[45m","\x1B[49m"),bgCyan:r("\x1B[46m","\x1B[49m"),bgWhite:r("\x1B[47m","\x1B[49m"),blackBright:r("\x1B[90m","\x1B[39m"),redBright:r("\x1B[91m","\x1B[39m"),greenBright:r("\x1B[92m","\x1B[39m"),yellowBright:r("\x1B[93m","\x1B[39m"),blueBright:r("\x1B[94m","\x1B[39m"),magentaBright:r("\x1B[95m","\x1B[39m"),cyanBright:r("\x1B[96m","\x1B[39m"),whiteBright:r("\x1B[97m","\x1B[39m"),bgBlackBright:r("\x1B[100m","\x1B[49m"),bgRedBright:r("\x1B[101m","\x1B[49m"),bgGreenBright:r("\x1B[102m","\x1B[49m"),bgYellowBright:r("\x1B[103m","\x1B[49m"),bgBlueBright:r("\x1B[104m","\x1B[49m"),bgMagentaBright:r("\x1B[105m","\x1B[49m"),bgCyanBright:r("\x1B[106m","\x1B[49m"),bgWhiteBright:r("\x1B[107m","\x1B[49m")}};sn.exports=kn();sn.exports.createColors=kn});function G(n){Tn=n??!1}class A{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;cliColor=p.default.blue;mutedColor=p.default.dim;infoColor=p.default.cyan;warnColor=p.default.yellow;errorColor=p.default.red;defaultColor=p.default.white;progressFgColorMap={ESM:p.default.yellow,CJS:p.default.green,IIFE:p.default.magenta,DTS:p.default.blue};progressBgColorMap={ESM:p.default.bgYellow,CJS:p.default.bgGreen,IIFE:p.default.bgMagenta,DTS:p.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!A.instance)A.instance=new A;return A.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(n){if(!n?.once)return!0;if(this.loggedOnceMessages.has(n.once))return!1;return this.loggedOnceMessages.add(n.once),!0}formatMessage({fgColor:n,bgColor:r,label:t,message:e,identifier:i,muted:o}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),c=o?this.mutedColor(e):e,a=i?` ${r(p.default.black(` ${i} `))}`:"";return`${n(t)} ${s}${c}${a}`}output(n,r={},t=console.log){if(Tn||!this.shouldLog(r))return;if(r.verticalSpace)t("");if(t(n),r.verticalSpace)t("")}cli(n,r={}){let t=this.formatMessage({fgColor:this.cliColor,bgColor:p.default.bgBlue,label:this.labels.cli,message:n,identifier:r.identifier,muted:r.muted});this.output(t,r)}info(n,r={}){let t=this.formatMessage({fgColor:this.infoColor,bgColor:p.default.bgCyan,label:this.labels.info,message:n,identifier:r.identifier,muted:r.muted});this.output(t,r)}warn(n,r={}){let t=this.formatMessage({fgColor:this.warnColor,bgColor:p.default.bgYellow,label:this.labels.warn,message:n,identifier:r.identifier,muted:r.muted});this.output(t,r,console.warn)}error(n,r={}){let t=this.formatMessage({fgColor:this.errorColor,bgColor:p.default.bgRed,label:this.labels.error,message:n,identifier:r.identifier,muted:r.muted});this.output(t,r,console.error)}getProgressFgColor(n){for(let[r,t]of Object.entries(this.progressFgColorMap))if(n.includes(r))return t;return this.defaultColor}getProgressBgColor(n){for(let[r,t]of Object.entries(this.progressBgColorMap))if(n.includes(r))return t;return p.default.bgWhite}progress(n,r,t={}){let e=this.getProgressFgColor(n),i=this.getProgressBgColor(n),o=this.formatMessage({fgColor:e,bgColor:i,label:n,message:r,identifier:t.identifier,muted:t.muted});this.output(o,t)}}var p,Tn=!1,l;var T=d(()=>{p=E(v(),1);l=A.getInstance()});function an(n){return n instanceof Z}var b,R,I,w,C,Q,Z,y=(n)=>{if(n instanceof Error)return n.message;return String(n)},vr,un=(n,r)=>{let t=y(n),e=r?`[${r}] `:"",i=an(n),o="ERROR";if(n instanceof I)o="BUILD ERROR";else if(n instanceof w)o="DTS ERROR";else if(n instanceof C)o="CLI ERROR";else if(n instanceof Q)o="WATCH ERROR";else if(i)o="ISOLATED DECL ERROR";else if(n instanceof R)o="BUNUP ERROR";let s=vr.find((c)=>c.pattern.test(t)&&(c.errorType===o||!c.errorType));if(!s)console.error(`${b.default.red(o)} ${e}${i?b.default.dim(t):t}`);if(s)console.log(`
4
+ `),s.logSolution(t),console.log(`
5
+ `);else if(!i)console.error(b.default.dim(b.default.white("If you think this is a bug, please open an issue at: ")+b.default.cyan("https://github.com/arshad-yaseen/bunup/issues/new")))},$n=(n,r)=>{un(n,r),process.exit(1)};var B=d(()=>{b=E(v(),1);T();R=class R extends Error{constructor(n){super(n);this.name="BunupError"}};I=class I extends R{constructor(n){super(n);this.name="BunupBuildError"}};w=class w extends R{constructor(n){super(n);this.name="BunupDTSBuildError"}};C=class C extends R{constructor(n){super(n);this.name="BunupCLIError"}};Q=class Q extends R{constructor(n){super(n);this.name="BunupWatchError"}};Z=class Z extends R{constructor(n){super(n);this.name="BunupIsolatedDeclError"}};vr=[{pattern:/Could not resolve: "bun"/i,errorType:"BUILD ERROR",logSolution:()=>{l.error(b.default.white("You're trying to build a project that uses Bun. ")+b.default.white("Please set the target option to ")+b.default.cyan("`bun`")+b.default.white(`.
6
+ `)+b.default.white("Example: ")+b.default.green("`bunup --target bun`")+b.default.white(" or in config: ")+b.default.green("{ target: 'bun' }"))}}]});import Ln from"fs/promises";import Ur from"path";function Rn(n,r,t){return Array.isArray(n)?n.map((e)=>({...e,[r]:t})):{...n,[r]:t}}function In(n){return Array.isArray(n)?n:[n]}function Mn(n,r){switch(n){case"esm":return j(r)?".js":".mjs";case"cjs":return j(r)?".cjs":".js";case"iife":return".global.js"}}function An(n,r){switch(n){case"esm":return j(r)?".d.ts":".d.mts";case"cjs":return j(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function cn(n){return n==="node"||n==="bun"}function j(n){return n==="module"}function z(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function jn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function M(n,r=3){return n.split("/").slice(-r).join("/")}async function En(n,r){let t=Ur.join(n,r);try{await Ln.rm(t,{recursive:!0,force:!0})}catch(e){throw new I(`Failed to clean output directory: ${e}`)}await Ln.mkdir(t,{recursive:!0})}function V(n){return[".ts",".mts",".cts",".tsx"].some((r)=>n.endsWith(r))}var O=d(()=>{B()});import{basename as _r,dirname as Hr,extname as Wr}from"path";function X(n){let r=_r(n),t=Wr(r);return t?r.slice(0,-t.length):r}function U(n){if(typeof n==="string")return[{fullEntryPath:n,name:X(n)}];if(typeof n==="object"&&!Array.isArray(n))return Object.entries(n).map(([e,i])=>({fullEntryPath:i,name:e}));let r=[],t=new Set;for(let e of n){let i=X(e);if(!t.has(i)){r.push({fullEntryPath:e,name:i}),t.add(i);continue}let s=Hr(e).split("/").filter((a)=>a!=="."&&a!=="");if(s.length===0){let a=1,u;do u=`${i}_${a++}`;while(t.has(u));r.push({fullEntryPath:e,name:u}),t.add(u);continue}let c=!1;for(let a=1;a<=s.length&&!c;a++){let m=`${s.slice(-a).join("/")}/${i}`;if(!t.has(m))r.push({fullEntryPath:e,name:m}),t.add(m),c=!0}if(!c){let a=1,u;do u=`${s.join("/")}/${i}_${a++}`;while(t.has(u));r.push({fullEntryPath:e,name:u}),t.add(u)}}return r}function vn(n){return n.filter((r)=>V(r.fullEntryPath))}function Un(n,r){return`[dir]/${n}${r}`}var N=d(()=>{O()});import Fr from"path";import{loadConfig as Wn}from"coffi";async function Dn(n,r,t){return Array.isArray(n)&&"root"in n[0]?n.filter((e)=>t?t.includes(e.name):!0).map((e)=>({rootDir:Fr.resolve(r,e.root),options:Rn(e.config,"name",e.name)})):[{rootDir:r,options:n}]}async function Yn(n){let{config:r,filepath:t}=await Wn({name:"package",cwd:n,extensions:[".json"]});return{packageJson:r,path:t}}async function qn(n,r){let{config:t,filepath:e}=await Wn({name:"tsconfig",cwd:n,extensions:[".json"],preferredPath:r});return{tsconfig:t,path:e}}var mn=d(()=>{O()});function Kr(n){return jn(n).map((r)=>new RegExp(`^${r}($|\\/|\\\\)`))}function Fn(n,r){return typeof r==="string"?r===n:r.test(n)}function nn(n,r,t){let i=Kr(t).some((s)=>s.test(n))||r.external?.some((s)=>Fn(n,s)),o=r.noExternal?.some((s)=>Fn(n,s));return i&&!o}var gn=d(()=>{O()});import{resolveTsImportPath as Gr}from"ts-import-resolver";var H="\x00dts:",Kn=(n,r,t)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(fn(e))return e;if(!i||!fn(i))return null;let o=r.tsconfig?Gr({path:e,importer:_(i),tsconfig:r.tsconfig,rootDir:t}):null;if(!o)return null;let s=$(o);if(n.has(s))return rn(s);return null},load(e){if(e.startsWith(H)){let i=_(e),o=n.get(i);if(o)return o}return null}}};var pn=d(()=>{W()});function Gn(n){return n.endsWith(".d.ts")||n.endsWith(".d.mts")||n.endsWith(".d.cts")}function Qn(n){return dn.test(n)&&!Gn(n)}function $(n){if(Gn(n))return n;if(n.endsWith(".mts"))return`${n.slice(0,-4)}.d.mts`;if(n.endsWith(".cts"))return`${n.slice(0,-4)}.d.cts`;if(dn.test(n))return n.replace(dn,".d.ts");return`${n}.d.ts`}function fn(n){return n.startsWith(H)}function _(n){return n.replace(H,"")}function rn(n){return`${H}${n}`}function Zn(n,r){if(r===void 0)return"";let t=n.slice(0,r).split(`
7
+ `),e=t.length,i=t[t.length-1].length+1;return` (${e}:${i})`}function zn(n,r,t,e){if(typeof e==="boolean"&&e)return!1;if(Array.isArray(e)){for(let i of e)if(typeof i==="string"&&n===i)return!1;else if(i instanceof RegExp&&i.test(n))return!1}return nn(n,r,t)}var dn;var W=d(()=>{gn();pn();dn=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/});import Vn from"path";import{ResolverFactory as Qr}from"oxc-resolver";function Xn(n,r){return{name:"bunup:types-resolve",buildStart(){bn||=new Qr({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...n.path&&{tsconfig:{configFile:n.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(t,e){if(r===!1)return;if(t==="bun")return;let i=e?_(e):void 0;if(/\0/.test(t))return;if(Array.isArray(r)){if(!r.some((a)=>typeof a==="string"?a===t:a.test(t)))return}let o=i?Vn.dirname(i):process.cwd(),{path:s}=await bn.async(o,t);if(!s)return;if(Qn(s)){let c=$(s);try{let{path:a}=await bn.async(Vn.dirname(s),c);if(a)return a}catch(a){}return}return s}}}var bn;var Nn=d(()=>{W()});import{build as Zr}from"rolldown";import{dts as zr}from"rolldown-plugin-dts";async function Jn(n,r,t,e,i,o){let s=$(n),c=rn(s),a=typeof t.dts==="object"&&"resolve"in t.dts?t.dts.resolve:void 0;try{let{output:u}=await Zr({input:c,output:{dir:t.outDir},write:!1,...i.path&&{resolve:{tsconfigFilename:i.path}},onwarn(m,g){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(m.code??""))return;g(m)},plugins:[Kn(r,i,o),a&&Xn(i,a),zr({dtsInput:!0,emitDtsOnly:!0})],external:(m)=>zn(m,t,e,a)});if(!u[0]?.code)return l.warn(`Generated empty declaration file for entry "${n}"`,{muted:!0}),"";return u[0].code}catch(u){throw new w(`DTS bundling failed for entry "${n}": ${y(u)}`)}}var Pn=d(()=>{B();T();Nn();W();pn()});import{resolveTsImportPath as Vr}from"ts-import-resolver";function te(n){let r=new Set,t=[Xr,Nr,Jr,Pr,ne,re,ee];for(let e of t){let i=n.matchAll(e);for(let o of i)if(o[1])r.add(o[1])}return r}async function nr(n,r,t){let e=new Set([n]),i=[n];while(i.length){let o=i.pop();if(!o)continue;try{let s=await Bun.file(o).text(),c=te(s);for(let a of c){let u=r.tsconfig?Vr({path:a,importer:o,tsconfig:r.tsconfig,rootDir:t}):null;if(!u)continue;if(!e.has(u))e.add(u),i.push(u)}}catch(s){l.warn(`Error processing ${o}: ${y(s)}`)}}return e}var Xr,Nr,Jr,Pr,ne,re,ee;var rr=d(()=>{B();T();Xr=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Nr=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Jr=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Pr=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,ne=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,re=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,ee=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g});import{isolatedDeclaration as ie}from"oxc-transform";async function er(n,r){let t=!1,e=new Map;if(await Promise.all([...n].map(async(i)=>{try{let o=$(i);if(!await Bun.file(i).exists())return;let c=await Bun.file(i).text(),{code:a,errors:u}=ie(i,c);if(a)e.set(o,a);for(let m of u){if(!t&&!r)console.log(`
8
+ `);let g=m.labels[0],f=g?Zn(c,g.start):"",h=`${M(i)}${f}: ${oe(m.message)}`;l[r?"warn":"error"](h),t=!0}}catch(o){l.warn(`Failed to generate declaration for ${i}: ${y(o)}`)}})),t&&!r)throw console.log(`
9
+ `),new Z(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${xn.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${xn.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return e}function oe(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var xn;var tr=d(()=>{xn=E(v(),1);B();T();O();W()});import ir from"fs/promises";import hn from"path";async function or(n,r){let t=hn.resolve(n),e=hn.resolve(t,r);if(!await ir.exists(t))throw new w(`Root directory does not exist: ${t}`);if(!await Bun.file(e).exists())throw new w(`Entry file does not exist: ${e}`);if(!V(e))throw new w(`Entry file must be a TypeScript file: ${e}`);if(hn.relative(t,e).startsWith(".."))throw new w(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}var sr=d(()=>{B();O()});async function ar(n,r,t,e,i){let{absoluteEntry:o}=await or(n,r),s=await nr(o,e,n),c=await er(s,t.watch);return Jn(o,c,t,i,e,n)}var ur=d(()=>{Pn();rr();tr();sr()});function en(n){return{...se,...n}}function cr(n){let{minify:r,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:i}=n,o=r===!0;return{whitespace:t??o,identifiers:e??o,syntax:i??o}}function lr(n,r){return r==="cjs"?n:void 0}function mr(n,r,t,e){return{...typeof t==="object"&&Object.keys(t).reduce((i,o)=>{let s=JSON.stringify(t[o]);return i[`process.env.${o}`]=s,i[`import.meta.env.${o}`]=s,i},{}),...n,...e==="cjs"&&(r===!0||typeof r==="object"&&r.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function gr(n,r){return n===void 0?r==="esm":n}function fr(n){return typeof n==="string"?n:void 0}var se;var wn=d(()=>{se={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0}});function pr(n,r){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let i=e.path;if(nn(i,n,r))return{path:i,external:!0};return null})}}}var dr=d(()=>{gn()});function br({format:n,target:r,shims:t}){let i=ue(t).map((o)=>yn[o]).filter((o)=>o.appliesTo(n,r));if(i.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:ae},async({path:s})=>{let c=await Bun.file(s).text(),a=i.filter((f)=>f.isNeededInFile(c));if(a.length===0)return;let{shebangLine:u,codeContent:m}=ce(c),g=a.map((f)=>f.generateCode()).join("");return{contents:u+g+m}})}}}function ue(n){if(n===!0)return Object.keys(yn);if(!n)return[];return Object.entries(n).filter(([r,t])=>t&&(r in yn)).map(([r])=>r)}function ce(n){if(!n.startsWith("#!"))return{shebangLine:"",codeContent:n};let r=n.indexOf(`
10
+ `);return r===-1?{shebangLine:"",codeContent:n}:{shebangLine:n.slice(0,r+1),codeContent:n.slice(r+1)}}var ae,yn;var xr=d(()=>{O();ae=/\.(js|ts|jsx|tsx|mts|cts)$/,yn={dirnameFilename:{appliesTo:(n,r)=>n==="esm"&&cn(r),isNeededInFile:(n)=>/\b__dirname\b/.test(n)||/\b__filename\b/.test(n),generateCode:()=>`import { fileURLToPath } from 'url';
11
11
  import { dirname } from 'path';
12
12
 
13
13
  const __filename = fileURLToPath(import.meta.url);
14
14
  const __dirname = dirname(__filename);
15
15
 
16
- `},importMetaUrl:{appliesTo:(n,e)=>n==="cjs"&&on(e),isNeededInFile:(n)=>/\bimport\.meta\.url\b/.test(n),generateCode:()=>`import { pathToFileURL } from 'url';
16
+ `},importMetaUrl:{appliesTo:(n,r)=>n==="cjs"&&cn(r),isNeededInFile:(n)=>/\bimport\.meta\.url\b/.test(n),generateCode:()=>`import { pathToFileURL } from 'url';
17
17
 
18
18
  const importMetaUrl = pathToFileURL(__filename).href;
19
19
 
20
- `}}});function xe(n){return n.filter((e)=>e.type==="bun")}var he={};Le(he,{build:()=>wn});async function wn(n,e=process.cwd()){let r=P(n);if(!r.entry||r.entry.length===0||!r.outDir)throw new R("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)En(e,r.outDir);q(r.silent);let{packageJson:t,path:i}=await Dn(e);if(t&&i)m.cli(`Using package.json: ${T(i,2)}`,{muted:!0,identifier:r.name,once:`${i}:${r.name}`});let s=_(r.entry),o=t?.type;if(!r.dtsOnly){let a=[fe(r,t),...xe(r.plugins??[]).map((u)=>u.plugin)],c=r.format.flatMap((u)=>s.map((l)=>{return cr(r,e,l,u,o,a)}));await Promise.all(c)}if(r.dts||r.dtsOnly){let a=await Yn(e,r.preferredTsconfigPath);if(a.path)m.cli(`Using tsconfig: ${T(a.path,2)}`,{muted:!0,identifier:r.name,once:`${a.path}:${r.name}`});let c=r.format.filter((l)=>{if(l==="iife"&&!A(o)&&r.format.includes("cjs"))return!1;return!0}),u=typeof r.dts==="object"&&r.dts.entry?_(r.dts.entry):jn(s);try{await Promise.all(u.map(async(l)=>{let g=await oe(e,l.fullEntryPath,r,a,t);await Promise.all(c.map(async(x)=>{let M=r.outputExtension?.({format:x,packageType:o,options:r,entry:l}).dts??In(x,o),S=`${r.outDir}/${l.name}${M}`,yn=`${e}/${S}`;await Bun.write(yn,g);let Ce=Bun.file(yn).size||0;m.progress("DTS",S,an(Ce),r.name)}))}))}catch(l){if(tn(l))throw l;throw new h(w(l))}}if(r.onBuildSuccess)await r.onBuildSuccess(r)}async function cr(n,e,r,t,i,s){let o=n.outputExtension?.({format:t,packageType:i,options:n,entry:r}).js??Mn(t,i),a=await Bun.build({entrypoints:[`${e}/${r.fullEntryPath}`],format:t,naming:{entry:_n(r.name,o)},splitting:me(n.splitting,t),bytecode:ue(n.bytecode,t),define:le(n.define,n.shims,n.env,t),minify:ce(n),outdir:`${e}/${n.outDir}`,target:n.target,sourcemap:n.sourcemap,loader:n.loader,drop:n.drop,banner:n.banner,footer:n.footer,publicPath:n.publicPath,env:ge(n.env),plugins:[...s,pe({format:t,target:n.target,shims:n.shims})],throw:!1});if(!a.success)for(let g of a.logs){if(g.level==="error")throw new R(g.message);if(g.level==="warning")m.warn(g.message);else if(g.level==="info")m.info(g.message)}let c=`${n.outDir}/${r.name}${o}`,u=`${e}/${c}`,l=Bun.file(u).size||0;m.progress(t.toUpperCase(),c,an(l),n.name)}var Cn=d(()=>{ae();y();X();un();$();xn();de();be();B()});import{exec as ur}from"tinyexec";var cn=E(j(),1);var Y="0.4.73";var $n="https://bunup.dev/cli-options";y();X();$();function b(n){return(e,r)=>{r[n]=e===!0||e==="true"}}function O(n){return(e,r)=>{if(typeof e==="string")r[n]=e;else throw new C(`Option --${n} requires a string value`)}}function V(n){return(e,r)=>{if(typeof e==="string")r[n]=e.split(",");else throw new C(`Option --${n} requires a string value`)}}function Ue(n){return(e,r)=>{if(typeof e==="boolean")r[n]=e;else if(typeof e==="string")if(e.toLowerCase()==="true"||e.toLowerCase()==="false")r[n]=e.toLowerCase()==="true";else r[n]=e;else throw new C(`Option --${n} requires a boolean or string value`)}}function He(){console.log(`
20
+ `}}});function hr(n){if(!n)return[];return n.filter((r)=>r.type==="bun")}function wr(n){if(!n)return[];return n.filter((r)=>r.type==="bunup")}async function yr(n,r){if(!n)return;for(let t of n)if(t.hooks.onBuildStart)await t.hooks.onBuildStart(r)}async function Cr(n,r,t){if(!n)return;for(let e of n)if(e.hooks.onBuildDone)await e.hooks.onBuildDone({options:r,output:t})}var Br={};Rr(Br,{build:()=>Cn});async function Cn(n,r=process.cwd()){let t={files:[]},e=en(n);if(!e.entry||e.entry.length===0||!e.outDir)throw new I("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(e.clean)En(r,e.outDir);G(e.silent);let{packageJson:i,path:o}=await Yn(r);if(i&&o)l.cli(`Using package.json: ${M(o,2)}`,{muted:!0,identifier:e.name,once:`${o}:${e.name}`});let s=wr(e.plugins);await yr(s,e);let c=U(e.entry),a=i?.type;if(!e.dtsOnly){let u=[pr(e,i),...hr(e.plugins).map((g)=>g.plugin)],m=e.format.flatMap((g)=>c.map(async(f)=>{let L=e.outputExtension?.({format:g,packageType:a,options:e,entry:f}).js??Mn(g,a),h=await Bun.build({entrypoints:[`${r}/${f.fullEntryPath}`],format:g,naming:{entry:Un(f.name,L)},splitting:gr(e.splitting,g),bytecode:lr(e.bytecode,g),define:mr(e.define,e.shims,e.env,g),minify:cr(e),outdir:`${r}/${e.outDir}`,target:e.target,sourcemap:e.sourcemap,loader:e.loader,drop:e.drop,banner:e.banner,footer:e.footer,publicPath:e.publicPath,env:fr(e.env),plugins:[...u,br({format:g,target:e.target,shims:e.shims})],throw:!1});if(!h.success)for(let S of h.logs){if(S.level==="error")throw new I(S.message);if(S.level==="warning")l.warn(S.message);else if(S.level==="info")l.info(S.message)}let D=`${e.outDir}/${f.name}${L}`,Y=`${r}/${D}`;t.files.push({path:Y}),l.progress(g.toUpperCase(),D,{identifier:e.name})}));await Promise.all(m)}if(e.dts||e.dtsOnly){let u=await qn(r,e.preferredTsconfigPath);if(u.path)l.cli(`Using tsconfig: ${M(u.path,2)}`,{muted:!0,identifier:e.name,once:`${u.path}:${e.name}`});let m=e.format.filter((f)=>{if(f==="iife"&&!j(a)&&e.format.includes("cjs"))return!1;return!0}),g=typeof e.dts==="object"&&e.dts.entry?U(e.dts.entry):vn(c);try{await Promise.all(g.map(async(f)=>{let L=await ar(r,f.fullEntryPath,e,u,i);await Promise.all(m.map(async(h)=>{let D=e.outputExtension?.({format:h,packageType:a,options:e,entry:f}).dts??An(h,a),Y=`${e.outDir}/${f.name}${D}`,S=`${r}/${Y}`;t.files.push({path:S}),await Bun.write(S,L),l.progress("DTS",Y,{identifier:e.name})}))}))}catch(f){if(an(f))throw f;throw new w(y(f))}}if(await Cr(s,e,t),e.onSuccess)await e.onSuccess(e)}var Bn=d(()=>{ur();B();N();mn();T();wn();dr();xr();O()});import{exec as me}from"tinyexec";var ln=E(v(),1);var K="0.4.74";var Sn="https://bunup.dev/cli-options";B();N();T();function x(n){return(r,t)=>{t[n]=r===!0||r==="true"}}function k(n){return(r,t)=>{if(typeof r==="string")t[n]=r;else throw new C(`Option --${n} requires a string value`)}}function J(n){return(r,t)=>{if(typeof r==="string")t[n]=r.split(",");else throw new C(`Option --${n} requires a string value`)}}function Dr(n){return(r,t)=>{if(typeof r==="boolean")t[n]=r;else if(typeof r==="string")if(r.toLowerCase()==="true"||r.toLowerCase()==="false")t[n]=r.toLowerCase()==="true";else t[n]=r;else throw new C(`Option --${n} requires a boolean or string value`)}}function Yr(){console.log(`
21
21
  Bunup - \u26A1\uFE0F A blazing-fast build tool for your libraries built with Bun.
22
- `),console.log("For more information on available options, visit:"),console.log(`${cn.default.cyan(cn.default.underline($n))}
23
- `),process.exit(0)}function We(){console.log(Y),process.exit(0)}var vn={name:{flags:["n","name"],handler:O("name")},format:{flags:["f","format"],handler:V("format")},outDir:{flags:["o","out-dir"],handler:O("outDir")},minify:{flags:["m","minify"],handler:b("minify")},watch:{flags:["w","watch"],handler:b("watch")},dts:{flags:["d","dts"],handler:b("dts")},banner:{flags:["bn","banner"],handler:O("banner")},footer:{flags:["ft","footer"],handler:O("footer")},external:{flags:["e","external"],handler:V("external")},sourcemap:{flags:["sm","sourcemap"],handler:Ue("sourcemap")},target:{flags:["t","target"],handler:O("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:b("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:b("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:b("minifySyntax")},clean:{flags:["c","clean"],handler:b("clean")},splitting:{flags:["s","splitting"],handler:b("splitting")},noExternal:{flags:["ne","no-external"],handler:V("noExternal")},preferredTsconfigPath:{flags:["tsconfig","preferred-tsconfig-path"],handler:O("preferredTsconfigPath")},bytecode:{flags:["bc","bytecode"],handler:b("bytecode")},dtsOnly:{flags:["do","dts-only"],handler:b("dtsOnly")},silent:{flags:["silent"],handler:b("silent")},config:{flags:["config"],handler:O("config")},publicPath:{flags:["pp","public-path"],handler:O("publicPath")},env:{flags:["env"],handler:O("env")},shims:{flags:["shims"],handler:b("shims")},onSuccess:{flags:["onSuccess"],handler:O("onSuccess")},filter:{flags:["filter"],handler:V("filter")},entry:{flags:["entry"],handler:(n,e,r)=>{if(typeof n!=="string")throw new C(`Entry${r?` --entry.${r}`:""} requires a string value`);let t=e.entry||{};if(r){if(t[r])m.warn(`Duplicate entry name '${r}' provided via --entry.${r}. Overwriting previous entry.`);t[r]=n}else{let i=Z(n);if(t[i])m.warn(`Duplicate entry name '${i}' derived from '${n}'. Overwriting previous entry.`);t[i]=n}e.entry=t}},resolveDts:{flags:["rd","resolve-dts"],handler:(n,e)=>{if(!e.dts)e.dts={};if(typeof e.dts==="boolean")e.dts={};if(typeof n==="string")if(n==="true"||n==="false")e.dts.resolve=n==="true";else e.dts.resolve=n.split(",");else e.dts.resolve=!0}},help:{flags:["h","help"],handler:()=>He()},version:{flags:["v","version"],handler:()=>We()}},N={};for(let n of Object.values(vn))for(let e of n.flags)N[e]=n.handler;function Un(n){let e={};for(let r=0;r<n.length;r++){let t=n[r];if(t.startsWith("--")){let i,s;if(t.includes("=")){let[o,a]=t.slice(2).split("=",2);i=o,s=a}else{i=t.slice(2);let o=n[r+1];if(s=o&&!o.startsWith("-")?o:!0,typeof s==="string")r++}if(i.includes(".")){let[o,a]=i.split(".",2),c=N[o];if(c)c(s,e,a);else throw new C(`Unknown option: --${i}`)}else{let o=N[i];if(o)o(s,e);else throw new C(`Unknown option: --${i}`)}}else if(t.startsWith("-")){let i=t.slice(1),s=n[r+1],o=s&&!s.startsWith("-")?s:!0;if(typeof o==="string")r++;let a=N[i];if(a)a(o,e);else throw new C(`Unknown option: -${i}`)}else vn.entry.handler(t,e,void 0)}return e}y();$();import{loadConfig as lr}from"coffi";un();B();Cn();y();X();$();xn();B();import nn from"path";async function we(n,e){let r=new Set,t=P(n),i=_(t.entry);for(let u of i){let l=nn.resolve(e,u.fullEntryPath),g=nn.dirname(l);r.add(g)}let o=(await import("chokidar")).watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,nn.join(e,t.outDir)]}),a=!1,c=async(u=!1)=>{if(a)return;a=!0;try{let l=performance.now();if(await wn({...t,entry:i.map((g)=>g.fullEntryPath),clean:!1},e),!u)m.cli(`\uD83D\uDCE6 Rebuild finished in ${K(performance.now()-l)}`)}catch(l){sn(l)}finally{a=!1}};o.on("change",(u)=>{let l=nn.relative(e,u);m.cli(`File changed: ${l}`,{muted:!0,once:l}),c()}),o.on("error",(u)=>{throw new G(`Watcher error: ${w(u)}`)}),await c(!0)}async function mr(n=Bun.argv.slice(2)){let e=Un(n);q(e.silent);let r=process.cwd(),{config:t,filepath:i}=await lr({name:"bunup.config",extensions:[".ts",".js",".mjs",".cjs"],maxDepth:1,preferredPath:e.config,packageJsonProperty:"bunup"}),s=!t?[{rootDir:r,options:e}]:await Wn(t,r,e.filter);if(m.cli(`Using bunup v${Y} and bun v${Bun.version}`,{muted:!0}),i)m.cli(`Using config file: ${T(i,2)}`,{muted:!0});let o=performance.now();m.cli("Build started");let{build:a}=await Promise.resolve().then(() => (Cn(),he));await Promise.all(s.flatMap(({options:l,rootDir:g})=>{return Tn(l).map(async(M)=>{let S={...M,...gr(e)};if(S.watch)await we(S,g);else await a(S,g)})}));let c=performance.now()-o,u=K(c);if(m.cli(`\u26A1\uFE0F Build completed in ${u}`),e.watch)m.cli("\uD83D\uDC40 Watching for file changes");if(e.onSuccess)m.cli(`Running command: ${e.onSuccess}`,{muted:!0}),await ur(e.onSuccess,[],{nodeOptions:{shell:!0,stdio:"inherit"}});if(!e.watch)process.exit(process.exitCode??0)}function gr(n){return{...n,onSuccess:void 0,config:void 0}}mr().catch((n)=>Ln(n));
22
+ `),console.log("For more information on available options, visit:"),console.log(`${ln.default.cyan(ln.default.underline(Sn))}
23
+ `),process.exit(0)}function qr(){console.log(K),process.exit(0)}var _n={name:{flags:["n","name"],handler:k("name")},format:{flags:["f","format"],handler:J("format")},outDir:{flags:["o","out-dir"],handler:k("outDir")},minify:{flags:["m","minify"],handler:x("minify")},watch:{flags:["w","watch"],handler:x("watch")},dts:{flags:["d","dts"],handler:x("dts")},banner:{flags:["bn","banner"],handler:k("banner")},footer:{flags:["ft","footer"],handler:k("footer")},external:{flags:["e","external"],handler:J("external")},sourcemap:{flags:["sm","sourcemap"],handler:Dr("sourcemap")},target:{flags:["t","target"],handler:k("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:x("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:x("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:x("minifySyntax")},clean:{flags:["c","clean"],handler:x("clean")},splitting:{flags:["s","splitting"],handler:x("splitting")},noExternal:{flags:["ne","no-external"],handler:J("noExternal")},preferredTsconfigPath:{flags:["tsconfig","preferred-tsconfig-path"],handler:k("preferredTsconfigPath")},bytecode:{flags:["bc","bytecode"],handler:x("bytecode")},dtsOnly:{flags:["do","dts-only"],handler:x("dtsOnly")},silent:{flags:["silent"],handler:x("silent")},config:{flags:["config"],handler:k("config")},publicPath:{flags:["pp","public-path"],handler:k("publicPath")},env:{flags:["env"],handler:k("env")},shims:{flags:["shims"],handler:x("shims")},onSuccess:{flags:["onSuccess"],handler:k("onSuccess")},filter:{flags:["filter"],handler:J("filter")},entry:{flags:["entry"],handler:(n,r,t)=>{if(typeof n!=="string")throw new C(`Entry${t?` --entry.${t}`:""} requires a string value`);let e=r.entry||{};if(t){if(e[t])l.warn(`Duplicate entry name '${t}' provided via --entry.${t}. Overwriting previous entry.`);e[t]=n}else{let i=X(n);if(e[i])l.warn(`Duplicate entry name '${i}' derived from '${n}'. Overwriting previous entry.`);e[i]=n}r.entry=e}},resolveDts:{flags:["rd","resolve-dts"],handler:(n,r)=>{if(!r.dts)r.dts={};if(typeof r.dts==="boolean")r.dts={};if(typeof n==="string")if(n==="true"||n==="false")r.dts.resolve=n==="true";else r.dts.resolve=n.split(",");else r.dts.resolve=!0}},help:{flags:["h","help"],handler:()=>Yr()},version:{flags:["v","version"],handler:()=>qr()}},P={};for(let n of Object.values(_n))for(let r of n.flags)P[r]=n.handler;function Hn(n){let r={};for(let t=0;t<n.length;t++){let e=n[t];if(e.startsWith("--")){let i,o;if(e.includes("=")){let[s,c]=e.slice(2).split("=",2);i=s,o=c}else{i=e.slice(2);let s=n[t+1];if(o=s&&!s.startsWith("-")?s:!0,typeof o==="string")t++}if(i.includes(".")){let[s,c]=i.split(".",2),a=P[s];if(a)a(o,r,c);else throw new C(`Unknown option: --${i}`)}else{let s=P[i];if(s)s(o,r);else throw new C(`Unknown option: --${i}`)}}else if(e.startsWith("-")){let i=e.slice(1),o=n[t+1],s=o&&!o.startsWith("-")?o:!0;if(typeof s==="string")t++;let c=P[i];if(c)c(s,r);else throw new C(`Unknown option: -${i}`)}else _n.entry.handler(e,r,void 0)}return r}B();T();import{loadConfig as ge}from"coffi";mn();O();Bn();B();N();T();wn();O();import tn from"path";async function Or(n,r){let t=new Set,e=en(n),i=U(e.entry);for(let u of i){let m=tn.resolve(r,u.fullEntryPath),g=tn.dirname(m);t.add(g)}let s=(await import("chokidar")).watch(Array.from(t),{persistent:!0,ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,tn.join(r,e.outDir)]}),c=!1,a=async(u=!1)=>{if(c)return;c=!0;try{let m=performance.now();if(await Cn({...e,entry:i.map((g)=>g.fullEntryPath),clean:!1},r),!u)l.cli(`\uD83D\uDCE6 Rebuild finished in ${z(performance.now()-m)}`)}catch(m){un(m)}finally{c=!1}};s.on("change",(u)=>{let m=tn.relative(r,u);l.cli(`File changed: ${m}`,{muted:!0,once:m}),a()}),s.on("error",(u)=>{throw new Q(`Watcher error: ${y(u)}`)}),await a(!0)}async function fe(n=Bun.argv.slice(2)){let r=Hn(n);G(r.silent);let t=process.cwd(),{config:e,filepath:i}=await ge({name:"bunup.config",extensions:[".ts",".js",".mjs",".cjs"],maxDepth:1,preferredPath:r.config,packageJsonProperty:"bunup"}),o=!e?[{rootDir:t,options:r}]:await Dn(e,t,r.filter);if(l.cli(`Using bunup v${K} and bun v${Bun.version}`,{muted:!0}),i)l.cli(`Using config file: ${M(i,2)}`,{muted:!0});let s=performance.now();l.cli("Build started");let{build:c}=await Promise.resolve().then(() => (Bn(),Br));await Promise.all(o.flatMap(({options:m,rootDir:g})=>{return In(m).map(async(L)=>{let h={...L,...pe(r)};if(h.watch)await Or(h,g);else await c(h,g)})}));let a=performance.now()-s,u=z(a);if(l.cli(`\u26A1\uFE0F Build completed in ${u}`),r.watch)l.cli("\uD83D\uDC40 Watching for file changes");if(r.onSuccess)l.cli(`Running command: ${r.onSuccess}`,{muted:!0}),await me(r.onSuccess,[],{nodeOptions:{shell:!0,stdio:"inherit"}});if(!r.watch)process.exit(process.exitCode??0)}function pe(n){return{...n,onSuccess:void 0,config:void 0}}fe().catch((n)=>$n(n));
package/dist/index.d.mts CHANGED
@@ -8,12 +8,66 @@ type ProcessableEntry = {
8
8
 
9
9
  //#endregion
10
10
  //#region \0dts:/home/runner/work/bunup/bunup/src/plugins/types.d.ts
11
+ /**
12
+ * Represents a Bun plugin that can be used with Bunup
13
+ */
11
14
  type BunupBunPlugin = {
15
+ /** Identifies this as a native Bun plugin */
12
16
  type: "bun"
17
+ /** Optional name for the plugin */
13
18
  name?: string
19
+ /** The actual Bun plugin implementation */
14
20
  plugin: BunPlugin
15
21
  };
16
- type Plugin = BunupBunPlugin;
22
+ /**
23
+ * Represents the output of a build operation
24
+ */
25
+ type BuildOutput = {
26
+ /** Array of generated files with their paths and contents */
27
+ files: Array<{
28
+ /** Path to the generated file */
29
+ path: string
30
+ }>
31
+ };
32
+ /**
33
+ * Context provided to build hooks
34
+ */
35
+ type BuildContext = {
36
+ /** The build options that were used */
37
+ options: BuildOptions
38
+ /** The output of the build */
39
+ output: BuildOutput
40
+ };
41
+ /**
42
+ * Hooks that can be implemented by Bunup plugins
43
+ */
44
+ type BunupPluginHooks = {
45
+ /**
46
+ * Called when a build is successfully completed
47
+ * @param ctx Build context containing options and output
48
+ */
49
+ onBuildDone?: (ctx: BuildContext) => MaybePromise<void>
50
+ /**
51
+ * Called before a build starts
52
+ * @param options Build options that will be used
53
+ */
54
+ onBuildStart?: (options: BuildOptions) => MaybePromise<void>
55
+ };
56
+ /**
57
+ * Represents a Bunup-specific plugin
58
+ */
59
+ type BunupPlugin = {
60
+ /** Identifies this as a Bunup-specific plugin */
61
+ type: "bunup"
62
+ /** Optional name for the plugin */
63
+ name?: string
64
+ /** The hooks implemented by this plugin */
65
+ hooks: BunupPluginHooks
66
+ };
67
+ /**
68
+ * Union type representing all supported plugin types
69
+ */
70
+ type Plugin = BunupBunPlugin | BunupPlugin;
17
71
 
18
72
  //#endregion
19
73
  //#region \0dts:/home/runner/work/bunup/bunup/src/options.d.ts
@@ -235,7 +289,7 @@ interface BuildOptions {
235
289
  *
236
290
  * @param options The build options that were used
237
291
  */
238
- onBuildSuccess?: (options: Partial<BuildOptions>) => MaybePromise<void>;
292
+ onSuccess?: (options: Partial<BuildOptions>) => MaybePromise<void>;
239
293
  /**
240
294
  * A banner to be added to the final bundle, this can be a directive like "use client" for react or a comment block such as a license for the code.
241
295
  *
package/dist/index.d.ts CHANGED
@@ -8,12 +8,66 @@ type ProcessableEntry = {
8
8
 
9
9
  //#endregion
10
10
  //#region \0dts:/home/runner/work/bunup/bunup/src/plugins/types.d.ts
11
+ /**
12
+ * Represents a Bun plugin that can be used with Bunup
13
+ */
11
14
  type BunupBunPlugin = {
15
+ /** Identifies this as a native Bun plugin */
12
16
  type: "bun"
17
+ /** Optional name for the plugin */
13
18
  name?: string
19
+ /** The actual Bun plugin implementation */
14
20
  plugin: BunPlugin
15
21
  };
16
- type Plugin = BunupBunPlugin;
22
+ /**
23
+ * Represents the output of a build operation
24
+ */
25
+ type BuildOutput = {
26
+ /** Array of generated files with their paths and contents */
27
+ files: Array<{
28
+ /** Path to the generated file */
29
+ path: string
30
+ }>
31
+ };
32
+ /**
33
+ * Context provided to build hooks
34
+ */
35
+ type BuildContext = {
36
+ /** The build options that were used */
37
+ options: BuildOptions
38
+ /** The output of the build */
39
+ output: BuildOutput
40
+ };
41
+ /**
42
+ * Hooks that can be implemented by Bunup plugins
43
+ */
44
+ type BunupPluginHooks = {
45
+ /**
46
+ * Called when a build is successfully completed
47
+ * @param ctx Build context containing options and output
48
+ */
49
+ onBuildDone?: (ctx: BuildContext) => MaybePromise<void>
50
+ /**
51
+ * Called before a build starts
52
+ * @param options Build options that will be used
53
+ */
54
+ onBuildStart?: (options: BuildOptions) => MaybePromise<void>
55
+ };
56
+ /**
57
+ * Represents a Bunup-specific plugin
58
+ */
59
+ type BunupPlugin = {
60
+ /** Identifies this as a Bunup-specific plugin */
61
+ type: "bunup"
62
+ /** Optional name for the plugin */
63
+ name?: string
64
+ /** The hooks implemented by this plugin */
65
+ hooks: BunupPluginHooks
66
+ };
67
+ /**
68
+ * Union type representing all supported plugin types
69
+ */
70
+ type Plugin = BunupBunPlugin | BunupPlugin;
17
71
 
18
72
  //#endregion
19
73
  //#region \0dts:/home/runner/work/bunup/bunup/src/options.d.ts
@@ -235,7 +289,7 @@ interface BuildOptions {
235
289
  *
236
290
  * @param options The build options that were used
237
291
  */
238
- onBuildSuccess?: (options: Partial<BuildOptions>) => MaybePromise<void>;
292
+ onSuccess?: (options: Partial<BuildOptions>) => MaybePromise<void>;
239
293
  /**
240
294
  * A banner to be added to the final bundle, this can be a directive like "use client" for react or a comment block such as a license for the code.
241
295
  *
package/dist/index.js CHANGED
@@ -1,16 +1,16 @@
1
1
  // @bun @bun-cjs
2
- (function(exports, require, module, __filename, __dirname) {var Xr=Object.create;var{getPrototypeOf:Nr,defineProperty:M,getOwnPropertyNames:P,getOwnPropertyDescriptor:Vr}=Object,rr=Object.prototype.hasOwnProperty;var l=(r,n,t)=>{t=r!=null?Xr(Nr(r)):{};let e=n||!r||!r.__esModule?M(t,"default",{value:r,enumerable:!0}):t;for(let i of P(r))if(!rr.call(e,i))M(e,i,{get:()=>r[i],enumerable:!0});return e},v=new WeakMap,zr=(r)=>{var n=v.get(r),t;if(n)return n;if(n=M({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")P(r).map((e)=>!rr.call(n,e)&&M(n,e,{get:()=>r[e],enumerable:!(t=Vr(r,e))||t.enumerable}));return v.set(r,n),n},Jr=(r,n)=>()=>(n||r((n={exports:{}}).exports,n),n.exports);var vr=(r,n)=>{for(var t in n)M(r,t,{get:n[t],enumerable:!0,configurable:!0,set:(e)=>n[t]=()=>e})};var A=Jr((Rn,G)=>{var O=process||{},er=O.argv||[],E=O.env||{},Pr=!(!!E.NO_COLOR||er.includes("--no-color"))&&(!!E.FORCE_COLOR||er.includes("--color")||O.platform==="win32"||(O.stdout||{}).isTTY&&E.TERM!=="dumb"||!!E.CI),rn=(r,n,t=r)=>(e)=>{let i=""+e,o=i.indexOf(n,r.length);return~o?r+nn(i,n,t,o)+n:r+i+n},nn=(r,n,t,e)=>{let i="",o=0;do i+=r.substring(o,e)+t,o=e+n.length,e=r.indexOf(n,o);while(~e);return i+r.substring(o)},ir=(r=Pr)=>{let n=r?rn:()=>String;return{isColorSupported:r,reset:n("\x1B[0m","\x1B[0m"),bold:n("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:n("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:n("\x1B[3m","\x1B[23m"),underline:n("\x1B[4m","\x1B[24m"),inverse:n("\x1B[7m","\x1B[27m"),hidden:n("\x1B[8m","\x1B[28m"),strikethrough:n("\x1B[9m","\x1B[29m"),black:n("\x1B[30m","\x1B[39m"),red:n("\x1B[31m","\x1B[39m"),green:n("\x1B[32m","\x1B[39m"),yellow:n("\x1B[33m","\x1B[39m"),blue:n("\x1B[34m","\x1B[39m"),magenta:n("\x1B[35m","\x1B[39m"),cyan:n("\x1B[36m","\x1B[39m"),white:n("\x1B[37m","\x1B[39m"),gray:n("\x1B[90m","\x1B[39m"),bgBlack:n("\x1B[40m","\x1B[49m"),bgRed:n("\x1B[41m","\x1B[49m"),bgGreen:n("\x1B[42m","\x1B[49m"),bgYellow:n("\x1B[43m","\x1B[49m"),bgBlue:n("\x1B[44m","\x1B[49m"),bgMagenta:n("\x1B[45m","\x1B[49m"),bgCyan:n("\x1B[46m","\x1B[49m"),bgWhite:n("\x1B[47m","\x1B[49m"),blackBright:n("\x1B[90m","\x1B[39m"),redBright:n("\x1B[91m","\x1B[39m"),greenBright:n("\x1B[92m","\x1B[39m"),yellowBright:n("\x1B[93m","\x1B[39m"),blueBright:n("\x1B[94m","\x1B[39m"),magentaBright:n("\x1B[95m","\x1B[39m"),cyanBright:n("\x1B[96m","\x1B[39m"),whiteBright:n("\x1B[97m","\x1B[39m"),bgBlackBright:n("\x1B[100m","\x1B[49m"),bgRedBright:n("\x1B[101m","\x1B[49m"),bgGreenBright:n("\x1B[102m","\x1B[49m"),bgYellowBright:n("\x1B[103m","\x1B[49m"),bgBlueBright:n("\x1B[104m","\x1B[49m"),bgMagentaBright:n("\x1B[105m","\x1B[49m"),bgCyanBright:n("\x1B[106m","\x1B[49m"),bgWhiteBright:n("\x1B[107m","\x1B[49m")}};G.exports=ir();G.exports.createColors=ir});var wn={};vr(wn,{defineWorkspace:()=>tr,defineConfig:()=>nr,build:()=>Qr});module.exports=zr(wn);function nr(r){return r}function tr(r){return r}var Rr=require("rolldown"),Mr=require("rolldown-plugin-dts");var tn=l(A());var b=l(A()),or=!1;function sr(r){or=r??!1}class w{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;cliColor=b.default.blue;mutedColor=b.default.dim;infoColor=b.default.cyan;warnColor=b.default.yellow;errorColor=b.default.red;sizeColor=b.default.green;defaultColor=b.default.white;progressFgColorMap={ESM:b.default.yellow,CJS:b.default.green,IIFE:b.default.magenta,DTS:b.default.blue};progressBgColorMap={ESM:b.default.bgYellow,CJS:b.default.bgGreen,IIFE:b.default.bgMagenta,DTS:b.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!w.instance)w.instance=new w;return w.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(r){if(!r?.once)return!0;if(this.loggedOnceMessages.has(r.once))return!1;return this.loggedOnceMessages.add(r.once),!0}formatMessage({fgColor:r,bgColor:n,label:t,message:e,size:i,identifier:o,muted:s}){let u=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),g=s?this.mutedColor(e):e;if(i){let[c,...a]=g.split(" "),f=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),I=o?` ${n(b.default.black(` ${o} `))}`:"";return`${r(t)} ${u}${c}${f} ${this.sizeColor(i)} ${a.join(" ")}${I}`}let m=o?` ${n(b.default.black(` ${o} `))}`:"";return`${r(t)} ${u}${g}${m}`}output(r,n={},t=console.log){if(or||!this.shouldLog(n))return;if(n.verticalSpace)t("");if(t(r),n.verticalSpace)t("")}cli(r,n={}){let t=this.formatMessage({fgColor:this.cliColor,bgColor:b.default.bgBlue,label:this.labels.cli,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n)}info(r,n={}){let t=this.formatMessage({fgColor:this.infoColor,bgColor:b.default.bgCyan,label:this.labels.info,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n)}warn(r,n={}){let t=this.formatMessage({fgColor:this.warnColor,bgColor:b.default.bgYellow,label:this.labels.warn,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n,console.warn)}error(r,n={}){let t=this.formatMessage({fgColor:this.errorColor,bgColor:b.default.bgRed,label:this.labels.error,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n,console.error)}getProgressFgColor(r){for(let[n,t]of Object.entries(this.progressFgColorMap))if(r.includes(n))return t;return this.defaultColor}getProgressBgColor(r){for(let[n,t]of Object.entries(this.progressBgColorMap))if(r.includes(n))return t;return b.default.bgWhite}progress(r,n,t,e){let i,o,s={};if(typeof t==="string")i=t,o=e;else if(t)i=t.size,o=t.identifier,s=t;let u=this.getProgressFgColor(r),g=this.getProgressBgColor(r),m=this.formatMessage({fgColor:u,bgColor:g,label:r,message:n,size:i,identifier:o,muted:s.muted});this.output(m,s)}}var x=w.getInstance();class k extends Error{constructor(r){super(r);this.name="BunupError"}}class B extends k{constructor(r){super(r);this.name="BunupBuildError"}}class p extends k{constructor(r){super(r);this.name="BunupDTSBuildError"}}class j extends k{constructor(r){super(r);this.name="BunupIsolatedDeclError"}}var d=(r)=>{if(r instanceof Error)return r.message;return String(r)};function gr(r){return r instanceof j}var Q=l(require("path")),Br=require("oxc-resolver");var U=l(require("fs/promises")),mr=l(require("path"));function ur(r,n){switch(r){case"esm":return h(n)?".js":".mjs";case"cjs":return h(n)?".cjs":".js";case"iife":return".global.js"}}function cr(r,n){switch(r){case"esm":return h(n)?".d.ts":".d.mts";case"cjs":return h(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function Y(r){return r==="node"||r==="bun"}function h(r){return r==="module"}function br(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function F(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/1024**t).toFixed(2)} ${n[t]}`}function L(r,n=3){return r.split("/").slice(-n).join("/")}async function ar(r,n){let t=mr.default.join(r,n);try{await U.default.rm(t,{recursive:!0,force:!0})}catch(e){throw new B(`Failed to clean output directory: ${e}`)}await U.default.mkdir(t,{recursive:!0})}function y(r){return[".ts",".mts",".cts",".tsx"].some((n)=>r.endsWith(n))}function en(r){return br(r).map((n)=>new RegExp(`^${n}($|\\/|\\\\)`))}function xr(r,n){return typeof n==="string"?n===r:n.test(r)}function _(r,n,t){let i=en(t).some((s)=>s.test(r))||n.external?.some((s)=>xr(r,s)),o=n.noExternal?.some((s)=>xr(r,s));return i&&!o}var fr=require("ts-import-resolver");var T="\x00dts:",pr=(r,n,t)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(H(e))return e;if(!i||!H(i))return null;let o=n.tsconfig?fr.resolveTsImportPath({path:e,importer:$(i),tsconfig:n.tsconfig,rootDir:t}):null;if(!o)return null;let s=C(o);if(r.has(s))return W(s);return null},load(e){if(e.startsWith(T)){let i=$(e),o=r.get(i);if(o)return o}return null}}};var K=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/;function lr(r){return r.endsWith(".d.ts")||r.endsWith(".d.mts")||r.endsWith(".d.cts")}function dr(r){return K.test(r)&&!lr(r)}function C(r){if(lr(r))return r;if(r.endsWith(".mts"))return`${r.slice(0,-4)}.d.mts`;if(r.endsWith(".cts"))return`${r.slice(0,-4)}.d.cts`;if(K.test(r))return r.replace(K,".d.ts");return`${r}.d.ts`}function H(r){return r.startsWith(T)}function $(r){return r.replace(T,"")}function W(r){return`${T}${r}`}function Cr(r,n){if(n===void 0)return"";let t=r.slice(0,n).split(`
3
- `),e=t.length,i=t[t.length-1].length+1;return` (${e}:${i})`}function wr(r,n,t,e){if(typeof e==="boolean"&&e)return!1;if(Array.isArray(e)){for(let i of e)if(typeof i==="string"&&r===i)return!1;else if(i instanceof RegExp&&i.test(r))return!1}return _(r,n,t)}var q;function hr(r,n){return{name:"bunup:types-resolve",buildStart(){q||=new Br.ResolverFactory({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...r.path&&{tsconfig:{configFile:r.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(t,e){if(n===!1)return;if(t==="bun")return;let i=e?$(e):void 0;if(/\0/.test(t))return;if(Array.isArray(n)){if(!n.some((g)=>typeof g==="string"?g===t:g.test(t)))return}let o=i?Q.default.dirname(i):process.cwd(),{path:s}=await q.async(o,t);if(!s)return;if(dr(s)){let u=C(s);try{let{path:g}=await q.async(Q.default.dirname(s),u);if(g)return g}catch(g){}return}return s}}}async function Lr(r,n,t,e,i,o){let s=C(r),u=W(s),g=typeof t.dts==="object"&&"resolve"in t.dts?t.dts.resolve:void 0;try{let{output:m}=await Rr.build({input:u,output:{dir:t.outDir},write:!1,...i.path&&{resolve:{tsconfigFilename:i.path}},onwarn(c,a){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;a(c)},plugins:[pr(n,i,o),g&&hr(i,g),Mr.dts({dtsInput:!0,emitDtsOnly:!0})],external:(c)=>wr(c,t,e,g)});if(!m[0]?.code)return x.warn(`Generated empty declaration file for entry "${r}"`,{muted:!0}),"";return m[0].code}catch(m){throw new p(`DTS bundling failed for entry "${r}": ${d(m)}`)}}var $r=require("ts-import-resolver");var on=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,sn=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,gn=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,mn=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,un=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,cn=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,bn=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function an(r){let n=new Set,t=[on,sn,gn,mn,un,cn,bn];for(let e of t){let i=r.matchAll(e);for(let o of i)if(o[1])n.add(o[1])}return n}async function Tr(r,n,t){let e=new Set([r]),i=[r];while(i.length){let o=i.pop();if(!o)continue;try{let s=await Bun.file(o).text(),u=an(s);for(let g of u){let m=n.tsconfig?$r.resolveTsImportPath({path:g,importer:o,tsconfig:n.tsconfig,rootDir:t}):null;if(!m)continue;if(!e.has(m))e.add(m),i.push(m)}}catch(s){x.warn(`Error processing ${o}: ${d(s)}`)}}return e}var Ir=require("oxc-transform"),Z=l(A());async function Sr(r,n){let t=!1,e=new Map;if(await Promise.all([...r].map(async(i)=>{try{let o=C(i);if(!await Bun.file(i).exists())return;let u=await Bun.file(i).text(),{code:g,errors:m}=Ir.isolatedDeclaration(i,u);if(g)e.set(o,g);for(let c of m){if(!t&&!n)console.log(`
4
- `);let a=c.labels[0],f=a?Cr(u,a.start):"",S=`${L(i)}${f}: ${xn(c.message)}`;x[n?"warn":"error"](S),t=!0}}catch(o){x.warn(`Failed to generate declaration for ${i}: ${d(o)}`)}})),t&&!n)throw console.log(`
5
- `),new j(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${Z.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${Z.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return e}function xn(r){return r.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var X=l(require("fs/promises")),D=l(require("path"));async function Er(r,n){let t=D.default.resolve(r),e=D.default.resolve(t,n);if(!await X.default.exists(t))throw new p(`Root directory does not exist: ${t}`);if(!await Bun.file(e).exists())throw new p(`Entry file does not exist: ${e}`);if(!y(e))throw new p(`Entry file must be a TypeScript file: ${e}`);if(D.default.relative(t,e).startsWith(".."))throw new p(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}async function Or(r,n,t,e,i){let{absoluteEntry:o}=await Er(r,n),s=await Tr(o,e,r),u=await Sr(s,t.watch);return Lr(o,u,t,i,e,r)}var R=require("path");function Ar(r){let n=R.basename(r),t=R.extname(n);return t?n.slice(0,-t.length):n}function N(r){if(typeof r==="string")return[{fullEntryPath:r,name:Ar(r)}];if(typeof r==="object"&&!Array.isArray(r))return Object.entries(r).map(([e,i])=>({fullEntryPath:i,name:e}));let n=[],t=new Set;for(let e of r){let i=Ar(e);if(!t.has(i)){n.push({fullEntryPath:e,name:i}),t.add(i);continue}let s=R.dirname(e).split("/").filter((g)=>g!=="."&&g!=="");if(s.length===0){let g=1,m;do m=`${i}_${g++}`;while(t.has(m));n.push({fullEntryPath:e,name:m}),t.add(m);continue}let u=!1;for(let g=1;g<=s.length&&!u;g++){let c=`${s.slice(-g).join("/")}/${i}`;if(!t.has(c))n.push({fullEntryPath:e,name:c}),t.add(c),u=!0}if(!u){let g=1,m;do m=`${s.join("/")}/${i}_${g++}`;while(t.has(m));n.push({fullEntryPath:e,name:m}),t.add(m)}}return n}function kr(r){return r.filter((n)=>y(n.fullEntryPath))}function jr(r,n){return`[dir]/${r}${n}`}var V=require("coffi");async function yr(r){let{config:n,filepath:t}=await V.loadConfig({name:"package",cwd:r,extensions:[".json"]});return{packageJson:n,path:t}}async function _r(r,n){let{config:t,filepath:e}=await V.loadConfig({name:"tsconfig",cwd:r,extensions:[".json"],preferredPath:n});return{tsconfig:t,path:e}}var fn={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function Wr(r){return{...fn,...r}}function Dr(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:i}=r,o=n===!0;return{whitespace:t??o,identifiers:e??o,syntax:i??o}}function Gr(r,n){return n==="cjs"?r:void 0}function Ur(r,n,t,e){return{...typeof t==="object"&&Object.keys(t).reduce((i,o)=>{let s=JSON.stringify(t[o]);return i[`process.env.${o}`]=s,i[`import.meta.env.${o}`]=s,i},{}),...r,...e==="cjs"&&(n===!0||typeof n==="object"&&n.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Yr(r,n){return r===void 0?n==="esm":r}function Fr(r){return typeof r==="string"?r:void 0}function Hr(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let i=e.path;if(_(i,r,n))return{path:i,external:!0};return null})}}}var pn=/\.(js|ts|jsx|tsx|mts|cts)$/,z={dirnameFilename:{appliesTo:(r,n)=>r==="esm"&&Y(n),isNeededInFile:(r)=>/\b__dirname\b/.test(r)||/\b__filename\b/.test(r),generateCode:()=>`import { fileURLToPath } from 'url';
2
+ (function(exports, require, module, __filename, __dirname) {var Nr=Object.create;var{getPrototypeOf:Jr,defineProperty:I,getOwnPropertyNames:rr,getOwnPropertyDescriptor:vr}=Object,nr=Object.prototype.hasOwnProperty;var d=(r,n,e)=>{e=r!=null?Nr(Jr(r)):{};let t=n||!r||!r.__esModule?I(e,"default",{value:r,enumerable:!0}):e;for(let o of rr(r))if(!nr.call(t,o))I(t,o,{get:()=>r[o],enumerable:!0});return t},P=new WeakMap,Pr=(r)=>{var n=P.get(r),e;if(n)return n;if(n=I({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")rr(r).map((t)=>!nr.call(n,t)&&I(n,t,{get:()=>r[t],enumerable:!(e=vr(r,t))||e.enumerable}));return P.set(r,n),n},rn=(r,n)=>()=>(n||r((n={exports:{}}).exports,n),n.exports);var nn=(r,n)=>{for(var e in n)I(r,e,{get:n[e],enumerable:!0,configurable:!0,set:(t)=>n[e]=()=>t})};var j=rn((Tn,K)=>{var A=process||{},or=A.argv||[],$=A.env||{},tn=!(!!$.NO_COLOR||or.includes("--no-color"))&&(!!$.FORCE_COLOR||or.includes("--color")||A.platform==="win32"||(A.stdout||{}).isTTY&&$.TERM!=="dumb"||!!$.CI),en=(r,n,e=r)=>(t)=>{let o=""+t,i=o.indexOf(n,r.length);return~i?r+on(o,n,e,i)+n:r+o+n},on=(r,n,e,t)=>{let o="",i=0;do o+=r.substring(i,t)+e,i=t+n.length,t=r.indexOf(n,i);while(~t);return o+r.substring(i)},ir=(r=tn)=>{let n=r?en:()=>String;return{isColorSupported:r,reset:n("\x1B[0m","\x1B[0m"),bold:n("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:n("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:n("\x1B[3m","\x1B[23m"),underline:n("\x1B[4m","\x1B[24m"),inverse:n("\x1B[7m","\x1B[27m"),hidden:n("\x1B[8m","\x1B[28m"),strikethrough:n("\x1B[9m","\x1B[29m"),black:n("\x1B[30m","\x1B[39m"),red:n("\x1B[31m","\x1B[39m"),green:n("\x1B[32m","\x1B[39m"),yellow:n("\x1B[33m","\x1B[39m"),blue:n("\x1B[34m","\x1B[39m"),magenta:n("\x1B[35m","\x1B[39m"),cyan:n("\x1B[36m","\x1B[39m"),white:n("\x1B[37m","\x1B[39m"),gray:n("\x1B[90m","\x1B[39m"),bgBlack:n("\x1B[40m","\x1B[49m"),bgRed:n("\x1B[41m","\x1B[49m"),bgGreen:n("\x1B[42m","\x1B[49m"),bgYellow:n("\x1B[43m","\x1B[49m"),bgBlue:n("\x1B[44m","\x1B[49m"),bgMagenta:n("\x1B[45m","\x1B[49m"),bgCyan:n("\x1B[46m","\x1B[49m"),bgWhite:n("\x1B[47m","\x1B[49m"),blackBright:n("\x1B[90m","\x1B[39m"),redBright:n("\x1B[91m","\x1B[39m"),greenBright:n("\x1B[92m","\x1B[39m"),yellowBright:n("\x1B[93m","\x1B[39m"),blueBright:n("\x1B[94m","\x1B[39m"),magentaBright:n("\x1B[95m","\x1B[39m"),cyanBright:n("\x1B[96m","\x1B[39m"),whiteBright:n("\x1B[97m","\x1B[39m"),bgBlackBright:n("\x1B[100m","\x1B[49m"),bgRedBright:n("\x1B[101m","\x1B[49m"),bgGreenBright:n("\x1B[102m","\x1B[49m"),bgYellowBright:n("\x1B[103m","\x1B[49m"),bgBlueBright:n("\x1B[104m","\x1B[49m"),bgMagentaBright:n("\x1B[105m","\x1B[49m"),bgCyanBright:n("\x1B[106m","\x1B[49m"),bgWhiteBright:n("\x1B[107m","\x1B[49m")}};K.exports=ir();K.exports.createColors=ir});var hn={};nn(hn,{defineWorkspace:()=>er,defineConfig:()=>tr,build:()=>Xr});module.exports=Pr(hn);function tr(r){return r}function er(r){return r}var Rr=require("rolldown"),Tr=require("rolldown-plugin-dts");var sn=d(j());var c=d(j()),sr=!1;function ur(r){sr=r??!1}class h{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;cliColor=c.default.blue;mutedColor=c.default.dim;infoColor=c.default.cyan;warnColor=c.default.yellow;errorColor=c.default.red;defaultColor=c.default.white;progressFgColorMap={ESM:c.default.yellow,CJS:c.default.green,IIFE:c.default.magenta,DTS:c.default.blue};progressBgColorMap={ESM:c.default.bgYellow,CJS:c.default.bgGreen,IIFE:c.default.bgMagenta,DTS:c.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!h.instance)h.instance=new h;return h.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(r){if(!r?.once)return!0;if(this.loggedOnceMessages.has(r.once))return!1;return this.loggedOnceMessages.add(r.once),!0}formatMessage({fgColor:r,bgColor:n,label:e,message:t,identifier:o,muted:i}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-e.length)),m=i?this.mutedColor(t):t,u=o?` ${n(c.default.black(` ${o} `))}`:"";return`${r(e)} ${s}${m}${u}`}output(r,n={},e=console.log){if(sr||!this.shouldLog(n))return;if(n.verticalSpace)e("");if(e(r),n.verticalSpace)e("")}cli(r,n={}){let e=this.formatMessage({fgColor:this.cliColor,bgColor:c.default.bgBlue,label:this.labels.cli,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n)}info(r,n={}){let e=this.formatMessage({fgColor:this.infoColor,bgColor:c.default.bgCyan,label:this.labels.info,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n)}warn(r,n={}){let e=this.formatMessage({fgColor:this.warnColor,bgColor:c.default.bgYellow,label:this.labels.warn,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n,console.warn)}error(r,n={}){let e=this.formatMessage({fgColor:this.errorColor,bgColor:c.default.bgRed,label:this.labels.error,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n,console.error)}getProgressFgColor(r){for(let[n,e]of Object.entries(this.progressFgColorMap))if(r.includes(n))return e;return this.defaultColor}getProgressBgColor(r){for(let[n,e]of Object.entries(this.progressBgColorMap))if(r.includes(n))return e;return c.default.bgWhite}progress(r,n,e={}){let t=this.getProgressFgColor(r),o=this.getProgressBgColor(r),i=this.formatMessage({fgColor:t,bgColor:o,label:r,message:n,identifier:e.identifier,muted:e.muted});this.output(i,e)}}var p=h.getInstance();class D extends Error{constructor(r){super(r);this.name="BunupError"}}class O extends D{constructor(r){super(r);this.name="BunupBuildError"}}class f extends D{constructor(r){super(r);this.name="BunupDTSBuildError"}}class W extends D{constructor(r){super(r);this.name="BunupIsolatedDeclError"}}var C=(r)=>{if(r instanceof Error)return r.message;return String(r)};function gr(r){return r instanceof W}var z=d(require("path")),hr=require("oxc-resolver");var q=d(require("fs/promises")),mr=d(require("path"));function cr(r,n){switch(r){case"esm":return R(n)?".js":".mjs";case"cjs":return R(n)?".cjs":".js";case"iife":return".global.js"}}function br(r,n){switch(r){case"esm":return R(n)?".d.ts":".d.mts";case"cjs":return R(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function G(r){return r==="node"||r==="bun"}function R(r){return r==="module"}function ar(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function L(r,n=3){return r.split("/").slice(-n).join("/")}async function xr(r,n){let e=mr.default.join(r,n);try{await q.default.rm(e,{recursive:!0,force:!0})}catch(t){throw new O(`Failed to clean output directory: ${t}`)}await q.default.mkdir(e,{recursive:!0})}function _(r){return[".ts",".mts",".cts",".tsx"].some((n)=>r.endsWith(n))}function un(r){return ar(r).map((n)=>new RegExp(`^${n}($|\\/|\\\\)`))}function pr(r,n){return typeof n==="string"?n===r:n.test(r)}function U(r,n,e){let o=un(e).some((s)=>s.test(r))||n.external?.some((s)=>pr(r,s)),i=n.noExternal?.some((s)=>pr(r,s));return o&&!i}var fr=require("ts-import-resolver");var M="\x00dts:",lr=(r,n,e)=>{return{name:"bunup:virtual-dts",async resolveId(t,o){if(H(t))return t;if(!o||!H(o))return null;let i=n.tsconfig?fr.resolveTsImportPath({path:t,importer:k(o),tsconfig:n.tsconfig,rootDir:e}):null;if(!i)return null;let s=B(i);if(r.has(s))return Y(s);return null},load(t){if(t.startsWith(M)){let o=k(t),i=r.get(o);if(i)return i}return null}}};var Q=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/;function dr(r){return r.endsWith(".d.ts")||r.endsWith(".d.mts")||r.endsWith(".d.cts")}function Cr(r){return Q.test(r)&&!dr(r)}function B(r){if(dr(r))return r;if(r.endsWith(".mts"))return`${r.slice(0,-4)}.d.mts`;if(r.endsWith(".cts"))return`${r.slice(0,-4)}.d.cts`;if(Q.test(r))return r.replace(Q,".d.ts");return`${r}.d.ts`}function H(r){return r.startsWith(M)}function k(r){return r.replace(M,"")}function Y(r){return`${M}${r}`}function Br(r,n){if(n===void 0)return"";let e=r.slice(0,n).split(`
3
+ `),t=e.length,o=e[e.length-1].length+1;return` (${t}:${o})`}function wr(r,n,e,t){if(typeof t==="boolean"&&t)return!1;if(Array.isArray(t)){for(let o of t)if(typeof o==="string"&&r===o)return!1;else if(o instanceof RegExp&&o.test(r))return!1}return U(r,n,e)}var Z;function Or(r,n){return{name:"bunup:types-resolve",buildStart(){Z||=new hr.ResolverFactory({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...r.path&&{tsconfig:{configFile:r.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(e,t){if(n===!1)return;if(e==="bun")return;let o=t?k(t):void 0;if(/\0/.test(e))return;if(Array.isArray(n)){if(!n.some((u)=>typeof u==="string"?u===e:u.test(e)))return}let i=o?z.default.dirname(o):process.cwd(),{path:s}=await Z.async(i,e);if(!s)return;if(Cr(s)){let m=B(s);try{let{path:u}=await Z.async(z.default.dirname(s),m);if(u)return u}catch(u){}return}return s}}}async function Sr(r,n,e,t,o,i){let s=B(r),m=Y(s),u=typeof e.dts==="object"&&"resolve"in e.dts?e.dts.resolve:void 0;try{let{output:g}=await Rr.build({input:m,output:{dir:e.outDir},write:!1,...o.path&&{resolve:{tsconfigFilename:o.path}},onwarn(x,a){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;a(x)},plugins:[lr(n,o,i),u&&Or(o,u),Tr.dts({dtsInput:!0,emitDtsOnly:!0})],external:(x)=>wr(x,e,t,u)});if(!g[0]?.code)return p.warn(`Generated empty declaration file for entry "${r}"`,{muted:!0}),"";return g[0].code}catch(g){throw new f(`DTS bundling failed for entry "${r}": ${C(g)}`)}}var Ir=require("ts-import-resolver");var gn=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,mn=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,cn=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,bn=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,an=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,xn=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,pn=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function fn(r){let n=new Set,e=[gn,mn,cn,bn,an,xn,pn];for(let t of e){let o=r.matchAll(t);for(let i of o)if(i[1])n.add(i[1])}return n}async function Lr(r,n,e){let t=new Set([r]),o=[r];while(o.length){let i=o.pop();if(!i)continue;try{let s=await Bun.file(i).text(),m=fn(s);for(let u of m){let g=n.tsconfig?Ir.resolveTsImportPath({path:u,importer:i,tsconfig:n.tsconfig,rootDir:e}):null;if(!g)continue;if(!t.has(g))t.add(g),o.push(g)}}catch(s){p.warn(`Error processing ${i}: ${C(s)}`)}}return t}var kr=require("oxc-transform"),V=d(j());async function Mr(r,n){let e=!1,t=new Map;if(await Promise.all([...r].map(async(o)=>{try{let i=B(o);if(!await Bun.file(o).exists())return;let m=await Bun.file(o).text(),{code:u,errors:g}=kr.isolatedDeclaration(o,m);if(u)t.set(i,u);for(let x of g){if(!e&&!n)console.log(`
4
+ `);let a=x.labels[0],b=a?Br(m,a.start):"",w=`${L(o)}${b}: ${ln(x.message)}`;p[n?"warn":"error"](w),e=!0}}catch(i){p.warn(`Failed to generate declaration for ${o}: ${C(i)}`)}})),e&&!n)throw console.log(`
5
+ `),new W(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${V.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${V.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return t}function ln(r){return r.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var X=d(require("fs/promises")),F=d(require("path"));async function Er(r,n){let e=F.default.resolve(r),t=F.default.resolve(e,n);if(!await X.default.exists(e))throw new f(`Root directory does not exist: ${e}`);if(!await Bun.file(t).exists())throw new f(`Entry file does not exist: ${t}`);if(!_(t))throw new f(`Entry file must be a TypeScript file: ${t}`);if(F.default.relative(e,t).startsWith(".."))throw new f(`Entry file must be within rootDir: ${t}`);return{absoluteRootDir:e,absoluteEntry:t}}async function yr(r,n,e,t,o){let{absoluteEntry:i}=await Er(r,n),s=await Lr(i,t,r),m=await Mr(s,e.watch);return Sr(i,m,e,o,t,r)}var T=require("path");function $r(r){let n=T.basename(r),e=T.extname(n);return e?n.slice(0,-e.length):n}function N(r){if(typeof r==="string")return[{fullEntryPath:r,name:$r(r)}];if(typeof r==="object"&&!Array.isArray(r))return Object.entries(r).map(([t,o])=>({fullEntryPath:o,name:t}));let n=[],e=new Set;for(let t of r){let o=$r(t);if(!e.has(o)){n.push({fullEntryPath:t,name:o}),e.add(o);continue}let s=T.dirname(t).split("/").filter((u)=>u!=="."&&u!=="");if(s.length===0){let u=1,g;do g=`${o}_${u++}`;while(e.has(g));n.push({fullEntryPath:t,name:g}),e.add(g);continue}let m=!1;for(let u=1;u<=s.length&&!m;u++){let x=`${s.slice(-u).join("/")}/${o}`;if(!e.has(x))n.push({fullEntryPath:t,name:x}),e.add(x),m=!0}if(!m){let u=1,g;do g=`${s.join("/")}/${o}_${u++}`;while(e.has(g));n.push({fullEntryPath:t,name:g}),e.add(g)}}return n}function Ar(r){return r.filter((n)=>_(n.fullEntryPath))}function jr(r,n){return`[dir]/${r}${n}`}var J=require("coffi");async function Dr(r){let{config:n,filepath:e}=await J.loadConfig({name:"package",cwd:r,extensions:[".json"]});return{packageJson:n,path:e}}async function Wr(r,n){let{config:e,filepath:t}=await J.loadConfig({name:"tsconfig",cwd:r,extensions:[".json"],preferredPath:n});return{tsconfig:e,path:t}}var dn={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function _r(r){return{...dn,...r}}function Ur(r){let{minify:n,minifyWhitespace:e,minifyIdentifiers:t,minifySyntax:o}=r,i=n===!0;return{whitespace:e??i,identifiers:t??i,syntax:o??i}}function Yr(r,n){return n==="cjs"?r:void 0}function Fr(r,n,e,t){return{...typeof e==="object"&&Object.keys(e).reduce((o,i)=>{let s=JSON.stringify(e[i]);return o[`process.env.${i}`]=s,o[`import.meta.env.${i}`]=s,o},{}),...r,...t==="cjs"&&(n===!0||typeof n==="object"&&n.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Kr(r,n){return r===void 0?n==="esm":r}function qr(r){return typeof r==="string"?r:void 0}function Gr(r,n){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(t)=>{let o=t.path;if(U(o,r,n))return{path:o,external:!0};return null})}}}var Cn=/\.(js|ts|jsx|tsx|mts|cts)$/,v={dirnameFilename:{appliesTo:(r,n)=>r==="esm"&&G(n),isNeededInFile:(r)=>/\b__dirname\b/.test(r)||/\b__filename\b/.test(r),generateCode:()=>`import { fileURLToPath } from 'url';
6
6
  import { dirname } from 'path';
7
7
 
8
8
  const __filename = fileURLToPath(import.meta.url);
9
9
  const __dirname = dirname(__filename);
10
10
 
11
- `},importMetaUrl:{appliesTo:(r,n)=>r==="cjs"&&Y(n),isNeededInFile:(r)=>/\bimport\.meta\.url\b/.test(r),generateCode:()=>`import { pathToFileURL } from 'url';
11
+ `},importMetaUrl:{appliesTo:(r,n)=>r==="cjs"&&G(n),isNeededInFile:(r)=>/\bimport\.meta\.url\b/.test(r),generateCode:()=>`import { pathToFileURL } from 'url';
12
12
 
13
13
  const importMetaUrl = pathToFileURL(__filename).href;
14
14
 
15
- `}};function Kr({format:r,target:n,shims:t}){let i=ln(t).map((o)=>z[o]).filter((o)=>o.appliesTo(r,n));if(i.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:pn},async({path:s})=>{let u=await Bun.file(s).text(),g=i.filter((f)=>f.isNeededInFile(u));if(g.length===0)return;let{shebangLine:m,codeContent:c}=dn(u),a=g.map((f)=>f.generateCode()).join("");return{contents:m+a+c}})}}}function ln(r){if(r===!0)return Object.keys(z);if(!r)return[];return Object.entries(r).filter(([n,t])=>t&&(n in z)).map(([n])=>n)}function dn(r){if(!r.startsWith("#!"))return{shebangLine:"",codeContent:r};let n=r.indexOf(`
16
- `);return n===-1?{shebangLine:"",codeContent:r}:{shebangLine:r.slice(0,n+1),codeContent:r.slice(n+1)}}function qr(r){return r.filter((n)=>n.type==="bun")}async function Qr(r,n=process.cwd()){let t=Wr(r);if(!t.entry||t.entry.length===0||!t.outDir)throw new B("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(t.clean)ar(n,t.outDir);sr(t.silent);let{packageJson:e,path:i}=await yr(n);if(e&&i)x.cli(`Using package.json: ${L(i,2)}`,{muted:!0,identifier:t.name,once:`${i}:${t.name}`});let o=N(t.entry),s=e?.type;if(!t.dtsOnly){let u=[Hr(t,e),...qr(t.plugins??[]).map((m)=>m.plugin)],g=t.format.flatMap((m)=>o.map((c)=>{return Cn(t,n,c,m,s,u)}));await Promise.all(g)}if(t.dts||t.dtsOnly){let u=await _r(n,t.preferredTsconfigPath);if(u.path)x.cli(`Using tsconfig: ${L(u.path,2)}`,{muted:!0,identifier:t.name,once:`${u.path}:${t.name}`});let g=t.format.filter((c)=>{if(c==="iife"&&!h(s)&&t.format.includes("cjs"))return!1;return!0}),m=typeof t.dts==="object"&&t.dts.entry?N(t.dts.entry):kr(o);try{await Promise.all(m.map(async(c)=>{let a=await Or(n,c.fullEntryPath,t,u,e);await Promise.all(g.map(async(f)=>{let I=t.outputExtension?.({format:f,packageType:s,options:t,entry:c}).dts??cr(f,s),S=`${t.outDir}/${c.name}${I}`,J=`${n}/${S}`;await Bun.write(J,a);let Zr=Bun.file(J).size||0;x.progress("DTS",S,F(Zr),t.name)}))}))}catch(c){if(gr(c))throw c;throw new p(d(c))}}if(t.onBuildSuccess)await t.onBuildSuccess(t)}async function Cn(r,n,t,e,i,o){let s=r.outputExtension?.({format:e,packageType:i,options:r,entry:t}).js??ur(e,i),u=await Bun.build({entrypoints:[`${n}/${t.fullEntryPath}`],format:e,naming:{entry:jr(t.name,s)},splitting:Yr(r.splitting,e),bytecode:Gr(r.bytecode,e),define:Ur(r.define,r.shims,r.env,e),minify:Dr(r),outdir:`${n}/${r.outDir}`,target:r.target,sourcemap:r.sourcemap,loader:r.loader,drop:r.drop,banner:r.banner,footer:r.footer,publicPath:r.publicPath,env:Fr(r.env),plugins:[...o,Kr({format:e,target:r.target,shims:r.shims})],throw:!1});if(!u.success)for(let a of u.logs){if(a.level==="error")throw new B(a.message);if(a.level==="warning")x.warn(a.message);else if(a.level==="info")x.info(a.message)}let g=`${r.outDir}/${t.name}${s}`,m=`${n}/${g}`,c=Bun.file(m).size||0;x.progress(e.toUpperCase(),g,F(c),r.name)}})
15
+ `}};function Hr({format:r,target:n,shims:e}){let o=Bn(e).map((i)=>v[i]).filter((i)=>i.appliesTo(r,n));if(o.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(i){i.onLoad({filter:Cn},async({path:s})=>{let m=await Bun.file(s).text(),u=o.filter((b)=>b.isNeededInFile(m));if(u.length===0)return;let{shebangLine:g,codeContent:x}=wn(m),a=u.map((b)=>b.generateCode()).join("");return{contents:g+a+x}})}}}function Bn(r){if(r===!0)return Object.keys(v);if(!r)return[];return Object.entries(r).filter(([n,e])=>e&&(n in v)).map(([n])=>n)}function wn(r){if(!r.startsWith("#!"))return{shebangLine:"",codeContent:r};let n=r.indexOf(`
16
+ `);return n===-1?{shebangLine:"",codeContent:r}:{shebangLine:r.slice(0,n+1),codeContent:r.slice(n+1)}}function Qr(r){if(!r)return[];return r.filter((n)=>n.type==="bun")}function Zr(r){if(!r)return[];return r.filter((n)=>n.type==="bunup")}async function zr(r,n){if(!r)return;for(let e of r)if(e.hooks.onBuildStart)await e.hooks.onBuildStart(n)}async function Vr(r,n,e){if(!r)return;for(let t of r)if(t.hooks.onBuildDone)await t.hooks.onBuildDone({options:n,output:e})}async function Xr(r,n=process.cwd()){let e={files:[]},t=_r(r);if(!t.entry||t.entry.length===0||!t.outDir)throw new O("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(t.clean)xr(n,t.outDir);ur(t.silent);let{packageJson:o,path:i}=await Dr(n);if(o&&i)p.cli(`Using package.json: ${L(i,2)}`,{muted:!0,identifier:t.name,once:`${i}:${t.name}`});let s=Zr(t.plugins);await zr(s,t);let m=N(t.entry),u=o?.type;if(!t.dtsOnly){let g=[Gr(t,o),...Qr(t.plugins).map((a)=>a.plugin)],x=t.format.flatMap((a)=>m.map(async(b)=>{let S=t.outputExtension?.({format:a,packageType:u,options:t,entry:b}).js??cr(a,u),w=await Bun.build({entrypoints:[`${n}/${b.fullEntryPath}`],format:a,naming:{entry:jr(b.name,S)},splitting:Kr(t.splitting,a),bytecode:Yr(t.bytecode,a),define:Fr(t.define,t.shims,t.env,a),minify:Ur(t),outdir:`${n}/${t.outDir}`,target:t.target,sourcemap:t.sourcemap,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer,publicPath:t.publicPath,env:qr(t.env),plugins:[...g,Hr({format:a,target:t.target,shims:t.shims})],throw:!1});if(!w.success)for(let l of w.logs){if(l.level==="error")throw new O(l.message);if(l.level==="warning")p.warn(l.message);else if(l.level==="info")p.info(l.message)}let E=`${t.outDir}/${b.name}${S}`,y=`${n}/${E}`;e.files.push({path:y}),p.progress(a.toUpperCase(),E,{identifier:t.name})}));await Promise.all(x)}if(t.dts||t.dtsOnly){let g=await Wr(n,t.preferredTsconfigPath);if(g.path)p.cli(`Using tsconfig: ${L(g.path,2)}`,{muted:!0,identifier:t.name,once:`${g.path}:${t.name}`});let x=t.format.filter((b)=>{if(b==="iife"&&!R(u)&&t.format.includes("cjs"))return!1;return!0}),a=typeof t.dts==="object"&&t.dts.entry?N(t.dts.entry):Ar(m);try{await Promise.all(a.map(async(b)=>{let S=await yr(n,b.fullEntryPath,t,g,o);await Promise.all(x.map(async(w)=>{let E=t.outputExtension?.({format:w,packageType:u,options:t,entry:b}).dts??br(w,u),y=`${t.outDir}/${b.name}${E}`,l=`${n}/${y}`;e.files.push({path:l}),await Bun.write(l,S),p.progress("DTS",y,{identifier:t.name})}))}))}catch(b){if(gr(b))throw b;throw new f(C(b))}}if(await Vr(s,t,e),t.onSuccess)await t.onSuccess(t)}})
package/dist/index.mjs CHANGED
@@ -1,16 +1,16 @@
1
1
  // @bun
2
- var jr=Object.create;var{getPrototypeOf:yr,defineProperty:Z,getOwnPropertyNames:_r}=Object;var Wr=Object.prototype.hasOwnProperty;var y=(r,n,t)=>{t=r!=null?jr(yr(r)):{};let e=n||!r||!r.__esModule?Z(t,"default",{value:r,enumerable:!0}):t;for(let i of _r(r))if(!Wr.call(e,i))Z(e,i,{get:()=>r[i],enumerable:!0});return e};var Dr=(r,n)=>()=>(n||r((n={exports:{}}).exports,n),n.exports);var S=Dr((wn,_)=>{var I=process||{},X=I.argv||[],T=I.env||{},Yr=!(!!T.NO_COLOR||X.includes("--no-color"))&&(!!T.FORCE_COLOR||X.includes("--color")||I.platform==="win32"||(I.stdout||{}).isTTY&&T.TERM!=="dumb"||!!T.CI),Fr=(r,n,t=r)=>(e)=>{let i=""+e,o=i.indexOf(n,r.length);return~o?r+Hr(i,n,t,o)+n:r+i+n},Hr=(r,n,t,e)=>{let i="",o=0;do i+=r.substring(o,e)+t,o=e+n.length,e=r.indexOf(n,o);while(~e);return i+r.substring(o)},N=(r=Yr)=>{let n=r?Fr:()=>String;return{isColorSupported:r,reset:n("\x1B[0m","\x1B[0m"),bold:n("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:n("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:n("\x1B[3m","\x1B[23m"),underline:n("\x1B[4m","\x1B[24m"),inverse:n("\x1B[7m","\x1B[27m"),hidden:n("\x1B[8m","\x1B[28m"),strikethrough:n("\x1B[9m","\x1B[29m"),black:n("\x1B[30m","\x1B[39m"),red:n("\x1B[31m","\x1B[39m"),green:n("\x1B[32m","\x1B[39m"),yellow:n("\x1B[33m","\x1B[39m"),blue:n("\x1B[34m","\x1B[39m"),magenta:n("\x1B[35m","\x1B[39m"),cyan:n("\x1B[36m","\x1B[39m"),white:n("\x1B[37m","\x1B[39m"),gray:n("\x1B[90m","\x1B[39m"),bgBlack:n("\x1B[40m","\x1B[49m"),bgRed:n("\x1B[41m","\x1B[49m"),bgGreen:n("\x1B[42m","\x1B[49m"),bgYellow:n("\x1B[43m","\x1B[49m"),bgBlue:n("\x1B[44m","\x1B[49m"),bgMagenta:n("\x1B[45m","\x1B[49m"),bgCyan:n("\x1B[46m","\x1B[49m"),bgWhite:n("\x1B[47m","\x1B[49m"),blackBright:n("\x1B[90m","\x1B[39m"),redBright:n("\x1B[91m","\x1B[39m"),greenBright:n("\x1B[92m","\x1B[39m"),yellowBright:n("\x1B[93m","\x1B[39m"),blueBright:n("\x1B[94m","\x1B[39m"),magentaBright:n("\x1B[95m","\x1B[39m"),cyanBright:n("\x1B[96m","\x1B[39m"),whiteBright:n("\x1B[97m","\x1B[39m"),bgBlackBright:n("\x1B[100m","\x1B[49m"),bgRedBright:n("\x1B[101m","\x1B[49m"),bgGreenBright:n("\x1B[102m","\x1B[49m"),bgYellowBright:n("\x1B[103m","\x1B[49m"),bgBlueBright:n("\x1B[104m","\x1B[49m"),bgMagentaBright:n("\x1B[105m","\x1B[49m"),bgCyanBright:n("\x1B[106m","\x1B[49m"),bgWhiteBright:n("\x1B[107m","\x1B[49m")}};_.exports=N();_.exports.createColors=N});function Gr(r){return r}function Ur(r){return r}import{build as Nr}from"rolldown";import{dts as Vr}from"rolldown-plugin-dts";var Kr=y(S(),1);var b=y(S(),1),V=!1;function z(r){V=r??!1}class C{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;cliColor=b.default.blue;mutedColor=b.default.dim;infoColor=b.default.cyan;warnColor=b.default.yellow;errorColor=b.default.red;sizeColor=b.default.green;defaultColor=b.default.white;progressFgColorMap={ESM:b.default.yellow,CJS:b.default.green,IIFE:b.default.magenta,DTS:b.default.blue};progressBgColorMap={ESM:b.default.bgYellow,CJS:b.default.bgGreen,IIFE:b.default.bgMagenta,DTS:b.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!C.instance)C.instance=new C;return C.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(r){if(!r?.once)return!0;if(this.loggedOnceMessages.has(r.once))return!1;return this.loggedOnceMessages.add(r.once),!0}formatMessage({fgColor:r,bgColor:n,label:t,message:e,size:i,identifier:o,muted:s}){let u=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),g=s?this.mutedColor(e):e;if(i){let[c,...a]=g.split(" "),f=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),L=o?` ${n(b.default.black(` ${o} `))}`:"";return`${r(t)} ${u}${c}${f} ${this.sizeColor(i)} ${a.join(" ")}${L}`}let m=o?` ${n(b.default.black(` ${o} `))}`:"";return`${r(t)} ${u}${g}${m}`}output(r,n={},t=console.log){if(V||!this.shouldLog(n))return;if(n.verticalSpace)t("");if(t(r),n.verticalSpace)t("")}cli(r,n={}){let t=this.formatMessage({fgColor:this.cliColor,bgColor:b.default.bgBlue,label:this.labels.cli,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n)}info(r,n={}){let t=this.formatMessage({fgColor:this.infoColor,bgColor:b.default.bgCyan,label:this.labels.info,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n)}warn(r,n={}){let t=this.formatMessage({fgColor:this.warnColor,bgColor:b.default.bgYellow,label:this.labels.warn,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n,console.warn)}error(r,n={}){let t=this.formatMessage({fgColor:this.errorColor,bgColor:b.default.bgRed,label:this.labels.error,message:r,identifier:n.identifier,muted:n.muted});this.output(t,n,console.error)}getProgressFgColor(r){for(let[n,t]of Object.entries(this.progressFgColorMap))if(r.includes(n))return t;return this.defaultColor}getProgressBgColor(r){for(let[n,t]of Object.entries(this.progressBgColorMap))if(r.includes(n))return t;return b.default.bgWhite}progress(r,n,t,e){let i,o,s={};if(typeof t==="string")i=t,o=e;else if(t)i=t.size,o=t.identifier,s=t;let u=this.getProgressFgColor(r),g=this.getProgressBgColor(r),m=this.formatMessage({fgColor:u,bgColor:g,label:r,message:n,size:i,identifier:o,muted:s.muted});this.output(m,s)}}var x=C.getInstance();class E extends Error{constructor(r){super(r);this.name="BunupError"}}class w extends E{constructor(r){super(r);this.name="BunupBuildError"}}class p extends E{constructor(r){super(r);this.name="BunupDTSBuildError"}}class O extends E{constructor(r){super(r);this.name="BunupIsolatedDeclError"}}var l=(r)=>{if(r instanceof Error)return r.message;return String(r)};function J(r){return r instanceof O}import ur from"path";import{ResolverFactory as Xr}from"oxc-resolver";import v from"fs/promises";import qr from"path";function P(r,n){switch(r){case"esm":return B(n)?".js":".mjs";case"cjs":return B(n)?".cjs":".js";case"iife":return".global.js"}}function rr(r,n){switch(r){case"esm":return B(n)?".d.ts":".d.mts";case"cjs":return B(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function W(r){return r==="node"||r==="bun"}function B(r){return r==="module"}function nr(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function D(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/1024**t).toFixed(2)} ${n[t]}`}function h(r,n=3){return r.split("/").slice(-n).join("/")}async function tr(r,n){let t=qr.join(r,n);try{await v.rm(t,{recursive:!0,force:!0})}catch(e){throw new w(`Failed to clean output directory: ${e}`)}await v.mkdir(t,{recursive:!0})}function A(r){return[".ts",".mts",".cts",".tsx"].some((n)=>r.endsWith(n))}function Qr(r){return nr(r).map((n)=>new RegExp(`^${n}($|\\/|\\\\)`))}function er(r,n){return typeof n==="string"?n===r:n.test(r)}function k(r,n,t){let i=Qr(t).some((s)=>s.test(r))||n.external?.some((s)=>er(r,s)),o=n.noExternal?.some((s)=>er(r,s));return i&&!o}import{resolveTsImportPath as Zr}from"ts-import-resolver";var M="\x00dts:",ir=(r,n,t)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(G(e))return e;if(!i||!G(i))return null;let o=n.tsconfig?Zr({path:e,importer:R(i),tsconfig:n.tsconfig,rootDir:t}):null;if(!o)return null;let s=d(o);if(r.has(s))return j(s);return null},load(e){if(e.startsWith(M)){let i=R(e),o=r.get(i);if(o)return o}return null}}};var U=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/;function or(r){return r.endsWith(".d.ts")||r.endsWith(".d.mts")||r.endsWith(".d.cts")}function sr(r){return U.test(r)&&!or(r)}function d(r){if(or(r))return r;if(r.endsWith(".mts"))return`${r.slice(0,-4)}.d.mts`;if(r.endsWith(".cts"))return`${r.slice(0,-4)}.d.cts`;if(U.test(r))return r.replace(U,".d.ts");return`${r}.d.ts`}function G(r){return r.startsWith(M)}function R(r){return r.replace(M,"")}function j(r){return`${M}${r}`}function gr(r,n){if(n===void 0)return"";let t=r.slice(0,n).split(`
3
- `),e=t.length,i=t[t.length-1].length+1;return` (${e}:${i})`}function mr(r,n,t,e){if(typeof e==="boolean"&&e)return!1;if(Array.isArray(e)){for(let i of e)if(typeof i==="string"&&r===i)return!1;else if(i instanceof RegExp&&i.test(r))return!1}return k(r,n,t)}var Y;function cr(r,n){return{name:"bunup:types-resolve",buildStart(){Y||=new Xr({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...r.path&&{tsconfig:{configFile:r.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(t,e){if(n===!1)return;if(t==="bun")return;let i=e?R(e):void 0;if(/\0/.test(t))return;if(Array.isArray(n)){if(!n.some((g)=>typeof g==="string"?g===t:g.test(t)))return}let o=i?ur.dirname(i):process.cwd(),{path:s}=await Y.async(o,t);if(!s)return;if(sr(s)){let u=d(s);try{let{path:g}=await Y.async(ur.dirname(s),u);if(g)return g}catch(g){}return}return s}}}async function br(r,n,t,e,i,o){let s=d(r),u=j(s),g=typeof t.dts==="object"&&"resolve"in t.dts?t.dts.resolve:void 0;try{let{output:m}=await Nr({input:u,output:{dir:t.outDir},write:!1,...i.path&&{resolve:{tsconfigFilename:i.path}},onwarn(c,a){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;a(c)},plugins:[ir(n,i,o),g&&cr(i,g),Vr({dtsInput:!0,emitDtsOnly:!0})],external:(c)=>mr(c,t,e,g)});if(!m[0]?.code)return x.warn(`Generated empty declaration file for entry "${r}"`,{muted:!0}),"";return m[0].code}catch(m){throw new p(`DTS bundling failed for entry "${r}": ${l(m)}`)}}import{resolveTsImportPath as zr}from"ts-import-resolver";var Jr=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,vr=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Pr=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,rn=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,nn=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,tn=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,en=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function on(r){let n=new Set,t=[Jr,vr,Pr,rn,nn,tn,en];for(let e of t){let i=r.matchAll(e);for(let o of i)if(o[1])n.add(o[1])}return n}async function ar(r,n,t){let e=new Set([r]),i=[r];while(i.length){let o=i.pop();if(!o)continue;try{let s=await Bun.file(o).text(),u=on(s);for(let g of u){let m=n.tsconfig?zr({path:g,importer:o,tsconfig:n.tsconfig,rootDir:t}):null;if(!m)continue;if(!e.has(m))e.add(m),i.push(m)}}catch(s){x.warn(`Error processing ${o}: ${l(s)}`)}}return e}var F=y(S(),1);import{isolatedDeclaration as sn}from"oxc-transform";async function xr(r,n){let t=!1,e=new Map;if(await Promise.all([...r].map(async(i)=>{try{let o=d(i);if(!await Bun.file(i).exists())return;let u=await Bun.file(i).text(),{code:g,errors:m}=sn(i,u);if(g)e.set(o,g);for(let c of m){if(!t&&!n)console.log(`
4
- `);let a=c.labels[0],f=a?gr(u,a.start):"",$=`${h(i)}${f}: ${gn(c.message)}`;x[n?"warn":"error"]($),t=!0}}catch(o){x.warn(`Failed to generate declaration for ${i}: ${l(o)}`)}})),t&&!n)throw console.log(`
5
- `),new O(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${F.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${F.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return e}function gn(r){return r.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}import fr from"fs/promises";import H from"path";async function pr(r,n){let t=H.resolve(r),e=H.resolve(t,n);if(!await fr.exists(t))throw new p(`Root directory does not exist: ${t}`);if(!await Bun.file(e).exists())throw new p(`Entry file does not exist: ${e}`);if(!A(e))throw new p(`Entry file must be a TypeScript file: ${e}`);if(H.relative(t,e).startsWith(".."))throw new p(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}async function lr(r,n,t,e,i){let{absoluteEntry:o}=await pr(r,n),s=await ar(o,e,r),u=await xr(s,t.watch);return br(o,u,t,i,e,r)}import{basename as mn,dirname as un,extname as cn}from"path";function dr(r){let n=mn(r),t=cn(n);return t?n.slice(0,-t.length):n}function K(r){if(typeof r==="string")return[{fullEntryPath:r,name:dr(r)}];if(typeof r==="object"&&!Array.isArray(r))return Object.entries(r).map(([e,i])=>({fullEntryPath:i,name:e}));let n=[],t=new Set;for(let e of r){let i=dr(e);if(!t.has(i)){n.push({fullEntryPath:e,name:i}),t.add(i);continue}let s=un(e).split("/").filter((g)=>g!=="."&&g!=="");if(s.length===0){let g=1,m;do m=`${i}_${g++}`;while(t.has(m));n.push({fullEntryPath:e,name:m}),t.add(m);continue}let u=!1;for(let g=1;g<=s.length&&!u;g++){let c=`${s.slice(-g).join("/")}/${i}`;if(!t.has(c))n.push({fullEntryPath:e,name:c}),t.add(c),u=!0}if(!u){let g=1,m;do m=`${s.join("/")}/${i}_${g++}`;while(t.has(m));n.push({fullEntryPath:e,name:m}),t.add(m)}}return n}function Cr(r){return r.filter((n)=>A(n.fullEntryPath))}function wr(r,n){return`[dir]/${r}${n}`}import{loadConfig as Br}from"coffi";async function hr(r){let{config:n,filepath:t}=await Br({name:"package",cwd:r,extensions:[".json"]});return{packageJson:n,path:t}}async function Rr(r,n){let{config:t,filepath:e}=await Br({name:"tsconfig",cwd:r,extensions:[".json"],preferredPath:n});return{tsconfig:t,path:e}}var bn={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function Mr(r){return{...bn,...r}}function Lr(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:i}=r,o=n===!0;return{whitespace:t??o,identifiers:e??o,syntax:i??o}}function $r(r,n){return n==="cjs"?r:void 0}function Tr(r,n,t,e){return{...typeof t==="object"&&Object.keys(t).reduce((i,o)=>{let s=JSON.stringify(t[o]);return i[`process.env.${o}`]=s,i[`import.meta.env.${o}`]=s,i},{}),...r,...e==="cjs"&&(n===!0||typeof n==="object"&&n.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Ir(r,n){return r===void 0?n==="esm":r}function Sr(r){return typeof r==="string"?r:void 0}function Er(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let i=e.path;if(k(i,r,n))return{path:i,external:!0};return null})}}}var an=/\.(js|ts|jsx|tsx|mts|cts)$/,q={dirnameFilename:{appliesTo:(r,n)=>r==="esm"&&W(n),isNeededInFile:(r)=>/\b__dirname\b/.test(r)||/\b__filename\b/.test(r),generateCode:()=>`import { fileURLToPath } from 'url';
2
+ var Wr=Object.create;var{getPrototypeOf:_r,defineProperty:z,getOwnPropertyNames:Ur}=Object;var Yr=Object.prototype.hasOwnProperty;var _=(r,n,e)=>{e=r!=null?Wr(_r(r)):{};let t=n||!r||!r.__esModule?z(e,"default",{value:r,enumerable:!0}):e;for(let o of Ur(r))if(!Yr.call(t,o))z(t,o,{get:()=>r[o],enumerable:!0});return t};var Fr=(r,n)=>()=>(n||r((n={exports:{}}).exports,n),n.exports);var y=Fr((hn,U)=>{var E=process||{},V=E.argv||[],M=E.env||{},Gr=!(!!M.NO_COLOR||V.includes("--no-color"))&&(!!M.FORCE_COLOR||V.includes("--color")||E.platform==="win32"||(E.stdout||{}).isTTY&&M.TERM!=="dumb"||!!M.CI),Hr=(r,n,e=r)=>(t)=>{let o=""+t,i=o.indexOf(n,r.length);return~i?r+Qr(o,n,e,i)+n:r+o+n},Qr=(r,n,e,t)=>{let o="",i=0;do o+=r.substring(i,t)+e,i=t+n.length,t=r.indexOf(n,i);while(~t);return o+r.substring(i)},X=(r=Gr)=>{let n=r?Hr:()=>String;return{isColorSupported:r,reset:n("\x1B[0m","\x1B[0m"),bold:n("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:n("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:n("\x1B[3m","\x1B[23m"),underline:n("\x1B[4m","\x1B[24m"),inverse:n("\x1B[7m","\x1B[27m"),hidden:n("\x1B[8m","\x1B[28m"),strikethrough:n("\x1B[9m","\x1B[29m"),black:n("\x1B[30m","\x1B[39m"),red:n("\x1B[31m","\x1B[39m"),green:n("\x1B[32m","\x1B[39m"),yellow:n("\x1B[33m","\x1B[39m"),blue:n("\x1B[34m","\x1B[39m"),magenta:n("\x1B[35m","\x1B[39m"),cyan:n("\x1B[36m","\x1B[39m"),white:n("\x1B[37m","\x1B[39m"),gray:n("\x1B[90m","\x1B[39m"),bgBlack:n("\x1B[40m","\x1B[49m"),bgRed:n("\x1B[41m","\x1B[49m"),bgGreen:n("\x1B[42m","\x1B[49m"),bgYellow:n("\x1B[43m","\x1B[49m"),bgBlue:n("\x1B[44m","\x1B[49m"),bgMagenta:n("\x1B[45m","\x1B[49m"),bgCyan:n("\x1B[46m","\x1B[49m"),bgWhite:n("\x1B[47m","\x1B[49m"),blackBright:n("\x1B[90m","\x1B[39m"),redBright:n("\x1B[91m","\x1B[39m"),greenBright:n("\x1B[92m","\x1B[39m"),yellowBright:n("\x1B[93m","\x1B[39m"),blueBright:n("\x1B[94m","\x1B[39m"),magentaBright:n("\x1B[95m","\x1B[39m"),cyanBright:n("\x1B[96m","\x1B[39m"),whiteBright:n("\x1B[97m","\x1B[39m"),bgBlackBright:n("\x1B[100m","\x1B[49m"),bgRedBright:n("\x1B[101m","\x1B[49m"),bgGreenBright:n("\x1B[102m","\x1B[49m"),bgYellowBright:n("\x1B[103m","\x1B[49m"),bgBlueBright:n("\x1B[104m","\x1B[49m"),bgMagentaBright:n("\x1B[105m","\x1B[49m"),bgCyanBright:n("\x1B[106m","\x1B[49m"),bgWhiteBright:n("\x1B[107m","\x1B[49m")}};U.exports=X();U.exports.createColors=X});function Kr(r){return r}function qr(r){return r}import{build as Jr}from"rolldown";import{dts as vr}from"rolldown-plugin-dts";var Zr=_(y(),1);var c=_(y(),1),N=!1;function J(r){N=r??!1}class w{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;cliColor=c.default.blue;mutedColor=c.default.dim;infoColor=c.default.cyan;warnColor=c.default.yellow;errorColor=c.default.red;defaultColor=c.default.white;progressFgColorMap={ESM:c.default.yellow,CJS:c.default.green,IIFE:c.default.magenta,DTS:c.default.blue};progressBgColorMap={ESM:c.default.bgYellow,CJS:c.default.bgGreen,IIFE:c.default.bgMagenta,DTS:c.default.bgBlue};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!w.instance)w.instance=new w;return w.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(r){if(!r?.once)return!0;if(this.loggedOnceMessages.has(r.once))return!1;return this.loggedOnceMessages.add(r.once),!0}formatMessage({fgColor:r,bgColor:n,label:e,message:t,identifier:o,muted:i}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-e.length)),m=i?this.mutedColor(t):t,u=o?` ${n(c.default.black(` ${o} `))}`:"";return`${r(e)} ${s}${m}${u}`}output(r,n={},e=console.log){if(N||!this.shouldLog(n))return;if(n.verticalSpace)e("");if(e(r),n.verticalSpace)e("")}cli(r,n={}){let e=this.formatMessage({fgColor:this.cliColor,bgColor:c.default.bgBlue,label:this.labels.cli,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n)}info(r,n={}){let e=this.formatMessage({fgColor:this.infoColor,bgColor:c.default.bgCyan,label:this.labels.info,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n)}warn(r,n={}){let e=this.formatMessage({fgColor:this.warnColor,bgColor:c.default.bgYellow,label:this.labels.warn,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n,console.warn)}error(r,n={}){let e=this.formatMessage({fgColor:this.errorColor,bgColor:c.default.bgRed,label:this.labels.error,message:r,identifier:n.identifier,muted:n.muted});this.output(e,n,console.error)}getProgressFgColor(r){for(let[n,e]of Object.entries(this.progressFgColorMap))if(r.includes(n))return e;return this.defaultColor}getProgressBgColor(r){for(let[n,e]of Object.entries(this.progressBgColorMap))if(r.includes(n))return e;return c.default.bgWhite}progress(r,n,e={}){let t=this.getProgressFgColor(r),o=this.getProgressBgColor(r),i=this.formatMessage({fgColor:t,bgColor:o,label:r,message:n,identifier:e.identifier,muted:e.muted});this.output(i,e)}}var p=w.getInstance();class $ extends Error{constructor(r){super(r);this.name="BunupError"}}class h extends ${constructor(r){super(r);this.name="BunupBuildError"}}class f extends ${constructor(r){super(r);this.name="BunupDTSBuildError"}}class A extends ${constructor(r){super(r);this.name="BunupIsolatedDeclError"}}var d=(r)=>{if(r instanceof Error)return r.message;return String(r)};function v(r){return r instanceof A}import cr from"path";import{ResolverFactory as Nr}from"oxc-resolver";import P from"fs/promises";import zr from"path";function rr(r,n){switch(r){case"esm":return O(n)?".js":".mjs";case"cjs":return O(n)?".cjs":".js";case"iife":return".global.js"}}function nr(r,n){switch(r){case"esm":return O(n)?".d.ts":".d.mts";case"cjs":return O(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function Y(r){return r==="node"||r==="bun"}function O(r){return r==="module"}function tr(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function T(r,n=3){return r.split("/").slice(-n).join("/")}async function er(r,n){let e=zr.join(r,n);try{await P.rm(e,{recursive:!0,force:!0})}catch(t){throw new h(`Failed to clean output directory: ${t}`)}await P.mkdir(e,{recursive:!0})}function j(r){return[".ts",".mts",".cts",".tsx"].some((n)=>r.endsWith(n))}function Vr(r){return tr(r).map((n)=>new RegExp(`^${n}($|\\/|\\\\)`))}function or(r,n){return typeof n==="string"?n===r:n.test(r)}function D(r,n,e){let o=Vr(e).some((s)=>s.test(r))||n.external?.some((s)=>or(r,s)),i=n.noExternal?.some((s)=>or(r,s));return o&&!i}import{resolveTsImportPath as Xr}from"ts-import-resolver";var I="\x00dts:",ir=(r,n,e)=>{return{name:"bunup:virtual-dts",async resolveId(t,o){if(F(t))return t;if(!o||!F(o))return null;let i=n.tsconfig?Xr({path:t,importer:S(o),tsconfig:n.tsconfig,rootDir:e}):null;if(!i)return null;let s=C(i);if(r.has(s))return W(s);return null},load(t){if(t.startsWith(I)){let o=S(t),i=r.get(o);if(i)return i}return null}}};var K=/\.(js|mjs|cjs|ts|mts|cts|tsx|jsx)$/;function sr(r){return r.endsWith(".d.ts")||r.endsWith(".d.mts")||r.endsWith(".d.cts")}function ur(r){return K.test(r)&&!sr(r)}function C(r){if(sr(r))return r;if(r.endsWith(".mts"))return`${r.slice(0,-4)}.d.mts`;if(r.endsWith(".cts"))return`${r.slice(0,-4)}.d.cts`;if(K.test(r))return r.replace(K,".d.ts");return`${r}.d.ts`}function F(r){return r.startsWith(I)}function S(r){return r.replace(I,"")}function W(r){return`${I}${r}`}function gr(r,n){if(n===void 0)return"";let e=r.slice(0,n).split(`
3
+ `),t=e.length,o=e[e.length-1].length+1;return` (${t}:${o})`}function mr(r,n,e,t){if(typeof t==="boolean"&&t)return!1;if(Array.isArray(t)){for(let o of t)if(typeof o==="string"&&r===o)return!1;else if(o instanceof RegExp&&o.test(r))return!1}return D(r,n,e)}var q;function br(r,n){return{name:"bunup:types-resolve",buildStart(){q||=new Nr({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],...r.path&&{tsconfig:{configFile:r.path}},modules:["node_modules","node_modules/@types"]})},async resolveId(e,t){if(n===!1)return;if(e==="bun")return;let o=t?S(t):void 0;if(/\0/.test(e))return;if(Array.isArray(n)){if(!n.some((u)=>typeof u==="string"?u===e:u.test(e)))return}let i=o?cr.dirname(o):process.cwd(),{path:s}=await q.async(i,e);if(!s)return;if(ur(s)){let m=C(s);try{let{path:u}=await q.async(cr.dirname(s),m);if(u)return u}catch(u){}return}return s}}}async function ar(r,n,e,t,o,i){let s=C(r),m=W(s),u=typeof e.dts==="object"&&"resolve"in e.dts?e.dts.resolve:void 0;try{let{output:g}=await Jr({input:m,output:{dir:e.outDir},write:!1,...o.path&&{resolve:{tsconfigFilename:o.path}},onwarn(x,a){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;a(x)},plugins:[ir(n,o,i),u&&br(o,u),vr({dtsInput:!0,emitDtsOnly:!0})],external:(x)=>mr(x,e,t,u)});if(!g[0]?.code)return p.warn(`Generated empty declaration file for entry "${r}"`,{muted:!0}),"";return g[0].code}catch(g){throw new f(`DTS bundling failed for entry "${r}": ${d(g)}`)}}import{resolveTsImportPath as Pr}from"ts-import-resolver";var rn=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,nn=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,tn=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,en=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,on=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,sn=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,un=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function gn(r){let n=new Set,e=[rn,nn,tn,en,on,sn,un];for(let t of e){let o=r.matchAll(t);for(let i of o)if(i[1])n.add(i[1])}return n}async function xr(r,n,e){let t=new Set([r]),o=[r];while(o.length){let i=o.pop();if(!i)continue;try{let s=await Bun.file(i).text(),m=gn(s);for(let u of m){let g=n.tsconfig?Pr({path:u,importer:i,tsconfig:n.tsconfig,rootDir:e}):null;if(!g)continue;if(!t.has(g))t.add(g),o.push(g)}}catch(s){p.warn(`Error processing ${i}: ${d(s)}`)}}return t}var G=_(y(),1);import{isolatedDeclaration as mn}from"oxc-transform";async function pr(r,n){let e=!1,t=new Map;if(await Promise.all([...r].map(async(o)=>{try{let i=C(o);if(!await Bun.file(o).exists())return;let m=await Bun.file(o).text(),{code:u,errors:g}=mn(o,m);if(u)t.set(i,u);for(let x of g){if(!e&&!n)console.log(`
4
+ `);let a=x.labels[0],b=a?gr(m,a.start):"",B=`${T(o)}${b}: ${cn(x.message)}`;p[n?"warn":"error"](B),e=!0}}catch(i){p.warn(`Failed to generate declaration for ${o}: ${d(i)}`)}})),e&&!n)throw console.log(`
5
+ `),new A(`TypeScript is asking for explicit type annotations on your exports. This helps ensure better, more reliable type declarations for your library. Bunup uses TypeScript's ${G.default.blue("isolatedDeclarations")} feature to generate these declarations, which requires each export from your library to be fully typed. You can learn more here: ${G.default.blue("https://www.typescriptlang.org/docs/handbook/release-notes/typescript-5-5.html#isolated-declarations")}`);return t}function cn(r){return r.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}import fr from"fs/promises";import H from"path";async function lr(r,n){let e=H.resolve(r),t=H.resolve(e,n);if(!await fr.exists(e))throw new f(`Root directory does not exist: ${e}`);if(!await Bun.file(t).exists())throw new f(`Entry file does not exist: ${t}`);if(!j(t))throw new f(`Entry file must be a TypeScript file: ${t}`);if(H.relative(e,t).startsWith(".."))throw new f(`Entry file must be within rootDir: ${t}`);return{absoluteRootDir:e,absoluteEntry:t}}async function dr(r,n,e,t,o){let{absoluteEntry:i}=await lr(r,n),s=await xr(i,t,r),m=await pr(s,e.watch);return ar(i,m,e,o,t,r)}import{basename as bn,dirname as an,extname as xn}from"path";function Cr(r){let n=bn(r),e=xn(n);return e?n.slice(0,-e.length):n}function Q(r){if(typeof r==="string")return[{fullEntryPath:r,name:Cr(r)}];if(typeof r==="object"&&!Array.isArray(r))return Object.entries(r).map(([t,o])=>({fullEntryPath:o,name:t}));let n=[],e=new Set;for(let t of r){let o=Cr(t);if(!e.has(o)){n.push({fullEntryPath:t,name:o}),e.add(o);continue}let s=an(t).split("/").filter((u)=>u!=="."&&u!=="");if(s.length===0){let u=1,g;do g=`${o}_${u++}`;while(e.has(g));n.push({fullEntryPath:t,name:g}),e.add(g);continue}let m=!1;for(let u=1;u<=s.length&&!m;u++){let x=`${s.slice(-u).join("/")}/${o}`;if(!e.has(x))n.push({fullEntryPath:t,name:x}),e.add(x),m=!0}if(!m){let u=1,g;do g=`${s.join("/")}/${o}_${u++}`;while(e.has(g));n.push({fullEntryPath:t,name:g}),e.add(g)}}return n}function Br(r){return r.filter((n)=>j(n.fullEntryPath))}function wr(r,n){return`[dir]/${r}${n}`}import{loadConfig as hr}from"coffi";async function Or(r){let{config:n,filepath:e}=await hr({name:"package",cwd:r,extensions:[".json"]});return{packageJson:n,path:e}}async function Rr(r,n){let{config:e,filepath:t}=await hr({name:"tsconfig",cwd:r,extensions:[".json"],preferredPath:n});return{tsconfig:e,path:t}}var pn={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function Tr(r){return{...pn,...r}}function Sr(r){let{minify:n,minifyWhitespace:e,minifyIdentifiers:t,minifySyntax:o}=r,i=n===!0;return{whitespace:e??i,identifiers:t??i,syntax:o??i}}function Ir(r,n){return n==="cjs"?r:void 0}function Lr(r,n,e,t){return{...typeof e==="object"&&Object.keys(e).reduce((o,i)=>{let s=JSON.stringify(e[i]);return o[`process.env.${i}`]=s,o[`import.meta.env.${i}`]=s,o},{}),...r,...t==="cjs"&&(n===!0||typeof n==="object"&&n.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function kr(r,n){return r===void 0?n==="esm":r}function Mr(r){return typeof r==="string"?r:void 0}function Er(r,n){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(t)=>{let o=t.path;if(D(o,r,n))return{path:o,external:!0};return null})}}}var fn=/\.(js|ts|jsx|tsx|mts|cts)$/,Z={dirnameFilename:{appliesTo:(r,n)=>r==="esm"&&Y(n),isNeededInFile:(r)=>/\b__dirname\b/.test(r)||/\b__filename\b/.test(r),generateCode:()=>`import { fileURLToPath } from 'url';
6
6
  import { dirname } from 'path';
7
7
 
8
8
  const __filename = fileURLToPath(import.meta.url);
9
9
  const __dirname = dirname(__filename);
10
10
 
11
- `},importMetaUrl:{appliesTo:(r,n)=>r==="cjs"&&W(n),isNeededInFile:(r)=>/\bimport\.meta\.url\b/.test(r),generateCode:()=>`import { pathToFileURL } from 'url';
11
+ `},importMetaUrl:{appliesTo:(r,n)=>r==="cjs"&&Y(n),isNeededInFile:(r)=>/\bimport\.meta\.url\b/.test(r),generateCode:()=>`import { pathToFileURL } from 'url';
12
12
 
13
13
  const importMetaUrl = pathToFileURL(__filename).href;
14
14
 
15
- `}};function Or({format:r,target:n,shims:t}){let i=xn(t).map((o)=>q[o]).filter((o)=>o.appliesTo(r,n));if(i.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:an},async({path:s})=>{let u=await Bun.file(s).text(),g=i.filter((f)=>f.isNeededInFile(u));if(g.length===0)return;let{shebangLine:m,codeContent:c}=fn(u),a=g.map((f)=>f.generateCode()).join("");return{contents:m+a+c}})}}}function xn(r){if(r===!0)return Object.keys(q);if(!r)return[];return Object.entries(r).filter(([n,t])=>t&&(n in q)).map(([n])=>n)}function fn(r){if(!r.startsWith("#!"))return{shebangLine:"",codeContent:r};let n=r.indexOf(`
16
- `);return n===-1?{shebangLine:"",codeContent:r}:{shebangLine:r.slice(0,n+1),codeContent:r.slice(n+1)}}function Ar(r){return r.filter((n)=>n.type==="bun")}async function pn(r,n=process.cwd()){let t=Mr(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.");if(t.clean)tr(n,t.outDir);z(t.silent);let{packageJson:e,path:i}=await hr(n);if(e&&i)x.cli(`Using package.json: ${h(i,2)}`,{muted:!0,identifier:t.name,once:`${i}:${t.name}`});let o=K(t.entry),s=e?.type;if(!t.dtsOnly){let u=[Er(t,e),...Ar(t.plugins??[]).map((m)=>m.plugin)],g=t.format.flatMap((m)=>o.map((c)=>{return ln(t,n,c,m,s,u)}));await Promise.all(g)}if(t.dts||t.dtsOnly){let u=await Rr(n,t.preferredTsconfigPath);if(u.path)x.cli(`Using tsconfig: ${h(u.path,2)}`,{muted:!0,identifier:t.name,once:`${u.path}:${t.name}`});let g=t.format.filter((c)=>{if(c==="iife"&&!B(s)&&t.format.includes("cjs"))return!1;return!0}),m=typeof t.dts==="object"&&t.dts.entry?K(t.dts.entry):Cr(o);try{await Promise.all(m.map(async(c)=>{let a=await lr(n,c.fullEntryPath,t,u,e);await Promise.all(g.map(async(f)=>{let L=t.outputExtension?.({format:f,packageType:s,options:t,entry:c}).dts??rr(f,s),$=`${t.outDir}/${c.name}${L}`,Q=`${n}/${$}`;await Bun.write(Q,a);let kr=Bun.file(Q).size||0;x.progress("DTS",$,D(kr),t.name)}))}))}catch(c){if(J(c))throw c;throw new p(l(c))}}if(t.onBuildSuccess)await t.onBuildSuccess(t)}async function ln(r,n,t,e,i,o){let s=r.outputExtension?.({format:e,packageType:i,options:r,entry:t}).js??P(e,i),u=await Bun.build({entrypoints:[`${n}/${t.fullEntryPath}`],format:e,naming:{entry:wr(t.name,s)},splitting:Ir(r.splitting,e),bytecode:$r(r.bytecode,e),define:Tr(r.define,r.shims,r.env,e),minify:Lr(r),outdir:`${n}/${r.outDir}`,target:r.target,sourcemap:r.sourcemap,loader:r.loader,drop:r.drop,banner:r.banner,footer:r.footer,publicPath:r.publicPath,env:Sr(r.env),plugins:[...o,Or({format:e,target:r.target,shims:r.shims})],throw:!1});if(!u.success)for(let a of u.logs){if(a.level==="error")throw new w(a.message);if(a.level==="warning")x.warn(a.message);else if(a.level==="info")x.info(a.message)}let g=`${r.outDir}/${t.name}${s}`,m=`${n}/${g}`,c=Bun.file(m).size||0;x.progress(e.toUpperCase(),g,D(c),r.name)}export{Ur as defineWorkspace,Gr as defineConfig,pn as build};
15
+ `}};function yr({format:r,target:n,shims:e}){let o=ln(e).map((i)=>Z[i]).filter((i)=>i.appliesTo(r,n));if(o.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(i){i.onLoad({filter:fn},async({path:s})=>{let m=await Bun.file(s).text(),u=o.filter((b)=>b.isNeededInFile(m));if(u.length===0)return;let{shebangLine:g,codeContent:x}=dn(m),a=u.map((b)=>b.generateCode()).join("");return{contents:g+a+x}})}}}function ln(r){if(r===!0)return Object.keys(Z);if(!r)return[];return Object.entries(r).filter(([n,e])=>e&&(n in Z)).map(([n])=>n)}function dn(r){if(!r.startsWith("#!"))return{shebangLine:"",codeContent:r};let n=r.indexOf(`
16
+ `);return n===-1?{shebangLine:"",codeContent:r}:{shebangLine:r.slice(0,n+1),codeContent:r.slice(n+1)}}function $r(r){if(!r)return[];return r.filter((n)=>n.type==="bun")}function Ar(r){if(!r)return[];return r.filter((n)=>n.type==="bunup")}async function jr(r,n){if(!r)return;for(let e of r)if(e.hooks.onBuildStart)await e.hooks.onBuildStart(n)}async function Dr(r,n,e){if(!r)return;for(let t of r)if(t.hooks.onBuildDone)await t.hooks.onBuildDone({options:n,output:e})}async function Cn(r,n=process.cwd()){let e={files:[]},t=Tr(r);if(!t.entry||t.entry.length===0||!t.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(t.clean)er(n,t.outDir);J(t.silent);let{packageJson:o,path:i}=await Or(n);if(o&&i)p.cli(`Using package.json: ${T(i,2)}`,{muted:!0,identifier:t.name,once:`${i}:${t.name}`});let s=Ar(t.plugins);await jr(s,t);let m=Q(t.entry),u=o?.type;if(!t.dtsOnly){let g=[Er(t,o),...$r(t.plugins).map((a)=>a.plugin)],x=t.format.flatMap((a)=>m.map(async(b)=>{let R=t.outputExtension?.({format:a,packageType:u,options:t,entry:b}).js??rr(a,u),B=await Bun.build({entrypoints:[`${n}/${b.fullEntryPath}`],format:a,naming:{entry:wr(b.name,R)},splitting:kr(t.splitting,a),bytecode:Ir(t.bytecode,a),define:Lr(t.define,t.shims,t.env,a),minify:Sr(t),outdir:`${n}/${t.outDir}`,target:t.target,sourcemap:t.sourcemap,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer,publicPath:t.publicPath,env:Mr(t.env),plugins:[...g,yr({format:a,target:t.target,shims:t.shims})],throw:!1});if(!B.success)for(let l of B.logs){if(l.level==="error")throw new h(l.message);if(l.level==="warning")p.warn(l.message);else if(l.level==="info")p.info(l.message)}let L=`${t.outDir}/${b.name}${R}`,k=`${n}/${L}`;e.files.push({path:k}),p.progress(a.toUpperCase(),L,{identifier:t.name})}));await Promise.all(x)}if(t.dts||t.dtsOnly){let g=await Rr(n,t.preferredTsconfigPath);if(g.path)p.cli(`Using tsconfig: ${T(g.path,2)}`,{muted:!0,identifier:t.name,once:`${g.path}:${t.name}`});let x=t.format.filter((b)=>{if(b==="iife"&&!O(u)&&t.format.includes("cjs"))return!1;return!0}),a=typeof t.dts==="object"&&t.dts.entry?Q(t.dts.entry):Br(m);try{await Promise.all(a.map(async(b)=>{let R=await dr(n,b.fullEntryPath,t,g,o);await Promise.all(x.map(async(B)=>{let L=t.outputExtension?.({format:B,packageType:u,options:t,entry:b}).dts??nr(B,u),k=`${t.outDir}/${b.name}${L}`,l=`${n}/${k}`;e.files.push({path:l}),await Bun.write(l,R),p.progress("DTS",k,{identifier:t.name})}))}))}catch(b){if(v(b))throw b;throw new f(d(b))}}if(await Dr(s,t,e),t.onSuccess)await t.onSuccess(t)}export{qr as defineWorkspace,Kr as defineConfig,Cn as build};
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "bunup",
3
3
  "description": "⚡ A blazing-fast build tool for your libraries built with Bun.",
4
- "version": "0.4.73",
4
+ "version": "0.4.74",
5
5
  "license": "MIT",
6
6
  "author": "Arshad Yaseen <m@arshadyaseen.com> (https://arshadyaseen.com)",
7
7
  "maintainers": [