bunup 0.2.9 → 0.2.11

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,13 +1,13 @@
1
1
  #!/usr/bin/env bun
2
2
  // @bun
3
- import{loadTsConfig as jn}from"load-tsconfig";class C extends Error{constructor(n){super(n);this.name="BunupError"}}class y extends C{constructor(n){super(n);this.name="BunupBuildError"}}class g extends C{constructor(n){super(n);this.name="BunupDTSBuildError"}}class d extends C{constructor(n){super(n);this.name="BunupCLIError"}}class B extends C{constructor(n){super(n);this.name="BunupWatchError"}}var u=(n)=>{if(n instanceof Error)return n.message;return String(n)},Tn=(n,r)=>{let t=u(n),e=r?`[${r}] `:"",s="ERROR";if(n instanceof y)s="BUILD ERROR";else if(n instanceof g)s="DTS ERROR";else if(n instanceof d)s="CLI ERROR";else if(n instanceof B)s="WATCH ERROR";else if(n instanceof C)s="BUNUP ERROR";if(console.error(`\x1B[31m${s}\x1B[0m ${e}${t}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
3
+ import{loadTsConfig as kn}from"load-tsconfig";class v extends Error{constructor(n){super(n);this.name="BunupError"}}class y extends v{constructor(n){super(n);this.name="BunupBuildError"}}class g extends v{constructor(n){super(n);this.name="BunupDTSBuildError"}}class d extends v{constructor(n){super(n);this.name="BunupCLIError"}}class R extends v{constructor(n){super(n);this.name="BunupWatchError"}}var u=(n)=>{if(n instanceof Error)return n.message;return String(n)},Tn=(n,r)=>{let t=u(n),e=r?`[${r}] `:"",s="ERROR";if(n instanceof y)s="BUILD ERROR";else if(n instanceof g)s="DTS ERROR";else if(n instanceof d)s="CLI ERROR";else if(n instanceof R)s="WATCH ERROR";else if(n instanceof v)s="BUNUP ERROR";if(console.error(`\x1B[31m${s}\x1B[0m ${e}${t}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
4
4
  `).slice(1).join(`
5
- `)+"\x1B[0m")},z=(n,r)=>{Tn(n,r),process.exit(1)};var l={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(n,r,t,e,s){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length));if(e){let[i,...c]=t.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-i.length)),m=s?` \x1B[48;5;${n};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${o}${i}${p} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${c.join(" ")}${m}`}let a=s?` \x1B[48;5;${n};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${o}${t}${a}`},cli(n){let r=this.labels.cli;console.log(this.formatMessage(this.colors.cli,r,n))},info(n){console.log(`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`)},warn(n){let r=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,r,n))},error(n){let r=this.labels.error;console.error(this.formatMessage(this.colors.error,r,n))},progress(n,r,t,e){let s=String(n),o=this.colors.default;for(let[a,i]of Object.entries(this.colors.progress))if(s.includes(a)){o=i;break}console.log(this.formatMessage(o,s,r,t,e))}};function X(n){try{return jn(".",n)}catch(r){return l.warn(`Failed to load tsconfig: ${u(r)}`),{path:n,data:{},files:[]}}}import{rollup as qn}from"rollup";import In from"rollup-plugin-dts";import Y from"typescript";import _ from"node:fs";import Mn from"node:path";var R={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function V(n,r){return{outdir:`${r}/${n.outDir}`,minify:kn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function kn(n){let{minify:r,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:s}=n,o=r===!0;return{whitespace:t??o,identifiers:e??o,syntax:s??o}}function G(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function nn(n=8){return Math.random().toString(36).substring(2,2+n)}function rn(n,r){switch(n){case"esm":return".mjs";case"cjs":return A(r)?".cjs":".js";case"iife":return".global.js"}}function tn(n,r){switch(n){case"esm":return".d.mts";case"cjs":return A(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function A(n){return n==="module"}function en(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function sn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function on(n,r){return n===void 0?r==="esm":n}function q(n){if(n===0)return"0 B";let r=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));if(t===0)return`${n} ${r[t]}`;return`${(n/Math.pow(1024,t)).toFixed(2)} ${r[t]}`}function $(n,r=3){return n.split("/").slice(-r).join("/")}function I(n,r){let t=Mn.join(n,r);if(_.existsSync(t))try{_.rmSync(t,{recursive:!0,force:!0})}catch(e){throw new y(`Failed to clean output directory: ${e}`)}_.mkdirSync(t,{recursive:!0})}function J(n){return n||R.outDir}function an(n){return n.map((r)=>typeof r==="string"?new RegExp(`^${G(r)}($|\\/|\\\\)`):r)}function N(n,r){return an(n.external||[]).concat(sn(r).map((t)=>new RegExp(`^${G(t)}($|\\/|\\\\)`)))}function T(n){return an(n.noExternal||[])}import j from"node:fs";import P from"node:path";async function cn(n){let r=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let t of r){let e=P.join(n,`bunup.config${t}`);try{if(!j.existsSync(e))continue;let s=await Dn(e,t);if(!s)continue;return{configs:Wn(s,n),configFilePath:e}}catch(s){throw new y(`Failed to load config from ${e}: ${u(s)}`)}}return{configs:[],configFilePath:""}}async function Dn(n,r){if(r===".json"||r===".jsonc")return Un(n);return Hn(n)}function Un(n){try{let r=j.readFileSync(n,"utf8"),t=JSON.parse(r);return t.bunup||t}catch(r){throw new Error(`Invalid JSON in config file. ${u(r)}`)}}async function Hn(n){try{let r=await import(`file://${n}`),t=r.default||r;if(!t)return l.warn(`No export found in ${n}. Make sure you're exporting your configuration.`),{};return t}catch(r){throw new Error(`Failed to import config file. ${u(r)}`)}}function Wn(n,r){let t=[];if(Ln(n))_n(n,r,t);else if(Array.isArray(n))Gn(n,r,t);else if(n&&typeof n==="object")t.push({options:n,rootDir:r});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return t}function Ln(n){return Array.isArray(n)&&n.length>0&&n.every((r)=>typeof r==="object"&&r!==null&&("name"in r)&&("root"in r)&&("config"in r))}function _n(n,r,t){for(let e of n){let s=P.resolve(r,e.root);if(Array.isArray(e.config))for(let o of e.config)t.push({options:{name:e.name,...o},rootDir:s});else t.push({options:{name:e.name,...e.config},rootDir:s})}}function Gn(n,r,t){for(let e of n){if(!e||typeof e!=="object")throw new Error("Invalid configuration item. Expected an object.");t.push({options:e,rootDir:r})}}function k(n){let r=P.join(n,"package.json");try{if(!j.existsSync(r))return null;let t=j.readFileSync(r,"utf8");return JSON.parse(t)}catch(t){return l.warn(`Failed to load package.json at ${r}: ${u(t)}`),null}}import v from"path";var x="\x00virtual:",ln=(n)=>{return{name:"bunup:virtual-dts",resolveId(r,t){if(r.startsWith(x))return r;if(!t?.startsWith(x)||!r.startsWith("."))return null;let e=t.slice(x.length),s=v.resolve(v.dirname(e),r);if(r==="."){let a=v.join(v.dirname(e),"index.d.ts");if(n.has(a))return`${x}${a}`;s=v.dirname(e)}if(n.has(s))return`${x}${s}`;let o=`${s}.d.ts`;if(n.has(o))return`${x}${o}`;if(r.startsWith(".")){let a=v.join(s,"index.d.ts");if(n.has(a))return`${x}${a}`}return null},load(r){if(r.startsWith(x)){let t=r.slice(x.length),e=n.get(t);if(e)return E.add(t),e}return null}}};async function fn(n,r,t,e,s){let o=n.replace(/\.tsx?$/,".d.ts"),a=`${x}${o}`,i=s.data?.compilerOptions,c=k(e),p=N(t,c),m=T(t),f;try{f=await qn({input:a,onwarn(b,O){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(b.code??""))return;O(b)},plugins:[ln(r),In({tsconfig:s.path,compilerOptions:{...i?Y.parseJsonConfigFileContent({compilerOptions:i},Y.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:Y.ScriptTarget.ESNext}})],external:(b)=>p.some((O)=>O.test(b))&&!m.some((O)=>O.test(b))});let{output:h}=await f.generate({});if(!h[0]?.code)throw new g("Generated bundle is empty");return h[0].code}catch(h){throw new g(`DTS bundling failed: ${u(h)}`)}finally{if(f)await f.close()}}import gn from"node:fs";import mn from"node:path";import M from"node:path";function F(n){let r=M.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?M.resolve(r,n.data.compilerOptions.baseUrl):r}function pn(n){let r=new Map,t=n.data?.compilerOptions?.paths;if(!t)return r;let e=F(n);for(let[s,o]of Object.entries(t))if(Array.isArray(o)&&o.length){let a=s.replace(/\*/g,"(.*)"),i=o[0].replace(/\*/g,"$1");r.set(`^${a}$`,M.join(e,i))}return r}function un(n,r,t){for(let[e,s]of r){let o=new RegExp(e),a=n.match(o);if(a)return s.replace("$1",a[1]||"")}return t?M.join(t,n):null}var Jn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Pn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function dn(n,r){let t=new Set([n]),e=[n],s=pn(r),o=F(r);while(e.length){let a=e.pop();if(!a)continue;try{let i=await gn.promises.readFile(a,"utf8"),c=Yn(i);for(let p of c){let m=p.startsWith(".")?mn.resolve(mn.dirname(a),p):un(p,s,o);if(!m)continue;let f=Fn(m);if(f&&!t.has(f))t.add(f),e.push(f)}}catch(i){l.warn(`Error processing ${a}: ${u(i)}`)}}return t}function Yn(n){let r=new Set;for(let t of[Jn,Pn]){let e;while((e=t.exec(n))!==null)r.add(e[2])}return Array.from(r)}function Fn(n){let r=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of r){let e=`${n}${t}`;if(gn.existsSync(e)&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}import Kn from"node:fs";import{isolatedDeclaration as Qn}from"oxc-transform";async function hn(n){let r=new Map;return await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.tsx?$/,".d.ts"),s=await Kn.promises.readFile(t,"utf8"),{code:o}=Qn(t,s);if(o)r.set(e,o)}catch(e){l.warn(`Failed to generate declaration for ${t}: ${u(e)}`)}})),r}import Q from"node:fs";import K from"node:path";import{isolatedDeclaration as Zn}from"oxc-transform";function xn(n,r){let t=K.resolve(n),e=K.resolve(t,r);if(!Q.existsSync(t))throw new g(`Root directory does not exist: ${t}`);if(!Q.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(K.relative(t,e).startsWith(".."))throw new g(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}async function yn(n){let r=!1;if(await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.d\.ts$/,".ts"),s=await Q.promises.readFile(e,"utf8"),{errors:o}=Zn(e,s);o.forEach((a)=>{if(!r)console.log(`
6
- `);let i=a.labels[0],c=i?zn(s,i.start):"",m=`${$(e)}${c}: ${Xn(a.message)}`;l.warn(m),r=!0})}catch{}})),r)l.info(`
5
+ `)+"\x1B[0m")},z=(n,r)=>{Tn(n,r),process.exit(1)};var l={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(n,r,t,e,s){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length));if(e){let[i,...c]=t.split(" "),f=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-i.length)),m=s?` \x1B[48;5;${n};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${o}${i}${f} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${c.join(" ")}${m}`}let a=s?` \x1B[48;5;${n};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${o}${t}${a}`},cli(n){let r=this.labels.cli;console.log(this.formatMessage(this.colors.cli,r,n))},info(n){console.log(`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`)},warn(n){let r=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,r,n))},error(n){let r=this.labels.error;console.error(this.formatMessage(this.colors.error,r,n))},progress(n,r,t,e){let s=String(n),o=this.colors.default;for(let[a,i]of Object.entries(this.colors.progress))if(s.includes(a)){o=i;break}console.log(this.formatMessage(o,s,r,t,e))}};function X(n){try{return kn(".",n)}catch(r){return l.warn(`Failed to load tsconfig: ${u(r)}`),{path:n,data:{},files:[]}}}import{rollup as In}from"rollup";import Jn from"rollup-plugin-dts";import P from"typescript";import G from"node:fs";import Dn from"node:path";var O={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function V(n,r){return{outdir:`${r}/${n.outDir}`,minify:Mn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function Mn(n){let{minify:r,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:s}=n,o=r===!0;return{whitespace:t??o,identifiers:e??o,syntax:s??o}}function _(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function nn(n=8){return Math.random().toString(36).substring(2,2+n)}function rn(n,r){switch(n){case"esm":return".mjs";case"cjs":return A(r)?".cjs":".js";case"iife":return".global.js"}}function tn(n,r){switch(n){case"esm":return".d.mts";case"cjs":return A(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function A(n){return n==="module"}function en(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function sn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function on(n,r){return n===void 0?r==="esm":n}function q(n){if(n===0)return"0 B";let r=["B","KB","MB","GB"],t=Math.floor(Math.log(n)/Math.log(1024));if(t===0)return`${n} ${r[t]}`;return`${(n/Math.pow(1024,t)).toFixed(2)} ${r[t]}`}function C(n,r=3){return n.split("/").slice(-r).join("/")}function I(n,r){let t=Dn.join(n,r);if(G.existsSync(t))try{G.rmSync(t,{recursive:!0,force:!0})}catch(e){throw new y(`Failed to clean output directory: ${e}`)}G.mkdirSync(t,{recursive:!0})}function J(n){return n||O.outDir}function an(n){return n===void 0?O.clean:n}function cn(n){return n.map((r)=>typeof r==="string"?new RegExp(`^${_(r)}($|\\/|\\\\)`):r)}function N(n,r){return cn(n.external||[]).concat(sn(r).map((t)=>new RegExp(`^${_(t)}($|\\/|\\\\)`)))}function j(n){return cn(n.noExternal||[])}import T from"node:fs";import Y from"node:path";async function ln(n){let r=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let t of r){let e=Y.join(n,`bunup.config${t}`);try{if(!T.existsSync(e))continue;let s=await Un(e,t);if(!s)continue;return{configs:Ln(s,n),configFilePath:e}}catch(s){throw new y(`Failed to load config from ${e}: ${u(s)}`)}}return{configs:[],configFilePath:""}}async function Un(n,r){if(r===".json"||r===".jsonc")return Hn(n);return Wn(n)}function Hn(n){try{let r=T.readFileSync(n,"utf8"),t=JSON.parse(r);return t.bunup||t}catch(r){throw new Error(`Invalid JSON in config file. ${u(r)}`)}}async function Wn(n){try{let r=await import(`file://${n}`),t=r.default||r;if(!t)return l.warn(`No export found in ${n}. Make sure you're exporting your configuration.`),{};return t}catch(r){throw new Error(`Failed to import config file. ${u(r)}`)}}function Ln(n,r){let t=[];if(Gn(n))_n(n,r,t);else if(Array.isArray(n))qn(n,r,t);else if(n&&typeof n==="object")t.push({options:n,rootDir:r});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return t}function Gn(n){return Array.isArray(n)&&n.length>0&&n.every((r)=>typeof r==="object"&&r!==null&&("name"in r)&&("root"in r)&&("config"in r))}function _n(n,r,t){for(let e of n){let s=Y.resolve(r,e.root);if(Array.isArray(e.config))for(let o of e.config)t.push({options:{name:e.name,...o},rootDir:s});else t.push({options:{name:e.name,...e.config},rootDir:s})}}function qn(n,r,t){for(let e of n){if(!e||typeof e!=="object")throw new Error("Invalid configuration item. Expected an object.");t.push({options:e,rootDir:r})}}function k(n){let r=Y.join(n,"package.json");try{if(!T.existsSync(r))return null;let t=T.readFileSync(r,"utf8");return JSON.parse(t)}catch(t){return l.warn(`Failed to load package.json at ${r}: ${u(t)}`),null}}import E from"path";var x="\x00virtual:",fn=(n)=>{return{name:"bunup:virtual-dts",resolveId(r,t){if(r.startsWith(x))return r;if(!t?.startsWith(x)||!r.startsWith("."))return null;let e=t.slice(x.length),s=E.resolve(E.dirname(e),r);if(r==="."){let a=E.join(E.dirname(e),"index.d.ts");if(n.has(a))return`${x}${a}`;s=E.dirname(e)}if(n.has(s))return`${x}${s}`;let o=`${s}.d.ts`;if(n.has(o))return`${x}${o}`;if(r.startsWith(".")){let a=E.join(s,"index.d.ts");if(n.has(a))return`${x}${a}`}return null},load(r){if(r.startsWith(x)){let t=r.slice(x.length),e=n.get(t);if(e)return B.add(t),e}return null}}};async function pn(n,r,t,e,s){let o=n.replace(/\.tsx?$/,".d.ts"),a=`${x}${o}`,i=s.data?.compilerOptions,c=k(e),f=N(t,c),m=j(t),p;try{p=await In({input:a,onwarn(b,$){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(b.code??""))return;$(b)},plugins:[fn(r),Jn({tsconfig:s.path,compilerOptions:{...i?P.parseJsonConfigFileContent({compilerOptions:i},P.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:P.ScriptTarget.ESNext}})],external:(b)=>f.some(($)=>$.test(b))&&!m.some(($)=>$.test(b))});let{output:h}=await p.generate({});if(!h[0]?.code)throw new g("Generated bundle is empty");return h[0].code}catch(h){throw new g(`DTS bundling failed: ${u(h)}`)}finally{if(p)await p.close()}}import dn from"node:fs";import gn from"node:path";import M from"node:path";function F(n){let r=M.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?M.resolve(r,n.data.compilerOptions.baseUrl):r}function un(n){let r=new Map,t=n.data?.compilerOptions?.paths;if(!t)return r;let e=F(n);for(let[s,o]of Object.entries(t))if(Array.isArray(o)&&o.length){let a=s.replace(/\*/g,"(.*)"),i=o[0].replace(/\*/g,"$1");r.set(`^${a}$`,M.join(e,i))}return r}function mn(n,r,t){for(let[e,s]of r){let o=new RegExp(e),a=n.match(o);if(a)return s.replace("$1",a[1]||"")}return t?M.join(t,n):null}var Yn=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Pn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function hn(n,r){let t=new Set([n]),e=[n],s=un(r),o=F(r);while(e.length){let a=e.pop();if(!a)continue;try{let i=await dn.promises.readFile(a,"utf8"),c=Fn(i);for(let f of c){let m=f.startsWith(".")?gn.resolve(gn.dirname(a),f):mn(f,s,o);if(!m)continue;let p=Kn(m);if(p&&!t.has(p))t.add(p),e.push(p)}}catch(i){l.warn(`Error processing ${a}: ${u(i)}`)}}return t}function Fn(n){let r=new Set;for(let t of[Yn,Pn]){let e;while((e=t.exec(n))!==null)r.add(e[2])}return Array.from(r)}function Kn(n){let r=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of r){let e=`${n}${t}`;if(dn.existsSync(e)&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}import Qn from"node:fs";import{isolatedDeclaration as Zn}from"oxc-transform";async function xn(n){let r=new Map;return await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.tsx?$/,".d.ts"),s=await Qn.promises.readFile(t,"utf8"),{code:o}=Zn(t,s);if(o)r.set(e,o)}catch(e){l.warn(`Failed to generate declaration for ${t}: ${u(e)}`)}})),r}import Q from"node:fs";import K from"node:path";import{isolatedDeclaration as zn}from"oxc-transform";function yn(n,r){let t=K.resolve(n),e=K.resolve(t,r);if(!Q.existsSync(t))throw new g(`Root directory does not exist: ${t}`);if(!Q.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(K.relative(t,e).startsWith(".."))throw new g(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}async function wn(n){let r=!1;if(await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.d\.ts$/,".ts"),s=await Q.promises.readFile(e,"utf8"),{errors:o}=zn(e,s);o.forEach((a)=>{if(!r)console.log(`
6
+ `);let i=a.labels[0],c=i?Xn(s,i.start):"",m=`${C(e)}${c}: ${Vn(a.message)}`;l.warn(m),r=!0})}catch{}})),r)l.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 zn(n,r){if(r===void 0)return"";let t=n.slice(0,r).split(`
9
- `),e=t.length,s=t[t.length-1].length+1;return` (${e}:${s})`}function Xn(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function wn(n,r,t){let{absoluteRootDir:e,absoluteEntry:s}=xn(n,r),o=X(t.preferredTsconfigPath),a=await dn(s,o),i=await hn(a);return fn(s,i,t,e,o)}function D(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function S(n){let r=[],t=new Set;function e(s,o){if(t.has(s)){let a=nn();r.push({name:`${s}_${a}`,path:o})}else r.push({name:s,path:o}),t.add(s)}if(Array.isArray(n))for(let s of n){let o=D(s);e(o,s)}else Object.entries(n).forEach(([s,o])=>{e(s,o)});return r}function bn(n,r){return`[dir]/${n}${r}`}function On(n,r){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let s=e.path;if(n.some((a)=>a.test(s))&&!r.some((a)=>a.test(s)))return{path:s,external:!0};return null})}}}var E=new Set;async function U(n,r){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 t=k(r),e=t?.type,s=N(n,t),o=T(n),a=[On(s,o)],i=S(n.entry),c=V(n,r),p=n.format.flatMap((m)=>i.map((f)=>{return Vn(n,r,f,m,e,a,c)}));try{await Promise.all(p)}catch(m){throw console.error(m),new y("Build process encountered errors")}if(n.dts){let m=n.format.filter((h)=>{if(h==="iife"&&!A(e)&&n.format.includes("cjs"))return!1;return!0}),f=n.dts===!0?i:S(n.dts.entry);try{await Promise.all(f.map(async(h)=>{let b=await wn(r,h.path,n);await Promise.all(m.map(async(O)=>{let An=tn(O,e),L=`${r}/${n.outDir}/${h.name}${An}`;await Bun.write(L,b);let Nn=Bun.file(L).size||0;l.progress("DTS",$(L),q(Nn),n.name)}))}))}catch(h){throw new g(`DTS build process encountered errors: ${u(h)}`)}}}async function Vn(n,r,t,e,s,o,a){let i=rn(e,s),c=await Bun.build({...a,entrypoints:[`${r}/${t.path}`],format:e,naming:{entry:bn(t.name,i)},splitting:on(n.splitting,e),plugins:o,throw:!1});if(!c.success)throw c.logs.forEach((f)=>{if(f.level==="error")l.error(f.message);else if(f.level==="warning")l.warn(f.message);else if(f.level==="info")l.info(f.message)}),new y(`Build failed for ${t.path} (${e})`);let p=`${r}/${n.outDir}/${t.name}${i}`,m=Bun.file(p).size||0;l.progress(e.toUpperCase(),$(p),q(m),n.name)}var $n="0.2.9";var Cn="https://bun.sh/docs/installation",vn="https://bunup.arshadyaseen.com/#cli-options";function w(n){return(r,t)=>{t[n]=r===!0?!0:r==="true"}}function H(n){return(r,t)=>{if(typeof r==="string")t[n]=r;else throw new d(`Option --${n} requires a string value`)}}function En(n){return(r,t)=>{if(typeof r==="string")t[n]=r.split(",");else throw new d(`Option --${n} requires a string value`)}}function rr(){console.log(`
8
+ `)}function Xn(n,r){if(r===void 0)return"";let t=n.slice(0,r).split(`
9
+ `),e=t.length,s=t[t.length-1].length+1;return` (${e}:${s})`}function Vn(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function bn(n,r,t){let{absoluteRootDir:e,absoluteEntry:s}=yn(n,r),o=X(t.preferredTsconfigPath),a=await hn(s,o),i=await xn(a);return pn(s,i,t,e,o)}function D(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function S(n){let r=[],t=new Set;function e(s,o){if(t.has(s)){let a=nn();r.push({name:`${s}_${a}`,path:o})}else r.push({name:s,path:o}),t.add(s)}if(Array.isArray(n))for(let s of n){let o=D(s);e(o,s)}else Object.entries(n).forEach(([s,o])=>{e(s,o)});return r}function $n(n,r){return`[dir]/${n}${r}`}function On(n,r){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let s=e.path;if(n.some((a)=>a.test(s))&&!r.some((a)=>a.test(s)))return{path:s,external:!0};return null})}}}var B=new Set;async function U(n,r){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 t=k(r),e=t?.type,s=N(n,t),o=j(n),a=[On(s,o)],i=S(n.entry),c=V(n,r),f=n.format.flatMap((m)=>i.map((p)=>{return nr(n,r,p,m,e,a,c)}));try{await Promise.all(f)}catch(m){throw console.error(m),new y("Build process encountered errors")}if(n.dts){let m=n.format.filter((h)=>{if(h==="iife"&&!A(e)&&n.format.includes("cjs"))return!1;return!0}),p=n.dts===!0?i:S(n.dts.entry);try{await Promise.all(p.map(async(h)=>{let b=await bn(r,h.path,n);await Promise.all(m.map(async($)=>{let Nn=tn($,e),L=`${r}/${n.outDir}/${h.name}${Nn}`;await Bun.write(L,b);let jn=Bun.file(L).size||0;l.progress("DTS",C(L),q(jn),n.name)}))}))}catch(h){throw new g(`DTS build process encountered errors: ${u(h)}`)}}}async function nr(n,r,t,e,s,o,a){let i=rn(e,s),c=await Bun.build({...a,entrypoints:[`${r}/${t.path}`],format:e,naming:{entry:$n(t.name,i)},splitting:on(n.splitting,e),plugins:o,throw:!1});if(!c.success)throw c.logs.forEach((p)=>{if(p.level==="error")l.error(p.message);else if(p.level==="warning")l.warn(p.message);else if(p.level==="info")l.info(p.message)}),new y(`Build failed for ${t.path} (${e})`);let f=`${r}/${n.outDir}/${t.name}${i}`,m=Bun.file(f).size||0;l.progress(e.toUpperCase(),C(f),q(m),n.name)}var Cn="0.2.11";var vn="https://bun.sh/docs/installation",En="https://bunup.arshadyaseen.com/#cli-options";function w(n){return(r,t)=>{t[n]=r===!0?!0:r==="true"}}function H(n){return(r,t)=>{if(typeof r==="string")t[n]=r;else throw new d(`Option --${n} requires a string value`)}}function Bn(n){return(r,t)=>{if(typeof r==="string")t[n]=r.split(",");else throw new d(`Option --${n} requires a string value`)}}function tr(){console.log(`
10
10
  Bunup - An extremely fast, zero-config bundler for JavaScript and TypeScript, powered by Bun.
11
- `),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${vn}\x1B[0m
12
- `),process.exit(0)}function tr(){console.log($n),process.exit(0)}var er={name:{flags:["n","name"],handler:H("name")},format:{flags:["f","format"],handler:(n,r)=>{if(typeof n==="string")r.format=n.split(",");else throw new d("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:H("outDir")},minify:{flags:["m","minify"],handler:w("minify")},watch:{flags:["w","watch"],handler:w("watch")},dts:{flags:["d","dts"],handler:w("dts")},external:{flags:["e","external"],handler:En("external")},sourcemap:{flags:["sm","sourcemap"],handler:H("sourcemap")},target:{flags:["t","target"],handler:H("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:w("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:w("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:w("minifySyntax")},clean:{flags:["c","clean"],handler:w("clean")},splitting:{flags:["s","splitting"],handler:w("splitting")},noExternal:{flags:["ne","no-external"],handler:En("noExternal")}},sr={help:{flags:["h","help"],handler:()=>rr()},version:{flags:["v","version"],handler:()=>tr()}},W={};for(let n of Object.values(er))if(n)for(let r of n.flags)W[r]=n.handler;for(let n of Object.values(sr))for(let r of n.flags)W[r]=n.handler;function Bn(n){let r={},t={},e=0;while(e<n.length){let s=n[e];if(s.startsWith("--")){let o,a;if(s.includes("=")){let[i,c]=s.slice(2).split("=",2);o=i,a=c}else{o=s.slice(2);let i=n[e+1];if(a=i&&!i.startsWith("-")?i:!0,typeof a==="string")e++}if(o==="entry")if(typeof a==="string"){let i=D(a);if(t[i])l.warn(`Duplicate entry name '${i}' derived from '${a}'. Overwriting previous entry.`);t[i]=a}else throw new d("Option --entry requires a string value");else if(o.startsWith("entry.")){let i=o.slice(6);if(typeof a==="string"){if(t[i])l.warn(`Duplicate entry name '${i}' provided via --entry.${i}. Overwriting previous entry.`);t[i]=a}else throw new d(`Option --entry.${i} requires a string value`)}else{let i=W[o];if(i)i(a,r);else throw new d(`Unknown option: --${o}`)}}else if(s.startsWith("-")){let o=s.slice(1),a=n[e+1],i=a&&!a.startsWith("-")?a:!0;if(typeof i==="string")e++;let c=W[o];if(c)c(i,r);else throw new d(`Unknown option: -${o}`)}else{let o=D(s);if(t[o])l.warn(`Duplicate entry name '${o}' derived from positional argument '${s}'. Overwriting previous entry.`);t[o]=s}e++}if(Object.keys(t).length>0)r.entry=t;return r}(()=>{if(typeof Bun==="undefined")throw new d(`Bunup requires Bun to run.
13
- To install Bun, visit `+Cn)})();import Z from"node:path";import or from"chokidar";async function Rn(n,r){let t=new Set,e=S(n.entry);e.forEach((c)=>{let p=Z.resolve(r,c.path),m=Z.dirname(p);t.add(m)});let s=or.watch(Array.from(t),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),o=null,a=!1,i=async()=>{if(a)return;a=!0;try{await U({...n,entry:e.map((c)=>c.path),clean:!1},r),n.onBuildEnd?.()}catch(c){throw new B(`Build failed: ${u(c)}`)}finally{a=!1}};s.on("change",(c)=>{let p=Z.relative(r,c);if(l.cli(`File changed: ${p}`),o)clearTimeout(o);o=setTimeout(()=>i(),300)}),s.on("error",(c)=>{throw new B(`Watcher error: ${u(c)}`)}),await i()}async function ir(n=Bun.argv.slice(2)){let r=Bn(n),{configs:t,configFilePath:e}=await cn(process.cwd());if(e)l.cli(`Using config file: ${$(e,2)}`);if(r.watch)l.cli("Starting watch mode"),l.cli("Watching for file changes");let s=performance.now();if(l.cli("Build started"),t.length===0){let i={...R,...r},c=process.cwd();if(i.clean)I(c,J(i.outDir));await Sn(i,c)}else{for(let{options:i,rootDir:c}of t)if(i.clean)I(c,J(i.outDir));await Promise.all(t.map(async({options:i,rootDir:c})=>{let p={...R,...i,...r};await Sn(p,c)}))}let o=performance.now()-s,a=en(o);if(l.cli(`\u26A1\uFE0F Build completed in ${a}`),E.size>0)await yn(E),E.clear();if(!r.watch)process.exit(0)}async function Sn(n,r){if(n.watch)await Rn(n,r);else await U(n,r),n.onBuildEnd?.()}ir().catch((n)=>z(n));export{ir as main};
11
+ `),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${En}\x1B[0m
12
+ `),process.exit(0)}function er(){console.log(Cn),process.exit(0)}var sr={name:{flags:["n","name"],handler:H("name")},format:{flags:["f","format"],handler:(n,r)=>{if(typeof n==="string")r.format=n.split(",");else throw new d("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:H("outDir")},minify:{flags:["m","minify"],handler:w("minify")},watch:{flags:["w","watch"],handler:w("watch")},dts:{flags:["d","dts"],handler:w("dts")},external:{flags:["e","external"],handler:Bn("external")},sourcemap:{flags:["sm","sourcemap"],handler:H("sourcemap")},target:{flags:["t","target"],handler:H("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:w("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:w("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:w("minifySyntax")},clean:{flags:["c","clean"],handler:w("clean")},splitting:{flags:["s","splitting"],handler:w("splitting")},noExternal:{flags:["ne","no-external"],handler:Bn("noExternal")}},or={help:{flags:["h","help"],handler:()=>tr()},version:{flags:["v","version"],handler:()=>er()}},W={};for(let n of Object.values(sr))if(n)for(let r of n.flags)W[r]=n.handler;for(let n of Object.values(or))for(let r of n.flags)W[r]=n.handler;function Rn(n){let r={},t={},e=0;while(e<n.length){let s=n[e];if(s.startsWith("--")){let o,a;if(s.includes("=")){let[i,c]=s.slice(2).split("=",2);o=i,a=c}else{o=s.slice(2);let i=n[e+1];if(a=i&&!i.startsWith("-")?i:!0,typeof a==="string")e++}if(o==="entry")if(typeof a==="string"){let i=D(a);if(t[i])l.warn(`Duplicate entry name '${i}' derived from '${a}'. Overwriting previous entry.`);t[i]=a}else throw new d("Option --entry requires a string value");else if(o.startsWith("entry.")){let i=o.slice(6);if(typeof a==="string"){if(t[i])l.warn(`Duplicate entry name '${i}' provided via --entry.${i}. Overwriting previous entry.`);t[i]=a}else throw new d(`Option --entry.${i} requires a string value`)}else{let i=W[o];if(i)i(a,r);else throw new d(`Unknown option: --${o}`)}}else if(s.startsWith("-")){let o=s.slice(1),a=n[e+1],i=a&&!a.startsWith("-")?a:!0;if(typeof i==="string")e++;let c=W[o];if(c)c(i,r);else throw new d(`Unknown option: -${o}`)}else{let o=D(s);if(t[o])l.warn(`Duplicate entry name '${o}' derived from positional argument '${s}'. Overwriting previous entry.`);t[o]=s}e++}if(Object.keys(t).length>0)r.entry=t;return r}(()=>{if(typeof Bun==="undefined")throw new d(`Bunup requires Bun to run.
13
+ To install Bun, visit `+vn)})();import Z from"node:path";import ir from"chokidar";async function Sn(n,r){let t=new Set,e=S(n.entry);e.forEach((c)=>{let f=Z.resolve(r,c.path),m=Z.dirname(f);t.add(m)});let s=ir.watch(Array.from(t),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),o=null,a=!1,i=async()=>{if(a)return;a=!0;try{await U({...n,entry:e.map((c)=>c.path),clean:!1},r),n.onBuildEnd?.()}catch(c){throw new R(`Build failed: ${u(c)}`)}finally{a=!1}};s.on("change",(c)=>{let f=Z.relative(r,c);if(l.cli(`File changed: ${f}`),o)clearTimeout(o);o=setTimeout(()=>i(),300)}),s.on("error",(c)=>{throw new R(`Watcher error: ${u(c)}`)}),await i()}async function ar(n=Bun.argv.slice(2)){let r=Rn(n),{configs:t,configFilePath:e}=await ln(process.cwd());if(e)l.cli(`Using config file: ${C(e,2)}`);if(r.watch)l.cli("Starting watch mode"),l.cli("Watching for file changes");let s=performance.now();if(l.cli("Build started"),t.length===0){let i={...O,...r},c=process.cwd();if(i.clean)I(c,J(i.outDir));await An(i,c)}else{for(let{options:i,rootDir:c}of t)if(an(i.clean))I(c,J(i.outDir));await Promise.all(t.map(async({options:i,rootDir:c})=>{let f={...O,...i,...r};console.log(O,i,r,f),await An(f,c)}))}let o=performance.now()-s,a=en(o);if(l.cli(`\u26A1\uFE0F Build completed in ${a}`),B.size>0)await wn(B),B.clear();if(!r.watch)process.exit(0)}async function An(n,r){if(n.watch)await Sn(n,r);else await U(n,r),n.onBuildEnd?.()}ar().catch((n)=>z(n));export{ar as main};
package/build/index.js CHANGED
@@ -1 +1 @@
1
- var Rr=require("node:module");var hr=Object.create;var{getPrototypeOf:Cr,defineProperty:y,getOwnPropertyNames:U,getOwnPropertyDescriptor:yr}=Object,K=Object.prototype.hasOwnProperty;var g=(r,n,t)=>{t=r!=null?hr(Cr(r)):{};let o=n||!r||!r.__esModule?y(t,"default",{value:r,enumerable:!0}):t;for(let s of U(r))if(!K.call(o,s))y(o,s,{get:()=>r[s],enumerable:!0});return o},q=new WeakMap,Or=(r)=>{var n=q.get(r),t;if(n)return n;if(n=y({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")U(r).map((o)=>!K.call(n,o)&&y(n,o,{get:()=>r[o],enumerable:!(t=yr(r,o))||t.enumerable}));return q.set(r,n),n};var br=(r,n)=>{for(var t in n)y(r,t,{get:n[t],enumerable:!0,configurable:!0,set:(o)=>n[t]=()=>o})};var Gr={};br(Gr,{defineWorkspace:()=>Q,defineConfig:()=>L,build:()=>$r});module.exports=Or(Gr);function L(r){return r}function Q(r){return r}var Z=require("load-tsconfig");class M extends Error{constructor(r){super(r);this.name="BunupError"}}class h extends M{constructor(r){super(r);this.name="BunupBuildError"}}class x extends M{constructor(r){super(r);this.name="BunupDTSBuildError"}}var u=(r)=>{if(r instanceof Error)return r.message;return String(r)};var f={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(r,n,t,o,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));if(o){let[c,...$]=t.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),l=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${c}${p} \x1B[38;5;${this.colors.size}m${o}\x1B[0m ${$.join(" ")}${l}`}let i=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${t}${i}`},cli(r){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,r))},info(r){console.log(`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`)},warn(r){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,r))},error(r){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,r))},progress(r,n,t,o){let s=String(r),e=this.colors.default;for(let[i,c]of Object.entries(this.colors.progress))if(s.includes(i)){e=c;break}console.log(this.formatMessage(e,s,n,t,o))}};function z(r){try{return Z.loadTsConfig(".",r)}catch(n){return f.warn(`Failed to load tsconfig: ${u(n)}`),{path:r,data:{},files:[]}}}var sr=require("rollup"),er=g(require("rollup-plugin-dts")),j=g(require("typescript"));var vr=g(require("node:fs")),Sr=g(require("node:path"));function _(r,n){return{outdir:`${n}/${r.outDir}`,minify:Br(r),target:r.target,splitting:r.splitting,sourcemap:r.sourcemap}}function Br(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:o,minifySyntax:s}=r,e=n===!0;return{whitespace:t??e,identifiers:o??e,syntax:s??e}}function T(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function F(r=8){return Math.random().toString(36).substring(2,2+r)}function P(r,n){switch(r){case"esm":return".mjs";case"cjs":return b(n)?".cjs":".js";case"iife":return".global.js"}}function X(r,n){switch(r){case"esm":return".d.mts";case"cjs":return b(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function b(r){return r==="module"}function I(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function V(r,n){return r===void 0?n==="esm":r}function D(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/Math.pow(1024,t)).toFixed(2)} ${n[t]}`}function R(r,n=3){return r.split("/").slice(-n).join("/")}function rr(r){return r.map((n)=>typeof n==="string"?new RegExp(`^${T(n)}($|\\/|\\\\)`):n)}function B(r,n){return rr(r.external||[]).concat(I(n).map((t)=>new RegExp(`^${T(t)}($|\\/|\\\\)`)))}function v(r){return rr(r.noExternal||[])}var W=g(require("node:fs")),nr=g(require("node:path"));function S(r){let n=nr.default.join(r,"package.json");try{if(!W.default.existsSync(n))return null;let t=W.default.readFileSync(n,"utf8");return JSON.parse(t)}catch(t){return f.warn(`Failed to load package.json at ${n}: ${u(t)}`),null}}var C=g(require("path"));var d="\x00virtual:",tr=(r)=>{return{name:"bunup:virtual-dts",resolveId(n,t){if(n.startsWith(d))return n;if(!t?.startsWith(d)||!n.startsWith("."))return null;let o=t.slice(d.length),s=C.default.resolve(C.default.dirname(o),n);if(n==="."){let i=C.default.join(C.default.dirname(o),"index.d.ts");if(r.has(i))return`${d}${i}`;s=C.default.dirname(o)}if(r.has(s))return`${d}${s}`;let e=`${s}.d.ts`;if(r.has(e))return`${d}${e}`;if(n.startsWith(".")){let i=C.default.join(s,"index.d.ts");if(r.has(i))return`${d}${i}`}return null},load(n){if(n.startsWith(d)){let t=n.slice(d.length),o=r.get(t);if(o)return or.add(t),o}return null}}};async function ir(r,n,t,o,s){let e=r.replace(/\.tsx?$/,".d.ts"),i=`${d}${e}`,c=s.data?.compilerOptions,$=S(o),p=B(t,$),l=v(t),a;try{a=await sr.rollup({input:i,onwarn(w,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(w.code??""))return;E(w)},plugins:[tr(n),er.default({tsconfig:s.path,compilerOptions:{...c?j.default.parseJsonConfigFileContent({compilerOptions:c},j.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:j.default.ScriptTarget.ESNext}})],external:(w)=>p.some((E)=>E.test(w))&&!l.some((E)=>E.test(w))});let{output:m}=await a.generate({});if(!m[0]?.code)throw new x("Generated bundle is empty");return m[0].code}catch(m){throw new x(`DTS bundling failed: ${u(m)}`)}finally{if(a)await a.close()}}var H=g(require("node:fs")),k=g(require("node:path"));var O=g(require("node:path"));function G(r){let n=O.default.dirname(r.path||"");return r.data?.compilerOptions?.baseUrl?O.default.resolve(n,r.data.compilerOptions.baseUrl):n}function cr(r){let n=new Map,t=r.data?.compilerOptions?.paths;if(!t)return n;let o=G(r);for(let[s,e]of Object.entries(t))if(Array.isArray(e)&&e.length){let i=s.replace(/\*/g,"(.*)"),c=e[0].replace(/\*/g,"$1");n.set(`^${i}$`,O.default.join(o,c))}return n}function ar(r,n,t){for(let[o,s]of n){let e=new RegExp(o),i=r.match(e);if(i)return s.replace("$1",i[1]||"")}return t?O.default.join(t,r):null}var jr=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Nr=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function fr(r,n){let t=new Set([r]),o=[r],s=cr(n),e=G(n);while(o.length){let i=o.pop();if(!i)continue;try{let c=await H.default.promises.readFile(i,"utf8"),$=Ar(c);for(let p of $){let l=p.startsWith(".")?k.default.resolve(k.default.dirname(i),p):ar(p,s,e);if(!l)continue;let a=Mr(l);if(a&&!t.has(a))t.add(a),o.push(a)}}catch(c){f.warn(`Error processing ${i}: ${u(c)}`)}}return t}function Ar(r){let n=new Set;for(let t of[jr,Nr]){let o;while((o=t.exec(r))!==null)n.add(o[2])}return Array.from(n)}function Mr(r){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of n){let o=`${r}${t}`;if(H.default.existsSync(o)&&(o.endsWith(".ts")||o.endsWith(".tsx")))return o}return null}var lr=g(require("node:fs")),gr=require("oxc-transform");async function pr(r){let n=new Map;return await Promise.all([...r].map(async(t)=>{try{let o=t.replace(/\.tsx?$/,".d.ts"),s=await lr.default.promises.readFile(t,"utf8"),{code:e}=gr.isolatedDeclaration(t,s);if(e)n.set(o,e)}catch(o){f.warn(`Failed to generate declaration for ${t}: ${u(o)}`)}})),n}var J=g(require("node:fs")),N=g(require("node:path")),Tr=require("oxc-transform");function ur(r,n){let t=N.default.resolve(r),o=N.default.resolve(t,n);if(!J.default.existsSync(t))throw new x(`Root directory does not exist: ${t}`);if(!J.default.existsSync(o))throw new x(`Entry file does not exist: ${o}`);if(!o.endsWith(".ts"))throw new x(`Entry file must be a TypeScript file (.ts): ${o}`);if(N.default.relative(t,o).startsWith(".."))throw new x(`Entry file must be within rootDir: ${o}`);return{absoluteRootDir:t,absoluteEntry:o}}async function mr(r,n,t){let{absoluteRootDir:o,absoluteEntry:s}=ur(r,n),e=z(t.preferredTsconfigPath),i=await fr(s,e),c=await pr(i);return ir(s,c,t,o,e)}function Dr(r){return r.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function Y(r){let n=[],t=new Set;function o(s,e){if(t.has(s)){let i=F();n.push({name:`${s}_${i}`,path:e})}else n.push({name:s,path:e}),t.add(s)}if(Array.isArray(r))for(let s of r){let e=Dr(s);o(e,s)}else Object.entries(r).forEach(([s,e])=>{o(s,e)});return n}function xr(r,n){return`[dir]/${r}${n}`}function dr(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(o)=>{let s=o.path;if(r.some((i)=>i.test(s))&&!n.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var or=new Set;async function $r(r,n){if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let t=S(n),o=t?.type,s=B(r,t),e=v(r),i=[dr(s,e)],c=Y(r.entry),$=_(r,n),p=r.format.flatMap((l)=>c.map((a)=>{return Wr(r,n,a,l,o,i,$)}));try{await Promise.all(p)}catch(l){throw console.error(l),new h("Build process encountered errors")}if(r.dts){let l=r.format.filter((m)=>{if(m==="iife"&&!b(o)&&r.format.includes("cjs"))return!1;return!0}),a=r.dts===!0?c:Y(r.dts.entry);try{await Promise.all(a.map(async(m)=>{let w=await mr(n,m.path,r);await Promise.all(l.map(async(E)=>{let wr=X(E,o),A=`${n}/${r.outDir}/${m.name}${wr}`;await Bun.write(A,w);let Er=Bun.file(A).size||0;f.progress("DTS",R(A),D(Er),r.name)}))}))}catch(m){throw new x(`DTS build process encountered errors: ${u(m)}`)}}}async function Wr(r,n,t,o,s,e,i){let c=P(o,s),$=await Bun.build({...i,entrypoints:[`${n}/${t.path}`],format:o,naming:{entry:xr(t.name,c)},splitting:V(r.splitting,o),plugins:e,throw:!1});if(!$.success)throw $.logs.forEach((a)=>{if(a.level==="error")f.error(a.message);else if(a.level==="warning")f.warn(a.message);else if(a.level==="info")f.info(a.message)}),new h(`Build failed for ${t.path} (${o})`);let p=`${n}/${r.outDir}/${t.name}${c}`,l=Bun.file(p).size||0;f.progress(o.toUpperCase(),R(p),D(l),r.name)}
1
+ var Rr=require("node:module");var hr=Object.create;var{getPrototypeOf:Cr,defineProperty:y,getOwnPropertyNames:U,getOwnPropertyDescriptor:yr}=Object,K=Object.prototype.hasOwnProperty;var g=(r,n,t)=>{t=r!=null?hr(Cr(r)):{};let o=n||!r||!r.__esModule?y(t,"default",{value:r,enumerable:!0}):t;for(let s of U(r))if(!K.call(o,s))y(o,s,{get:()=>r[s],enumerable:!0});return o},q=new WeakMap,br=(r)=>{var n=q.get(r),t;if(n)return n;if(n=y({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")U(r).map((o)=>!K.call(n,o)&&y(n,o,{get:()=>r[o],enumerable:!(t=yr(r,o))||t.enumerable}));return q.set(r,n),n};var Or=(r,n)=>{for(var t in n)y(r,t,{get:n[t],enumerable:!0,configurable:!0,set:(o)=>n[t]=()=>o})};var Gr={};Or(Gr,{defineWorkspace:()=>Z,defineConfig:()=>Q,build:()=>$r});module.exports=br(Gr);function Q(r){return r}function Z(r){return r}var z=require("load-tsconfig");class M extends Error{constructor(r){super(r);this.name="BunupError"}}class h extends M{constructor(r){super(r);this.name="BunupBuildError"}}class x extends M{constructor(r){super(r);this.name="BunupDTSBuildError"}}var u=(r)=>{if(r instanceof Error)return r.message;return String(r)};var f={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(r,n,t,o,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));if(o){let[c,...$]=t.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),l=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${c}${p} \x1B[38;5;${this.colors.size}m${o}\x1B[0m ${$.join(" ")}${l}`}let i=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${t}${i}`},cli(r){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,r))},info(r){console.log(`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`)},warn(r){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,r))},error(r){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,r))},progress(r,n,t,o){let s=String(r),e=this.colors.default;for(let[i,c]of Object.entries(this.colors.progress))if(s.includes(i)){e=c;break}console.log(this.formatMessage(e,s,n,t,o))}};function L(r){try{return z.loadTsConfig(".",r)}catch(n){return f.warn(`Failed to load tsconfig: ${u(n)}`),{path:r,data:{},files:[]}}}var sr=require("rollup"),er=g(require("rollup-plugin-dts")),j=g(require("typescript"));var vr=g(require("node:fs")),Sr=g(require("node:path"));function X(r,n){return{outdir:`${n}/${r.outDir}`,minify:Br(r),target:r.target,splitting:r.splitting,sourcemap:r.sourcemap}}function Br(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:o,minifySyntax:s}=r,e=n===!0;return{whitespace:t??e,identifiers:o??e,syntax:s??e}}function T(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function _(r=8){return Math.random().toString(36).substring(2,2+r)}function F(r,n){switch(r){case"esm":return".mjs";case"cjs":return O(n)?".cjs":".js";case"iife":return".global.js"}}function P(r,n){switch(r){case"esm":return".d.mts";case"cjs":return O(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function O(r){return r==="module"}function I(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function V(r,n){return r===void 0?n==="esm":r}function W(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/Math.pow(1024,t)).toFixed(2)} ${n[t]}`}function R(r,n=3){return r.split("/").slice(-n).join("/")}function rr(r){return r.map((n)=>typeof n==="string"?new RegExp(`^${T(n)}($|\\/|\\\\)`):n)}function B(r,n){return rr(r.external||[]).concat(I(n).map((t)=>new RegExp(`^${T(t)}($|\\/|\\\\)`)))}function v(r){return rr(r.noExternal||[])}var D=g(require("node:fs")),nr=g(require("node:path"));function S(r){let n=nr.default.join(r,"package.json");try{if(!D.default.existsSync(n))return null;let t=D.default.readFileSync(n,"utf8");return JSON.parse(t)}catch(t){return f.warn(`Failed to load package.json at ${n}: ${u(t)}`),null}}var C=g(require("path"));var d="\x00virtual:",tr=(r)=>{return{name:"bunup:virtual-dts",resolveId(n,t){if(n.startsWith(d))return n;if(!t?.startsWith(d)||!n.startsWith("."))return null;let o=t.slice(d.length),s=C.default.resolve(C.default.dirname(o),n);if(n==="."){let i=C.default.join(C.default.dirname(o),"index.d.ts");if(r.has(i))return`${d}${i}`;s=C.default.dirname(o)}if(r.has(s))return`${d}${s}`;let e=`${s}.d.ts`;if(r.has(e))return`${d}${e}`;if(n.startsWith(".")){let i=C.default.join(s,"index.d.ts");if(r.has(i))return`${d}${i}`}return null},load(n){if(n.startsWith(d)){let t=n.slice(d.length),o=r.get(t);if(o)return or.add(t),o}return null}}};async function ir(r,n,t,o,s){let e=r.replace(/\.tsx?$/,".d.ts"),i=`${d}${e}`,c=s.data?.compilerOptions,$=S(o),p=B(t,$),l=v(t),a;try{a=await sr.rollup({input:i,onwarn(w,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(w.code??""))return;E(w)},plugins:[tr(n),er.default({tsconfig:s.path,compilerOptions:{...c?j.default.parseJsonConfigFileContent({compilerOptions:c},j.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:j.default.ScriptTarget.ESNext}})],external:(w)=>p.some((E)=>E.test(w))&&!l.some((E)=>E.test(w))});let{output:m}=await a.generate({});if(!m[0]?.code)throw new x("Generated bundle is empty");return m[0].code}catch(m){throw new x(`DTS bundling failed: ${u(m)}`)}finally{if(a)await a.close()}}var H=g(require("node:fs")),k=g(require("node:path"));var b=g(require("node:path"));function G(r){let n=b.default.dirname(r.path||"");return r.data?.compilerOptions?.baseUrl?b.default.resolve(n,r.data.compilerOptions.baseUrl):n}function cr(r){let n=new Map,t=r.data?.compilerOptions?.paths;if(!t)return n;let o=G(r);for(let[s,e]of Object.entries(t))if(Array.isArray(e)&&e.length){let i=s.replace(/\*/g,"(.*)"),c=e[0].replace(/\*/g,"$1");n.set(`^${i}$`,b.default.join(o,c))}return n}function ar(r,n,t){for(let[o,s]of n){let e=new RegExp(o),i=r.match(e);if(i)return s.replace("$1",i[1]||"")}return t?b.default.join(t,r):null}var jr=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Nr=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function fr(r,n){let t=new Set([r]),o=[r],s=cr(n),e=G(n);while(o.length){let i=o.pop();if(!i)continue;try{let c=await H.default.promises.readFile(i,"utf8"),$=Ar(c);for(let p of $){let l=p.startsWith(".")?k.default.resolve(k.default.dirname(i),p):ar(p,s,e);if(!l)continue;let a=Mr(l);if(a&&!t.has(a))t.add(a),o.push(a)}}catch(c){f.warn(`Error processing ${i}: ${u(c)}`)}}return t}function Ar(r){let n=new Set;for(let t of[jr,Nr]){let o;while((o=t.exec(r))!==null)n.add(o[2])}return Array.from(n)}function Mr(r){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of n){let o=`${r}${t}`;if(H.default.existsSync(o)&&(o.endsWith(".ts")||o.endsWith(".tsx")))return o}return null}var lr=g(require("node:fs")),gr=require("oxc-transform");async function pr(r){let n=new Map;return await Promise.all([...r].map(async(t)=>{try{let o=t.replace(/\.tsx?$/,".d.ts"),s=await lr.default.promises.readFile(t,"utf8"),{code:e}=gr.isolatedDeclaration(t,s);if(e)n.set(o,e)}catch(o){f.warn(`Failed to generate declaration for ${t}: ${u(o)}`)}})),n}var J=g(require("node:fs")),N=g(require("node:path")),Tr=require("oxc-transform");function ur(r,n){let t=N.default.resolve(r),o=N.default.resolve(t,n);if(!J.default.existsSync(t))throw new x(`Root directory does not exist: ${t}`);if(!J.default.existsSync(o))throw new x(`Entry file does not exist: ${o}`);if(!o.endsWith(".ts"))throw new x(`Entry file must be a TypeScript file (.ts): ${o}`);if(N.default.relative(t,o).startsWith(".."))throw new x(`Entry file must be within rootDir: ${o}`);return{absoluteRootDir:t,absoluteEntry:o}}async function mr(r,n,t){let{absoluteRootDir:o,absoluteEntry:s}=ur(r,n),e=L(t.preferredTsconfigPath),i=await fr(s,e),c=await pr(i);return ir(s,c,t,o,e)}function Wr(r){return r.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function Y(r){let n=[],t=new Set;function o(s,e){if(t.has(s)){let i=_();n.push({name:`${s}_${i}`,path:e})}else n.push({name:s,path:e}),t.add(s)}if(Array.isArray(r))for(let s of r){let e=Wr(s);o(e,s)}else Object.entries(r).forEach(([s,e])=>{o(s,e)});return n}function xr(r,n){return`[dir]/${r}${n}`}function dr(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(o)=>{let s=o.path;if(r.some((i)=>i.test(s))&&!n.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var or=new Set;async function $r(r,n){if(!r.entry||r.entry.length===0||!r.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let t=S(n),o=t?.type,s=B(r,t),e=v(r),i=[dr(s,e)],c=Y(r.entry),$=X(r,n),p=r.format.flatMap((l)=>c.map((a)=>{return Dr(r,n,a,l,o,i,$)}));try{await Promise.all(p)}catch(l){throw console.error(l),new h("Build process encountered errors")}if(r.dts){let l=r.format.filter((m)=>{if(m==="iife"&&!O(o)&&r.format.includes("cjs"))return!1;return!0}),a=r.dts===!0?c:Y(r.dts.entry);try{await Promise.all(a.map(async(m)=>{let w=await mr(n,m.path,r);await Promise.all(l.map(async(E)=>{let wr=P(E,o),A=`${n}/${r.outDir}/${m.name}${wr}`;await Bun.write(A,w);let Er=Bun.file(A).size||0;f.progress("DTS",R(A),W(Er),r.name)}))}))}catch(m){throw new x(`DTS build process encountered errors: ${u(m)}`)}}}async function Dr(r,n,t,o,s,e,i){let c=F(o,s),$=await Bun.build({...i,entrypoints:[`${n}/${t.path}`],format:o,naming:{entry:xr(t.name,c)},splitting:V(r.splitting,o),plugins:e,throw:!1});if(!$.success)throw $.logs.forEach((a)=>{if(a.level==="error")f.error(a.message);else if(a.level==="warning")f.warn(a.message);else if(a.level==="info")f.info(a.message)}),new h(`Build failed for ${t.path} (${o})`);let p=`${n}/${r.outDir}/${t.name}${c}`,l=Bun.file(p).size||0;f.progress(o.toUpperCase(),R(p),W(l),r.name)}
package/build/index.mjs CHANGED
@@ -1 +1 @@
1
- function ir(r){return r}function cr(r){return r}import{loadTsConfig as ar}from"load-tsconfig";class S extends Error{constructor(r){super(r);this.name="BunupError"}}class E extends S{constructor(r){super(r);this.name="BunupBuildError"}}class m extends S{constructor(r){super(r);this.name="BunupDTSBuildError"}}var p=(r)=>{if(r instanceof Error)return r.message;return String(r)};var f={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(r,n,t,o,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));if(o){let[c,...d]=t.split(" "),g=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),l=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${c}${g} \x1B[38;5;${this.colors.size}m${o}\x1B[0m ${d.join(" ")}${l}`}let i=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${t}${i}`},cli(r){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,r))},info(r){console.log(`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`)},warn(r){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,r))},error(r){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,r))},progress(r,n,t,o){let s=String(r),e=this.colors.default;for(let[i,c]of Object.entries(this.colors.progress))if(s.includes(i)){e=c;break}console.log(this.formatMessage(e,s,n,t,o))}};function W(r){try{return ar(".",r)}catch(n){return f.warn(`Failed to load tsconfig: ${p(n)}`),{path:r,data:{},files:[]}}}import{rollup as gr}from"rollup";import pr from"rollup-plugin-dts";import A from"typescript";import Mr from"node:fs";import Dr from"node:path";function G(r,n){return{outdir:`${n}/${r.outDir}`,minify:fr(r),target:r.target,splitting:r.splitting,sourcemap:r.sourcemap}}function fr(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:o,minifySyntax:s}=r,e=n===!0;return{whitespace:t??e,identifiers:o??e,syntax:s??e}}function j(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function k(r=8){return Math.random().toString(36).substring(2,2+r)}function H(r,n){switch(r){case"esm":return".mjs";case"cjs":return C(n)?".cjs":".js";case"iife":return".global.js"}}function J(r,n){switch(r){case"esm":return".d.mts";case"cjs":return C(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function C(r){return r==="module"}function Y(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function q(r,n){return r===void 0?n==="esm":r}function N(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/Math.pow(1024,t)).toFixed(2)} ${n[t]}`}function y(r,n=3){return r.split("/").slice(-n).join("/")}function U(r){return r.map((n)=>typeof n==="string"?new RegExp(`^${j(n)}($|\\/|\\\\)`):n)}function O(r,n){return U(r.external||[]).concat(Y(n).map((t)=>new RegExp(`^${j(t)}($|\\/|\\\\)`)))}function b(r){return U(r.noExternal||[])}import K from"node:fs";import lr from"node:path";function R(r){let n=lr.join(r,"package.json");try{if(!K.existsSync(n))return null;let t=K.readFileSync(n,"utf8");return JSON.parse(t)}catch(t){return f.warn(`Failed to load package.json at ${n}: ${p(t)}`),null}}import h from"path";var x="\x00virtual:",L=(r)=>{return{name:"bunup:virtual-dts",resolveId(n,t){if(n.startsWith(x))return n;if(!t?.startsWith(x)||!n.startsWith("."))return null;let o=t.slice(x.length),s=h.resolve(h.dirname(o),n);if(n==="."){let i=h.join(h.dirname(o),"index.d.ts");if(r.has(i))return`${x}${i}`;s=h.dirname(o)}if(r.has(s))return`${x}${s}`;let e=`${s}.d.ts`;if(r.has(e))return`${x}${e}`;if(n.startsWith(".")){let i=h.join(s,"index.d.ts");if(r.has(i))return`${x}${i}`}return null},load(n){if(n.startsWith(x)){let t=n.slice(x.length),o=r.get(t);if(o)return Q.add(t),o}return null}}};async function Z(r,n,t,o,s){let e=r.replace(/\.tsx?$/,".d.ts"),i=`${x}${e}`,c=s.data?.compilerOptions,d=R(o),g=O(t,d),l=b(t),a;try{a=await gr({input:i,onwarn($,w){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes($.code??""))return;w($)},plugins:[L(n),pr({tsconfig:s.path,compilerOptions:{...c?A.parseJsonConfigFileContent({compilerOptions:c},A.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:A.ScriptTarget.ESNext}})],external:($)=>g.some((w)=>w.test($))&&!l.some((w)=>w.test($))});let{output:u}=await a.generate({});if(!u[0]?.code)throw new m("Generated bundle is empty");return u[0].code}catch(u){throw new m(`DTS bundling failed: ${p(u)}`)}finally{if(a)await a.close()}}import P from"node:fs";import F from"node:path";import B from"node:path";function M(r){let n=B.dirname(r.path||"");return r.data?.compilerOptions?.baseUrl?B.resolve(n,r.data.compilerOptions.baseUrl):n}function z(r){let n=new Map,t=r.data?.compilerOptions?.paths;if(!t)return n;let o=M(r);for(let[s,e]of Object.entries(t))if(Array.isArray(e)&&e.length){let i=s.replace(/\*/g,"(.*)"),c=e[0].replace(/\*/g,"$1");n.set(`^${i}$`,B.join(o,c))}return n}function _(r,n,t){for(let[o,s]of n){let e=new RegExp(o),i=r.match(e);if(i)return s.replace("$1",i[1]||"")}return t?B.join(t,r):null}var ur=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,mr=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function X(r,n){let t=new Set([r]),o=[r],s=z(n),e=M(n);while(o.length){let i=o.pop();if(!i)continue;try{let c=await P.promises.readFile(i,"utf8"),d=xr(c);for(let g of d){let l=g.startsWith(".")?F.resolve(F.dirname(i),g):_(g,s,e);if(!l)continue;let a=dr(l);if(a&&!t.has(a))t.add(a),o.push(a)}}catch(c){f.warn(`Error processing ${i}: ${p(c)}`)}}return t}function xr(r){let n=new Set;for(let t of[ur,mr]){let o;while((o=t.exec(r))!==null)n.add(o[2])}return Array.from(n)}function dr(r){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of n){let o=`${r}${t}`;if(P.existsSync(o)&&(o.endsWith(".ts")||o.endsWith(".tsx")))return o}return null}import $r from"node:fs";import{isolatedDeclaration as wr}from"oxc-transform";async function I(r){let n=new Map;return await Promise.all([...r].map(async(t)=>{try{let o=t.replace(/\.tsx?$/,".d.ts"),s=await $r.promises.readFile(t,"utf8"),{code:e}=wr(t,s);if(e)n.set(o,e)}catch(o){f.warn(`Failed to generate declaration for ${t}: ${p(o)}`)}})),n}import V from"node:fs";import T from"node:path";import{isolatedDeclaration as Cn}from"oxc-transform";function rr(r,n){let t=T.resolve(r),o=T.resolve(t,n);if(!V.existsSync(t))throw new m(`Root directory does not exist: ${t}`);if(!V.existsSync(o))throw new m(`Entry file does not exist: ${o}`);if(!o.endsWith(".ts"))throw new m(`Entry file must be a TypeScript file (.ts): ${o}`);if(T.relative(t,o).startsWith(".."))throw new m(`Entry file must be within rootDir: ${o}`);return{absoluteRootDir:t,absoluteEntry:o}}async function nr(r,n,t){let{absoluteRootDir:o,absoluteEntry:s}=rr(r,n),e=W(t.preferredTsconfigPath),i=await X(s,e),c=await I(i);return Z(s,c,t,o,e)}function Er(r){return r.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function D(r){let n=[],t=new Set;function o(s,e){if(t.has(s)){let i=k();n.push({name:`${s}_${i}`,path:e})}else n.push({name:s,path:e}),t.add(s)}if(Array.isArray(r))for(let s of r){let e=Er(s);o(e,s)}else Object.entries(r).forEach(([s,e])=>{o(s,e)});return n}function tr(r,n){return`[dir]/${r}${n}`}function or(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(o)=>{let s=o.path;if(r.some((i)=>i.test(s))&&!n.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var Q=new Set;async function hr(r,n){if(!r.entry||r.entry.length===0||!r.outDir)throw new E("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let t=R(n),o=t?.type,s=O(r,t),e=b(r),i=[or(s,e)],c=D(r.entry),d=G(r,n),g=r.format.flatMap((l)=>c.map((a)=>{return Cr(r,n,a,l,o,i,d)}));try{await Promise.all(g)}catch(l){throw console.error(l),new E("Build process encountered errors")}if(r.dts){let l=r.format.filter((u)=>{if(u==="iife"&&!C(o)&&r.format.includes("cjs"))return!1;return!0}),a=r.dts===!0?c:D(r.dts.entry);try{await Promise.all(a.map(async(u)=>{let $=await nr(n,u.path,r);await Promise.all(l.map(async(w)=>{let sr=J(w,o),v=`${n}/${r.outDir}/${u.name}${sr}`;await Bun.write(v,$);let er=Bun.file(v).size||0;f.progress("DTS",y(v),N(er),r.name)}))}))}catch(u){throw new m(`DTS build process encountered errors: ${p(u)}`)}}}async function Cr(r,n,t,o,s,e,i){let c=H(o,s),d=await Bun.build({...i,entrypoints:[`${n}/${t.path}`],format:o,naming:{entry:tr(t.name,c)},splitting:q(r.splitting,o),plugins:e,throw:!1});if(!d.success)throw d.logs.forEach((a)=>{if(a.level==="error")f.error(a.message);else if(a.level==="warning")f.warn(a.message);else if(a.level==="info")f.info(a.message)}),new E(`Build failed for ${t.path} (${o})`);let g=`${n}/${r.outDir}/${t.name}${c}`,l=Bun.file(g).size||0;f.progress(o.toUpperCase(),y(g),N(l),r.name)}export{cr as defineWorkspace,ir as defineConfig,hr as build};
1
+ function ir(r){return r}function cr(r){return r}import{loadTsConfig as ar}from"load-tsconfig";class S extends Error{constructor(r){super(r);this.name="BunupError"}}class E extends S{constructor(r){super(r);this.name="BunupBuildError"}}class m extends S{constructor(r){super(r);this.name="BunupDTSBuildError"}}var p=(r)=>{if(r instanceof Error)return r.message;return String(r)};var f={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(r,n,t,o,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length));if(o){let[c,...d]=t.split(" "),g=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-c.length)),l=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${c}${g} \x1B[38;5;${this.colors.size}m${o}\x1B[0m ${d.join(" ")}${l}`}let i=s?` \x1B[48;5;${r};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${r}m${n}\x1B[0m ${e}${t}${i}`},cli(r){let n=this.labels.cli;console.log(this.formatMessage(this.colors.cli,n,r))},info(r){console.log(`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`)},warn(r){let n=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,n,r))},error(r){let n=this.labels.error;console.error(this.formatMessage(this.colors.error,n,r))},progress(r,n,t,o){let s=String(r),e=this.colors.default;for(let[i,c]of Object.entries(this.colors.progress))if(s.includes(i)){e=c;break}console.log(this.formatMessage(e,s,n,t,o))}};function D(r){try{return ar(".",r)}catch(n){return f.warn(`Failed to load tsconfig: ${p(n)}`),{path:r,data:{},files:[]}}}import{rollup as gr}from"rollup";import pr from"rollup-plugin-dts";import A from"typescript";import Mr from"node:fs";import Wr from"node:path";function G(r,n){return{outdir:`${n}/${r.outDir}`,minify:fr(r),target:r.target,splitting:r.splitting,sourcemap:r.sourcemap}}function fr(r){let{minify:n,minifyWhitespace:t,minifyIdentifiers:o,minifySyntax:s}=r,e=n===!0;return{whitespace:t??e,identifiers:o??e,syntax:s??e}}function j(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function k(r=8){return Math.random().toString(36).substring(2,2+r)}function H(r,n){switch(r){case"esm":return".mjs";case"cjs":return C(n)?".cjs":".js";case"iife":return".global.js"}}function J(r,n){switch(r){case"esm":return".d.mts";case"cjs":return C(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function C(r){return r==="module"}function Y(r){if(!r)return[];return Array.from(new Set([...Object.keys(r.dependencies||{}),...Object.keys(r.peerDependencies||{})]))}function q(r,n){return r===void 0?n==="esm":r}function N(r){if(r===0)return"0 B";let n=["B","KB","MB","GB"],t=Math.floor(Math.log(r)/Math.log(1024));if(t===0)return`${r} ${n[t]}`;return`${(r/Math.pow(1024,t)).toFixed(2)} ${n[t]}`}function y(r,n=3){return r.split("/").slice(-n).join("/")}function U(r){return r.map((n)=>typeof n==="string"?new RegExp(`^${j(n)}($|\\/|\\\\)`):n)}function b(r,n){return U(r.external||[]).concat(Y(n).map((t)=>new RegExp(`^${j(t)}($|\\/|\\\\)`)))}function O(r){return U(r.noExternal||[])}import K from"node:fs";import lr from"node:path";function R(r){let n=lr.join(r,"package.json");try{if(!K.existsSync(n))return null;let t=K.readFileSync(n,"utf8");return JSON.parse(t)}catch(t){return f.warn(`Failed to load package.json at ${n}: ${p(t)}`),null}}import h from"path";var x="\x00virtual:",Q=(r)=>{return{name:"bunup:virtual-dts",resolveId(n,t){if(n.startsWith(x))return n;if(!t?.startsWith(x)||!n.startsWith("."))return null;let o=t.slice(x.length),s=h.resolve(h.dirname(o),n);if(n==="."){let i=h.join(h.dirname(o),"index.d.ts");if(r.has(i))return`${x}${i}`;s=h.dirname(o)}if(r.has(s))return`${x}${s}`;let e=`${s}.d.ts`;if(r.has(e))return`${x}${e}`;if(n.startsWith(".")){let i=h.join(s,"index.d.ts");if(r.has(i))return`${x}${i}`}return null},load(n){if(n.startsWith(x)){let t=n.slice(x.length),o=r.get(t);if(o)return Z.add(t),o}return null}}};async function z(r,n,t,o,s){let e=r.replace(/\.tsx?$/,".d.ts"),i=`${x}${e}`,c=s.data?.compilerOptions,d=R(o),g=b(t,d),l=O(t),a;try{a=await gr({input:i,onwarn($,w){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes($.code??""))return;w($)},plugins:[Q(n),pr({tsconfig:s.path,compilerOptions:{...c?A.parseJsonConfigFileContent({compilerOptions:c},A.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:A.ScriptTarget.ESNext}})],external:($)=>g.some((w)=>w.test($))&&!l.some((w)=>w.test($))});let{output:u}=await a.generate({});if(!u[0]?.code)throw new m("Generated bundle is empty");return u[0].code}catch(u){throw new m(`DTS bundling failed: ${p(u)}`)}finally{if(a)await a.close()}}import F from"node:fs";import _ from"node:path";import B from"node:path";function M(r){let n=B.dirname(r.path||"");return r.data?.compilerOptions?.baseUrl?B.resolve(n,r.data.compilerOptions.baseUrl):n}function L(r){let n=new Map,t=r.data?.compilerOptions?.paths;if(!t)return n;let o=M(r);for(let[s,e]of Object.entries(t))if(Array.isArray(e)&&e.length){let i=s.replace(/\*/g,"(.*)"),c=e[0].replace(/\*/g,"$1");n.set(`^${i}$`,B.join(o,c))}return n}function X(r,n,t){for(let[o,s]of n){let e=new RegExp(o),i=r.match(e);if(i)return s.replace("$1",i[1]||"")}return t?B.join(t,r):null}var ur=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,mr=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function P(r,n){let t=new Set([r]),o=[r],s=L(n),e=M(n);while(o.length){let i=o.pop();if(!i)continue;try{let c=await F.promises.readFile(i,"utf8"),d=xr(c);for(let g of d){let l=g.startsWith(".")?_.resolve(_.dirname(i),g):X(g,s,e);if(!l)continue;let a=dr(l);if(a&&!t.has(a))t.add(a),o.push(a)}}catch(c){f.warn(`Error processing ${i}: ${p(c)}`)}}return t}function xr(r){let n=new Set;for(let t of[ur,mr]){let o;while((o=t.exec(r))!==null)n.add(o[2])}return Array.from(n)}function dr(r){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of n){let o=`${r}${t}`;if(F.existsSync(o)&&(o.endsWith(".ts")||o.endsWith(".tsx")))return o}return null}import $r from"node:fs";import{isolatedDeclaration as wr}from"oxc-transform";async function I(r){let n=new Map;return await Promise.all([...r].map(async(t)=>{try{let o=t.replace(/\.tsx?$/,".d.ts"),s=await $r.promises.readFile(t,"utf8"),{code:e}=wr(t,s);if(e)n.set(o,e)}catch(o){f.warn(`Failed to generate declaration for ${t}: ${p(o)}`)}})),n}import V from"node:fs";import T from"node:path";import{isolatedDeclaration as Cn}from"oxc-transform";function rr(r,n){let t=T.resolve(r),o=T.resolve(t,n);if(!V.existsSync(t))throw new m(`Root directory does not exist: ${t}`);if(!V.existsSync(o))throw new m(`Entry file does not exist: ${o}`);if(!o.endsWith(".ts"))throw new m(`Entry file must be a TypeScript file (.ts): ${o}`);if(T.relative(t,o).startsWith(".."))throw new m(`Entry file must be within rootDir: ${o}`);return{absoluteRootDir:t,absoluteEntry:o}}async function nr(r,n,t){let{absoluteRootDir:o,absoluteEntry:s}=rr(r,n),e=D(t.preferredTsconfigPath),i=await P(s,e),c=await I(i);return z(s,c,t,o,e)}function Er(r){return r.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function W(r){let n=[],t=new Set;function o(s,e){if(t.has(s)){let i=k();n.push({name:`${s}_${i}`,path:e})}else n.push({name:s,path:e}),t.add(s)}if(Array.isArray(r))for(let s of r){let e=Er(s);o(e,s)}else Object.entries(r).forEach(([s,e])=>{o(s,e)});return n}function tr(r,n){return`[dir]/${r}${n}`}function or(r,n){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(o)=>{let s=o.path;if(r.some((i)=>i.test(s))&&!n.some((i)=>i.test(s)))return{path:s,external:!0};return null})}}}var Z=new Set;async function hr(r,n){if(!r.entry||r.entry.length===0||!r.outDir)throw new E("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let t=R(n),o=t?.type,s=b(r,t),e=O(r),i=[or(s,e)],c=W(r.entry),d=G(r,n),g=r.format.flatMap((l)=>c.map((a)=>{return Cr(r,n,a,l,o,i,d)}));try{await Promise.all(g)}catch(l){throw console.error(l),new E("Build process encountered errors")}if(r.dts){let l=r.format.filter((u)=>{if(u==="iife"&&!C(o)&&r.format.includes("cjs"))return!1;return!0}),a=r.dts===!0?c:W(r.dts.entry);try{await Promise.all(a.map(async(u)=>{let $=await nr(n,u.path,r);await Promise.all(l.map(async(w)=>{let sr=J(w,o),v=`${n}/${r.outDir}/${u.name}${sr}`;await Bun.write(v,$);let er=Bun.file(v).size||0;f.progress("DTS",y(v),N(er),r.name)}))}))}catch(u){throw new m(`DTS build process encountered errors: ${p(u)}`)}}}async function Cr(r,n,t,o,s,e,i){let c=H(o,s),d=await Bun.build({...i,entrypoints:[`${n}/${t.path}`],format:o,naming:{entry:tr(t.name,c)},splitting:q(r.splitting,o),plugins:e,throw:!1});if(!d.success)throw d.logs.forEach((a)=>{if(a.level==="error")f.error(a.message);else if(a.level==="warning")f.warn(a.message);else if(a.level==="info")f.info(a.message)}),new E(`Build failed for ${t.path} (${o})`);let g=`${n}/${r.outDir}/${t.name}${c}`,l=Bun.file(g).size||0;f.progress(o.toUpperCase(),y(g),N(l),r.name)}export{cr as defineWorkspace,ir as defineConfig,hr as build};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "bunup",
3
- "version": "0.2.9",
3
+ "version": "0.2.11",
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",