bunup 0.4.19 → 0.4.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/cli.mjs CHANGED
@@ -1,16 +1,16 @@
1
1
  #!/usr/bin/env bun
2
2
  // @bun
3
- import{build as Ge}from"rolldown";import{dts as Xe}from"rolldown-plugin-dts";var ee=!1;function P(e){ee=e??!1}class C{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};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(e){if(!e?.once)return!0;if(this.loggedOnceMessages.has(e.once))return!1;return this.loggedOnceMessages.add(e.once),!0}formatMessage({colorCode:e,label:t,message:n,size:r,identifier:s,muted:o}){let i=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=o?`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`:n;if(r){let[c,...f]=a.split(" "),m=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),p=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${i}${c}${m} \x1B[38;5;${this.colors.size}m${r}\x1B[0m ${f.join(" ")}${p}`}let l=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${i}${a}${l}`}output(e,t={},n=console.log){if(ee)return;if(!this.shouldLog(t))return;if(t.verticalSpace)console.log("");if(n(e),t.verticalSpace)console.log("")}cli(e,t={}){let n=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:e,identifier:t.identifier,muted:t.muted});this.output(n,t)}info(e,t={}){let n=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:e,identifier:t.identifier,muted:t.muted});this.output(n,t)}warn(e,t={}){let n=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:e,identifier:t.identifier,muted:t.muted});this.output(n,t,console.warn)}error(e,t={}){let n=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:e,identifier:t.identifier,muted:t.muted});this.output(n,t,console.error)}progress(e,t,n,r){let s=String(e),o=this.colors.default,i,a,l={};if(typeof n==="string")i=n,a=r;else if(n)i=n.size,a=n.identifier,l=n;for(let[f,m]of Object.entries(this.colors.progress))if(s.includes(f)){o=m;break}let c=this.formatMessage({colorCode:o,label:s,message:t,size:i,identifier:a,muted:l.muted});this.output(c,l)}}var u=C.getInstance();class E extends Error{constructor(e){super(e);this.name="BunupError"}}class w extends E{constructor(e){super(e);this.name="BunupBuildError"}}class h extends E{constructor(e){super(e);this.name="BunupDTSBuildError"}}class d extends E{constructor(e){super(e);this.name="BunupCLIError"}}class L extends E{constructor(e){super(e);this.name="BunupWatchError"}}var b=(e)=>{if(e instanceof Error)return e.message;return String(e)},Fe=[{pattern:/Could not resolve: "bun"/i,errorType:"BUILD ERROR",logSolution:()=>{u.error("\x1B[0mYou're trying to build a project that uses Bun. Please set the target option to \x1B[36m`bun`\x1B[0m.\nExample: \x1B[32m`bunup --target bun`\x1B[0m or in config: \x1B[32m{ target: 'bun' }\x1B[0m")}}],q=(e,t)=>{let n=b(e),r=t?`[${t}] `:"",s="ERROR";if(e instanceof w)s="BUILD ERROR";else if(e instanceof h)s="DTS ERROR";else if(e instanceof d)s="CLI ERROR";else if(e instanceof L)s="WATCH ERROR";else if(e instanceof E)s="BUNUP ERROR";let o=Fe.find((i)=>i.pattern.test(n)&&(i.errorType===s||!i.errorType));if(!o)console.error(`\x1B[31m${s}\x1B[0m ${r}${n}`);if(o)console.log(`
4
- `),o.logSolution(n),console.log(`
5
- `);else console.error("\x1B[90mIf you think this is a bug, please open an issue at: \x1B[36mhttps://github.com/arshadyaseen/bunup/issues/new\x1B[0m")},te=(e,t)=>{q(e,t),process.exit(1)};import ne from"node:fs/promises";import We from"node:path";function V(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function re(e=8){let t="";while(t.length<e)t+=Math.random().toString(36).substring(2);return t.substring(0,e)}function se(e,t,n){return Array.isArray(e)?e.map((r)=>({...r,[t]:n})):{...e,[t]:n}}function ie(e){return Array.isArray(e)?e:[e]}function oe(e,t){switch(e){case"esm":return $(t)?".js":".mjs";case"cjs":return $(t)?".cjs":".js";case"iife":return".global.js"}}function ae(e,t){switch(e){case"esm":return $(t)?".d.ts":".d.mts";case"cjs":return $(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function G(e){return e==="node"||e==="bun"}function $(e){return e==="module"}function D(e){return e>=1000?`${(e/1000).toFixed(2)}s`:`${Math.round(e)}ms`}function le(e){if(!e)return[];return Array.from(new Set([...Object.keys(e.dependencies||{}),...Object.keys(e.peerDependencies||{})]))}function X(e){if(e===0)return"0 B";let t=["B","KB","MB","GB"],n=Math.floor(Math.log(e)/Math.log(1024));if(n===0)return`${e} ${t[n]}`;return`${(e/1024**n).toFixed(2)} ${t[n]}`}function x(e,t=3){return e.split("/").slice(-t).join("/")}async function ce(e,t){let n=We.join(e,t);try{await ne.rm(n,{recursive:!0,force:!0})}catch(r){throw new w(`Failed to clean output directory: ${r}`)}await ne.mkdir(n,{recursive:!0})}function A(e){return[".ts",".mts",".cts",".tsx"].some((t)=>e.endsWith(t))}function ue(e){return e.map((t)=>typeof t==="string"?new RegExp(`^${V(t)}($|\\/|\\\\)`):t)}function I(e,t){return ue(e.external||[]).concat(le(t).map((n)=>new RegExp(`^${V(n)}($|\\/|\\\\)`)))}function M(e){return ue(e.noExternal||[])}import qe from"node:path";import{ResolverFactory as Ve}from"oxc-resolver";import{resolveTypeScriptImportPath as He}from"ts-import-resolver";var O="\x00dts:",fe=(e,t,n)=>{return{name:"bunup:virtual-dts",async resolveId(r,s){if(Y(r))return r;if(!s||!Y(s))return null;let o=He({path:r,importer:R(s),tsconfig:t.tsconfig,rootDir:n});if(!o)return null;let i=T(o);if(e.has(i))return _(i);return null},load(r){if(r.startsWith(O)){let s=R(r),o=e.get(s);if(o)return S.add(s),o}return null}}};function T(e){if(e.endsWith(".d.ts")||e.endsWith(".d.mts")||e.endsWith(".d.cts"))return e;return e.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function Y(e){return e.startsWith(O)}function R(e){return e.replace(O,"")}function _(e){return`${O}${e}`}var pe;function me(e){return{name:"bunup:types-resolve",buildStart(){pe||=new Ve({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts",".d.cts",".d.mts",".cts",".mts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,n){let r=n?R(n):void 0;if(/\0/.test(t))return;if(e){if(!e.some((a)=>{let l=!1;if(typeof a==="string")l=a===t||!!r?.includes(a);else l=a.test(t)||!!(r&&a.test(r));return l}))return}let s=r?qe.dirname(r):process.cwd(),{path:o}=await pe.async(s,t);if(!o)return;if(/[cm]?jsx?$/.test(o)){let i=o.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(i).exists()?i:void 0}return o}}}async function de(e,t,n,r,s,o){let i=T(e),a=_(i),l=I(n,r),c=M(n);try{let{output:f}=await Ge({input:a,output:{dir:n.outDir,inlineDynamicImports:!0},write:!1,onwarn(m,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(m.code??""))return;p(m)},plugins:[fe(t,s,o),typeof n.dts==="object"&&"resolve"in n.dts&&me(typeof n.dts.resolve==="boolean"?void 0:n.dts.resolve),Xe({dtsInput:!0,emitDtsOnly:!0})],external:(m)=>l.some((p)=>p.test(m))&&!c.some((p)=>p.test(m))});if(!f[0]?.code)return u.warn(`Generated empty declaration file for entry "${e}"`,{muted:!0}),"";return f[0].code}catch(f){throw new h(`DTS bundling failed for entry "${e}": ${b(f)}`)}}import{resolveTypeScriptImportPath as Ye}from"ts-import-resolver";var Ke=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Je=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,ze=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Qe=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ze=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,et=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,tt=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function nt(e){let t=new Set,n=[Ke,Je,ze,Qe,Ze,et,tt];for(let r of n){let s=e.matchAll(r);for(let o of s)if(o[1])t.add(o[1])}return t}async function ge(e,t,n){let r=new Set([e]),s=[e];while(s.length){let o=s.pop();if(!o)continue;try{let i=await Bun.file(o).text(),a=nt(i);for(let l of a){let c=Ye({path:l,importer:o,tsconfig:t.tsconfig,rootDir:n});if(!c)continue;if(!r.has(c))r.add(c),s.push(c)}}catch(i){u.warn(`Error processing ${o}: ${b(i)}`)}}return r}import{isolatedDeclaration as rt}from"oxc-transform";async function he(e){let t=new Map;return await Promise.all([...e].map(async(n)=>{try{let r=T(n);if(!await Bun.file(n).exists())return;let o=await Bun.file(n).text(),{code:i}=rt(n,o);if(i)t.set(r,i)}catch(r){u.warn(`Failed to generate declaration for ${n}: ${b(r)}`)}})),t}import be from"node:fs/promises";import K from"node:path";import{isolatedDeclaration as st}from"oxc-transform";async function xe(e,t){let n=K.resolve(e),r=K.resolve(n,t);if(!await be.exists(n))throw new h(`Root directory does not exist: ${n}`);if(!await Bun.file(r).exists())throw new h(`Entry file does not exist: ${r}`);if(!A(r))throw new h(`Entry file must be a TypeScript file: ${r}`);if(K.relative(n,r).startsWith(".."))throw new h(`Entry file must be within rootDir: ${r}`);return{absoluteRootDir:n,absoluteEntry:r}}async function ye(e){let t=!1;if(await Promise.all([...e].map(async(n)=>{try{let r=n.replace(/\.d\.ts$/,".ts"),s=await Bun.file(r).text(),{errors:o}=st(r,s);for(let i of o){if(!t)console.log(`
6
- `);let a=i.labels[0],l=a?it(s,a.start):"",f=`${x(r)}${l}: ${ot(i.message)}`;u.warn(f),t=!0}}catch{}})),t)u.info(`
3
+ import{build as Ge}from"rolldown";import{dts as Xe}from"rolldown-plugin-dts";var ee=!1;function B(e){ee=e??!1}class C{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};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(e){if(!e?.once)return!0;if(this.loggedOnceMessages.has(e.once))return!1;return this.loggedOnceMessages.add(e.once),!0}formatMessage({colorCode:e,label:t,message:r,size:n,identifier:s,muted:o}){let i=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=o?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(n){let[l,...f]=a.split(" "),m=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-l.length)),p=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${i}${l}${m} \x1B[38;5;${this.colors.size}m${n}\x1B[0m ${f.join(" ")}${p}`}let c=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${i}${a}${c}`}output(e,t={},r=console.log){if(ee)return;if(!this.shouldLog(t))return;if(t.verticalSpace)console.log("");if(r(e),t.verticalSpace)console.log("")}cli(e,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}info(e,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}warn(e,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)}error(e,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)}progress(e,t,r,n){let s=String(e),o=this.colors.default,i,a,c={};if(typeof r==="string")i=r,a=n;else if(r)i=r.size,a=r.identifier,c=r;for(let[f,m]of Object.entries(this.colors.progress))if(s.includes(f)){o=m;break}let l=this.formatMessage({colorCode:o,label:s,message:t,size:i,identifier:a,muted:c.muted});this.output(l,c)}}var u=C.getInstance();class E extends Error{constructor(e){super(e);this.name="BunupError"}}class w extends E{constructor(e){super(e);this.name="BunupBuildError"}}class h extends E{constructor(e){super(e);this.name="BunupDTSBuildError"}}class d extends E{constructor(e){super(e);this.name="BunupCLIError"}}class v extends E{constructor(e){super(e);this.name="BunupWatchError"}}var b=(e)=>{if(e instanceof Error)return e.message;return String(e)},Fe=[{pattern:/Could not resolve: "bun"/i,errorType:"BUILD ERROR",logSolution:()=>{u.error("\x1B[0mYou're trying to build a project that uses Bun. Please set the target option to \x1B[36m`bun`\x1B[0m.\nExample: \x1B[32m`bunup --target bun`\x1B[0m or in config: \x1B[32m{ target: 'bun' }\x1B[0m")}}],q=(e,t)=>{let r=b(e),n=t?`[${t}] `:"",s="ERROR";if(e instanceof w)s="BUILD ERROR";else if(e instanceof h)s="DTS ERROR";else if(e instanceof d)s="CLI ERROR";else if(e instanceof v)s="WATCH ERROR";else if(e instanceof E)s="BUNUP ERROR";let o=Fe.find((i)=>i.pattern.test(r)&&(i.errorType===s||!i.errorType));if(!o)console.error(`\x1B[31m${s}\x1B[0m ${n}${r}`);if(o)console.log(`
4
+ `),o.logSolution(r),console.log(`
5
+ `);else console.error("\x1B[90mIf you think this is a bug, please open an issue at: \x1B[36mhttps://github.com/arshad-yaseen/bunup/issues/new\x1B[0m")},te=(e,t)=>{q(e,t),process.exit(1)};import re from"node:fs/promises";import We from"node:path";function V(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ne(e=8){let t="";while(t.length<e)t+=Math.random().toString(36).substring(2);return t.substring(0,e)}function se(e,t,r){return Array.isArray(e)?e.map((n)=>({...n,[t]:r})):{...e,[t]:r}}function ie(e){return Array.isArray(e)?e:[e]}function oe(e,t){switch(e){case"esm":return R(t)?".js":".mjs";case"cjs":return R(t)?".cjs":".js";case"iife":return".global.js"}}function ae(e,t){switch(e){case"esm":return R(t)?".d.ts":".d.mts";case"cjs":return R(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function G(e){return e==="node"||e==="bun"}function R(e){return e==="module"}function L(e){return e>=1000?`${(e/1000).toFixed(2)}s`:`${Math.round(e)}ms`}function le(e){if(!e)return[];return Array.from(new Set([...Object.keys(e.dependencies||{}),...Object.keys(e.peerDependencies||{})]))}function X(e){if(e===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));if(r===0)return`${e} ${t[r]}`;return`${(e/1024**r).toFixed(2)} ${t[r]}`}function y(e,t=3){return e.split("/").slice(-t).join("/")}async function ce(e,t){let r=We.join(e,t);try{await re.rm(r,{recursive:!0,force:!0})}catch(n){throw new w(`Failed to clean output directory: ${n}`)}await re.mkdir(r,{recursive:!0})}function I(e){return[".ts",".mts",".cts",".tsx"].some((t)=>e.endsWith(t))}function ue(e){return e.map((t)=>typeof t==="string"?new RegExp(`^${V(t)}($|\\/|\\\\)`):t)}function D(e,t){return ue(e.external||[]).concat(le(t).map((r)=>new RegExp(`^${V(r)}($|\\/|\\\\)`)))}function A(e){return ue(e.noExternal||[])}import qe from"node:path";import{ResolverFactory as Ve}from"oxc-resolver";import{resolveTypeScriptImportPath as He}from"ts-import-resolver";var O="\x00dts:",fe=(e,t,r)=>{return{name:"bunup:virtual-dts",async resolveId(n,s){if(Y(n))return n;if(!s||!Y(s))return null;let o=He({path:n,importer:T(s),tsconfig:t.tsconfig,rootDir:r});if(!o)return null;let i=$(o);if(e.has(i))return _(i);return null},load(n){if(n.startsWith(O)){let s=T(n),o=e.get(s);if(o)return S.add(s),o}return null}}};function $(e){if(e.endsWith(".d.ts")||e.endsWith(".d.mts")||e.endsWith(".d.cts"))return e;return e.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function Y(e){return e.startsWith(O)}function T(e){return e.replace(O,"")}function _(e){return`${O}${e}`}var pe;function me(e){return{name:"bunup:types-resolve",buildStart(){pe||=new Ve({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(t==="bun")return;let n=r?T(r):void 0;if(/\0/.test(t))return;if(e){if(!e.some((a)=>typeof a==="string"?a===t:a.test(t)))return}let s=n?qe.dirname(n):process.cwd(),{path:o}=await pe.async(s,t);return o}}}async function de(e,t,r,n,s,o){let i=$(e),a=_(i),c=D(r,n),l=A(r);try{let{output:f}=await Ge({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(m,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(m.code??""))return;p(m)},plugins:[fe(t,s,o),typeof r.dts==="object"&&"resolve"in r.dts&&me(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),Xe({dtsInput:!0,emitDtsOnly:!0})],external:(m)=>c.some((p)=>p.test(m))&&!l.some((p)=>p.test(m))});if(!f[0]?.code)return u.warn(`Generated empty declaration file for entry "${e}"`,{muted:!0}),"";return f[0].code}catch(f){throw new h(`DTS bundling failed for entry "${e}": ${b(f)}`)}}import{resolveTypeScriptImportPath as Ye}from"ts-import-resolver";var Ke=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Je=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,ze=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Qe=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ze=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,et=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,tt=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function rt(e){let t=new Set,r=[Ke,Je,ze,Qe,Ze,et,tt];for(let n of r){let s=e.matchAll(n);for(let o of s)if(o[1])t.add(o[1])}return t}async function ge(e,t,r){let n=new Set([e]),s=[e];while(s.length){let o=s.pop();if(!o)continue;try{let i=await Bun.file(o).text(),a=rt(i);for(let c of a){let l=Ye({path:c,importer:o,tsconfig:t.tsconfig,rootDir:r});if(!l)continue;if(!n.has(l))n.add(l),s.push(l)}}catch(i){u.warn(`Error processing ${o}: ${b(i)}`)}}return n}import{isolatedDeclaration as nt}from"oxc-transform";async function he(e){let t=new Map;return await Promise.all([...e].map(async(r)=>{try{let n=$(r);if(!await Bun.file(r).exists())return;let o=await Bun.file(r).text(),{code:i}=nt(r,o);if(i)t.set(n,i)}catch(n){u.warn(`Failed to generate declaration for ${r}: ${b(n)}`)}})),t}import be from"node:fs/promises";import K from"node:path";import{isolatedDeclaration as st}from"oxc-transform";async function ye(e,t){let r=K.resolve(e),n=K.resolve(r,t);if(!await be.exists(r))throw new h(`Root directory does not exist: ${r}`);if(!await Bun.file(n).exists())throw new h(`Entry file does not exist: ${n}`);if(!I(n))throw new h(`Entry file must be a TypeScript file: ${n}`);if(K.relative(r,n).startsWith(".."))throw new h(`Entry file must be within rootDir: ${n}`);return{absoluteRootDir:r,absoluteEntry:n}}async function xe(e){let t=!1;if(await Promise.all([...e].map(async(r)=>{try{let n=r.replace(/\.d\.ts$/,".ts"),s=await Bun.file(n).text(),{errors:o}=st(n,s);for(let i of o){if(!t)console.log(`
6
+ `);let a=i.labels[0],c=a?it(s,a.start):"",f=`${y(n)}${c}: ${ot(i.message)}`;u.warn(f),t=!0}}catch{}})),t)u.info(`
7
7
  You may have noticed some TypeScript warnings above related to missing type annotations. This is because Bunup uses TypeScript's "isolatedDeclarations" approach for generating declaration files. This modern approach requires explicit type annotations on exports for better, more accurate type declarations. Other bundlers might not show these warnings because they use different, potentially less precise methods. Adding the suggested type annotations will not only silence these warnings but also improve the quality of your published type definitions, making your library more reliable for consumers.
8
- `)}function it(e,t){if(t===void 0)return"";let n=e.slice(0,t).split(`
9
- `),r=n.length,s=n[n.length-1].length+1;return` (${r}:${s})`}function ot(e){return e.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function we(e,t,n,r,s){let{absoluteEntry:o}=await xe(e,t),i=await ge(o,r,e),a=await he(i);return de(o,a,n,s,r,e)}function j(e){return e.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function B(e,{warnOnConflict:t=!0}={}){let n=[],r=new Set,s={};function o(i,a){if(r.has(i)){let l=re(),c=`${i}_${l}`;if(t)u.warn(`Output name conflict: "${i}" is used by multiple files.
8
+ `)}function it(e,t){if(t===void 0)return"";let r=e.slice(0,t).split(`
9
+ `),n=r.length,s=r[r.length-1].length+1;return` (${n}:${s})`}function ot(e){return e.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function we(e,t,r,n,s){let{absoluteEntry:o}=await ye(e,t),i=await ge(o,n,e),a=await he(i);return de(o,a,r,s,n,e)}function M(e){return e.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function P(e,{warnOnConflict:t=!0}={}){let r=[],n=new Set,s={};function o(i,a){if(n.has(i)){let c=ne(),l=`${i}_${c}`;if(t)u.warn(`Output name conflict: "${i}" is used by multiple files.
10
10
  Bunup uses filenames without extensions as output names by default.
11
11
 
12
12
  ${s[i]} -> ${i}.js
13
- ${a} -> ${c}.js (auto-renamed to avoid conflict)
13
+ ${a} -> ${l}.js (auto-renamed to avoid conflict)
14
14
 
15
15
  To fix this, use named entries in your configuration:
16
16
  {
@@ -20,7 +20,7 @@ To fix this, use named entries in your configuration:
20
20
  }
21
21
  }
22
22
 
23
- See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});n.push({name:c,path:a})}else n.push({name:i,path:a}),r.add(i),s[i]=a}if(Array.isArray(e))for(let i of e){let a=j(i);o(a,i)}else if(typeof e==="object")for(let[i,a]of Object.entries(e))o(i,a);else{let i=j(e);o(i,e)}return n}function Ce(e){return e.filter((t)=>A(t.path))}function Ee(e,t){return`[dir]/${e}${t}`}import{loadConfig as $e}from"coffi";async function Te(e,t){return Array.isArray(e)&&"root"in e[0]?e.map((n)=>({rootDir:n.root,options:se(n.config,"name",n.name)})):[{rootDir:t,options:e}]}async function Se(e){let{config:t,filepath:n}=await $e({name:"package",cwd:e,extensions:[".json"],maxDepth:1});return{packageJson:t,path:n}}async function Re(e,t){let{config:n,filepath:r}=await $e({name:"tsconfig",cwd:e,extensions:[".json"],preferredPath:t,maxDepth:3});return{tsconfig:n,path:r}}var at={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function v(e){return{...at,...e}}function Oe(e){let{minify:t,minifyWhitespace:n,minifyIdentifiers:r,minifySyntax:s}=e,o=t===!0;return{whitespace:n??o,identifiers:r??o,syntax:s??o}}function Be(e,t){return t==="cjs"?e:void 0}function Pe(e,t,n,r){return{...typeof n==="object"&&Object.keys(n).reduce((s,o)=>{let i=JSON.stringify(n[o]);return s[`process.env.${o}`]=i,s[`import.meta.env.${o}`]=i,s},{}),...e,...r==="cjs"&&(t===!0||typeof t==="object"&&t.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Le(e,t){return e===void 0?t==="esm":e}function De(e){return typeof e==="string"?e:void 0}function Ae(e,t){return{name:"bunup:external-plugin",setup(n){n.onResolve({filter:/.*/},(r)=>{let s=r.path;if(e.some((i)=>i.test(s))&&!t.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var lt=/\.(js|ts|jsx|tsx|mts|cts)$/,J={dirnameFilename:{appliesTo:(e,t)=>e==="esm"&&G(t),isNeededInFile:(e)=>/\b__dirname\b/.test(e)||/\b__filename\b/.test(e),generateCode:()=>`import { fileURLToPath } from 'url';
23
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});r.push({name:l,path:a})}else r.push({name:i,path:a}),n.add(i),s[i]=a}if(Array.isArray(e))for(let i of e){let a=M(i);o(a,i)}else if(typeof e==="object")for(let[i,a]of Object.entries(e))o(i,a);else{let i=M(e);o(i,e)}return r}function Ce(e){return e.filter((t)=>I(t.path))}function Ee(e,t){return`[dir]/${e}${t}`}import{loadConfig as Re}from"coffi";async function $e(e,t){return Array.isArray(e)&&"root"in e[0]?e.map((r)=>({rootDir:r.root,options:se(r.config,"name",r.name)})):[{rootDir:t,options:e}]}async function Se(e){let{config:t,filepath:r}=await Re({name:"package",cwd:e,extensions:[".json"],maxDepth:1});return{packageJson:t,path:r}}async function Te(e,t){let{config:r,filepath:n}=await Re({name:"tsconfig",cwd:e,extensions:[".json"],preferredPath:t,maxDepth:3});return{tsconfig:r,path:n}}var at={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function j(e){return{...at,...e}}function Oe(e){let{minify:t,minifyWhitespace:r,minifyIdentifiers:n,minifySyntax:s}=e,o=t===!0;return{whitespace:r??o,identifiers:n??o,syntax:s??o}}function Pe(e,t){return t==="cjs"?e:void 0}function Be(e,t,r,n){return{...typeof r==="object"&&Object.keys(r).reduce((s,o)=>{let i=JSON.stringify(r[o]);return s[`process.env.${o}`]=i,s[`import.meta.env.${o}`]=i,s},{}),...e,...n==="cjs"&&(t===!0||typeof t==="object"&&t.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function ve(e,t){return e===void 0?t==="esm":e}function Le(e){return typeof e==="string"?e:void 0}function Ie(e,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(n)=>{let s=n.path;if(e.some((i)=>i.test(s))&&!t.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var lt=/\.(js|ts|jsx|tsx|mts|cts)$/,J={dirnameFilename:{appliesTo:(e,t)=>e==="esm"&&G(t),isNeededInFile:(e)=>/\b__dirname\b/.test(e)||/\b__filename\b/.test(e),generateCode:()=>`import { fileURLToPath } from 'url';
24
24
  import { dirname } from 'path';
25
25
 
26
26
  const __filename = fileURLToPath(import.meta.url);
@@ -30,9 +30,9 @@ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0})
30
30
 
31
31
  const importMetaUrl = pathToFileURL(__filename).href;
32
32
 
33
- `}};function Ie({format:e,target:t,shims:n}){let s=ct(n).map((o)=>J[o]).filter((o)=>o.appliesTo(e,t));if(s.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:lt},async({path:i})=>{let a=await Bun.file(i).text(),l=s.filter((p)=>p.isNeededInFile(a));if(l.length===0)return;let{shebangLine:c,codeContent:f}=ut(a),m=l.map((p)=>p.generateCode()).join("");return{contents:c+m+f}})}}}function ct(e){if(e===!0)return Object.keys(J);if(!e)return[];return Object.entries(e).filter(([t,n])=>n&&(t in J)).map(([t])=>t)}function ut(e){if(!e.startsWith("#!"))return{shebangLine:"",codeContent:e};let t=e.indexOf(`
34
- `);return t===-1?{shebangLine:"",codeContent:e}:{shebangLine:e.slice(0,t+1),codeContent:e.slice(t+1)}}var S=new Set;async function k(e,t){let n=v(e);if(!n.entry||n.entry.length===0||!n.outDir)throw new w("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(n.clean)ce(t,n.outDir);P(n.silent);let{packageJson:r,path:s}=await Se(t);if(r&&s)u.cli(`Using package.json: ${x(s,2)}`,{muted:!0,identifier:n.name,once:`${s}:${n.name}`});let o=B(n.entry),i=r?.type,a=I(n,r),l=M(n);if(!n.dtsOnly){let c=[Ae(a,l)],f=n.format.flatMap((m)=>o.map((p)=>{return ft(n,t,p,m,i,c)}));await Promise.all(f)}if(n.dts||n.dtsOnly){let c=await Re(t,n.preferredTsconfigPath);if(c.path)u.cli(`Using tsconfig: ${x(c.path,2)}`,{muted:!0,identifier:n.name,once:`${c.path}:${n.name}`});let f=n.format.filter((p)=>{if(p==="iife"&&!$(i)&&n.format.includes("cjs"))return!1;return!0}),m=typeof n.dts==="object"&&n.dts.entry?B(n.dts.entry):Ce(o);try{await Promise.all(m.map(async(p)=>{let W=await we(t,p.path,n,c,r);await Promise.all(f.map(async(Z)=>{let Ne=n.outputExtension?.({format:Z,packageType:i,options:n,entry:p}).dts??ae(Z,i),H=`${t}/${n.outDir}/${p.name}${Ne}`;await Bun.write(H,W);let Ue=Bun.file(H).size||0;u.progress("DTS",x(H),X(Ue),n.name)}))}))}catch(p){throw new h(b(p))}}}async function ft(e,t,n,r,s,o){let i=e.outputExtension?.({format:r,packageType:s,options:e,entry:n}).js??oe(r,s),a=await Bun.build({entrypoints:[`${t}/${n.path}`],format:r,naming:{entry:Ee(n.name,i)},splitting:Le(e.splitting,r),bytecode:Be(e.bytecode,r),define:Pe(e.define,e.shims,e.env,r),minify:Oe(e),outdir:`${t}/${e.outDir}`,target:e.target,sourcemap:e.sourcemap,loader:e.loader,drop:e.drop,banner:e.banner,footer:e.footer,publicPath:e.publicPath,env:De(e.env),plugins:[...o,Ie({format:r,target:e.target,shims:e.shims}),...e.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let f of a.logs){if(f.level==="error")throw new w(f.message);if(f.level==="warning")u.warn(f.message);else if(f.level==="info")u.info(f.message)}let l=`${t}/${e.outDir}/${n.name}${i}`,c=Bun.file(l).size||0;u.progress(r.toUpperCase(),x(l),X(c),e.name)}var N="0.4.19";var Me="https://bun.sh/docs/installation",_e="https://bunup.arshadyaseen.com/#cli-options";function g(e){return(t,n)=>{n[e]=t===!0||t==="true"}}function y(e){return(t,n)=>{if(typeof t==="string")n[e]=t;else throw new d(`Option --${e} requires a string value`)}}function z(e){return(t,n)=>{if(typeof t==="string")n[e]=t.split(",");else throw new d(`Option --${e} requires a string value`)}}function mt(e){return(t,n)=>{if(typeof t==="boolean")n[e]=t;else if(typeof t==="string")if(t.toLowerCase()==="true"||t.toLowerCase()==="false")n[e]=t.toLowerCase()==="true";else n[e]=t;else throw new d(`Option --${e} requires a boolean or string value`)}}function dt(){console.log(`
33
+ `}};function De({format:e,target:t,shims:r}){let s=ct(r).map((o)=>J[o]).filter((o)=>o.appliesTo(e,t));if(s.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:lt},async({path:i})=>{let a=await Bun.file(i).text(),c=s.filter((p)=>p.isNeededInFile(a));if(c.length===0)return;let{shebangLine:l,codeContent:f}=ut(a),m=c.map((p)=>p.generateCode()).join("");return{contents:l+m+f}})}}}function ct(e){if(e===!0)return Object.keys(J);if(!e)return[];return Object.entries(e).filter(([t,r])=>r&&(t in J)).map(([t])=>t)}function ut(e){if(!e.startsWith("#!"))return{shebangLine:"",codeContent:e};let t=e.indexOf(`
34
+ `);return t===-1?{shebangLine:"",codeContent:e}:{shebangLine:e.slice(0,t+1),codeContent:e.slice(t+1)}}var S=new Set;async function k(e,t){let r=j(e);if(!r.entry||r.entry.length===0||!r.outDir)throw new w("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)ce(t,r.outDir);B(r.silent);let{packageJson:n,path:s}=await Se(t);if(n&&s)u.cli(`Using package.json: ${y(s,2)}`,{muted:!0,identifier:r.name,once:`${s}:${r.name}`});let o=P(r.entry),i=n?.type,a=D(r,n),c=A(r);if(!r.dtsOnly){let l=[Ie(a,c)],f=r.format.flatMap((m)=>o.map((p)=>{return ft(r,t,p,m,i,l)}));await Promise.all(f)}if(r.dts||r.dtsOnly){let l=await Te(t,r.preferredTsconfigPath);if(l.path)u.cli(`Using tsconfig: ${y(l.path,2)}`,{muted:!0,identifier:r.name,once:`${l.path}:${r.name}`});let f=r.format.filter((p)=>{if(p==="iife"&&!R(i)&&r.format.includes("cjs"))return!1;return!0}),m=typeof r.dts==="object"&&r.dts.entry?P(r.dts.entry):Ce(o);try{await Promise.all(m.map(async(p)=>{let W=await we(t,p.path,r,l,n);await Promise.all(f.map(async(Z)=>{let Ne=r.outputExtension?.({format:Z,packageType:i,options:r,entry:p}).dts??ae(Z,i),H=`${t}/${r.outDir}/${p.name}${Ne}`;await Bun.write(H,W);let Ue=Bun.file(H).size||0;u.progress("DTS",y(H),X(Ue),r.name)}))}))}catch(p){throw new h(b(p))}}}async function ft(e,t,r,n,s,o){let i=e.outputExtension?.({format:n,packageType:s,options:e,entry:r}).js??oe(n,s),a=await Bun.build({entrypoints:[`${t}/${r.path}`],format:n,naming:{entry:Ee(r.name,i)},splitting:ve(e.splitting,n),bytecode:Pe(e.bytecode,n),define:Be(e.define,e.shims,e.env,n),minify:Oe(e),outdir:`${t}/${e.outDir}`,target:e.target,sourcemap:e.sourcemap,loader:e.loader,drop:e.drop,banner:e.banner,footer:e.footer,publicPath:e.publicPath,env:Le(e.env),plugins:[...o,De({format:n,target:e.target,shims:e.shims}),...e.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let f of a.logs){if(f.level==="error")throw new w(f.message);if(f.level==="warning")u.warn(f.message);else if(f.level==="info")u.info(f.message)}let c=`${t}/${e.outDir}/${r.name}${i}`,l=Bun.file(c).size||0;u.progress(n.toUpperCase(),y(c),X(l),e.name)}var N="0.4.20";var Ae="https://bun.sh/docs/installation",_e="https://bunup.arshadyaseen.com/#cli-options";function g(e){return(t,r)=>{r[e]=t===!0||t==="true"}}function x(e){return(t,r)=>{if(typeof t==="string")r[e]=t;else throw new d(`Option --${e} requires a string value`)}}function z(e){return(t,r)=>{if(typeof t==="string")r[e]=t.split(",");else throw new d(`Option --${e} requires a string value`)}}function mt(e){return(t,r)=>{if(typeof t==="boolean")r[e]=t;else if(typeof t==="string")if(t.toLowerCase()==="true"||t.toLowerCase()==="false")r[e]=t.toLowerCase()==="true";else r[e]=t;else throw new d(`Option --${e} requires a boolean or string value`)}}function dt(){console.log(`
35
35
  Bunup - An extremely fast, zero-config bundler for JavaScript and TypeScript, powered by Bun.
36
36
  `),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${_e}\x1B[0m
37
- `),process.exit(0)}function gt(){console.log(N),process.exit(0)}var je={name:{flags:["n","name"],handler:y("name")},format:{flags:["f","format"],handler:z("format")},outDir:{flags:["o","out-dir"],handler:y("outDir")},minify:{flags:["m","minify"],handler:g("minify")},watch:{flags:["w","watch"],handler:g("watch")},dts:{flags:["d","dts"],handler:g("dts")},banner:{flags:["bn","banner"],handler:y("banner")},footer:{flags:["ft","footer"],handler:y("footer")},external:{flags:["e","external"],handler:z("external")},sourcemap:{flags:["sm","sourcemap"],handler:mt("sourcemap")},target:{flags:["t","target"],handler:y("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:g("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:g("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:g("minifySyntax")},clean:{flags:["c","clean"],handler:g("clean")},splitting:{flags:["s","splitting"],handler:g("splitting")},noExternal:{flags:["ne","no-external"],handler:z("noExternal")},preferredTsconfigPath:{flags:["tsconfig","preferred-tsconfig-path"],handler:y("preferredTsconfigPath")},bytecode:{flags:["bc","bytecode"],handler:g("bytecode")},dtsOnly:{flags:["do","dts-only"],handler:g("dtsOnly")},silent:{flags:["silent"],handler:g("silent")},config:{flags:["config"],handler:y("config")},publicPath:{flags:["pp","public-path"],handler:y("publicPath")},env:{flags:["env"],handler:y("env")},shims:{flags:["shims"],handler:g("shims")},entry:{flags:["entry"],handler:(e,t,n)=>{if(typeof e!=="string")throw new d(`Entry${n?` --entry.${n}`:""} requires a string value`);let r=t.entry||{};if(n){if(r[n])u.warn(`Duplicate entry name '${n}' provided via --entry.${n}. Overwriting previous entry.`);r[n]=e}else{let s=j(e);if(r[s])u.warn(`Duplicate entry name '${s}' derived from '${e}'. Overwriting previous entry.`);r[s]=e}t.entry=r}},resolveDts:{flags:["rd","resolve-dts"],handler:(e,t)=>{if(!t.dts)t.dts={};if(typeof t.dts==="boolean")t.dts={};if(typeof e==="string")if(e==="true"||e==="false")t.dts.resolve=e==="true";else t.dts.resolve=e.split(",");else t.dts.resolve=!0}},help:{flags:["h","help"],handler:()=>dt()},version:{flags:["v","version"],handler:()=>gt()}},U={};for(let e of Object.values(je))for(let t of e.flags)U[t]=e.handler;function ve(e){let t={};for(let n=0;n<e.length;n++){let r=e[n];if(r.startsWith("--")){let s,o;if(r.includes("=")){let[i,a]=r.slice(2).split("=",2);s=i,o=a}else{s=r.slice(2);let i=e[n+1];if(o=i&&!i.startsWith("-")?i:!0,typeof o==="string")n++}if(s.includes(".")){let[i,a]=s.split(".",2),l=U[i];if(l)l(o,t,a);else throw new d(`Unknown option: --${s}`)}else{let i=U[s];if(i)i(o,t);else throw new d(`Unknown option: --${s}`)}}else if(r.startsWith("-")){let s=r.slice(1),o=e[n+1],i=o&&!o.startsWith("-")?o:!0;if(typeof i==="string")n++;let a=U[s];if(a)a(i,t);else throw new d(`Unknown option: -${s}`)}else je.entry.handler(r,t,void 0)}return t}(()=>{if(typeof Bun==="undefined")throw new d(`Bunup requires Bun to run.
38
- To install Bun, visit ${Me}`)})();import{loadConfig as bt}from"coffi";import F from"node:path";import ht from"chokidar";async function ke(e,t){let n=new Set,r=v(e),s=B(r.entry);for(let l of s){let c=F.resolve(t,l.path),f=F.dirname(c);n.add(f)}let o=ht.watch(Array.from(n),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,F.join(t,r.outDir)]}),i=!1,a=async(l=!1)=>{if(i)return;i=!0;try{let c=performance.now();if(await k({...r,entry:s.map((f)=>f.path),clean:!1},t),r.onBuildSuccess?.(),!l)u.cli(`\uD83D\uDCE6 Rebuild finished in ${D(performance.now()-c)}`);await Q()}catch(c){q(c)}finally{i=!1}};o.on("change",(l)=>{let c=F.relative(t,l);u.cli(`File changed: ${c}`,{muted:!0,once:c}),a()}),o.on("error",(l)=>{throw new L(`Watcher error: ${b(l)}`)}),await a(!0)}async function xt(e=Bun.argv.slice(2)){let t=ve(e);P(t.silent);let n=process.cwd(),{config:r,filepath:s}=await bt({name:"bunup.config",extensions:[".ts",".js",".mjs",".cjs"],maxDepth:1,preferredPath:t.config}),o=!r?[{rootDir:n,options:t}]:await Te(r,n);if(u.cli(`Using bunup v${N} and bun v${Bun.version}`,{muted:!0}),s)u.cli(`Using config file: ${x(s,2)}`,{muted:!0});let i=performance.now();u.cli("Build started"),await Promise.all(o.flatMap(({options:c,rootDir:f})=>{return ie(c).map(async(p)=>{let W={...p,...t};return yt(W,f)})}));let a=performance.now()-i,l=D(a);if(u.cli(`\u26A1\uFE0F Build completed in ${l}`),await Q(),t.watch)u.cli("\uD83D\uDC40 Watching for file changes");if(!t.watch)process.exit(0)}async function Q(){if(S.size>0)await ye(S),S.clear()}async function yt(e,t){if(e.watch)await ke(e,t);else await k(e,t),e.onBuildSuccess?.()}xt().catch((e)=>te(e));export{Q as validateDtsFiles,xt as main};
37
+ `),process.exit(0)}function gt(){console.log(N),process.exit(0)}var Me={name:{flags:["n","name"],handler:x("name")},format:{flags:["f","format"],handler:z("format")},outDir:{flags:["o","out-dir"],handler:x("outDir")},minify:{flags:["m","minify"],handler:g("minify")},watch:{flags:["w","watch"],handler:g("watch")},dts:{flags:["d","dts"],handler:g("dts")},banner:{flags:["bn","banner"],handler:x("banner")},footer:{flags:["ft","footer"],handler:x("footer")},external:{flags:["e","external"],handler:z("external")},sourcemap:{flags:["sm","sourcemap"],handler:mt("sourcemap")},target:{flags:["t","target"],handler:x("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:g("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:g("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:g("minifySyntax")},clean:{flags:["c","clean"],handler:g("clean")},splitting:{flags:["s","splitting"],handler:g("splitting")},noExternal:{flags:["ne","no-external"],handler:z("noExternal")},preferredTsconfigPath:{flags:["tsconfig","preferred-tsconfig-path"],handler:x("preferredTsconfigPath")},bytecode:{flags:["bc","bytecode"],handler:g("bytecode")},dtsOnly:{flags:["do","dts-only"],handler:g("dtsOnly")},silent:{flags:["silent"],handler:g("silent")},config:{flags:["config"],handler:x("config")},publicPath:{flags:["pp","public-path"],handler:x("publicPath")},env:{flags:["env"],handler:x("env")},shims:{flags:["shims"],handler:g("shims")},entry:{flags:["entry"],handler:(e,t,r)=>{if(typeof e!=="string")throw new d(`Entry${r?` --entry.${r}`:""} requires a string value`);let n=t.entry||{};if(r){if(n[r])u.warn(`Duplicate entry name '${r}' provided via --entry.${r}. Overwriting previous entry.`);n[r]=e}else{let s=M(e);if(n[s])u.warn(`Duplicate entry name '${s}' derived from '${e}'. Overwriting previous entry.`);n[s]=e}t.entry=n}},resolveDts:{flags:["rd","resolve-dts"],handler:(e,t)=>{if(!t.dts)t.dts={};if(typeof t.dts==="boolean")t.dts={};if(typeof e==="string")if(e==="true"||e==="false")t.dts.resolve=e==="true";else t.dts.resolve=e.split(",");else t.dts.resolve=!0}},help:{flags:["h","help"],handler:()=>dt()},version:{flags:["v","version"],handler:()=>gt()}},U={};for(let e of Object.values(Me))for(let t of e.flags)U[t]=e.handler;function je(e){let t={};for(let r=0;r<e.length;r++){let n=e[r];if(n.startsWith("--")){let s,o;if(n.includes("=")){let[i,a]=n.slice(2).split("=",2);s=i,o=a}else{s=n.slice(2);let i=e[r+1];if(o=i&&!i.startsWith("-")?i:!0,typeof o==="string")r++}if(s.includes(".")){let[i,a]=s.split(".",2),c=U[i];if(c)c(o,t,a);else throw new d(`Unknown option: --${s}`)}else{let i=U[s];if(i)i(o,t);else throw new d(`Unknown option: --${s}`)}}else if(n.startsWith("-")){let s=n.slice(1),o=e[r+1],i=o&&!o.startsWith("-")?o:!0;if(typeof i==="string")r++;let a=U[s];if(a)a(i,t);else throw new d(`Unknown option: -${s}`)}else Me.entry.handler(n,t,void 0)}return t}(()=>{if(typeof Bun==="undefined")throw new d(`Bunup requires Bun to run.
38
+ To install Bun, visit ${Ae}`)})();import{loadConfig as bt}from"coffi";import F from"node:path";import ht from"chokidar";async function ke(e,t){let r=new Set,n=j(e),s=P(n.entry);for(let c of s){let l=F.resolve(t,c.path),f=F.dirname(l);r.add(f)}let o=ht.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,F.join(t,n.outDir)]}),i=!1,a=async(c=!1)=>{if(i)return;i=!0;try{let l=performance.now();if(await k({...n,entry:s.map((f)=>f.path),clean:!1},t),n.onBuildSuccess?.(),!c)u.cli(`\uD83D\uDCE6 Rebuild finished in ${L(performance.now()-l)}`);await Q()}catch(l){q(l)}finally{i=!1}};o.on("change",(c)=>{let l=F.relative(t,c);u.cli(`File changed: ${l}`,{muted:!0,once:l}),a()}),o.on("error",(c)=>{throw new v(`Watcher error: ${b(c)}`)}),await a(!0)}async function yt(e=Bun.argv.slice(2)){let t=je(e);B(t.silent);let r=process.cwd(),{config:n,filepath:s}=await bt({name:"bunup.config",extensions:[".ts",".js",".mjs",".cjs"],maxDepth:1,preferredPath:t.config}),o=!n?[{rootDir:r,options:t}]:await $e(n,r);if(u.cli(`Using bunup v${N} and bun v${Bun.version}`,{muted:!0}),s)u.cli(`Using config file: ${y(s,2)}`,{muted:!0});let i=performance.now();u.cli("Build started"),await Promise.all(o.flatMap(({options:l,rootDir:f})=>{return ie(l).map(async(p)=>{let W={...p,...t};return xt(W,f)})}));let a=performance.now()-i,c=L(a);if(u.cli(`\u26A1\uFE0F Build completed in ${c}`),await Q(),t.watch)u.cli("\uD83D\uDC40 Watching for file changes");if(!t.watch)process.exit(0)}async function Q(){if(S.size>0)await xe(S),S.clear()}async function xt(e,t){if(e.watch)await ke(e,t);else await k(e,t),e.onBuildSuccess?.()}yt().catch((e)=>te(e));export{Q as validateDtsFiles,yt as main};
package/build/index.js CHANGED
@@ -1,26 +1,26 @@
1
- var Ut=require("node:module");var _t=Object.create;var{getPrototypeOf:jt,defineProperty:w,getOwnPropertyNames:G,getOwnPropertyDescriptor:Nt}=Object,q=Object.prototype.hasOwnProperty;var R=(t,e,r)=>{r=t!=null?_t(jt(t)):{};let n=e||!t||!t.__esModule?w(r,"default",{value:t,enumerable:!0}):r;for(let i of G(t))if(!q.call(n,i))w(n,i,{get:()=>t[i],enumerable:!0});return n},V=new WeakMap,Ft=(t)=>{var e=V.get(t),r;if(e)return e;if(e=w({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")G(t).map((n)=>!q.call(e,n)&&w(e,n,{get:()=>t[n],enumerable:!(r=Nt(t,n))||r.enumerable}));return V.set(t,e),e};var Wt=(t,e)=>{for(var r in e)w(t,r,{get:e[r],enumerable:!0,configurable:!0,set:(n)=>e[r]=()=>n})};var ee={};Wt(ee,{defineWorkspace:()=>H,defineConfig:()=>X,build:()=>It});module.exports=Ft(ee);function X(t){return t}function H(t){return t}var ct=require("rolldown"),lt=require("rolldown-plugin-dts");var K=!1;function Y(t){K=t??!1}class x{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!x.instance)x.instance=new x;return x.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(t){if(!t?.once)return!0;if(this.loggedOnceMessages.has(t.once))return!1;return this.loggedOnceMessages.add(t.once),!0}formatMessage({colorCode:t,label:e,message:r,size:n,identifier:i,muted:o}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-e.length)),a=o?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(n){let[u,...l]=a.split(" "),g=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-u.length)),f=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${e}\x1B[0m ${s}${u}${g} \x1B[38;5;${this.colors.size}m${n}\x1B[0m ${l.join(" ")}${f}`}let c=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${e}\x1B[0m ${s}${a}${c}`}output(t,e={},r=console.log){if(K)return;if(!this.shouldLog(e))return;if(e.verticalSpace)console.log("");if(r(t),e.verticalSpace)console.log("")}cli(t,e={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e)}info(t,e={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e)}warn(t,e={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e,console.warn)}error(t,e={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e,console.error)}progress(t,e,r,n){let i=String(t),o=this.colors.default,s,a,c={};if(typeof r==="string")s=r,a=n;else if(r)s=r.size,a=r.identifier,c=r;for(let[l,g]of Object.entries(this.colors.progress))if(i.includes(l)){o=g;break}let u=this.formatMessage({colorCode:o,label:i,message:e,size:s,identifier:a,muted:c.muted});this.output(u,c)}}var m=x.getInstance();class I extends Error{constructor(t){super(t);this.name="BunupError"}}class h extends I{constructor(t){super(t);this.name="BunupBuildError"}}class p extends I{constructor(t){super(t);this.name="BunupDTSBuildError"}}var d=(t)=>{if(t instanceof Error)return t.message;return String(t)};var M=R(require("node:fs/promises")),v=R(require("node:path"));function O(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Q(t=8){let e="";while(e.length<t)e+=Math.random().toString(36).substring(2);return e.substring(0,t)}function Z(t,e){switch(t){case"esm":return b(e)?".js":".mjs";case"cjs":return b(e)?".cjs":".js";case"iife":return".global.js"}}function z(t,e){switch(t){case"esm":return b(e)?".d.ts":".d.mts";case"cjs":return b(e)?".d.cts":".d.ts";case"iife":return".d.ts"}}function A(t){return t==="node"||t==="bun"}function b(t){return t==="module"}function J(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function _(t){if(t===0)return"0 B";let e=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${e[r]}`;return`${(t/1024**r).toFixed(2)} ${e[r]}`}function y(t,e=3){return t.split("/").slice(-e).join("/")}async function tt(t,e){let r=v.default.join(t,e);try{await M.default.rm(r,{recursive:!0,force:!0})}catch(n){throw new h(`Failed to clean output directory: ${n}`)}await M.default.mkdir(r,{recursive:!0})}function $(t){return[".ts",".mts",".cts",".tsx"].some((e)=>t.endsWith(e))}function et(t){return t.map((e)=>typeof e==="string"?new RegExp(`^${O(e)}($|\\/|\\\\)`):e)}function T(t,e){return et(t.external||[]).concat(J(e).map((r)=>new RegExp(`^${O(r)}($|\\/|\\\\)`)))}function P(t){return et(t.noExternal||[])}var ot=R(require("node:path")),at=require("oxc-resolver");var rt=require("ts-import-resolver");var S="\x00dts:",nt=(t,e,r)=>{return{name:"bunup:virtual-dts",async resolveId(n,i){if(j(n))return n;if(!i||!j(i))return null;let o=rt.resolveTypeScriptImportPath({path:n,importer:C(i),tsconfig:e.tsconfig,rootDir:r});if(!o)return null;let s=E(o);if(t.has(s))return B(s);return null},load(n){if(n.startsWith(S)){let i=C(n),o=t.get(i);if(o)return st.add(i),o}return null}}};function E(t){if(t.endsWith(".d.ts")||t.endsWith(".d.mts")||t.endsWith(".d.cts"))return t;return t.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function j(t){return t.startsWith(S)}function C(t){return t.replace(S,"")}function B(t){return`${S}${t}`}var it;function ut(t){return{name:"bunup:types-resolve",buildStart(){it||=new at.ResolverFactory({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts",".d.cts",".d.mts",".cts",".mts"],modules:["node_modules","node_modules/@types"]})},async resolveId(e,r){let n=r?C(r):void 0;if(/\0/.test(e))return;if(t){if(!t.some((a)=>{let c=!1;if(typeof a==="string")c=a===e||!!n?.includes(a);else c=a.test(e)||!!(n&&a.test(n));return c}))return}let i=n?ot.default.dirname(n):process.cwd(),{path:o}=await it.async(i,e);if(!o)return;if(/[cm]?jsx?$/.test(o)){let s=o.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return o}}}async function ft(t,e,r,n,i,o){let s=E(t),a=B(s),c=T(r,n),u=P(r);try{let{output:l}=await ct.build({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(g,f){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(g.code??""))return;f(g)},plugins:[nt(e,i,o),typeof r.dts==="object"&&"resolve"in r.dts&&ut(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),lt.dts({dtsInput:!0,emitDtsOnly:!0})],external:(g)=>c.some((f)=>f.test(g))&&!u.some((f)=>f.test(g))});if(!l[0]?.code)return m.warn(`Generated empty declaration file for entry "${t}"`,{muted:!0}),"";return l[0].code}catch(l){throw new p(`DTS bundling failed for entry "${t}": ${d(l)}`)}}var mt=require("ts-import-resolver");var kt=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Vt=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Gt=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,qt=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Xt=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ht=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,Kt=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function Yt(t){let e=new Set,r=[kt,Vt,Gt,qt,Xt,Ht,Kt];for(let n of r){let i=t.matchAll(n);for(let o of i)if(o[1])e.add(o[1])}return e}async function gt(t,e,r){let n=new Set([t]),i=[t];while(i.length){let o=i.pop();if(!o)continue;try{let s=await Bun.file(o).text(),a=Yt(s);for(let c of a){let u=mt.resolveTypeScriptImportPath({path:c,importer:o,tsconfig:e.tsconfig,rootDir:r});if(!u)continue;if(!n.has(u))n.add(u),i.push(u)}}catch(s){m.warn(`Error processing ${o}: ${d(s)}`)}}return n}var pt=require("oxc-transform");async function dt(t){let e=new Map;return await Promise.all([...t].map(async(r)=>{try{let n=E(r);if(!await Bun.file(r).exists())return;let o=await Bun.file(r).text(),{code:s}=pt.isolatedDeclaration(r,o);if(s)e.set(n,s)}catch(n){m.warn(`Failed to generate declaration for ${r}: ${d(n)}`)}})),e}var N=R(require("node:fs/promises")),D=R(require("node:path")),vt=require("oxc-transform");async function xt(t,e){let r=D.default.resolve(t),n=D.default.resolve(r,e);if(!await N.default.exists(r))throw new p(`Root directory does not exist: ${r}`);if(!await Bun.file(n).exists())throw new p(`Entry file does not exist: ${n}`);if(!$(n))throw new p(`Entry file must be a TypeScript file: ${n}`);if(D.default.relative(r,n).startsWith(".."))throw new p(`Entry file must be within rootDir: ${n}`);return{absoluteRootDir:r,absoluteEntry:n}}async function ht(t,e,r,n,i){let{absoluteEntry:o}=await xt(t,e),s=await gt(o,n,t),a=await dt(s);return ft(o,a,r,i,n,t)}function bt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function F(t,{warnOnConflict:e=!0}={}){let r=[],n=new Set,i={};function o(s,a){if(n.has(s)){let c=Q(),u=`${s}_${c}`;if(e)m.warn(`Output name conflict: "${s}" is used by multiple files.
1
+ var We=require("node:module");var _e=Object.create;var{getPrototypeOf:ve,defineProperty:w,getOwnPropertyNames:V,getOwnPropertyDescriptor:je}=Object,G=Object.prototype.hasOwnProperty;var R=(e,t,r)=>{r=e!=null?_e(ve(e)):{};let n=t||!e||!e.__esModule?w(r,"default",{value:e,enumerable:!0}):r;for(let s of V(e))if(!G.call(n,s))w(n,s,{get:()=>e[s],enumerable:!0});return n},U=new WeakMap,Ne=(e)=>{var t=U.get(e),r;if(t)return t;if(t=w({},"__esModule",{value:!0}),e&&typeof e==="object"||typeof e==="function")V(e).map((n)=>!G.call(t,n)&&w(t,n,{get:()=>e[n],enumerable:!(r=je(e,n))||r.enumerable}));return U.set(e,t),t};var Fe=(e,t)=>{for(var r in t)w(e,r,{get:t[r],enumerable:!0,configurable:!0,set:(n)=>t[r]=()=>n})};var tt={};Fe(tt,{defineWorkspace:()=>X,defineConfig:()=>q,build:()=>Le});module.exports=Ne(tt);function q(e){return e}function X(e){return e}var ce=require("rolldown"),le=require("rolldown-plugin-dts");var H=!1;function K(e){H=e??!1}class x{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!x.instance)x.instance=new x;return x.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(e){if(!e?.once)return!0;if(this.loggedOnceMessages.has(e.once))return!1;return this.loggedOnceMessages.add(e.once),!0}formatMessage({colorCode:e,label:t,message:r,size:n,identifier:s,muted:i}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=i?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(n){let[u,...c]=a.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-u.length)),l=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${o}${u}${p} \x1B[38;5;${this.colors.size}m${n}\x1B[0m ${c.join(" ")}${l}`}let m=s?` \x1B[48;5;${e};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${o}${a}${m}`}output(e,t={},r=console.log){if(H)return;if(!this.shouldLog(t))return;if(t.verticalSpace)console.log("");if(r(e),t.verticalSpace)console.log("")}cli(e,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}info(e,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}warn(e,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)}error(e,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)}progress(e,t,r,n){let s=String(e),i=this.colors.default,o,a,m={};if(typeof r==="string")o=r,a=n;else if(r)o=r.size,a=r.identifier,m=r;for(let[c,p]of Object.entries(this.colors.progress))if(s.includes(c)){i=p;break}let u=this.formatMessage({colorCode:i,label:s,message:t,size:o,identifier:a,muted:m.muted});this.output(u,m)}}var f=x.getInstance();class L extends Error{constructor(e){super(e);this.name="BunupError"}}class h extends L{constructor(e){super(e);this.name="BunupBuildError"}}class d extends L{constructor(e){super(e);this.name="BunupDTSBuildError"}}var g=(e)=>{if(e instanceof Error)return e.message;return String(e)};var M=R(require("node:fs/promises")),Y=R(require("node:path"));function O(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Q(e=8){let t="";while(t.length<e)t+=Math.random().toString(36).substring(2);return t.substring(0,e)}function Z(e,t){switch(e){case"esm":return b(t)?".js":".mjs";case"cjs":return b(t)?".cjs":".js";case"iife":return".global.js"}}function z(e,t){switch(e){case"esm":return b(t)?".d.ts":".d.mts";case"cjs":return b(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function A(e){return e==="node"||e==="bun"}function b(e){return e==="module"}function J(e){if(!e)return[];return Array.from(new Set([...Object.keys(e.dependencies||{}),...Object.keys(e.peerDependencies||{})]))}function _(e){if(e===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));if(r===0)return`${e} ${t[r]}`;return`${(e/1024**r).toFixed(2)} ${t[r]}`}function y(e,t=3){return e.split("/").slice(-t).join("/")}async function ee(e,t){let r=Y.default.join(e,t);try{await M.default.rm(r,{recursive:!0,force:!0})}catch(n){throw new h(`Failed to clean output directory: ${n}`)}await M.default.mkdir(r,{recursive:!0})}function $(e){return[".ts",".mts",".cts",".tsx"].some((t)=>e.endsWith(t))}function te(e){return e.map((t)=>typeof t==="string"?new RegExp(`^${O(t)}($|\\/|\\\\)`):t)}function T(e,t){return te(e.external||[]).concat(J(t).map((r)=>new RegExp(`^${O(r)}($|\\/|\\\\)`)))}function P(e){return te(e.noExternal||[])}var ie=R(require("node:path")),ae=require("oxc-resolver");var re=require("ts-import-resolver");var S="\x00dts:",ne=(e,t,r)=>{return{name:"bunup:virtual-dts",async resolveId(n,s){if(v(n))return n;if(!s||!v(s))return null;let i=re.resolveTypeScriptImportPath({path:n,importer:C(s),tsconfig:t.tsconfig,rootDir:r});if(!i)return null;let o=E(i);if(e.has(o))return B(o);return null},load(n){if(n.startsWith(S)){let s=C(n),i=e.get(s);if(i)return se.add(s),i}return null}}};function E(e){if(e.endsWith(".d.ts")||e.endsWith(".d.mts")||e.endsWith(".d.cts"))return e;return e.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function v(e){return e.startsWith(S)}function C(e){return e.replace(S,"")}function B(e){return`${S}${e}`}var oe;function ue(e){return{name:"bunup:types-resolve",buildStart(){oe||=new ae.ResolverFactory({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(t==="bun")return;let n=r?C(r):void 0;if(/\0/.test(t))return;if(e){if(!e.some((a)=>typeof a==="string"?a===t:a.test(t)))return}let s=n?ie.default.dirname(n):process.cwd(),{path:i}=await oe.async(s,t);return i}}}async function me(e,t,r,n,s,i){let o=E(e),a=B(o),m=T(r,n),u=P(r);try{let{output:c}=await ce.build({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(p,l){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(p.code??""))return;l(p)},plugins:[ne(t,s,i),typeof r.dts==="object"&&"resolve"in r.dts&&ue(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),le.dts({dtsInput:!0,emitDtsOnly:!0})],external:(p)=>m.some((l)=>l.test(p))&&!u.some((l)=>l.test(p))});if(!c[0]?.code)return f.warn(`Generated empty declaration file for entry "${e}"`,{muted:!0}),"";return c[0].code}catch(c){throw new d(`DTS bundling failed for entry "${e}": ${g(c)}`)}}var fe=require("ts-import-resolver");var ke=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Ue=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Ve=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ge=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,qe=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Xe=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,He=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function Ke(e){let t=new Set,r=[ke,Ue,Ve,Ge,qe,Xe,He];for(let n of r){let s=e.matchAll(n);for(let i of s)if(i[1])t.add(i[1])}return t}async function pe(e,t,r){let n=new Set([e]),s=[e];while(s.length){let i=s.pop();if(!i)continue;try{let o=await Bun.file(i).text(),a=Ke(o);for(let m of a){let u=fe.resolveTypeScriptImportPath({path:m,importer:i,tsconfig:t.tsconfig,rootDir:r});if(!u)continue;if(!n.has(u))n.add(u),s.push(u)}}catch(o){f.warn(`Error processing ${i}: ${g(o)}`)}}return n}var de=require("oxc-transform");async function ge(e){let t=new Map;return await Promise.all([...e].map(async(r)=>{try{let n=E(r);if(!await Bun.file(r).exists())return;let i=await Bun.file(r).text(),{code:o}=de.isolatedDeclaration(r,i);if(o)t.set(n,o)}catch(n){f.warn(`Failed to generate declaration for ${r}: ${g(n)}`)}})),t}var j=R(require("node:fs/promises")),D=R(require("node:path")),Ye=require("oxc-transform");async function xe(e,t){let r=D.default.resolve(e),n=D.default.resolve(r,t);if(!await j.default.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(n).exists())throw new d(`Entry file does not exist: ${n}`);if(!$(n))throw new d(`Entry file must be a TypeScript file: ${n}`);if(D.default.relative(r,n).startsWith(".."))throw new d(`Entry file must be within rootDir: ${n}`);return{absoluteRootDir:r,absoluteEntry:n}}async function he(e,t,r,n,s){let{absoluteEntry:i}=await xe(e,t),o=await pe(i,n,e),a=await ge(o);return me(i,a,r,s,n,e)}function be(e){return e.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function N(e,{warnOnConflict:t=!0}={}){let r=[],n=new Set,s={};function i(o,a){if(n.has(o)){let m=Q(),u=`${o}_${m}`;if(t)f.warn(`Output name conflict: "${o}" is used by multiple files.
2
2
  Bunup uses filenames without extensions as output names by default.
3
3
 
4
- ${i[s]} -> ${s}.js
4
+ ${s[o]} -> ${o}.js
5
5
  ${a} -> ${u}.js (auto-renamed to avoid conflict)
6
6
 
7
7
  To fix this, use named entries in your configuration:
8
8
  {
9
9
  entry: {
10
- custom_name: "${i[s]}",
10
+ custom_name: "${s[o]}",
11
11
  another_name: "${a}"
12
12
  }
13
13
  }
14
14
 
15
- See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});r.push({name:u,path:a})}else r.push({name:s,path:a}),n.add(s),i[s]=a}if(Array.isArray(t))for(let s of t){let a=bt(s);o(a,s)}else if(typeof t==="object")for(let[s,a]of Object.entries(t))o(s,a);else{let s=bt(t);o(s,t)}return r}function yt(t){return t.filter((e)=>$(e.path))}function Et(t,e){return`[dir]/${t}${e}`}var W=require("coffi");async function wt(t){let{config:e,filepath:r}=await W.loadConfig({name:"package",cwd:t,extensions:[".json"],maxDepth:1});return{packageJson:e,path:r}}async function Rt(t,e){let{config:r,filepath:n}=await W.loadConfig({name:"tsconfig",cwd:t,extensions:[".json"],preferredPath:e,maxDepth:3});return{tsconfig:r,path:n}}var Qt={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function Ct(t){return{...Qt,...t}}function St(t){let{minify:e,minifyWhitespace:r,minifyIdentifiers:n,minifySyntax:i}=t,o=e===!0;return{whitespace:r??o,identifiers:n??o,syntax:i??o}}function $t(t,e){return e==="cjs"?t:void 0}function Tt(t,e,r,n){return{...typeof r==="object"&&Object.keys(r).reduce((i,o)=>{let s=JSON.stringify(r[o]);return i[`process.env.${o}`]=s,i[`import.meta.env.${o}`]=s,i},{}),...t,...n==="cjs"&&(e===!0||typeof e==="object"&&e.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Pt(t,e){return t===void 0?e==="esm":t}function Bt(t){return typeof t==="string"?t:void 0}function Dt(t,e){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(n)=>{let i=n.path;if(t.some((s)=>s.test(i))&&!e.some((s)=>s.test(i)))return{path:i,external:!0};return null})}}}var Zt=/\.(js|ts|jsx|tsx|mts|cts)$/,U={dirnameFilename:{appliesTo:(t,e)=>t==="esm"&&A(e),isNeededInFile:(t)=>/\b__dirname\b/.test(t)||/\b__filename\b/.test(t),generateCode:()=>`import { fileURLToPath } from 'url';
15
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});r.push({name:u,path:a})}else r.push({name:o,path:a}),n.add(o),s[o]=a}if(Array.isArray(e))for(let o of e){let a=be(o);i(a,o)}else if(typeof e==="object")for(let[o,a]of Object.entries(e))i(o,a);else{let o=be(e);i(o,e)}return r}function ye(e){return e.filter((t)=>$(t.path))}function Ee(e,t){return`[dir]/${e}${t}`}var F=require("coffi");async function we(e){let{config:t,filepath:r}=await F.loadConfig({name:"package",cwd:e,extensions:[".json"],maxDepth:1});return{packageJson:t,path:r}}async function Re(e,t){let{config:r,filepath:n}=await F.loadConfig({name:"tsconfig",cwd:e,extensions:[".json"],preferredPath:t,maxDepth:3});return{tsconfig:r,path:n}}var Qe={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function Ce(e){return{...Qe,...e}}function Se(e){let{minify:t,minifyWhitespace:r,minifyIdentifiers:n,minifySyntax:s}=e,i=t===!0;return{whitespace:r??i,identifiers:n??i,syntax:s??i}}function $e(e,t){return t==="cjs"?e:void 0}function Te(e,t,r,n){return{...typeof r==="object"&&Object.keys(r).reduce((s,i)=>{let o=JSON.stringify(r[i]);return s[`process.env.${i}`]=o,s[`import.meta.env.${i}`]=o,s},{}),...e,...n==="cjs"&&(t===!0||typeof t==="object"&&t.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function Pe(e,t){return e===void 0?t==="esm":e}function Be(e){return typeof e==="string"?e:void 0}function De(e,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(n)=>{let s=n.path;if(e.some((o)=>o.test(s))&&!t.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}var Ze=/\.(js|ts|jsx|tsx|mts|cts)$/,W={dirnameFilename:{appliesTo:(e,t)=>e==="esm"&&A(t),isNeededInFile:(e)=>/\b__dirname\b/.test(e)||/\b__filename\b/.test(e),generateCode:()=>`import { fileURLToPath } from 'url';
16
16
  import { dirname } from 'path';
17
17
 
18
18
  const __filename = fileURLToPath(import.meta.url);
19
19
  const __dirname = dirname(__filename);
20
20
 
21
- `},importMetaUrl:{appliesTo:(t,e)=>t==="cjs"&&A(e),isNeededInFile:(t)=>/\bimport\.meta\.url\b/.test(t),generateCode:()=>`import { pathToFileURL } from 'url';
21
+ `},importMetaUrl:{appliesTo:(e,t)=>e==="cjs"&&A(t),isNeededInFile:(e)=>/\bimport\.meta\.url\b/.test(e),generateCode:()=>`import { pathToFileURL } from 'url';
22
22
 
23
23
  const importMetaUrl = pathToFileURL(__filename).href;
24
24
 
25
- `}};function Lt({format:t,target:e,shims:r}){let i=zt(r).map((o)=>U[o]).filter((o)=>o.appliesTo(t,e));if(i.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(o){o.onLoad({filter:Zt},async({path:s})=>{let a=await Bun.file(s).text(),c=i.filter((f)=>f.isNeededInFile(a));if(c.length===0)return;let{shebangLine:u,codeContent:l}=Jt(a),g=c.map((f)=>f.generateCode()).join("");return{contents:u+g+l}})}}}function zt(t){if(t===!0)return Object.keys(U);if(!t)return[];return Object.entries(t).filter(([e,r])=>r&&(e in U)).map(([e])=>e)}function Jt(t){if(!t.startsWith("#!"))return{shebangLine:"",codeContent:t};let e=t.indexOf(`
26
- `);return e===-1?{shebangLine:"",codeContent:t}:{shebangLine:t.slice(0,e+1),codeContent:t.slice(e+1)}}var st=new Set;async function It(t,e){let r=Ct(t);if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)tt(e,r.outDir);Y(r.silent);let{packageJson:n,path:i}=await wt(e);if(n&&i)m.cli(`Using package.json: ${y(i,2)}`,{muted:!0,identifier:r.name,once:`${i}:${r.name}`});let o=F(r.entry),s=n?.type,a=T(r,n),c=P(r);if(!r.dtsOnly){let u=[Dt(a,c)],l=r.format.flatMap((g)=>o.map((f)=>{return te(r,e,f,g,s,u)}));await Promise.all(l)}if(r.dts||r.dtsOnly){let u=await Rt(e,r.preferredTsconfigPath);if(u.path)m.cli(`Using tsconfig: ${y(u.path,2)}`,{muted:!0,identifier:r.name,once:`${u.path}:${r.name}`});let l=r.format.filter((f)=>{if(f==="iife"&&!b(s)&&r.format.includes("cjs"))return!1;return!0}),g=typeof r.dts==="object"&&r.dts.entry?F(r.dts.entry):yt(o);try{await Promise.all(g.map(async(f)=>{let Mt=await ht(e,f.path,r,u,n);await Promise.all(l.map(async(k)=>{let Ot=r.outputExtension?.({format:k,packageType:s,options:r,entry:f}).dts??z(k,s),L=`${e}/${r.outDir}/${f.name}${Ot}`;await Bun.write(L,Mt);let At=Bun.file(L).size||0;m.progress("DTS",y(L),_(At),r.name)}))}))}catch(f){throw new p(d(f))}}}async function te(t,e,r,n,i,o){let s=t.outputExtension?.({format:n,packageType:i,options:t,entry:r}).js??Z(n,i),a=await Bun.build({entrypoints:[`${e}/${r.path}`],format:n,naming:{entry:Et(r.name,s)},splitting:Pt(t.splitting,n),bytecode:$t(t.bytecode,n),define:Tt(t.define,t.shims,t.env,n),minify:St(t),outdir:`${e}/${t.outDir}`,target:t.target,sourcemap:t.sourcemap,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer,publicPath:t.publicPath,env:Bt(t.env),plugins:[...o,Lt({format:n,target:t.target,shims:t.shims}),...t.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let l of a.logs){if(l.level==="error")throw new h(l.message);if(l.level==="warning")m.warn(l.message);else if(l.level==="info")m.info(l.message)}let c=`${e}/${t.outDir}/${r.name}${s}`,u=Bun.file(c).size||0;m.progress(n.toUpperCase(),y(c),_(u),t.name)}
25
+ `}};function Ie({format:e,target:t,shims:r}){let s=ze(r).map((i)=>W[i]).filter((i)=>i.appliesTo(e,t));if(s.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(i){i.onLoad({filter:Ze},async({path:o})=>{let a=await Bun.file(o).text(),m=s.filter((l)=>l.isNeededInFile(a));if(m.length===0)return;let{shebangLine:u,codeContent:c}=Je(a),p=m.map((l)=>l.generateCode()).join("");return{contents:u+p+c}})}}}function ze(e){if(e===!0)return Object.keys(W);if(!e)return[];return Object.entries(e).filter(([t,r])=>r&&(t in W)).map(([t])=>t)}function Je(e){if(!e.startsWith("#!"))return{shebangLine:"",codeContent:e};let t=e.indexOf(`
26
+ `);return t===-1?{shebangLine:"",codeContent:e}:{shebangLine:e.slice(0,t+1),codeContent:e.slice(t+1)}}var se=new Set;async function Le(e,t){let r=Ce(e);if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)ee(t,r.outDir);K(r.silent);let{packageJson:n,path:s}=await we(t);if(n&&s)f.cli(`Using package.json: ${y(s,2)}`,{muted:!0,identifier:r.name,once:`${s}:${r.name}`});let i=N(r.entry),o=n?.type,a=T(r,n),m=P(r);if(!r.dtsOnly){let u=[De(a,m)],c=r.format.flatMap((p)=>i.map((l)=>{return et(r,t,l,p,o,u)}));await Promise.all(c)}if(r.dts||r.dtsOnly){let u=await Re(t,r.preferredTsconfigPath);if(u.path)f.cli(`Using tsconfig: ${y(u.path,2)}`,{muted:!0,identifier:r.name,once:`${u.path}:${r.name}`});let c=r.format.filter((l)=>{if(l==="iife"&&!b(o)&&r.format.includes("cjs"))return!1;return!0}),p=typeof r.dts==="object"&&r.dts.entry?N(r.dts.entry):ye(i);try{await Promise.all(p.map(async(l)=>{let Me=await he(t,l.path,r,u,n);await Promise.all(c.map(async(k)=>{let Oe=r.outputExtension?.({format:k,packageType:o,options:r,entry:l}).dts??z(k,o),I=`${t}/${r.outDir}/${l.name}${Oe}`;await Bun.write(I,Me);let Ae=Bun.file(I).size||0;f.progress("DTS",y(I),_(Ae),r.name)}))}))}catch(l){throw new d(g(l))}}}async function et(e,t,r,n,s,i){let o=e.outputExtension?.({format:n,packageType:s,options:e,entry:r}).js??Z(n,s),a=await Bun.build({entrypoints:[`${t}/${r.path}`],format:n,naming:{entry:Ee(r.name,o)},splitting:Pe(e.splitting,n),bytecode:$e(e.bytecode,n),define:Te(e.define,e.shims,e.env,n),minify:Se(e),outdir:`${t}/${e.outDir}`,target:e.target,sourcemap:e.sourcemap,loader:e.loader,drop:e.drop,banner:e.banner,footer:e.footer,publicPath:e.publicPath,env:Be(e.env),plugins:[...i,Ie({format:n,target:e.target,shims:e.shims}),...e.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let c of a.logs){if(c.level==="error")throw new h(c.message);if(c.level==="warning")f.warn(c.message);else if(c.level==="info")f.info(c.message)}let m=`${t}/${e.outDir}/${r.name}${o}`,u=Bun.file(m).size||0;f.progress(n.toUpperCase(),y(m),_(u),e.name)}
package/build/index.mjs CHANGED
@@ -1,4 +1,4 @@
1
- function yt(t){return t}function Et(t){return t}import{build as $t}from"rolldown";import{dts as Tt}from"rolldown-plugin-dts";var N=!1;function F(t){N=t??!1}class x{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!x.instance)x.instance=new x;return x.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(t){if(!t?.once)return!0;if(this.loggedOnceMessages.has(t.once))return!1;return this.loggedOnceMessages.add(t.once),!0}formatMessage({colorCode:t,label:e,message:r,size:n,identifier:o,muted:i}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-e.length)),a=i?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(n){let[u,...l]=a.split(" "),g=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-u.length)),f=o?` \x1B[48;5;${t};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${t}m${e}\x1B[0m ${s}${u}${g} \x1B[38;5;${this.colors.size}m${n}\x1B[0m ${l.join(" ")}${f}`}let c=o?` \x1B[48;5;${t};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${t}m${e}\x1B[0m ${s}${a}${c}`}output(t,e={},r=console.log){if(N)return;if(!this.shouldLog(e))return;if(e.verticalSpace)console.log("");if(r(t),e.verticalSpace)console.log("")}cli(t,e={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e)}info(t,e={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e)}warn(t,e={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e,console.warn)}error(t,e={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:t,identifier:e.identifier,muted:e.muted});this.output(r,e,console.error)}progress(t,e,r,n){let o=String(t),i=this.colors.default,s,a,c={};if(typeof r==="string")s=r,a=n;else if(r)s=r.size,a=r.identifier,c=r;for(let[l,g]of Object.entries(this.colors.progress))if(o.includes(l)){i=g;break}let u=this.formatMessage({colorCode:i,label:o,message:e,size:s,identifier:a,muted:c.muted});this.output(u,c)}}var m=x.getInstance();class B extends Error{constructor(t){super(t);this.name="BunupError"}}class h extends B{constructor(t){super(t);this.name="BunupBuildError"}}class p extends B{constructor(t){super(t);this.name="BunupDTSBuildError"}}var d=(t)=>{if(t instanceof Error)return t.message;return String(t)};import W from"node:fs/promises";import wt from"node:path";function D(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function U(t=8){let e="";while(e.length<t)e+=Math.random().toString(36).substring(2);return e.substring(0,t)}function k(t,e){switch(t){case"esm":return b(e)?".js":".mjs";case"cjs":return b(e)?".cjs":".js";case"iife":return".global.js"}}function V(t,e){switch(t){case"esm":return b(e)?".d.ts":".d.mts";case"cjs":return b(e)?".d.cts":".d.ts";case"iife":return".d.ts"}}function L(t){return t==="node"||t==="bun"}function b(t){return t==="module"}function G(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function I(t){if(t===0)return"0 B";let e=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${e[r]}`;return`${(t/1024**r).toFixed(2)} ${e[r]}`}function y(t,e=3){return t.split("/").slice(-e).join("/")}async function q(t,e){let r=wt.join(t,e);try{await W.rm(r,{recursive:!0,force:!0})}catch(n){throw new h(`Failed to clean output directory: ${n}`)}await W.mkdir(r,{recursive:!0})}function C(t){return[".ts",".mts",".cts",".tsx"].some((e)=>t.endsWith(e))}function X(t){return t.map((e)=>typeof e==="string"?new RegExp(`^${D(e)}($|\\/|\\\\)`):e)}function S(t,e){return X(t.external||[]).concat(G(e).map((r)=>new RegExp(`^${D(r)}($|\\/|\\\\)`)))}function $(t){return X(t.noExternal||[])}import Ct from"node:path";import{ResolverFactory as St}from"oxc-resolver";import{resolveTypeScriptImportPath as Rt}from"ts-import-resolver";var R="\x00dts:",H=(t,e,r)=>{return{name:"bunup:virtual-dts",async resolveId(n,o){if(M(n))return n;if(!o||!M(o))return null;let i=Rt({path:n,importer:w(o),tsconfig:e.tsconfig,rootDir:r});if(!i)return null;let s=E(i);if(t.has(s))return T(s);return null},load(n){if(n.startsWith(R)){let o=w(n),i=t.get(o);if(i)return K.add(o),i}return null}}};function E(t){if(t.endsWith(".d.ts")||t.endsWith(".d.mts")||t.endsWith(".d.cts"))return t;return t.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function M(t){return t.startsWith(R)}function w(t){return t.replace(R,"")}function T(t){return`${R}${t}`}var Y;function v(t){return{name:"bunup:types-resolve",buildStart(){Y||=new St({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts",".d.cts",".d.mts",".cts",".mts"],modules:["node_modules","node_modules/@types"]})},async resolveId(e,r){let n=r?w(r):void 0;if(/\0/.test(e))return;if(t){if(!t.some((a)=>{let c=!1;if(typeof a==="string")c=a===e||!!n?.includes(a);else c=a.test(e)||!!(n&&a.test(n));return c}))return}let o=n?Ct.dirname(n):process.cwd(),{path:i}=await Y.async(o,e);if(!i)return;if(/[cm]?jsx?$/.test(i)){let s=i.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return i}}}async function Q(t,e,r,n,o,i){let s=E(t),a=T(s),c=S(r,n),u=$(r);try{let{output:l}=await $t({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(g,f){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(g.code??""))return;f(g)},plugins:[H(e,o,i),typeof r.dts==="object"&&"resolve"in r.dts&&v(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),Tt({dtsInput:!0,emitDtsOnly:!0})],external:(g)=>c.some((f)=>f.test(g))&&!u.some((f)=>f.test(g))});if(!l[0]?.code)return m.warn(`Generated empty declaration file for entry "${t}"`,{muted:!0}),"";return l[0].code}catch(l){throw new p(`DTS bundling failed for entry "${t}": ${d(l)}`)}}import{resolveTypeScriptImportPath as Pt}from"ts-import-resolver";var Bt=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,Dt=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Lt=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,It=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Mt=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Ot=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,At=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function _t(t){let e=new Set,r=[Bt,Dt,Lt,It,Mt,Ot,At];for(let n of r){let o=t.matchAll(n);for(let i of o)if(i[1])e.add(i[1])}return e}async function Z(t,e,r){let n=new Set([t]),o=[t];while(o.length){let i=o.pop();if(!i)continue;try{let s=await Bun.file(i).text(),a=_t(s);for(let c of a){let u=Pt({path:c,importer:i,tsconfig:e.tsconfig,rootDir:r});if(!u)continue;if(!n.has(u))n.add(u),o.push(u)}}catch(s){m.warn(`Error processing ${i}: ${d(s)}`)}}return n}import{isolatedDeclaration as jt}from"oxc-transform";async function z(t){let e=new Map;return await Promise.all([...t].map(async(r)=>{try{let n=E(r);if(!await Bun.file(r).exists())return;let i=await Bun.file(r).text(),{code:s}=jt(r,i);if(s)e.set(n,s)}catch(n){m.warn(`Failed to generate declaration for ${r}: ${d(n)}`)}})),e}import J from"node:fs/promises";import O from"node:path";import{isolatedDeclaration as Le}from"oxc-transform";async function tt(t,e){let r=O.resolve(t),n=O.resolve(r,e);if(!await J.exists(r))throw new p(`Root directory does not exist: ${r}`);if(!await Bun.file(n).exists())throw new p(`Entry file does not exist: ${n}`);if(!C(n))throw new p(`Entry file must be a TypeScript file: ${n}`);if(O.relative(r,n).startsWith(".."))throw new p(`Entry file must be within rootDir: ${n}`);return{absoluteRootDir:r,absoluteEntry:n}}async function et(t,e,r,n,o){let{absoluteEntry:i}=await tt(t,e),s=await Z(i,n,t),a=await z(s);return Q(i,a,r,o,n,t)}function rt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function A(t,{warnOnConflict:e=!0}={}){let r=[],n=new Set,o={};function i(s,a){if(n.has(s)){let c=U(),u=`${s}_${c}`;if(e)m.warn(`Output name conflict: "${s}" is used by multiple files.
1
+ function ye(e){return e}function Ee(e){return e}import{build as $e}from"rolldown";import{dts as Te}from"rolldown-plugin-dts";var j=!1;function N(e){j=e??!1}class x{static instance;loggedOnceMessages=new Set;MAX_LABEL_LENGTH=3;MAX_MESSAGE_LENGTH=25;colors={cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"};labels={cli:"CLI",info:"INFO",warn:"WARN",error:"ERROR"};constructor(){}static getInstance(){if(!x.instance)x.instance=new x;return x.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(e){if(!e?.once)return!0;if(this.loggedOnceMessages.has(e.once))return!1;return this.loggedOnceMessages.add(e.once),!0}formatMessage({colorCode:e,label:t,message:r,size:n,identifier:o,muted:i}){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=i?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(n){let[u,...c]=a.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-u.length)),l=o?` \x1B[48;5;${e};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${s}${u}${p} \x1B[38;5;${this.colors.size}m${n}\x1B[0m ${c.join(" ")}${l}`}let m=o?` \x1B[48;5;${e};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${e}m${t}\x1B[0m ${s}${a}${m}`}output(e,t={},r=console.log){if(j)return;if(!this.shouldLog(t))return;if(t.verticalSpace)console.log("");if(r(e),t.verticalSpace)console.log("")}cli(e,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}info(e,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t)}warn(e,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)}error(e,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:e,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)}progress(e,t,r,n){let o=String(e),i=this.colors.default,s,a,m={};if(typeof r==="string")s=r,a=n;else if(r)s=r.size,a=r.identifier,m=r;for(let[c,p]of Object.entries(this.colors.progress))if(o.includes(c)){i=p;break}let u=this.formatMessage({colorCode:i,label:o,message:t,size:s,identifier:a,muted:m.muted});this.output(u,m)}}var f=x.getInstance();class B extends Error{constructor(e){super(e);this.name="BunupError"}}class h extends B{constructor(e){super(e);this.name="BunupBuildError"}}class d extends B{constructor(e){super(e);this.name="BunupDTSBuildError"}}var g=(e)=>{if(e instanceof Error)return e.message;return String(e)};import F from"node:fs/promises";import we from"node:path";function D(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function W(e=8){let t="";while(t.length<e)t+=Math.random().toString(36).substring(2);return t.substring(0,e)}function k(e,t){switch(e){case"esm":return b(t)?".js":".mjs";case"cjs":return b(t)?".cjs":".js";case"iife":return".global.js"}}function U(e,t){switch(e){case"esm":return b(t)?".d.ts":".d.mts";case"cjs":return b(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function I(e){return e==="node"||e==="bun"}function b(e){return e==="module"}function V(e){if(!e)return[];return Array.from(new Set([...Object.keys(e.dependencies||{}),...Object.keys(e.peerDependencies||{})]))}function L(e){if(e===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(e)/Math.log(1024));if(r===0)return`${e} ${t[r]}`;return`${(e/1024**r).toFixed(2)} ${t[r]}`}function y(e,t=3){return e.split("/").slice(-t).join("/")}async function G(e,t){let r=we.join(e,t);try{await F.rm(r,{recursive:!0,force:!0})}catch(n){throw new h(`Failed to clean output directory: ${n}`)}await F.mkdir(r,{recursive:!0})}function C(e){return[".ts",".mts",".cts",".tsx"].some((t)=>e.endsWith(t))}function q(e){return e.map((t)=>typeof t==="string"?new RegExp(`^${D(t)}($|\\/|\\\\)`):t)}function S(e,t){return q(e.external||[]).concat(V(t).map((r)=>new RegExp(`^${D(r)}($|\\/|\\\\)`)))}function $(e){return q(e.noExternal||[])}import Ce from"node:path";import{ResolverFactory as Se}from"oxc-resolver";import{resolveTypeScriptImportPath as Re}from"ts-import-resolver";var R="\x00dts:",X=(e,t,r)=>{return{name:"bunup:virtual-dts",async resolveId(n,o){if(M(n))return n;if(!o||!M(o))return null;let i=Re({path:n,importer:w(o),tsconfig:t.tsconfig,rootDir:r});if(!i)return null;let s=E(i);if(e.has(s))return T(s);return null},load(n){if(n.startsWith(R)){let o=w(n),i=e.get(o);if(i)return H.add(o),i}return null}}};function E(e){if(e.endsWith(".d.ts")||e.endsWith(".d.mts")||e.endsWith(".d.cts"))return e;return e.replace(/\.(ts|tsx|mts|cts)$/,".d.ts")}function M(e){return e.startsWith(R)}function w(e){return e.replace(R,"")}function T(e){return`${R}${e}`}var K;function Y(e){return{name:"bunup:types-resolve",buildStart(){K||=new Se({mainFields:["types","typings","module","main"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".d.mts",".d.cts",".ts",".mts",".cts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(t==="bun")return;let n=r?w(r):void 0;if(/\0/.test(t))return;if(e){if(!e.some((a)=>typeof a==="string"?a===t:a.test(t)))return}let o=n?Ce.dirname(n):process.cwd(),{path:i}=await K.async(o,t);return i}}}async function Q(e,t,r,n,o,i){let s=E(e),a=T(s),m=S(r,n),u=$(r);try{let{output:c}=await $e({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(p,l){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(p.code??""))return;l(p)},plugins:[X(t,o,i),typeof r.dts==="object"&&"resolve"in r.dts&&Y(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),Te({dtsInput:!0,emitDtsOnly:!0})],external:(p)=>m.some((l)=>l.test(p))&&!u.some((l)=>l.test(p))});if(!c[0]?.code)return f.warn(`Generated empty declaration file for entry "${e}"`,{muted:!0}),"";return c[0].code}catch(c){throw new d(`DTS bundling failed for entry "${e}": ${g(c)}`)}}import{resolveTypeScriptImportPath as Pe}from"ts-import-resolver";var Be=/^\s*import\s+(?:[^'"]*?\s+from\s+)?['"]([^'"]+)['"]/gm,De=/^\s*export\s+.*from\s+['"]([^'"]+)['"]/gm,Ie=/import\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Le=/require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Me=/import\s+\w+\s*=\s*require\s*\(\s*['"]([^'"]+)['"]\s*\)/g,Oe=/\/\/\/\s*<reference\s+path\s*=\s*['"]([^'"]+)['"]\s*\/>/g,Ae=/\/\/\/\s*<reference\s+types\s*=\s*['"]([^'"]+)['"]\s*\/>/g;function _e(e){let t=new Set,r=[Be,De,Ie,Le,Me,Oe,Ae];for(let n of r){let o=e.matchAll(n);for(let i of o)if(i[1])t.add(i[1])}return t}async function Z(e,t,r){let n=new Set([e]),o=[e];while(o.length){let i=o.pop();if(!i)continue;try{let s=await Bun.file(i).text(),a=_e(s);for(let m of a){let u=Pe({path:m,importer:i,tsconfig:t.tsconfig,rootDir:r});if(!u)continue;if(!n.has(u))n.add(u),o.push(u)}}catch(s){f.warn(`Error processing ${i}: ${g(s)}`)}}return n}import{isolatedDeclaration as ve}from"oxc-transform";async function z(e){let t=new Map;return await Promise.all([...e].map(async(r)=>{try{let n=E(r);if(!await Bun.file(r).exists())return;let i=await Bun.file(r).text(),{code:s}=ve(r,i);if(s)t.set(n,s)}catch(n){f.warn(`Failed to generate declaration for ${r}: ${g(n)}`)}})),t}import J from"node:fs/promises";import O from"node:path";import{isolatedDeclaration as It}from"oxc-transform";async function ee(e,t){let r=O.resolve(e),n=O.resolve(r,t);if(!await J.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(n).exists())throw new d(`Entry file does not exist: ${n}`);if(!C(n))throw new d(`Entry file must be a TypeScript file: ${n}`);if(O.relative(r,n).startsWith(".."))throw new d(`Entry file must be within rootDir: ${n}`);return{absoluteRootDir:r,absoluteEntry:n}}async function te(e,t,r,n,o){let{absoluteEntry:i}=await ee(e,t),s=await Z(i,n,e),a=await z(s);return Q(i,a,r,o,n,e)}function re(e){return e.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function A(e,{warnOnConflict:t=!0}={}){let r=[],n=new Set,o={};function i(s,a){if(n.has(s)){let m=W(),u=`${s}_${m}`;if(t)f.warn(`Output name conflict: "${s}" is used by multiple files.
2
2
  Bunup uses filenames without extensions as output names by default.
3
3
 
4
4
  ${o[s]} -> ${s}.js
@@ -12,15 +12,15 @@ To fix this, use named entries in your configuration:
12
12
  }
13
13
  }
14
14
 
15
- See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});r.push({name:u,path:a})}else r.push({name:s,path:a}),n.add(s),o[s]=a}if(Array.isArray(t))for(let s of t){let a=rt(s);i(a,s)}else if(typeof t==="object")for(let[s,a]of Object.entries(t))i(s,a);else{let s=rt(t);i(s,t)}return r}function nt(t){return t.filter((e)=>C(e.path))}function st(t,e){return`[dir]/${t}${e}`}import{loadConfig as it}from"coffi";async function ot(t){let{config:e,filepath:r}=await it({name:"package",cwd:t,extensions:[".json"],maxDepth:1});return{packageJson:e,path:r}}async function at(t,e){let{config:r,filepath:n}=await it({name:"tsconfig",cwd:t,extensions:[".json"],preferredPath:e,maxDepth:3});return{tsconfig:r,path:n}}var Nt={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function ut(t){return{...Nt,...t}}function ct(t){let{minify:e,minifyWhitespace:r,minifyIdentifiers:n,minifySyntax:o}=t,i=e===!0;return{whitespace:r??i,identifiers:n??i,syntax:o??i}}function lt(t,e){return e==="cjs"?t:void 0}function ft(t,e,r,n){return{...typeof r==="object"&&Object.keys(r).reduce((o,i)=>{let s=JSON.stringify(r[i]);return o[`process.env.${i}`]=s,o[`import.meta.env.${i}`]=s,o},{}),...t,...n==="cjs"&&(e===!0||typeof e==="object"&&e.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function mt(t,e){return t===void 0?e==="esm":t}function gt(t){return typeof t==="string"?t:void 0}function pt(t,e){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(n)=>{let o=n.path;if(t.some((s)=>s.test(o))&&!e.some((s)=>s.test(o)))return{path:o,external:!0};return null})}}}var Ft=/\.(js|ts|jsx|tsx|mts|cts)$/,_={dirnameFilename:{appliesTo:(t,e)=>t==="esm"&&L(e),isNeededInFile:(t)=>/\b__dirname\b/.test(t)||/\b__filename\b/.test(t),generateCode:()=>`import { fileURLToPath } from 'url';
15
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0});r.push({name:u,path:a})}else r.push({name:s,path:a}),n.add(s),o[s]=a}if(Array.isArray(e))for(let s of e){let a=re(s);i(a,s)}else if(typeof e==="object")for(let[s,a]of Object.entries(e))i(s,a);else{let s=re(e);i(s,e)}return r}function ne(e){return e.filter((t)=>C(t.path))}function se(e,t){return`[dir]/${e}${t}`}import{loadConfig as oe}from"coffi";async function ie(e){let{config:t,filepath:r}=await oe({name:"package",cwd:e,extensions:[".json"],maxDepth:1});return{packageJson:t,path:r}}async function ae(e,t){let{config:r,filepath:n}=await oe({name:"tsconfig",cwd:e,extensions:[".json"],preferredPath:t,maxDepth:3});return{tsconfig:r,path:n}}var je={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function ue(e){return{...je,...e}}function ce(e){let{minify:t,minifyWhitespace:r,minifyIdentifiers:n,minifySyntax:o}=e,i=t===!0;return{whitespace:r??i,identifiers:n??i,syntax:o??i}}function le(e,t){return t==="cjs"?e:void 0}function me(e,t,r,n){return{...typeof r==="object"&&Object.keys(r).reduce((o,i)=>{let s=JSON.stringify(r[i]);return o[`process.env.${i}`]=s,o[`import.meta.env.${i}`]=s,o},{}),...e,...n==="cjs"&&(t===!0||typeof t==="object"&&t.importMetaUrl)&&{"import.meta.url":"importMetaUrl"}}}function fe(e,t){return e===void 0?t==="esm":e}function pe(e){return typeof e==="string"?e:void 0}function de(e,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(n)=>{let o=n.path;if(e.some((s)=>s.test(o))&&!t.some((s)=>s.test(o)))return{path:o,external:!0};return null})}}}var Ne=/\.(js|ts|jsx|tsx|mts|cts)$/,_={dirnameFilename:{appliesTo:(e,t)=>e==="esm"&&I(t),isNeededInFile:(e)=>/\b__dirname\b/.test(e)||/\b__filename\b/.test(e),generateCode:()=>`import { fileURLToPath } from 'url';
16
16
  import { dirname } from 'path';
17
17
 
18
18
  const __filename = fileURLToPath(import.meta.url);
19
19
  const __dirname = dirname(__filename);
20
20
 
21
- `},importMetaUrl:{appliesTo:(t,e)=>t==="cjs"&&L(e),isNeededInFile:(t)=>/\bimport\.meta\.url\b/.test(t),generateCode:()=>`import { pathToFileURL } from 'url';
21
+ `},importMetaUrl:{appliesTo:(e,t)=>e==="cjs"&&I(t),isNeededInFile:(e)=>/\bimport\.meta\.url\b/.test(e),generateCode:()=>`import { pathToFileURL } from 'url';
22
22
 
23
23
  const importMetaUrl = pathToFileURL(__filename).href;
24
24
 
25
- `}};function dt({format:t,target:e,shims:r}){let o=Wt(r).map((i)=>_[i]).filter((i)=>i.appliesTo(t,e));if(o.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(i){i.onLoad({filter:Ft},async({path:s})=>{let a=await Bun.file(s).text(),c=o.filter((f)=>f.isNeededInFile(a));if(c.length===0)return;let{shebangLine:u,codeContent:l}=Ut(a),g=c.map((f)=>f.generateCode()).join("");return{contents:u+g+l}})}}}function Wt(t){if(t===!0)return Object.keys(_);if(!t)return[];return Object.entries(t).filter(([e,r])=>r&&(e in _)).map(([e])=>e)}function Ut(t){if(!t.startsWith("#!"))return{shebangLine:"",codeContent:t};let e=t.indexOf(`
26
- `);return e===-1?{shebangLine:"",codeContent:t}:{shebangLine:t.slice(0,e+1),codeContent:t.slice(e+1)}}var K=new Set;async function kt(t,e){let r=ut(t);if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)q(e,r.outDir);F(r.silent);let{packageJson:n,path:o}=await ot(e);if(n&&o)m.cli(`Using package.json: ${y(o,2)}`,{muted:!0,identifier:r.name,once:`${o}:${r.name}`});let i=A(r.entry),s=n?.type,a=S(r,n),c=$(r);if(!r.dtsOnly){let u=[pt(a,c)],l=r.format.flatMap((g)=>i.map((f)=>{return Vt(r,e,f,g,s,u)}));await Promise.all(l)}if(r.dts||r.dtsOnly){let u=await at(e,r.preferredTsconfigPath);if(u.path)m.cli(`Using tsconfig: ${y(u.path,2)}`,{muted:!0,identifier:r.name,once:`${u.path}:${r.name}`});let l=r.format.filter((f)=>{if(f==="iife"&&!b(s)&&r.format.includes("cjs"))return!1;return!0}),g=typeof r.dts==="object"&&r.dts.entry?A(r.dts.entry):nt(i);try{await Promise.all(g.map(async(f)=>{let xt=await et(e,f.path,r,u,n);await Promise.all(l.map(async(j)=>{let ht=r.outputExtension?.({format:j,packageType:s,options:r,entry:f}).dts??V(j,s),P=`${e}/${r.outDir}/${f.name}${ht}`;await Bun.write(P,xt);let bt=Bun.file(P).size||0;m.progress("DTS",y(P),I(bt),r.name)}))}))}catch(f){throw new p(d(f))}}}async function Vt(t,e,r,n,o,i){let s=t.outputExtension?.({format:n,packageType:o,options:t,entry:r}).js??k(n,o),a=await Bun.build({entrypoints:[`${e}/${r.path}`],format:n,naming:{entry:st(r.name,s)},splitting:mt(t.splitting,n),bytecode:lt(t.bytecode,n),define:ft(t.define,t.shims,t.env,n),minify:ct(t),outdir:`${e}/${t.outDir}`,target:t.target,sourcemap:t.sourcemap,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer,publicPath:t.publicPath,env:gt(t.env),plugins:[...i,dt({format:n,target:t.target,shims:t.shims}),...t.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let l of a.logs){if(l.level==="error")throw new h(l.message);if(l.level==="warning")m.warn(l.message);else if(l.level==="info")m.info(l.message)}let c=`${e}/${t.outDir}/${r.name}${s}`,u=Bun.file(c).size||0;m.progress(n.toUpperCase(),y(c),I(u),t.name)}export{Et as defineWorkspace,yt as defineConfig,kt as build};
25
+ `}};function ge({format:e,target:t,shims:r}){let o=Fe(r).map((i)=>_[i]).filter((i)=>i.appliesTo(e,t));if(o.length===0)return{name:"bunup:inject-shims",setup(){}};return{name:"bunup:inject-shims",setup(i){i.onLoad({filter:Ne},async({path:s})=>{let a=await Bun.file(s).text(),m=o.filter((l)=>l.isNeededInFile(a));if(m.length===0)return;let{shebangLine:u,codeContent:c}=We(a),p=m.map((l)=>l.generateCode()).join("");return{contents:u+p+c}})}}}function Fe(e){if(e===!0)return Object.keys(_);if(!e)return[];return Object.entries(e).filter(([t,r])=>r&&(t in _)).map(([t])=>t)}function We(e){if(!e.startsWith("#!"))return{shebangLine:"",codeContent:e};let t=e.indexOf(`
26
+ `);return t===-1?{shebangLine:"",codeContent:e}:{shebangLine:e.slice(0,t+1),codeContent:e.slice(t+1)}}var H=new Set;async function ke(e,t){let r=ue(e);if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");if(r.clean)G(t,r.outDir);N(r.silent);let{packageJson:n,path:o}=await ie(t);if(n&&o)f.cli(`Using package.json: ${y(o,2)}`,{muted:!0,identifier:r.name,once:`${o}:${r.name}`});let i=A(r.entry),s=n?.type,a=S(r,n),m=$(r);if(!r.dtsOnly){let u=[de(a,m)],c=r.format.flatMap((p)=>i.map((l)=>{return Ue(r,t,l,p,s,u)}));await Promise.all(c)}if(r.dts||r.dtsOnly){let u=await ae(t,r.preferredTsconfigPath);if(u.path)f.cli(`Using tsconfig: ${y(u.path,2)}`,{muted:!0,identifier:r.name,once:`${u.path}:${r.name}`});let c=r.format.filter((l)=>{if(l==="iife"&&!b(s)&&r.format.includes("cjs"))return!1;return!0}),p=typeof r.dts==="object"&&r.dts.entry?A(r.dts.entry):ne(i);try{await Promise.all(p.map(async(l)=>{let xe=await te(t,l.path,r,u,n);await Promise.all(c.map(async(v)=>{let he=r.outputExtension?.({format:v,packageType:s,options:r,entry:l}).dts??U(v,s),P=`${t}/${r.outDir}/${l.name}${he}`;await Bun.write(P,xe);let be=Bun.file(P).size||0;f.progress("DTS",y(P),L(be),r.name)}))}))}catch(l){throw new d(g(l))}}}async function Ue(e,t,r,n,o,i){let s=e.outputExtension?.({format:n,packageType:o,options:e,entry:r}).js??k(n,o),a=await Bun.build({entrypoints:[`${t}/${r.path}`],format:n,naming:{entry:se(r.name,s)},splitting:fe(e.splitting,n),bytecode:le(e.bytecode,n),define:me(e.define,e.shims,e.env,n),minify:ce(e),outdir:`${t}/${e.outDir}`,target:e.target,sourcemap:e.sourcemap,loader:e.loader,drop:e.drop,banner:e.banner,footer:e.footer,publicPath:e.publicPath,env:pe(e.env),plugins:[...i,ge({format:n,target:e.target,shims:e.shims}),...e.bunBuildPlugins??[]],throw:!1});if(!a.success)for(let c of a.logs){if(c.level==="error")throw new h(c.message);if(c.level==="warning")f.warn(c.message);else if(c.level==="info")f.info(c.message)}let m=`${t}/${e.outDir}/${r.name}${s}`,u=Bun.file(m).size||0;f.progress(n.toUpperCase(),y(m),L(u),e.name)}export{Ee as defineWorkspace,ye as defineConfig,ke as build};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bunup",
3
- "version": "0.4.19",
3
+ "version": "0.4.20",
4
4
  "description": "An extremely fast, zero-config bundler for TypeScript & JavaScript, powered by Bun.",
5
5
  "main": "./build/index.js",
6
6
  "types": "./build/index.d.ts",
@@ -17,10 +17,10 @@
17
17
  "@commitlint/config-conventional": "^19.5.0",
18
18
  "@types/bun": "^1.2.5",
19
19
  "bumpp": "^10.1.0",
20
- "bunup": "^0.4.11",
20
+ "bunup": "^0.4.19",
21
21
  "husky": "^9.1.7",
22
22
  "typescript": "^5.8.3",
23
- "create-bunup": "0.4.19"
23
+ "create-bunup": "0.4.20"
24
24
  },
25
25
  "peerDependencies": {
26
26
  "typescript": ">=4.5.0"