bunup 0.1.39 → 0.1.41
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/README.md +8 -6
- package/build/cli.mjs +6 -6
- package/build/dtsWorker.js +6 -6
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -5,12 +5,14 @@
|
|
|
5
5
|
|
|
6
6
|
An extremely fast, zero-config bundler for TypeScript & JavaScript, powered by [Bun](https://bun.sh) and [Oxc](https://oxc.rs/).
|
|
7
7
|
|
|
8
|
-
| Bundler
|
|
9
|
-
|
|
|
10
|
-
| bunup
|
|
11
|
-
| bunup (+ dts)
|
|
12
|
-
|
|
|
13
|
-
|
|
|
8
|
+
| Bundler | Format | Build Time | Relative Speed |
|
|
9
|
+
| -------------- | -------- | ---------- | -------------------- |
|
|
10
|
+
| bunup | esm, cjs | **6ms** | **⚡️ 9.7x faster** |
|
|
11
|
+
| bunup (+ dts) | esm, cjs | **32ms** | **⚡️ 25.8x faster** |
|
|
12
|
+
| tsdown | esm, cjs | 22ms | 2.6x faster |
|
|
13
|
+
| tsdown (+ dts) | esm, cjs | 52ms | 15.9x faster |
|
|
14
|
+
| tsup | esm, cjs | 58ms | baseline |
|
|
15
|
+
| tsup (+ dts) | esm, cjs | 825ms | baseline |
|
|
14
16
|
|
|
15
17
|
_Lower build time is better. Benchmark run on the same code with identical output formats._
|
|
16
18
|
|
package/build/cli.mjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
#!/usr/bin/env bun
|
|
2
2
|
// @bun
|
|
3
|
-
import
|
|
3
|
+
import z from"node:fs";import In from"node:path";import{isMainThread as Vn}from"node:worker_threads";import{isMainThread as Ln,parentPort as Y,Worker as Un,workerData as Tn}from"node:worker_threads";class E extends Error{constructor(n){super(n);this.name="BunupError"}}class h extends E{constructor(n){super(n);this.name="BunupBuildError"}}class p extends E{constructor(n){super(n);this.name="BunupDTSBuildError"}}class $ extends E{constructor(n){super(n);this.name="BunupCLIError"}}class B extends E{constructor(n){super(n);this.name="BunupWatchError"}}var m=(n)=>{if(n instanceof Error)return n.message;return String(n)},bn=(n,t)=>{let r=m(n),s=t?`[${t}] `:"",e="ERROR";if(n instanceof h)e="BUILD ERROR";else if(n instanceof p)e="DTS ERROR";else if(n instanceof $)e="CLI ERROR";else if(n instanceof B)e="WATCH ERROR";else if(n instanceof E)e="BUNUP ERROR";if(console.error(`\x1B[31m[${e}]\x1B[0m ${s}${r}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
|
|
4
4
|
`).slice(1).join(`
|
|
5
|
-
`)+"\x1B[0m")},k=(t
|
|
6
|
-
`);let a=o.labels[0],
|
|
5
|
+
`)+"\x1B[0m")},k=(n,t)=>{bn(n,t),process.exit(1)};var f={MAX_LABEL_LENGTH:5,colors:{cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(n,t,r,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length));if(s){let[i,...o]=r.split(" ");return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${i} \x1B[38;5;${this.colors.size}m${s}\x1B[0m ${o.join(" ")}`}return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${r}`},cli(n){let t=this.labels.cli;console.log(this.formatMessage(this.colors.cli,t,n))},info(n){console.log(`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`)},warn(n){let t=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,t,n))},error(n){let t=this.labels.error;console.error(this.formatMessage(this.colors.error,t,n))},progress(n,t,r){let s=String(n),e=this.colors.default;for(let[i,o]of Object.entries(this.colors.progress))if(s.includes(i)){e=o;break}console.log(this.formatMessage(e,s,t,r))}};function I(n,t){return`${t?`${t.replace(/-/g,"_")}_`:""}${n}`.toUpperCase()}function Q(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function V(n=8){return Math.random().toString(36).substring(2,2+n)}function P(n,t){switch(n){case"esm":return".mjs";case"cjs":return N(t)?".cjs":".js";case"iife":return".global.js"}}function D(n,t){switch(n){case"esm":return".d.mts";case"cjs":return N(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function N(n){return n==="module"}function S(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function F(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function nn(n,t){return n===void 0?t==="esm":n}function j(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 H(n,t=3){return n.split("/").slice(-t).join("/")}import{loadTsConfig as Nn}from"load-tsconfig";function tn(n){try{return Nn(".",n)}catch(t){return f.warn(`Failed to load tsconfig: ${m(t)}`),{path:n,data:{},files:[]}}}import{rollup as Hn}from"rollup";import An from"rollup-plugin-dts";import Z from"typescript";function rn(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${Q(t)}($|\\/|\\\\)`):t)}function A(n,t){return rn(n.external||[]).concat(F(t).map((r)=>new RegExp(`^${Q(r)}($|\\/|\\\\)`)))}function W(n){return rn(n.noExternal||[])}import q from"node:fs";import en from"node:path";var R={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function sn(n,t){return{outdir:`${t}/${n.outDir}`,minify:Sn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function Sn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:s,minifySyntax:e}=n,i=t===!0;return{whitespace:r??i,identifiers:s??i,syntax:e??i}}async function on(n){let t=[],r="";for(let s of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let e=en.join(n,`bunup.config${s}`);try{if(!q.existsSync(e))continue;let i;if(r=e,s===".json"||s===".jsonc"){let o=q.readFileSync(e,"utf8"),a=JSON.parse(o);i=a.bunup||a}else{let o=await import(`file://${e}`);if(i=o.default||o,!i)f.warn(`No default export found in ${e}`),i={}}if(Array.isArray(i))for(let o of i)t.push({options:{...R,...o},rootDir:n});else t.push({options:{...R,...i},rootDir:n});break}catch(i){throw new h(`Failed to load config from ${e}: ${m(i)}`)}}return{configs:t,configFilePath:r}}function G(n){let t=en.join(n,"package.json");try{if(!q.existsSync(t))return null;let r=q.readFileSync(t,"utf8");return JSON.parse(r)}catch(r){return f.warn(`Failed to load package.json at ${t}: ${m(r)}`),null}}import v from"path";var w="\x00virtual:",jn=()=>{return global.allFilesUsedToBundleDts||O||new Set},an=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(w))return t;if(!r?.startsWith(w)||!t.startsWith("."))return null;let s=r.slice(w.length),e=v.resolve(v.dirname(s),t);if(t==="."){let o=v.join(v.dirname(s),"index.d.ts");if(n.has(o))return`${w}${o}`;e=v.dirname(s)}if(n.has(e))return`${w}${e}`;let i=`${e}.d.ts`;if(n.has(i))return`${w}${i}`;if(t.startsWith(".")){let o=v.join(e,"index.d.ts");if(n.has(o))return`${w}${o}`}return null},load(t){if(t.startsWith(w)){let r=t.slice(w.length),s=n.get(r);if(s)return jn().add(r),s}return null}}};async function cn(n,t,r,s,e){let i=n.replace(/\.tsx?$/,".d.ts"),o=`${w}${i}`,a=e.data?.compilerOptions,l=G(s),g=A(r,l),u=W(r),c;try{c=await Hn({input:o,onwarn(y,C){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(y.code??""))return;C(y)},plugins:[an(t),An({tsconfig:e.path,compilerOptions:{...a?Z.parseJsonConfigFileContent({compilerOptions:a},Z.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:Z.ScriptTarget.ESNext}})],external:(y)=>g.some((C)=>C.test(y))&&!u.some((C)=>C.test(y))});let{output:x}=await c.generate({});if(!x[0]?.code)throw new p("Generated bundle is empty");return x[0].code}catch(x){throw new p(`DTS bundling failed: ${m(x)}`)}finally{if(c)await c.close()}}import mn from"node:fs";import un from"node:path";import M from"node:path";function L(n){let t=M.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?M.resolve(t,n.data.compilerOptions.baseUrl):t}function fn(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let s=L(n);for(let[e,i]of Object.entries(r))if(Array.isArray(i)&&i.length){let o=e.replace(/\*/g,"(.*)"),a=i[0].replace(/\*/g,"$1");t.set(`^${o}$`,M.join(s,a))}return t}function ln(n,t,r){for(let[s,e]of t){let i=new RegExp(s),o=n.match(i);if(o)return e.replace("$1",o[1]||"")}return r?M.join(r,n):null}var Wn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,qn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function gn(n,t){let r=new Set([n]),s=[n],e=fn(t),i=L(t);while(s.length){let o=s.pop();if(!o)continue;try{let a=await mn.promises.readFile(o,"utf8"),l=Gn(a);for(let g of l){let u=g.startsWith(".")?un.resolve(un.dirname(o),g):ln(g,e,i);if(!u)continue;let c=Mn(u);if(c&&!r.has(c))r.add(c),s.push(c)}}catch(a){f.warn(`Error processing ${o}: ${m(a)}`)}}return r}function Gn(n){let t=new Set;for(let r of[Wn,qn]){let s;while((s=r.exec(n))!==null)t.add(s[2])}return Array.from(t)}function Mn(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let s=`${n}${r}`;if(mn.existsSync(s)&&(s.endsWith(".ts")||s.endsWith(".tsx")))return s}return null}import Yn from"node:fs";import{isolatedDeclaration as Jn}from"oxc-transform";async function pn(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.tsx?$/,".d.ts"),e=await Yn.promises.readFile(r,"utf8"),{code:i}=Jn(r,e);if(i)t.set(s,i)}catch(s){f.warn(`Failed to generate declaration for ${r}: ${m(s)}`)}})),t}import T from"node:fs";import U from"node:path";import{isolatedDeclaration as Kn}from"oxc-transform";function xn(n,t){let r=U.resolve(n),s=U.resolve(r,t);if(!T.existsSync(r))throw new p(`Root directory does not exist: ${r}`);if(!T.existsSync(s))throw new p(`Entry file does not exist: ${s}`);if(!s.endsWith(".ts"))throw new p(`Entry file must be a TypeScript file (.ts): ${s}`);if(U.relative(r,s).startsWith(".."))throw new p(`Entry file must be within rootDir: ${s}`);return{absoluteRootDir:r,absoluteEntry:s}}async function $n(n){let t=!1;if(await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.d\.ts$/,".ts"),e=await T.promises.readFile(s,"utf8"),{errors:i}=Kn(s,e);i.forEach((o)=>{if(!t)console.log(`
|
|
6
|
+
`);let a=o.labels[0],l=a?Qn(e,a.start):"",u=`${H(s)}${l}: ${Zn(o.message)}`;f.warn(u),t=!0})}catch{}})),t)f.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
|
|
9
|
-
`),
|
|
10
|
-
To install Bun, visit https://bun.sh/docs/installation`)})();import
|
|
8
|
+
`)}function Qn(n,t){if(t===void 0)return"";let r=n.slice(0,t).split(`
|
|
9
|
+
`),s=r.length,e=r[r.length-1].length+1;return` (${s}:${e})`}function Zn(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function wn(n,t,r){let{absoluteRootDir:s,absoluteEntry:e}=xn(n,t),i=tn(r.preferredTsconfigPath),o=await gn(e,i),a=await pn(o);return cn(e,a,r,s,i)}async function yn(n,t,r,s,e){return new Promise((i,o)=>{let{onBuildEnd:a,...l}=s,g={rootDir:n,entries:t,formats:r,options:l,packageType:e},u=new Un(new URL("./dtsWorker.js",import.meta.url),{workerData:g});u.on("message",async(c)=>{if(c.success){let x=S(c.timeMs);if(f.progress("DTS",`Bundled types in ${x}`),c.filesUsed)c.filesUsed.forEach((y)=>O.add(y));i()}else o(new p(c.error||"Unknown DTS worker error"))}),u.on("error",o),u.on("exit",(c)=>{if(c!==0)o(new p(`DTS worker stopped with exit code ${c}`))})})}if(!Ln&&Y){let{rootDir:n,entries:t,formats:r,options:s,packageType:e}=Tn,i=performance.now(),o=new Set;global.allFilesUsedToBundleDts=o,f.progress("DTS","Bundling types");try{(async()=>{try{await Promise.all(t.map(async(l)=>{let g=await wn(n,l.path,s);await Promise.all(r.map(async(u)=>{let c=D(u,e),x=`${s.outDir}/${l.name}${c}`,y=`${n}/${x}`;await Bun.write(y,g);let C=Bun.file(y).size||0;f.progress("DTS",x,j(C))}))}));let a=performance.now()-i;Y?.postMessage({success:!0,timeMs:a,filesUsed:[...o]})}catch(a){Y?.postMessage({success:!1,error:m(a)})}})()}catch(a){Y?.postMessage({success:!1,error:m(a)})}}function Xn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function b(n){let t=[],r=new Set;function s(e,i){if(r.has(e)){let o=V();t.push({name:`${e}_${o}`,path:i})}else t.push({name:e,path:i}),r.add(e)}if(Array.isArray(n))for(let e of n){let i=Xn(e);s(i,e)}else Object.entries(n).forEach(([e,i])=>{s(e,i)});return t}function hn(n,t){return`[dir]/${n}${t}`}function dn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(s)=>{let e=s.path;if(n.some((o)=>o.test(e))&&!t.some((o)=>o.test(e)))return{path:e,external:!0};return null})}}}async function J(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 r=performance.now(),s=G(t),e=s?.type,i=A(n,s),o=W(n),a=[dn(i,o)],l=b(n.entry),g=n.format.flatMap((u)=>l.map((c)=>{return _n(n,t,c,u,e,a)}));try{await Promise.all(g);let u=performance.now()-r,c=S(u);f.cli(`\uD83D\uDCE6 Build success in ${c}`)}catch{throw new h("Build process encountered errors")}if(n.dts){let u=n.format.filter((x)=>{if(x==="iife"&&!N(e)&&n.format.includes("cjs"))return!1;return!0}),c=n.dts===!0?l:b(n.dts.entry);try{await yn(t,c,u,n,e)}catch(x){throw new p(`DTS build process encountered errors: ${m(x)}`)}}}async function _n(n,t,r,s,e,i){let o=P(s,e),a=sn(n,t),l=await Bun.build({...a,entrypoints:[`${t}/${r.path}`],format:s,naming:{entry:hn(r.name,o)},splitting:nn(n.splitting,s),plugins:i,throw:!1});if(!l.success)throw l.logs.forEach((c)=>{if(c.level==="error")f.error(c.message);else if(c.level==="warning")f.warn(c.message);else if(c.level==="info")f.info(c.message)}),new h(`Build failed for ${r} (${s})`);let g=`${n.outDir}/${r.name}${o}`,u=Bun.file(g).size||0;f.progress(I(s,n.name),g,j(u))}function d(n){return(t,r)=>{r[n]=t===!0?!0:t==="true"}}function K(n){return(t,r)=>{if(typeof t==="string")r[n]=t;else throw new $(`Option --${n} requires a string value`)}}function Cn(n){return(t,r)=>{if(typeof t==="string")r[n]=t.split(",");else throw new $(`Option --${n} requires a string value`)}}var zn={name:{flags:["n","name"],handler:K("name")},format:{flags:["f","format"],handler:(n,t)=>{if(typeof n==="string")t.format=n.split(",");else throw new $("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:K("outDir")},minify:{flags:["m","minify"],handler:d("minify")},watch:{flags:["w","watch"],handler:d("watch")},dts:{flags:["d","dts"],handler:d("dts")},external:{flags:["e","external"],handler:Cn("external")},sourcemap:{flags:["sm","sourcemap"],handler:K("sourcemap")},target:{flags:["t","target"],handler:K("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:d("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:d("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:d("minifySyntax")},clean:{flags:["c","clean"],handler:d("clean")},splitting:{flags:["s","splitting"],handler:d("splitting")},noExternal:{flags:["ne","no-external"],handler:Cn("noExternal")}},X={};for(let n of Object.values(zn))if(n)for(let t of n.flags)X[t]=n.handler;function On(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function En(n){let t={},r={},s=0;while(s<n.length){let e=n[s];if(e.startsWith("--")){let i,o;if(e.includes("=")){let[a,l]=e.slice(2).split("=",2);i=a,o=l}else{i=e.slice(2);let a=n[s+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")s++}if(i==="entry")if(typeof o==="string"){let a=On(o);if(r[a])f.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);r[a]=o}else throw new $("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(r[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);r[a]=o}else throw new $(`Option --entry.${a} requires a string value`)}else{let a=X[i];if(a)a(o,t);else throw new $(`Unknown option: --${i}`)}}else if(e.startsWith("-")){let i=e.slice(1),o=n[s+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")s++;let l=X[i];if(l)l(a,t);else throw new $(`Unknown option: -${i}`)}else{let i=On(e);if(r[i])f.warn(`Duplicate entry name '${i}' derived from positional argument '${e}'. Overwriting previous entry.`);r[i]=e}s++}if(Object.keys(r).length>0)t.entry=r;return t}(()=>{if(typeof Bun==="undefined")throw new $(`Bunup requires Bun to run.
|
|
10
|
+
To install Bun, visit https://bun.sh/docs/installation`)})();import _ from"node:path";import kn from"chokidar";async function Rn(n,t){let r=new Set,s=b(n.entry);s.forEach((l)=>{let g=_.resolve(t,l.path),u=_.dirname(g);r.add(u)});let e=kn.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),i=null,o=!1,a=async()=>{if(o)return;o=!0;try{await J({...n,entry:s.map((l)=>l.path),clean:!1},t),n.onBuildEnd?.()}catch(l){throw new B(`Build failed: ${m(l)}`)}finally{o=!1}};e.on("change",(l)=>{let g=_.relative(t,l);if(f.cli(`File changed: ${g}`),i)clearTimeout(i);i=setTimeout(()=>a(),300)}),e.on("error",(l)=>{throw new B(`Watcher error: ${m(l)}`)}),await a()}var O=new Set;async function Pn(n=Bun.argv.slice(2)){let t=En(n),{configs:r,configFilePath:s}=await on(process.cwd());f.cli(`Using config file: ${H(s,2)}`);let e=process.cwd();if(t.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(r.length===0){let i={...R,...t};if(i.clean)Bn(e,i.outDir);await vn(i,e)}else{for(let{options:i,rootDir:o}of r)if(i.clean)Bn(o,i.outDir);f.cli("Build started"),await Promise.all(r.map(async({options:i,rootDir:o})=>{let a={...R,...i,...t};await vn(a,o)}))}if(O.size>0)await $n(O),O.clear();if(!t.watch)process.exit(0)}async function vn(n,t){if(n.watch)await Rn(n,t);else await J(n,t),n.onBuildEnd?.()}function Bn(n,t){let r=In.join(n,t);if(z.existsSync(r))try{z.rmSync(r,{recursive:!0,force:!0})}catch(s){throw new h(`Failed to clean output directory: ${s}`)}z.mkdirSync(r,{recursive:!0})}if(Vn)Pn().catch((n)=>k(n));export{Pn as main,O as allFilesUsedToBundleDts};
|
package/build/dtsWorker.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
var
|
|
1
|
+
var _n=require("node:module");var Zn=Object.create;var{getPrototypeOf:Ln,defineProperty:N,getOwnPropertyNames:tn,getOwnPropertyDescriptor:Un}=Object,rn=Object.prototype.hasOwnProperty;var p=(n,t,r)=>{r=n!=null?Zn(Ln(n)):{};let s=t||!n||!n.__esModule?N(r,"default",{value:n,enumerable:!0}):r;for(let e of tn(n))if(!rn.call(s,e))N(s,e,{get:()=>n[e],enumerable:!0});return s},nn=new WeakMap,Tn=(n)=>{var t=nn.get(n),r;if(t)return t;if(t=N({},"__esModule",{value:!0}),n&&typeof n==="object"||typeof n==="function")tn(n).map((s)=>!rn.call(t,s)&&N(t,s,{get:()=>n[s],enumerable:!(r=Un(n,s))||r.enumerable}));return nn.set(n,t),t};var Xn=(n,t)=>{for(var r in t)N(n,r,{get:t[r],enumerable:!0,configurable:!0,set:(s)=>t[r]=()=>s})};var ot={};Xn(ot,{runDtsInWorker:()=>I});module.exports=Tn(ot);var h=require("node:worker_threads");var X=p(require("node:fs")),Bn=p(require("node:path")),bn=require("node:worker_threads");class B extends Error{constructor(n){super(n);this.name="BunupError"}}class C extends B{constructor(n){super(n);this.name="BunupBuildError"}}class x extends B{constructor(n){super(n);this.name="BunupDTSBuildError"}}class w extends B{constructor(n){super(n);this.name="BunupCLIError"}}class S extends B{constructor(n){super(n);this.name="BunupWatchError"}}var m=(n)=>{if(n instanceof Error)return n.message;return String(n)},zn=(n,t)=>{let r=m(n),s=t?`[${t}] `:"",e="ERROR";if(n instanceof C)e="BUILD ERROR";else if(n instanceof x)e="DTS ERROR";else if(n instanceof w)e="CLI ERROR";else if(n instanceof S)e="WATCH ERROR";else if(n instanceof B)e="BUNUP ERROR";if(console.error(`\x1B[31m[${e}]\x1B[0m ${s}${r}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
|
|
2
2
|
`).slice(1).join(`
|
|
3
|
-
`)+"\x1B[0m")},
|
|
4
|
-
To install Bun, visit https://bun.sh/docs/installation`)})();var
|
|
5
|
-
`);let a=o.labels[0],
|
|
3
|
+
`)+"\x1B[0m")},sn=(n,t)=>{zn(n,t),process.exit(1)};function z(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function en(n=8){return Math.random().toString(36).substring(2,2+n)}function on(n,t){switch(n){case"esm":return".mjs";case"cjs":return W(t)?".cjs":".js";case"iife":return".global.js"}}function an(n,t){switch(n){case"esm":return".d.mts";case"cjs":return W(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function W(n){return n==="module"}function q(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function cn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function fn(n,t){return n===void 0?t==="esm":n}function G(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 M(n,t=3){return n.split("/").slice(-t).join("/")}function kn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function j(n){let t=[],r=new Set;function s(e,i){if(r.has(e)){let o=en();t.push({name:`${e}_${o}`,path:i})}else t.push({name:e,path:i}),r.add(e)}if(Array.isArray(n))for(let e of n){let i=kn(e);s(i,e)}else Object.entries(n).forEach(([e,i])=>{s(e,i)});return t}function ln(n,t){return`[dir]/${n}${t}`}function un(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${z(t)}($|\\/|\\\\)`):t)}function Y(n,t){return un(n.external||[]).concat(cn(t).map((r)=>new RegExp(`^${z(r)}($|\\/|\\\\)`)))}function J(n){return un(n.noExternal||[])}var H=p(require("node:fs")),k=p(require("node:path"));var f={MAX_LABEL_LENGTH:5,colors:{cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(n,t,r,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length));if(s){let[i,...o]=r.split(" ");return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${i} \x1B[38;5;${this.colors.size}m${s}\x1B[0m ${o.join(" ")}`}return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${r}`},cli(n){let t=this.labels.cli;console.log(this.formatMessage(this.colors.cli,t,n))},info(n){console.log(`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`)},warn(n){let t=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,t,n))},error(n){let t=this.labels.error;console.error(this.formatMessage(this.colors.error,t,n))},progress(n,t,r){let s=String(n),e=this.colors.default;for(let[i,o]of Object.entries(this.colors.progress))if(s.includes(i)){e=o;break}console.log(this.formatMessage(e,s,t,r))}};function mn(n,t){return`${t?`${t.replace(/-/g,"_")}_`:""}${n}`.toUpperCase()}var b={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function gn(n,t){return{outdir:`${t}/${n.outDir}`,minify:In(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function In(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:s,minifySyntax:e}=n,i=t===!0;return{whitespace:r??i,identifiers:s??i,syntax:e??i}}async function pn(n){let t=[],r="";for(let s of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let e=k.default.join(n,`bunup.config${s}`);try{if(!H.default.existsSync(e))continue;let i;if(r=e,s===".json"||s===".jsonc"){let o=H.default.readFileSync(e,"utf8"),a=JSON.parse(o);i=a.bunup||a}else{let o=await import(`file://${e}`);if(i=o.default||o,!i)f.warn(`No default export found in ${e}`),i={}}if(Array.isArray(i))for(let o of i)t.push({options:{...b,...o},rootDir:n});else t.push({options:{...b,...i},rootDir:n});break}catch(i){throw new C(`Failed to load config from ${e}: ${m(i)}`)}}return{configs:t,configFilePath:r}}function K(n){let t=k.default.join(n,"package.json");try{if(!H.default.existsSync(t))return null;let r=H.default.readFileSync(t,"utf8");return JSON.parse(r)}catch(r){return f.warn(`Failed to load package.json at ${t}: ${m(r)}`),null}}function xn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(s)=>{let e=s.path;if(n.some((o)=>o.test(e))&&!t.some((o)=>o.test(e)))return{path:e,external:!0};return null})}}}async function Q(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new C("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let r=performance.now(),s=K(t),e=s?.type,i=Y(n,s),o=J(n),a=[xn(i,o)],l=j(n.entry),g=n.format.flatMap((u)=>l.map((c)=>{return Vn(n,t,c,u,e,a)}));try{await Promise.all(g);let u=performance.now()-r,c=q(u);f.cli(`\uD83D\uDCE6 Build success in ${c}`)}catch{throw new C("Build process encountered errors")}if(n.dts){let u=n.format.filter(($)=>{if($==="iife"&&!W(e)&&n.format.includes("cjs"))return!1;return!0}),c=n.dts===!0?l:j(n.dts.entry);try{await I(t,c,u,n,e)}catch($){throw new x(`DTS build process encountered errors: ${m($)}`)}}}async function Vn(n,t,r,s,e,i){let o=on(s,e),a=gn(n,t),l=await Bun.build({...a,entrypoints:[`${t}/${r.path}`],format:s,naming:{entry:ln(r.name,o)},splitting:fn(n.splitting,s),plugins:i,throw:!1});if(!l.success)throw l.logs.forEach((c)=>{if(c.level==="error")f.error(c.message);else if(c.level==="warning")f.warn(c.message);else if(c.level==="info")f.info(c.message)}),new C(`Build failed for ${r} (${s})`);let g=`${n.outDir}/${r.name}${o}`,u=Bun.file(g).size||0;f.progress(mn(s,n.name),g,G(u))}function O(n){return(t,r)=>{r[n]=t===!0?!0:t==="true"}}function Z(n){return(t,r)=>{if(typeof t==="string")r[n]=t;else throw new w(`Option --${n} requires a string value`)}}function $n(n){return(t,r)=>{if(typeof t==="string")r[n]=t.split(",");else throw new w(`Option --${n} requires a string value`)}}var Pn={name:{flags:["n","name"],handler:Z("name")},format:{flags:["f","format"],handler:(n,t)=>{if(typeof n==="string")t.format=n.split(",");else throw new w("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:Z("outDir")},minify:{flags:["m","minify"],handler:O("minify")},watch:{flags:["w","watch"],handler:O("watch")},dts:{flags:["d","dts"],handler:O("dts")},external:{flags:["e","external"],handler:$n("external")},sourcemap:{flags:["sm","sourcemap"],handler:Z("sourcemap")},target:{flags:["t","target"],handler:Z("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:O("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:O("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:O("minifySyntax")},clean:{flags:["c","clean"],handler:O("clean")},splitting:{flags:["s","splitting"],handler:O("splitting")},noExternal:{flags:["ne","no-external"],handler:$n("noExternal")}},V={};for(let n of Object.values(Pn))if(n)for(let t of n.flags)V[t]=n.handler;function wn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function yn(n){let t={},r={},s=0;while(s<n.length){let e=n[s];if(e.startsWith("--")){let i,o;if(e.includes("=")){let[a,l]=e.slice(2).split("=",2);i=a,o=l}else{i=e.slice(2);let a=n[s+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")s++}if(i==="entry")if(typeof o==="string"){let a=wn(o);if(r[a])f.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);r[a]=o}else throw new w("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(r[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);r[a]=o}else throw new w(`Option --entry.${a} requires a string value`)}else{let a=V[i];if(a)a(o,t);else throw new w(`Unknown option: --${i}`)}}else if(e.startsWith("-")){let i=e.slice(1),o=n[s+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")s++;let l=V[i];if(l)l(a,t);else throw new w(`Unknown option: -${i}`)}else{let i=wn(e);if(r[i])f.warn(`Duplicate entry name '${i}' derived from positional argument '${e}'. Overwriting previous entry.`);r[i]=e}s++}if(Object.keys(r).length>0)t.entry=r;return t}(()=>{if(typeof Bun==="undefined")throw new w(`Bunup requires Bun to run.
|
|
4
|
+
To install Bun, visit https://bun.sh/docs/installation`)})();var U=p(require("node:fs")),L=p(require("node:path")),hn=require("oxc-transform");function dn(n,t){let r=L.default.resolve(n),s=L.default.resolve(r,t);if(!U.default.existsSync(r))throw new x(`Root directory does not exist: ${r}`);if(!U.default.existsSync(s))throw new x(`Entry file does not exist: ${s}`);if(!s.endsWith(".ts"))throw new x(`Entry file must be a TypeScript file (.ts): ${s}`);if(L.default.relative(r,s).startsWith(".."))throw new x(`Entry file must be within rootDir: ${s}`);return{absoluteRootDir:r,absoluteEntry:s}}async function Cn(n){let t=!1;if(await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.d\.ts$/,".ts"),e=await U.default.promises.readFile(s,"utf8"),{errors:i}=hn.isolatedDeclaration(s,e);i.forEach((o)=>{if(!t)console.log(`
|
|
5
|
+
`);let a=o.labels[0],l=a?Dn(e,a.start):"",u=`${M(s)}${l}: ${Fn(o.message)}`;f.warn(u),t=!0})}catch{}})),t)f.info(`
|
|
6
6
|
You may have noticed some TypeScript warnings above related to missing type annotations. This is because Bunup uses TypeScript's "isolatedDeclarations" approach for generating declaration files. This modern approach requires explicit type annotations on exports for better, more accurate type declarations. Other bundlers might not show these warnings because they use different, potentially less precise methods. Adding the suggested type annotations will not only silence these warnings but also improve the quality of your published type definitions, making your library more reliable for consumers.
|
|
7
|
-
`)}function
|
|
8
|
-
`),
|
|
7
|
+
`)}function Dn(n,t){if(t===void 0)return"";let r=n.slice(0,t).split(`
|
|
8
|
+
`),s=r.length,e=r[r.length-1].length+1;return` (${s}:${e})`}function Fn(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var T=p(require("node:path")),On=p(require("chokidar"));async function En(n,t){let r=new Set,s=j(n.entry);s.forEach((l)=>{let g=T.default.resolve(t,l.path),u=T.default.dirname(g);r.add(u)});let e=On.default.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),i=null,o=!1,a=async()=>{if(o)return;o=!0;try{await Q({...n,entry:s.map((l)=>l.path),clean:!1},t),n.onBuildEnd?.()}catch(l){throw new S(`Build failed: ${m(l)}`)}finally{o=!1}};e.on("change",(l)=>{let g=T.default.relative(t,l);if(f.cli(`File changed: ${g}`),i)clearTimeout(i);i=setTimeout(()=>a(),300)}),e.on("error",(l)=>{throw new S(`Watcher error: ${m(l)}`)}),await a()}var R=new Set;async function nt(n=Bun.argv.slice(2)){let t=yn(n),{configs:r,configFilePath:s}=await pn(process.cwd());f.cli(`Using config file: ${M(s,2)}`);let e=process.cwd();if(t.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(r.length===0){let i={...b,...t};if(i.clean)vn(e,i.outDir);await Rn(i,e)}else{for(let{options:i,rootDir:o}of r)if(i.clean)vn(o,i.outDir);f.cli("Build started"),await Promise.all(r.map(async({options:i,rootDir:o})=>{let a={...b,...i,...t};await Rn(a,o)}))}if(R.size>0)await Cn(R),R.clear();if(!t.watch)process.exit(0)}async function Rn(n,t){if(n.watch)await En(n,t);else await Q(n,t),n.onBuildEnd?.()}function vn(n,t){let r=Bn.default.join(n,t);if(X.default.existsSync(r))try{X.default.rmSync(r,{recursive:!0,force:!0})}catch(s){throw new C(`Failed to clean output directory: ${s}`)}X.default.mkdirSync(r,{recursive:!0})}if(bn.isMainThread)nt().catch((n)=>sn(n));var Nn=require("load-tsconfig");function Sn(n){try{return Nn.loadTsConfig(".",n)}catch(t){return f.warn(`Failed to load tsconfig: ${m(t)}`),{path:n,data:{},files:[]}}}var Hn=require("rollup"),An=p(require("rollup-plugin-dts")),_=p(require("typescript"));var v=p(require("path"));var y="\x00virtual:",tt=()=>{return global.allFilesUsedToBundleDts||R||new Set},jn=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(y))return t;if(!r?.startsWith(y)||!t.startsWith("."))return null;let s=r.slice(y.length),e=v.default.resolve(v.default.dirname(s),t);if(t==="."){let o=v.default.join(v.default.dirname(s),"index.d.ts");if(n.has(o))return`${y}${o}`;e=v.default.dirname(s)}if(n.has(e))return`${y}${e}`;let i=`${e}.d.ts`;if(n.has(i))return`${y}${i}`;if(t.startsWith(".")){let o=v.default.join(e,"index.d.ts");if(n.has(o))return`${y}${o}`}return null},load(t){if(t.startsWith(y)){let r=t.slice(y.length),s=n.get(r);if(s)return tt().add(r),s}return null}}};async function Wn(n,t,r,s,e){let i=n.replace(/\.tsx?$/,".d.ts"),o=`${y}${i}`,a=e.data?.compilerOptions,l=K(s),g=Y(r,l),u=J(r),c;try{c=await Hn.rollup({input:o,onwarn(d,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(d.code??""))return;E(d)},plugins:[jn(t),An.default({tsconfig:e.path,compilerOptions:{...a?_.default.parseJsonConfigFileContent({compilerOptions:a},_.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:_.default.ScriptTarget.ESNext}})],external:(d)=>g.some((E)=>E.test(d))&&!u.some((E)=>E.test(d))});let{output:$}=await c.generate({});if(!$[0]?.code)throw new x("Generated bundle is empty");return $[0].code}catch($){throw new x(`DTS bundling failed: ${m($)}`)}finally{if(c)await c.close()}}var F=p(require("node:fs")),D=p(require("node:path"));var A=p(require("node:path"));function P(n){let t=A.default.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?A.default.resolve(t,n.data.compilerOptions.baseUrl):t}function qn(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let s=P(n);for(let[e,i]of Object.entries(r))if(Array.isArray(i)&&i.length){let o=e.replace(/\*/g,"(.*)"),a=i[0].replace(/\*/g,"$1");t.set(`^${o}$`,A.default.join(s,a))}return t}function Gn(n,t,r){for(let[s,e]of t){let i=new RegExp(s),o=n.match(i);if(o)return e.replace("$1",o[1]||"")}return r?A.default.join(r,n):null}var rt=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,st=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function Mn(n,t){let r=new Set([n]),s=[n],e=qn(t),i=P(t);while(s.length){let o=s.pop();if(!o)continue;try{let a=await F.default.promises.readFile(o,"utf8"),l=et(a);for(let g of l){let u=g.startsWith(".")?D.default.resolve(D.default.dirname(o),g):Gn(g,e,i);if(!u)continue;let c=it(u);if(c&&!r.has(c))r.add(c),s.push(c)}}catch(a){f.warn(`Error processing ${o}: ${m(a)}`)}}return r}function et(n){let t=new Set;for(let r of[rt,st]){let s;while((s=r.exec(n))!==null)t.add(s[2])}return Array.from(t)}function it(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let s=`${n}${r}`;if(F.default.existsSync(s)&&(s.endsWith(".ts")||s.endsWith(".tsx")))return s}return null}var Yn=p(require("node:fs")),Jn=require("oxc-transform");async function Kn(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.tsx?$/,".d.ts"),e=await Yn.default.promises.readFile(r,"utf8"),{code:i}=Jn.isolatedDeclaration(r,e);if(i)t.set(s,i)}catch(s){f.warn(`Failed to generate declaration for ${r}: ${m(s)}`)}})),t}async function Qn(n,t,r){let{absoluteRootDir:s,absoluteEntry:e}=dn(n,t),i=Sn(r.preferredTsconfigPath),o=await Mn(e,i),a=await Kn(o);return Wn(e,a,r,s,i)}async function I(n,t,r,s,e){return new Promise((i,o)=>{let{onBuildEnd:a,...l}=s,g={rootDir:n,entries:t,formats:r,options:l,packageType:e},u=new h.Worker(new URL("./dtsWorker.js",import.meta.url),{workerData:g});u.on("message",async(c)=>{if(c.success){let $=q(c.timeMs);if(f.progress("DTS",`Bundled types in ${$}`),c.filesUsed)c.filesUsed.forEach((d)=>R.add(d));i()}else o(new x(c.error||"Unknown DTS worker error"))}),u.on("error",o),u.on("exit",(c)=>{if(c!==0)o(new x(`DTS worker stopped with exit code ${c}`))})})}if(!h.isMainThread&&h.parentPort){let{rootDir:n,entries:t,formats:r,options:s,packageType:e}=h.workerData,i=performance.now(),o=new Set;global.allFilesUsedToBundleDts=o,f.progress("DTS","Bundling types");try{(async()=>{try{await Promise.all(t.map(async(l)=>{let g=await Qn(n,l.path,s);await Promise.all(r.map(async(u)=>{let c=an(u,e),$=`${s.outDir}/${l.name}${c}`,d=`${n}/${$}`;await Bun.write(d,g);let E=Bun.file(d).size||0;f.progress("DTS",$,G(E))}))}));let a=performance.now()-i;h.parentPort?.postMessage({success:!0,timeMs:a,filesUsed:[...o]})}catch(a){h.parentPort?.postMessage({success:!1,error:m(a)})}})()}catch(a){h.parentPort?.postMessage({success:!1,error:m(a)})}}
|