bunup 0.1.20 → 0.1.22

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