bunup 0.3.12 → 0.3.13

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
@@ -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/#using-a-configuration-file-with-named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:c,path:o})}else t.push({name:i,path:o}),e.add(i),r[i]=o}if(Array.isArray(n))for(let i of n){let o=A(i);s(o,i)}else if(typeof n==="object")Object.entries(n).forEach(([i,o])=>{s(i,o)});else{let i=A(n);s(i,n)}return t}function hn(n,t){return`[dir]/${n}${t}`}import{loadTsConfig as Qn}from"load-tsconfig";function xn(n){try{return Qn(".",n)}catch(t){return l.warn(`Failed to load tsconfig: ${m(t)}`),{path:n,data:{},files:[]}}}import Q from"node:path";async function yn(n){let t=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let e of t){let r=Q.join(n,`bunup.config${e}`);try{if(!await Bun.file(r).exists())continue;let i=await Zn(r,e);if(!i)continue;return{configs:Fn(i,n),configFilePath:r}}catch(s){throw new y(`Failed to load config from ${r}: ${m(s)}`)}}return{configs:[],configFilePath:""}}async function Zn(n,t){if(t===".json"||t===".jsonc")return zn(n);return Xn(n)}async function zn(n){try{let t=await Bun.file(n).text(),e=JSON.parse(t);return e.bunup||e}catch(t){throw new Error(`Invalid JSON in config file. ${m(t)}`)}}async function Xn(n){try{let t=await import(`file://${n}`),e=t.default||t;if(!e)return l.warn(`No export found in ${n}. Make sure you're exporting your configuration.`),{};return e}catch(t){throw new Error(`Failed to import config file. ${m(t)}`)}}function Fn(n,t){let e=[];if(Vn(n))nt(n,t,e);else if(Array.isArray(n))tt(n,t,e);else if(n&&typeof n==="object")e.push({options:n,rootDir:t});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return e}function Vn(n){return Array.isArray(n)&&n.length>0&&n.every((t)=>typeof t==="object"&&t!==null&&("name"in t)&&("root"in t)&&("config"in t))}function nt(n,t,e){for(let r of n){let s=Q.resolve(t,r.root);if(Array.isArray(r.config))for(let i of r.config)e.push({options:{name:r.name,...i},rootDir:s});else e.push({options:{name:r.name,...r.config},rootDir:s})}}function tt(n,t,e){for(let r of n){if(!r||typeof r!=="object")throw new Error("Invalid configuration item. Expected an object.");e.push({options:r,rootDir:t})}}async function wn(n){let t=Q.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let r=await Bun.file(t).text();return{packageJson:JSON.parse(r),path:t}}catch(e){return l.warn(`Failed to load package.json at ${t}: ${m(e)}`),{packageJson:null,path:t}}}function bn(n,t){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(r)=>{let s=r.path;if(n.some((o)=>o.test(s))&&!t.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}var v=new Set;async function D(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new y("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:e,path:r}=await wn(t);if(e)l.cli(`Using package.json: ${w(r)}`,{muted:!0});let s=e?.type,i=k(n,e),o=L(n),a=[bn(i,o)],c=T(n.entry),u=z(n,t),p=n.format.flatMap((f)=>c.map((x)=>{return et(n,t,x,f,s,a,u)}));if(await Promise.all(p),n.dts){let f=xn(n.preferredTsconfigPath);if(f.path)l.cli(`Using tsconfig: ${w(f.path)}`,{muted:!0});let x=n.format.filter((O)=>{if(O==="iife"&&!N(s)&&n.format.includes("cjs"))return!1;return!0}),$=typeof n.dts==="object"&&n.dts.entry?T(n.dts.entry):c;try{await Promise.all($.map(async(O)=>{let Rn=await dn(t,O.path,n,f,e);await Promise.all(x.map(async(Sn)=>{let jn=V(Sn,s),G=`${t}/${n.outDir}/${O.name}${jn}`;await Bun.write(G,Rn);let An=Bun.file(G).size||0;l.progress("DTS",w(G),P(An),n.name)}))}))}catch(O){throw new d(m(O))}}}async function et(n,t,e,r,s,i,o){let a=F(r,s),c=await Bun.build({...o,entrypoints:[`${t}/${e.path}`],format:r,naming:{entry:hn(e.name,a)},splitting:tn(n.splitting,r),plugins:i,throw:!1});if(!c.success)c.logs.forEach((f)=>{if(f.level==="error")throw new y(f.message);else if(f.level==="warning")l.warn(f.message);else if(f.level==="info")l.info(f.message)});let u=`${t}/${n.outDir}/${e.name}${a}`,p=Bun.file(u).size||0;l.progress(r.toUpperCase(),w(u),P(p),n.name)}var H="0.3.12";var $n="https://bun.sh/docs/installation",On="https://bunup.arshadyaseen.com/#cli-options";function b(n){return(t,e)=>{e[n]=t===!0?!0:t==="true"}}function S(n){return(t,e)=>{if(typeof t==="string")e[n]=t;else throw new h(`Option --${n} requires a string value`)}}function Cn(n){return(t,e)=>{if(typeof t==="string")e[n]=t.split(",");else throw new h(`Option --${n} requires a string value`)}}function st(){console.log(`
23
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:c,path:o})}else t.push({name:i,path:o}),e.add(i),r[i]=o}if(Array.isArray(n))for(let i of n){let o=A(i);s(o,i)}else if(typeof n==="object")Object.entries(n).forEach(([i,o])=>{s(i,o)});else{let i=A(n);s(i,n)}return t}function hn(n,t){return`[dir]/${n}${t}`}import{loadTsConfig as Qn}from"load-tsconfig";function xn(n){try{return Qn(".",n)}catch(t){return l.warn(`Failed to load tsconfig: ${m(t)}`),{path:n,data:{},files:[]}}}import Q from"node:path";async function yn(n){let t=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let e of t){let r=Q.join(n,`bunup.config${e}`);try{if(!await Bun.file(r).exists())continue;let i=await Zn(r,e);if(!i)continue;return{configs:Fn(i,n),configFilePath:r}}catch(s){throw new y(`Failed to load config from ${r}: ${m(s)}`)}}return{configs:[],configFilePath:""}}async function Zn(n,t){if(t===".json"||t===".jsonc")return zn(n);return Xn(n)}async function zn(n){try{let t=await Bun.file(n).text(),e=JSON.parse(t);return e.bunup||e}catch(t){throw new Error(`Invalid JSON in config file. ${m(t)}`)}}async function Xn(n){try{let t=await import(`file://${n}`),e=t.default||t;if(!e)return l.warn(`No export found in ${n}. Make sure you're exporting your configuration.`),{};return e}catch(t){throw new Error(`Failed to import config file. ${m(t)}`)}}function Fn(n,t){let e=[];if(Vn(n))nt(n,t,e);else if(Array.isArray(n))tt(n,t,e);else if(n&&typeof n==="object")e.push({options:n,rootDir:t});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return e}function Vn(n){return Array.isArray(n)&&n.length>0&&n.every((t)=>typeof t==="object"&&t!==null&&("name"in t)&&("root"in t)&&("config"in t))}function nt(n,t,e){for(let r of n){let s=Q.resolve(t,r.root);if(Array.isArray(r.config))for(let i of r.config)e.push({options:{name:r.name,...i},rootDir:s});else e.push({options:{name:r.name,...r.config},rootDir:s})}}function tt(n,t,e){for(let r of n){if(!r||typeof r!=="object")throw new Error("Invalid configuration item. Expected an object.");e.push({options:r,rootDir:t})}}async function wn(n){let t=Q.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let r=await Bun.file(t).text();return{packageJson:JSON.parse(r),path:t}}catch(e){return l.warn(`Failed to load package.json at ${t}: ${m(e)}`),{packageJson:null,path:t}}}function bn(n,t){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(r)=>{let s=r.path;if(n.some((o)=>o.test(s))&&!t.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}var v=new Set;async function D(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new y("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:e,path:r}=await wn(t);if(e)l.cli(`Using package.json: ${w(r)}`,{muted:!0});let s=e?.type,i=k(n,e),o=L(n),a=[bn(i,o)],c=T(n.entry),u=z(n,t),p=n.format.flatMap((f)=>c.map((x)=>{return et(n,t,x,f,s,a,u)}));if(await Promise.all(p),n.dts){let f=xn(n.preferredTsconfigPath);if(f.path)l.cli(`Using tsconfig: ${w(f.path)}`,{muted:!0});let x=n.format.filter((O)=>{if(O==="iife"&&!N(s)&&n.format.includes("cjs"))return!1;return!0}),$=typeof n.dts==="object"&&n.dts.entry?T(n.dts.entry):c;try{await Promise.all($.map(async(O)=>{let Rn=await dn(t,O.path,n,f,e);await Promise.all(x.map(async(Sn)=>{let jn=V(Sn,s),G=`${t}/${n.outDir}/${O.name}${jn}`;await Bun.write(G,Rn);let An=Bun.file(G).size||0;l.progress("DTS",w(G),P(An),n.name)}))}))}catch(O){throw new d(m(O))}}}async function et(n,t,e,r,s,i,o){let a=F(r,s),c=await Bun.build({...o,entrypoints:[`${t}/${e.path}`],format:r,naming:{entry:hn(e.name,a)},splitting:tn(n.splitting,r),plugins:i,throw:!1});if(!c.success)c.logs.forEach((f)=>{if(f.level==="error")throw new y(f.message);else if(f.level==="warning")l.warn(f.message);else if(f.level==="info")l.info(f.message)});let u=`${t}/${n.outDir}/${e.name}${a}`,p=Bun.file(u).size||0;l.progress(r.toUpperCase(),w(u),P(p),n.name)}var H="0.3.13";var $n="https://bun.sh/docs/installation",On="https://bunup.arshadyaseen.com/#cli-options";function b(n){return(t,e)=>{e[n]=t===!0?!0:t==="true"}}function S(n){return(t,e)=>{if(typeof t==="string")e[n]=t;else throw new h(`Option --${n} requires a string value`)}}function Cn(n){return(t,e)=>{if(typeof t==="string")e[n]=t.split(",");else throw new h(`Option --${n} requires a string value`)}}function st(){console.log(`
24
24
  Bunup - An extremely fast, zero-config bundler for JavaScript and TypeScript, powered by Bun.
25
25
  `),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${On}\x1B[0m
26
26
  `),process.exit(0)}function it(){console.log(H),process.exit(0)}var ot={name:{flags:["n","name"],handler:S("name")},format:{flags:["f","format"],handler:(n,t)=>{if(typeof n==="string")t.format=n.split(",");else throw new h("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:S("outDir")},minify:{flags:["m","minify"],handler:b("minify")},watch:{flags:["w","watch"],handler:b("watch")},dts:{flags:["d","dts"],handler:b("dts")},banner:{flags:["b","banner"],handler:S("banner")},footer:{flags:["f","footer"],handler:S("footer")},external:{flags:["e","external"],handler:Cn("external")},sourcemap:{flags:["sm","sourcemap"],handler:S("sourcemap")},target:{flags:["t","target"],handler:S("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:b("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:b("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:b("minifySyntax")},clean:{flags:["c","clean"],handler:b("clean")},splitting:{flags:["s","splitting"],handler:b("splitting")},noExternal:{flags:["ne","no-external"],handler:Cn("noExternal")}},at={help:{flags:["h","help"],handler:()=>st()},version:{flags:["v","version"],handler:()=>it()}},U={};for(let n of Object.values(ot))if(n)for(let t of n.flags)U[t]=n.handler;for(let n of Object.values(at))for(let t of n.flags)U[t]=n.handler;function En(n){let t={},e={},r=0;while(r<n.length){let s=n[r];if(s.startsWith("--")){let i,o;if(s.includes("=")){let[a,c]=s.slice(2).split("=",2);i=a,o=c}else{i=s.slice(2);let a=n[r+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")r++}if(i==="entry")if(typeof o==="string"){let a=A(o);if(e[a])l.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);e[a]=o}else throw new h("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(e[a])l.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);e[a]=o}else throw new h(`Option --entry.${a} requires a string value`)}else{let a=U[i];if(a)a(o,t);else throw new h(`Unknown option: --${i}`)}}else if(s.startsWith("-")){let i=s.slice(1),o=n[r+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")r++;let c=U[i];if(c)c(a,t);else throw new h(`Unknown option: -${i}`)}else{let i=A(s);if(e[i])l.warn(`Duplicate entry name '${i}' derived from positional argument '${s}'. Overwriting previous entry.`);e[i]=s}r++}if(Object.keys(e).length>0)t.entry=e;return t}(()=>{if(typeof Bun==="undefined")throw new h(`Bunup requires Bun to run.
package/build/index.js CHANGED
@@ -1,4 +1,4 @@
1
- var jn=require("node:module");var hn=Object.create;var{getPrototypeOf:bn,defineProperty:R,getOwnPropertyNames:G,getOwnPropertyDescriptor:Rn}=Object,H=Object.prototype.hasOwnProperty;var w=(n,t,r)=>{r=n!=null?hn(bn(n)):{};let e=t||!n||!n.__esModule?R(r,"default",{value:n,enumerable:!0}):r;for(let i of G(n))if(!H.call(e,i))R(e,i,{get:()=>n[i],enumerable:!0});return e},k=new WeakMap,Bn=(n)=>{var t=k.get(n),r;if(t)return t;if(t=R({},"__esModule",{value:!0}),n&&typeof n==="object"||typeof n==="function")G(n).map((e)=>!H.call(t,e)&&R(t,e,{get:()=>n[e],enumerable:!(r=Rn(n,e))||r.enumerable}));return k.set(n,t),t};var On=(n,t)=>{for(var r in t)R(n,r,{get:t[r],enumerable:!0,configurable:!0,set:(e)=>t[r]=()=>e})};var Ln={};On(Ln,{defineWorkspace:()=>J,defineConfig:()=>L,build:()=>wn});module.exports=Bn(Ln);function L(n){return n}function J(n){return n}var nn=require("rollup"),tn=w(require("rollup-plugin-dts")),M=w(require("typescript"));class A extends Error{constructor(n){super(n);this.name="BunupError"}}class h extends A{constructor(n){super(n);this.name="BunupBuildError"}}class d extends A{constructor(n){super(n);this.name="BunupDTSBuildError"}}var p=(n)=>{if(n instanceof Error)return n.message;return String(n)};var Nn=w(require("node:fs/promises")),Sn=w(require("node:path"));function Y(n,t){return{outdir:`${t}/${n.outDir}`,minify:Mn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap,define:n.define,loader:n.loader,drop:n.drop,banner:n.banner,footer:n.footer}}function Mn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=n,s=t===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function D(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function q(n=8){return Math.random().toString(36).substring(2,2+n)}function K(n,t){switch(n){case"esm":return".mjs";case"cjs":return B(t)?".cjs":".js";case"iife":return".global.js"}}function Q(n,t){switch(n){case"esm":return".d.mts";case"cjs":return B(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function B(n){return n==="module"}function Z(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function U(n,t){return n===void 0?t==="esm":n}function T(n){if(n===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${t[r]}`;return`${(n/Math.pow(1024,r)).toFixed(2)} ${t[r]}`}function b(n,t=3){return n.split("/").slice(-t).join("/")}function P(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${D(t)}($|\\/|\\\\)`):t)}function O(n,t){return P(n.external||[]).concat(Z(t).map((r)=>new RegExp(`^${D(r)}($|\\/|\\\\)`)))}function j(n){return P(n.noExternal||[])}var I=w(require("node:path")),V=require("oxc-resolver");var $=w(require("path"));var m="\x00virtual:",_=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(m))return t;if(!r?.startsWith(m)||!t.startsWith("."))return null;let e=r.slice(m.length),i=$.default.resolve($.default.dirname(e),t);if(t==="."){let o=$.default.join($.default.dirname(e),"index.d.ts");if(n.has(o))return`${m}${o}`;i=$.default.dirname(e)}if(n.has(i))return`${m}${i}`;let s=`${i}.d.ts`;if(n.has(s))return`${m}${s}`;if(t.startsWith(".")){let o=$.default.join(i,"index.d.ts");if(n.has(o))return`${m}${o}`}return null},load(t){if(t.startsWith(m)){let r=t.slice(m.length),e=n.get(r);if(e)return z.add(r),e}return null}}};var X;function F(n){return{name:"bunup:types-resolve",buildStart(){X||=new V.ResolverFactory({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(r=r?.replace(m,""),/\0/.test(t))return;if(n){if(!n.some((o)=>{let a=!1;if(typeof o==="string")a=o===t||!!(r&&r.includes(o));else a=o.test(t)||!!(r&&o.test(r));return a}))return}let e=r?I.default.dirname(r):process.cwd(),{path:i}=await X.async(e,t);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 rn(n,t,r,e,i){let s=n.replace(/\.tsx?$/,".d.ts"),o=`${m}${s}`,a=e.data?.compilerOptions,f=O(r,i),g=j(r),l;try{l=await nn.rollup({input:o,onwarn(x,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;E(x)},plugins:[_(t),typeof r.dts==="object"&&"resolve"in r.dts&&F(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),tn.default({tsconfig:e.path,compilerOptions:{...a?M.default.parseJsonConfigFileContent({compilerOptions:a},M.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:M.default.ScriptTarget.ESNext}})],external:(x)=>f.some((E)=>E.test(x))&&!g.some((E)=>E.test(x))});let{output:c}=await l.generate({});if(!c[0]?.code)throw new d("Generated bundle is empty");return c[0].code}catch(c){throw new d(`DTS bundling failed: ${p(c)}`)}finally{if(l)await l.close()}}var y=w(require("node:path"));var u={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"},formatMessage({colorCode:n,label:t,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[g,...l]=a.split(" "),c=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-g.length)),x=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${g}${c} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${l.join(" ")}${x}`}let f=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${a}${f}`},output(n,t={},r=console.log){if(t.verticalSpace)console.log("");if(r(n),t.verticalSpace)console.log("")},cli(n,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},info(n,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},warn(n,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)},error(n,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)},progress(n,t,r,e){let i=String(n),s=this.colors.default,o,a,f={};if(typeof r==="string")o=r,a=e;else if(r)o=r.size,a=r.identifier,f=r;for(let[l,c]of Object.entries(this.colors.progress))if(i.includes(l)){s=c;break}let g=this.formatMessage({colorCode:s,label:i,message:t,size:o,identifier:a,muted:f.muted});this.output(g,f)}};var An=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Dn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function en(n,t){let r=new Set([n]),e=[n],i=vn(t),s=sn(t);while(e.length){let o=e.pop();if(!o)continue;try{let a=await Bun.file(o).text(),f=Tn(a);for(let g of f){let l=g.startsWith(".")?y.default.resolve(y.default.dirname(o),g):kn(g,i,s);if(!l)continue;let c=await Wn(l);if(c&&!r.has(c))r.add(c),e.push(c)}}catch(a){u.warn(`Error processing ${o}: ${p(a)}`)}}return r}function Tn(n){let t=new Set;for(let r of[An,Dn]){let e;while((e=r.exec(n))!==null)t.add(e[2])}return Array.from(t)}async function Wn(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let e=`${n}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function sn(n){let t=y.default.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?y.default.resolve(t,n.data.compilerOptions.baseUrl):t}function vn(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let e=sn(n);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");t.set(`^${o}$`,y.default.join(e,a))}return t}function kn(n,t,r){for(let[e,i]of t){let s=new RegExp(e),o=n.match(s);if(o)return i.replace("$1",o[1]||"")}return r?y.default.join(r,n):null}var on=require("oxc-transform");async function an(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts");if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=on.isolatedDeclaration(r,s);if(o)t.set(e,o)}catch(e){u.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),t}var W=w(require("node:fs/promises")),N=w(require("node:path")),Gn=require("oxc-transform");async function cn(n,t){let r=N.default.resolve(n),e=N.default.resolve(r,t);if(!await W.default.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(N.default.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function fn(n,t,r,e,i){let{absoluteEntry:s}=await cn(n,t),o=await en(s,e),a=await an(o);return rn(s,a,r,e,i)}function un(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function v(n){let t=[],r=new Set,e={};function i(s,o){if(r.has(s)){let a=q(),f=`${s}_${a}`;u.warn(`Output name conflict: "${s}" is used by multiple files.
1
+ var jn=require("node:module");var hn=Object.create;var{getPrototypeOf:bn,defineProperty:R,getOwnPropertyNames:G,getOwnPropertyDescriptor:Rn}=Object,H=Object.prototype.hasOwnProperty;var w=(n,t,r)=>{r=n!=null?hn(bn(n)):{};let e=t||!n||!n.__esModule?R(r,"default",{value:n,enumerable:!0}):r;for(let i of G(n))if(!H.call(e,i))R(e,i,{get:()=>n[i],enumerable:!0});return e},k=new WeakMap,Bn=(n)=>{var t=k.get(n),r;if(t)return t;if(t=R({},"__esModule",{value:!0}),n&&typeof n==="object"||typeof n==="function")G(n).map((e)=>!H.call(t,e)&&R(t,e,{get:()=>n[e],enumerable:!(r=Rn(n,e))||r.enumerable}));return k.set(n,t),t};var On=(n,t)=>{for(var r in t)R(n,r,{get:t[r],enumerable:!0,configurable:!0,set:(e)=>t[r]=()=>e})};var Ln={};On(Ln,{defineWorkspace:()=>J,defineConfig:()=>L,build:()=>wn});module.exports=Bn(Ln);function L(n){return n}function J(n){return n}var nn=require("rollup"),tn=w(require("rollup-plugin-dts")),M=w(require("typescript"));class A extends Error{constructor(n){super(n);this.name="BunupError"}}class h extends A{constructor(n){super(n);this.name="BunupBuildError"}}class d extends A{constructor(n){super(n);this.name="BunupDTSBuildError"}}var p=(n)=>{if(n instanceof Error)return n.message;return String(n)};var Nn=w(require("node:fs/promises")),Sn=w(require("node:path"));function Y(n,t){return{outdir:`${t}/${n.outDir}`,minify:Mn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap,define:n.define,loader:n.loader,drop:n.drop,banner:n.banner,footer:n.footer}}function Mn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=n,s=t===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function D(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function q(n=8){return Math.random().toString(36).substring(2,2+n)}function K(n,t){switch(n){case"esm":return".mjs";case"cjs":return B(t)?".cjs":".js";case"iife":return".global.js"}}function Q(n,t){switch(n){case"esm":return".d.mts";case"cjs":return B(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function B(n){return n==="module"}function Z(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function U(n,t){return n===void 0?t==="esm":n}function T(n){if(n===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${t[r]}`;return`${(n/Math.pow(1024,r)).toFixed(2)} ${t[r]}`}function b(n,t=3){return n.split("/").slice(-t).join("/")}function P(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${D(t)}($|\\/|\\\\)`):t)}function O(n,t){return P(n.external||[]).concat(Z(t).map((r)=>new RegExp(`^${D(r)}($|\\/|\\\\)`)))}function j(n){return P(n.noExternal||[])}var I=w(require("node:path")),V=require("oxc-resolver");var $=w(require("path"));var m="\x00virtual:",_=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(m))return t;if(!r?.startsWith(m)||!t.startsWith("."))return null;let e=r.slice(m.length),i=$.default.resolve($.default.dirname(e),t);if(t==="."){let o=$.default.join($.default.dirname(e),"index.d.ts");if(n.has(o))return`${m}${o}`;i=$.default.dirname(e)}if(n.has(i))return`${m}${i}`;let s=`${i}.d.ts`;if(n.has(s))return`${m}${s}`;if(t.startsWith(".")){let o=$.default.join(i,"index.d.ts");if(n.has(o))return`${m}${o}`}return null},load(t){if(t.startsWith(m)){let r=t.slice(m.length),e=n.get(r);if(e)return z.add(r),e}return null}}};var X;function F(n){return{name:"bunup:types-resolve",buildStart(){X||=new V.ResolverFactory({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(r=r?.replace(m,""),/\0/.test(t))return;if(n){if(!n.some((o)=>{let c=!1;if(typeof o==="string")c=o===t||!!(r&&r.includes(o));else c=o.test(t)||!!(r&&o.test(r));return c}))return}let e=r?I.default.dirname(r):process.cwd(),{path:i}=await X.async(e,t);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 rn(n,t,r,e,i){let s=n.replace(/\.tsx?$/,".d.ts"),o=`${m}${s}`,c=e.data?.compilerOptions,f=O(r,i),g=j(r),l;try{l=await nn.rollup({input:o,onwarn(x,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;E(x)},plugins:[_(t),typeof r.dts==="object"&&"resolve"in r.dts&&F(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),tn.default({tsconfig:e.path,compilerOptions:{...c?M.default.parseJsonConfigFileContent({compilerOptions:c},M.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:M.default.ScriptTarget.ESNext}})],external:(x)=>f.some((E)=>E.test(x))&&!g.some((E)=>E.test(x))});let{output:a}=await l.generate({});if(!a[0]?.code)throw new d("Generated bundle is empty");return a[0].code}catch(a){throw new d(`DTS bundling failed: ${p(a)}`)}finally{if(l)await l.close()}}var y=w(require("node:path"));var u={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"},formatMessage({colorCode:n,label:t,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),c=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[g,...l]=c.split(" "),a=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-g.length)),x=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${g}${a} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${l.join(" ")}${x}`}let f=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${c}${f}`},output(n,t={},r=console.log){if(t.verticalSpace)console.log("");if(r(n),t.verticalSpace)console.log("")},cli(n,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},info(n,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},warn(n,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)},error(n,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)},progress(n,t,r,e){let i=String(n),s=this.colors.default,o,c,f={};if(typeof r==="string")o=r,c=e;else if(r)o=r.size,c=r.identifier,f=r;for(let[l,a]of Object.entries(this.colors.progress))if(i.includes(l)){s=a;break}let g=this.formatMessage({colorCode:s,label:i,message:t,size:o,identifier:c,muted:f.muted});this.output(g,f)}};var An=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Dn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function en(n,t){let r=new Set([n]),e=[n],i=vn(t),s=sn(t);while(e.length){let o=e.pop();if(!o)continue;try{let c=await Bun.file(o).text(),f=Tn(c);for(let g of f){let l=g.startsWith(".")?y.default.resolve(y.default.dirname(o),g):kn(g,i,s);if(!l)continue;let a=await Wn(l);if(a&&!r.has(a))r.add(a),e.push(a)}}catch(c){u.warn(`Error processing ${o}: ${p(c)}`)}}return r}function Tn(n){let t=new Set;for(let r of[An,Dn]){let e;while((e=r.exec(n))!==null)t.add(e[2])}return Array.from(t)}async function Wn(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let e=`${n}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function sn(n){let t=y.default.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?y.default.resolve(t,n.data.compilerOptions.baseUrl):t}function vn(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let e=sn(n);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),c=s[0].replace(/\*/g,"$1");t.set(`^${o}$`,y.default.join(e,c))}return t}function kn(n,t,r){for(let[e,i]of t){let s=new RegExp(e),o=n.match(s);if(o)return i.replace("$1",o[1]||"")}return r?y.default.join(r,n):null}var on=require("oxc-transform");async function cn(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts");if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=on.isolatedDeclaration(r,s);if(o)t.set(e,o)}catch(e){u.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),t}var W=w(require("node:fs/promises")),N=w(require("node:path")),Gn=require("oxc-transform");async function an(n,t){let r=N.default.resolve(n),e=N.default.resolve(r,t);if(!await W.default.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(N.default.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function fn(n,t,r,e,i){let{absoluteEntry:s}=await an(n,t),o=await en(s,e),c=await cn(o);return rn(s,c,r,e,i)}function un(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function v(n){let t=[],r=new Set,e={};function i(s,o){if(r.has(s)){let c=q(),f=`${s}_${c}`;u.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
  ${e[s]} -> ${s}.js
@@ -12,4 +12,4 @@ To fix this, use named entries in your configuration:
12
12
  }
13
13
  }
14
14
 
15
- See: https://bunup.arshadyaseen.com/#using-a-configuration-file-with-named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:f,path:o})}else t.push({name:s,path:o}),r.add(s),e[s]=o}if(Array.isArray(n))for(let s of n){let o=un(s);i(o,s)}else if(typeof n==="object")Object.entries(n).forEach(([s,o])=>{i(s,o)});else{let s=un(n);i(s,n)}return t}function gn(n,t){return`[dir]/${n}${t}`}var ln=require("load-tsconfig");function mn(n){try{return ln.loadTsConfig(".",n)}catch(t){return u.warn(`Failed to load tsconfig: ${p(t)}`),{path:n,data:{},files:[]}}}var pn=w(require("node:path"));async function xn(n){let t=pn.default.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let e=await Bun.file(t).text();return{packageJson:JSON.parse(e),path:t}}catch(r){return u.warn(`Failed to load package.json at ${t}: ${p(r)}`),{packageJson:null,path:t}}}function dn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let i=e.path;if(n.some((o)=>o.test(i))&&!t.some((o)=>o.test(i)))return{path:i,external:!0};return null})}}}var z=new Set;async function wn(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:r,path:e}=await xn(t);if(r)u.cli(`Using package.json: ${b(e)}`,{muted:!0});let i=r?.type,s=O(n,r),o=j(n),a=[dn(s,o)],f=v(n.entry),g=Y(n,t),l=n.format.flatMap((c)=>f.map((x)=>{return Hn(n,t,x,c,i,a,g)}));if(await Promise.all(l),n.dts){let c=mn(n.preferredTsconfigPath);if(c.path)u.cli(`Using tsconfig: ${b(c.path)}`,{muted:!0});let x=n.format.filter((C)=>{if(C==="iife"&&!B(i)&&n.format.includes("cjs"))return!1;return!0}),E=typeof n.dts==="object"&&n.dts.entry?v(n.dts.entry):f;try{await Promise.all(E.map(async(C)=>{let En=await fn(t,C.path,n,c,r);await Promise.all(x.map(async($n)=>{let yn=Q($n,i),S=`${t}/${n.outDir}/${C.name}${yn}`;await Bun.write(S,En);let Cn=Bun.file(S).size||0;u.progress("DTS",b(S),T(Cn),n.name)}))}))}catch(C){throw new d(p(C))}}}async function Hn(n,t,r,e,i,s,o){let a=K(e,i),f=await Bun.build({...o,entrypoints:[`${t}/${r.path}`],format:e,naming:{entry:gn(r.name,a)},splitting:U(n.splitting,e),plugins:s,throw:!1});if(!f.success)f.logs.forEach((c)=>{if(c.level==="error")throw new h(c.message);else if(c.level==="warning")u.warn(c.message);else if(c.level==="info")u.info(c.message)});let g=`${t}/${n.outDir}/${r.name}${a}`,l=Bun.file(g).size||0;u.progress(e.toUpperCase(),b(g),T(l),n.name)}
15
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:f,path:o})}else t.push({name:s,path:o}),r.add(s),e[s]=o}if(Array.isArray(n))for(let s of n){let o=un(s);i(o,s)}else if(typeof n==="object")Object.entries(n).forEach(([s,o])=>{i(s,o)});else{let s=un(n);i(s,n)}return t}function gn(n,t){return`[dir]/${n}${t}`}var ln=require("load-tsconfig");function mn(n){try{return ln.loadTsConfig(".",n)}catch(t){return u.warn(`Failed to load tsconfig: ${p(t)}`),{path:n,data:{},files:[]}}}var pn=w(require("node:path"));async function xn(n){let t=pn.default.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let e=await Bun.file(t).text();return{packageJson:JSON.parse(e),path:t}}catch(r){return u.warn(`Failed to load package.json at ${t}: ${p(r)}`),{packageJson:null,path:t}}}function dn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let i=e.path;if(n.some((o)=>o.test(i))&&!t.some((o)=>o.test(i)))return{path:i,external:!0};return null})}}}var z=new Set;async function wn(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:r,path:e}=await xn(t);if(r)u.cli(`Using package.json: ${b(e)}`,{muted:!0});let i=r?.type,s=O(n,r),o=j(n),c=[dn(s,o)],f=v(n.entry),g=Y(n,t),l=n.format.flatMap((a)=>f.map((x)=>{return Hn(n,t,x,a,i,c,g)}));if(await Promise.all(l),n.dts){let a=mn(n.preferredTsconfigPath);if(a.path)u.cli(`Using tsconfig: ${b(a.path)}`,{muted:!0});let x=n.format.filter((C)=>{if(C==="iife"&&!B(i)&&n.format.includes("cjs"))return!1;return!0}),E=typeof n.dts==="object"&&n.dts.entry?v(n.dts.entry):f;try{await Promise.all(E.map(async(C)=>{let En=await fn(t,C.path,n,a,r);await Promise.all(x.map(async($n)=>{let yn=Q($n,i),S=`${t}/${n.outDir}/${C.name}${yn}`;await Bun.write(S,En);let Cn=Bun.file(S).size||0;u.progress("DTS",b(S),T(Cn),n.name)}))}))}catch(C){throw new d(p(C))}}}async function Hn(n,t,r,e,i,s,o){let c=K(e,i),f=await Bun.build({...o,entrypoints:[`${t}/${r.path}`],format:e,naming:{entry:gn(r.name,c)},splitting:U(n.splitting,e),plugins:s,throw:!1});if(!f.success)f.logs.forEach((a)=>{if(a.level==="error")throw new h(a.message);else if(a.level==="warning")u.warn(a.message);else if(a.level==="info")u.info(a.message)});let g=`${t}/${n.outDir}/${r.name}${c}`,l=Bun.file(g).size||0;u.progress(e.toUpperCase(),b(g),T(l),n.name)}
package/build/index.mjs CHANGED
@@ -1,4 +1,4 @@
1
- function an(n){return n}function cn(n){return n}import{rollup as ln}from"rollup";import mn from"rollup-plugin-dts";import S from"typescript";class j extends Error{constructor(n){super(n);this.name="BunupError"}}class $ extends j{constructor(n){super(n);this.name="BunupBuildError"}}class d extends j{constructor(n){super(n);this.name="BunupDTSBuildError"}}var p=(n)=>{if(n instanceof Error)return n.message;return String(n)};import Sn from"node:fs/promises";import Dn from"node:path";function T(n,t){return{outdir:`${t}/${n.outDir}`,minify:fn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap,define:n.define,loader:n.loader,drop:n.drop,banner:n.banner,footer:n.footer}}function fn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=n,s=t===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function M(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function W(n=8){return Math.random().toString(36).substring(2,2+n)}function v(n,t){switch(n){case"esm":return".mjs";case"cjs":return b(t)?".cjs":".js";case"iife":return".global.js"}}function k(n,t){switch(n){case"esm":return".d.mts";case"cjs":return b(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function b(n){return n==="module"}function G(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function H(n,t){return n===void 0?t==="esm":n}function N(n){if(n===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${t[r]}`;return`${(n/Math.pow(1024,r)).toFixed(2)} ${t[r]}`}function y(n,t=3){return n.split("/").slice(-t).join("/")}function L(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${M(t)}($|\\/|\\\\)`):t)}function R(n,t){return L(n.external||[]).concat(G(t).map((r)=>new RegExp(`^${M(r)}($|\\/|\\\\)`)))}function B(n){return L(n.noExternal||[])}import un from"node:path";import{ResolverFactory as gn}from"oxc-resolver";import C from"path";var m="\x00virtual:",J=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(m))return t;if(!r?.startsWith(m)||!t.startsWith("."))return null;let e=r.slice(m.length),i=C.resolve(C.dirname(e),t);if(t==="."){let o=C.join(C.dirname(e),"index.d.ts");if(n.has(o))return`${m}${o}`;i=C.dirname(e)}if(n.has(i))return`${m}${i}`;let s=`${i}.d.ts`;if(n.has(s))return`${m}${s}`;if(t.startsWith(".")){let o=C.join(i,"index.d.ts");if(n.has(o))return`${m}${o}`}return null},load(t){if(t.startsWith(m)){let r=t.slice(m.length),e=n.get(r);if(e)return Y.add(r),e}return null}}};var q;function K(n){return{name:"bunup:types-resolve",buildStart(){q||=new gn({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(r=r?.replace(m,""),/\0/.test(t))return;if(n){if(!n.some((o)=>{let a=!1;if(typeof o==="string")a=o===t||!!(r&&r.includes(o));else a=o.test(t)||!!(r&&o.test(r));return a}))return}let e=r?un.dirname(r):process.cwd(),{path:i}=await q.async(e,t);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(n,t,r,e,i){let s=n.replace(/\.tsx?$/,".d.ts"),o=`${m}${s}`,a=e.data?.compilerOptions,f=R(r,i),g=B(r),l;try{l=await ln({input:o,onwarn(x,w){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;w(x)},plugins:[J(t),typeof r.dts==="object"&&"resolve"in r.dts&&K(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),mn({tsconfig:e.path,compilerOptions:{...a?S.parseJsonConfigFileContent({compilerOptions:a},S.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:S.ScriptTarget.ESNext}})],external:(x)=>f.some((w)=>w.test(x))&&!g.some((w)=>w.test(x))});let{output:c}=await l.generate({});if(!c[0]?.code)throw new d("Generated bundle is empty");return c[0].code}catch(c){throw new d(`DTS bundling failed: ${p(c)}`)}finally{if(l)await l.close()}}import h from"node:path";var u={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"},formatMessage({colorCode:n,label:t,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),a=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[g,...l]=a.split(" "),c=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-g.length)),x=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${g}${c} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${l.join(" ")}${x}`}let f=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${a}${f}`},output(n,t={},r=console.log){if(t.verticalSpace)console.log("");if(r(n),t.verticalSpace)console.log("")},cli(n,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},info(n,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},warn(n,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)},error(n,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)},progress(n,t,r,e){let i=String(n),s=this.colors.default,o,a,f={};if(typeof r==="string")o=r,a=e;else if(r)o=r.size,a=r.identifier,f=r;for(let[l,c]of Object.entries(this.colors.progress))if(i.includes(l)){s=c;break}let g=this.formatMessage({colorCode:s,label:i,message:t,size:o,identifier:a,muted:f.muted});this.output(g,f)}};var pn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,xn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function Z(n,t){let r=new Set([n]),e=[n],i=En(t),s=U(t);while(e.length){let o=e.pop();if(!o)continue;try{let a=await Bun.file(o).text(),f=dn(a);for(let g of f){let l=g.startsWith(".")?h.resolve(h.dirname(o),g):$n(g,i,s);if(!l)continue;let c=await wn(l);if(c&&!r.has(c))r.add(c),e.push(c)}}catch(a){u.warn(`Error processing ${o}: ${p(a)}`)}}return r}function dn(n){let t=new Set;for(let r of[pn,xn]){let e;while((e=r.exec(n))!==null)t.add(e[2])}return Array.from(t)}async function wn(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let e=`${n}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function U(n){let t=h.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?h.resolve(t,n.data.compilerOptions.baseUrl):t}function En(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let e=U(n);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");t.set(`^${o}$`,h.join(e,a))}return t}function $n(n,t,r){for(let[e,i]of t){let s=new RegExp(e),o=n.match(s);if(o)return i.replace("$1",o[1]||"")}return r?h.join(r,n):null}import{isolatedDeclaration as yn}from"oxc-transform";async function P(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts");if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=yn(r,s);if(o)t.set(e,o)}catch(e){u.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),t}import _ from"node:fs/promises";import A from"node:path";import{isolatedDeclaration as mt}from"oxc-transform";async function z(n,t){let r=A.resolve(n),e=A.resolve(r,t);if(!await _.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(A.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function X(n,t,r,e,i){let{absoluteEntry:s}=await z(n,t),o=await Z(s,e),a=await P(o);return Q(s,a,r,e,i)}function I(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function D(n){let t=[],r=new Set,e={};function i(s,o){if(r.has(s)){let a=W(),f=`${s}_${a}`;u.warn(`Output name conflict: "${s}" is used by multiple files.
1
+ function cn(n){return n}function an(n){return n}import{rollup as ln}from"rollup";import mn from"rollup-plugin-dts";import S from"typescript";class j extends Error{constructor(n){super(n);this.name="BunupError"}}class $ extends j{constructor(n){super(n);this.name="BunupBuildError"}}class d extends j{constructor(n){super(n);this.name="BunupDTSBuildError"}}var p=(n)=>{if(n instanceof Error)return n.message;return String(n)};import Sn from"node:fs/promises";import Dn from"node:path";function T(n,t){return{outdir:`${t}/${n.outDir}`,minify:fn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap,define:n.define,loader:n.loader,drop:n.drop,banner:n.banner,footer:n.footer}}function fn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=n,s=t===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function M(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function W(n=8){return Math.random().toString(36).substring(2,2+n)}function v(n,t){switch(n){case"esm":return".mjs";case"cjs":return b(t)?".cjs":".js";case"iife":return".global.js"}}function k(n,t){switch(n){case"esm":return".d.mts";case"cjs":return b(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function b(n){return n==="module"}function G(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function H(n,t){return n===void 0?t==="esm":n}function N(n){if(n===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${t[r]}`;return`${(n/Math.pow(1024,r)).toFixed(2)} ${t[r]}`}function y(n,t=3){return n.split("/").slice(-t).join("/")}function L(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${M(t)}($|\\/|\\\\)`):t)}function R(n,t){return L(n.external||[]).concat(G(t).map((r)=>new RegExp(`^${M(r)}($|\\/|\\\\)`)))}function B(n){return L(n.noExternal||[])}import un from"node:path";import{ResolverFactory as gn}from"oxc-resolver";import C from"path";var m="\x00virtual:",J=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(m))return t;if(!r?.startsWith(m)||!t.startsWith("."))return null;let e=r.slice(m.length),i=C.resolve(C.dirname(e),t);if(t==="."){let o=C.join(C.dirname(e),"index.d.ts");if(n.has(o))return`${m}${o}`;i=C.dirname(e)}if(n.has(i))return`${m}${i}`;let s=`${i}.d.ts`;if(n.has(s))return`${m}${s}`;if(t.startsWith(".")){let o=C.join(i,"index.d.ts");if(n.has(o))return`${m}${o}`}return null},load(t){if(t.startsWith(m)){let r=t.slice(m.length),e=n.get(r);if(e)return Y.add(r),e}return null}}};var q;function K(n){return{name:"bunup:types-resolve",buildStart(){q||=new gn({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(t,r){if(r=r?.replace(m,""),/\0/.test(t))return;if(n){if(!n.some((o)=>{let c=!1;if(typeof o==="string")c=o===t||!!(r&&r.includes(o));else c=o.test(t)||!!(r&&o.test(r));return c}))return}let e=r?un.dirname(r):process.cwd(),{path:i}=await q.async(e,t);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(n,t,r,e,i){let s=n.replace(/\.tsx?$/,".d.ts"),o=`${m}${s}`,c=e.data?.compilerOptions,f=R(r,i),g=B(r),l;try{l=await ln({input:o,onwarn(x,w){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(x.code??""))return;w(x)},plugins:[J(t),typeof r.dts==="object"&&"resolve"in r.dts&&K(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),mn({tsconfig:e.path,compilerOptions:{...c?S.parseJsonConfigFileContent({compilerOptions:c},S.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:S.ScriptTarget.ESNext}})],external:(x)=>f.some((w)=>w.test(x))&&!g.some((w)=>w.test(x))});let{output:a}=await l.generate({});if(!a[0]?.code)throw new d("Generated bundle is empty");return a[0].code}catch(a){throw new d(`DTS bundling failed: ${p(a)}`)}finally{if(l)await l.close()}}import h from"node:path";var u={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"},formatMessage({colorCode:n,label:t,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length)),c=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[g,...l]=c.split(" "),a=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-g.length)),x=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${g}${a} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${l.join(" ")}${x}`}let f=i?` \x1B[48;5;${n};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${n}m${t}\x1B[0m ${o}${c}${f}`},output(n,t={},r=console.log){if(t.verticalSpace)console.log("");if(r(n),t.verticalSpace)console.log("")},cli(n,t={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},info(n,t={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t)},warn(n,t={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.warn)},error(n,t={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:n,identifier:t.identifier,muted:t.muted});this.output(r,t,console.error)},progress(n,t,r,e){let i=String(n),s=this.colors.default,o,c,f={};if(typeof r==="string")o=r,c=e;else if(r)o=r.size,c=r.identifier,f=r;for(let[l,a]of Object.entries(this.colors.progress))if(i.includes(l)){s=a;break}let g=this.formatMessage({colorCode:s,label:i,message:t,size:o,identifier:c,muted:f.muted});this.output(g,f)}};var pn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,xn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function Z(n,t){let r=new Set([n]),e=[n],i=En(t),s=U(t);while(e.length){let o=e.pop();if(!o)continue;try{let c=await Bun.file(o).text(),f=dn(c);for(let g of f){let l=g.startsWith(".")?h.resolve(h.dirname(o),g):$n(g,i,s);if(!l)continue;let a=await wn(l);if(a&&!r.has(a))r.add(a),e.push(a)}}catch(c){u.warn(`Error processing ${o}: ${p(c)}`)}}return r}function dn(n){let t=new Set;for(let r of[pn,xn]){let e;while((e=r.exec(n))!==null)t.add(e[2])}return Array.from(t)}async function wn(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let e=`${n}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function U(n){let t=h.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?h.resolve(t,n.data.compilerOptions.baseUrl):t}function En(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let e=U(n);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),c=s[0].replace(/\*/g,"$1");t.set(`^${o}$`,h.join(e,c))}return t}function $n(n,t,r){for(let[e,i]of t){let s=new RegExp(e),o=n.match(s);if(o)return i.replace("$1",o[1]||"")}return r?h.join(r,n):null}import{isolatedDeclaration as yn}from"oxc-transform";async function P(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let e=r.replace(/\.tsx?$/,".d.ts");if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=yn(r,s);if(o)t.set(e,o)}catch(e){u.warn(`Failed to generate declaration for ${r}: ${p(e)}`)}})),t}import _ from"node:fs/promises";import A from"node:path";import{isolatedDeclaration as mt}from"oxc-transform";async function z(n,t){let r=A.resolve(n),e=A.resolve(r,t);if(!await _.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(A.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function X(n,t,r,e,i){let{absoluteEntry:s}=await z(n,t),o=await Z(s,e),c=await P(o);return Q(s,c,r,e,i)}function I(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function D(n){let t=[],r=new Set,e={};function i(s,o){if(r.has(s)){let c=W(),f=`${s}_${c}`;u.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
  ${e[s]} -> ${s}.js
@@ -12,4 +12,4 @@ To fix this, use named entries in your configuration:
12
12
  }
13
13
  }
14
14
 
15
- See: https://bunup.arshadyaseen.com/#using-a-configuration-file-with-named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:f,path:o})}else t.push({name:s,path:o}),r.add(s),e[s]=o}if(Array.isArray(n))for(let s of n){let o=I(s);i(o,s)}else if(typeof n==="object")Object.entries(n).forEach(([s,o])=>{i(s,o)});else{let s=I(n);i(s,n)}return t}function V(n,t){return`[dir]/${n}${t}`}import{loadTsConfig as Cn}from"load-tsconfig";function F(n){try{return Cn(".",n)}catch(t){return u.warn(`Failed to load tsconfig: ${p(t)}`),{path:n,data:{},files:[]}}}import hn from"node:path";async function nn(n){let t=hn.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let e=await Bun.file(t).text();return{packageJson:JSON.parse(e),path:t}}catch(r){return u.warn(`Failed to load package.json at ${t}: ${p(r)}`),{packageJson:null,path:t}}}function tn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let i=e.path;if(n.some((o)=>o.test(i))&&!t.some((o)=>o.test(i)))return{path:i,external:!0};return null})}}}var Y=new Set;async function bn(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new $("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:r,path:e}=await nn(t);if(r)u.cli(`Using package.json: ${y(e)}`,{muted:!0});let i=r?.type,s=R(n,r),o=B(n),a=[tn(s,o)],f=D(n.entry),g=T(n,t),l=n.format.flatMap((c)=>f.map((x)=>{return Rn(n,t,x,c,i,a,g)}));if(await Promise.all(l),n.dts){let c=F(n.preferredTsconfigPath);if(c.path)u.cli(`Using tsconfig: ${y(c.path)}`,{muted:!0});let x=n.format.filter((E)=>{if(E==="iife"&&!b(i)&&n.format.includes("cjs"))return!1;return!0}),w=typeof n.dts==="object"&&n.dts.entry?D(n.dts.entry):f;try{await Promise.all(w.map(async(E)=>{let rn=await X(t,E.path,n,c,r);await Promise.all(x.map(async(en)=>{let sn=k(en,i),O=`${t}/${n.outDir}/${E.name}${sn}`;await Bun.write(O,rn);let on=Bun.file(O).size||0;u.progress("DTS",y(O),N(on),n.name)}))}))}catch(E){throw new d(p(E))}}}async function Rn(n,t,r,e,i,s,o){let a=v(e,i),f=await Bun.build({...o,entrypoints:[`${t}/${r.path}`],format:e,naming:{entry:V(r.name,a)},splitting:H(n.splitting,e),plugins:s,throw:!1});if(!f.success)f.logs.forEach((c)=>{if(c.level==="error")throw new $(c.message);else if(c.level==="warning")u.warn(c.message);else if(c.level==="info")u.info(c.message)});let g=`${t}/${n.outDir}/${r.name}${a}`,l=Bun.file(g).size||0;u.progress(e.toUpperCase(),y(g),N(l),n.name)}export{cn as defineWorkspace,an as defineConfig,bn as build};
15
+ See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0}),t.push({name:f,path:o})}else t.push({name:s,path:o}),r.add(s),e[s]=o}if(Array.isArray(n))for(let s of n){let o=I(s);i(o,s)}else if(typeof n==="object")Object.entries(n).forEach(([s,o])=>{i(s,o)});else{let s=I(n);i(s,n)}return t}function V(n,t){return`[dir]/${n}${t}`}import{loadTsConfig as Cn}from"load-tsconfig";function F(n){try{return Cn(".",n)}catch(t){return u.warn(`Failed to load tsconfig: ${p(t)}`),{path:n,data:{},files:[]}}}import hn from"node:path";async function nn(n){let t=hn.join(n,"package.json");try{if(!await Bun.file(t).exists())return{packageJson:null,path:t};let e=await Bun.file(t).text();return{packageJson:JSON.parse(e),path:t}}catch(r){return u.warn(`Failed to load package.json at ${t}: ${p(r)}`),{packageJson:null,path:t}}}function tn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(e)=>{let i=e.path;if(n.some((o)=>o.test(i))&&!t.some((o)=>o.test(i)))return{path:i,external:!0};return null})}}}var Y=new Set;async function bn(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new $("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:r,path:e}=await nn(t);if(r)u.cli(`Using package.json: ${y(e)}`,{muted:!0});let i=r?.type,s=R(n,r),o=B(n),c=[tn(s,o)],f=D(n.entry),g=T(n,t),l=n.format.flatMap((a)=>f.map((x)=>{return Rn(n,t,x,a,i,c,g)}));if(await Promise.all(l),n.dts){let a=F(n.preferredTsconfigPath);if(a.path)u.cli(`Using tsconfig: ${y(a.path)}`,{muted:!0});let x=n.format.filter((E)=>{if(E==="iife"&&!b(i)&&n.format.includes("cjs"))return!1;return!0}),w=typeof n.dts==="object"&&n.dts.entry?D(n.dts.entry):f;try{await Promise.all(w.map(async(E)=>{let rn=await X(t,E.path,n,a,r);await Promise.all(x.map(async(en)=>{let sn=k(en,i),O=`${t}/${n.outDir}/${E.name}${sn}`;await Bun.write(O,rn);let on=Bun.file(O).size||0;u.progress("DTS",y(O),N(on),n.name)}))}))}catch(E){throw new d(p(E))}}}async function Rn(n,t,r,e,i,s,o){let c=v(e,i),f=await Bun.build({...o,entrypoints:[`${t}/${r.path}`],format:e,naming:{entry:V(r.name,c)},splitting:H(n.splitting,e),plugins:s,throw:!1});if(!f.success)f.logs.forEach((a)=>{if(a.level==="error")throw new $(a.message);else if(a.level==="warning")u.warn(a.message);else if(a.level==="info")u.info(a.message)});let g=`${t}/${n.outDir}/${r.name}${c}`,l=Bun.file(g).size||0;u.progress(e.toUpperCase(),y(g),N(l),n.name)}export{an as defineWorkspace,cn as defineConfig,bn as build};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bunup",
3
- "version": "0.3.12",
3
+ "version": "0.3.13",
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",