bunup 0.2.0 → 0.2.2
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 +8 -8
- package/build/index.d.mts +12 -4
- package/build/index.d.ts +12 -4
- package/build/index.js +1 -1
- package/build/index.mjs +1 -1
- package/package.json +2 -2
- package/build/dtsWorker.js +0 -11
package/build/cli.mjs
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
#!/usr/bin/env bun
|
|
2
2
|
// @bun
|
|
3
|
-
import
|
|
3
|
+
import{loadTsConfig as Nn}from"load-tsconfig";class B extends Error{constructor(n){super(n);this.name="BunupError"}}class h extends B{constructor(n){super(n);this.name="BunupBuildError"}}class m extends B{constructor(n){super(n);this.name="BunupDTSBuildError"}}class d extends B{constructor(n){super(n);this.name="BunupCLIError"}}class b extends B{constructor(n){super(n);this.name="BunupWatchError"}}var u=(n)=>{if(n instanceof Error)return n.message;return String(n)},Rn=(n,r)=>{let t=u(n),e=r?`[${r}] `:"",o="ERROR";if(n instanceof h)o="BUILD ERROR";else if(n instanceof m)o="DTS ERROR";else if(n instanceof d)o="CLI ERROR";else if(n instanceof b)o="WATCH ERROR";else if(n instanceof B)o="BUNUP ERROR";if(console.error(`\x1B[31m[${o}]\x1B[0m ${e}${t}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
|
|
4
4
|
`).slice(1).join(`
|
|
5
|
-
`)+"\x1B[0m")},
|
|
6
|
-
`);let a=i.labels[0],
|
|
5
|
+
`)+"\x1B[0m")},Q=(n,r)=>{Rn(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,o){let s=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-r.length));if(e){let[a,...c]=t.split(" "),p=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-a.length)),g=o?` \x1B[48;5;${n};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${s}${a}${p} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${c.join(" ")}${g}`}let i=o?` \x1B[48;5;${n};38;5;0m ${o} \x1B[0m`:"";return`\x1B[38;5;${n}m${r}\x1B[0m ${s}${t}${i}`},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 o=String(n),s=this.colors.default;for(let[i,a]of Object.entries(this.colors.progress))if(o.includes(i)){s=a;break}console.log(this.formatMessage(s,o,r,t,e))}};function Z(n){try{return Nn(".",n)}catch(r){return l.warn(`Failed to load tsconfig: ${u(r)}`),{path:n,data:{},files:[]}}}import{rollup as kn}from"rollup";import _n from"rollup-plugin-dts";import P from"typescript";import k from"node:fs";import Tn from"node:path";function _(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function z(n=8){return Math.random().toString(36).substring(2,2+n)}function X(n,r){switch(n){case"esm":return".mjs";case"cjs":return N(r)?".cjs":".js";case"iife":return".global.js"}}function V(n,r){switch(n){case"esm":return".d.mts";case"cjs":return N(r)?".d.cts":".d.ts";case"iife":return".d.ts"}}function N(n){return n==="module"}function nn(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function rn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function tn(n,r){return n===void 0?r==="esm":n}function I(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<10?`${n} ${r[t]}`:n<100?`${n} ${r[t]}`:`${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 G(n,r){let t=Tn.join(n,r);if(k.existsSync(t))try{k.rmSync(t,{recursive:!0,force:!0})}catch(e){throw new h(`Failed to clean output directory: ${e}`)}k.mkdirSync(t,{recursive:!0})}function en(n){return n.map((r)=>typeof r==="string"?new RegExp(`^${_(r)}($|\\/|\\\\)`):r)}function T(n,r){return en(n.external||[]).concat(rn(r).map((t)=>new RegExp(`^${_(t)}($|\\/|\\\\)`)))}function A(n){return en(n.noExternal||[])}import j from"node:fs";import q from"node:path";var w={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function on(n,r){return{outdir:`${r}/${n.outDir}`,minify:An(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function An(n){let{minify:r,minifyWhitespace:t,minifyIdentifiers:e,minifySyntax:o}=n,s=r===!0;return{whitespace:t??s,identifiers:e??s,syntax:o??s}}async function sn(n){let r=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let t of r){let e=q.join(n,`bunup.config${t}`);try{if(!j.existsSync(e))continue;let o=await jn(e,t);if(!o)continue;return{configs:Mn(o,n),configFilePath:e}}catch(o){throw new h(`Failed to load config from ${e}: ${u(o)}`)}}return{configs:[],configFilePath:""}}async function jn(n,r){if(r===".json"||r===".jsonc")return Dn(n);return Un(n)}function Dn(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 Un(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 Mn(n,r){let t=[];if(Hn(n))Ln(n,r,t);else if(Array.isArray(n))Wn(n,r,t);else if(n&&typeof n==="object")t.push({options:{...w,...n},rootDir:r});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return t}function Hn(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 Ln(n,r,t){for(let e of n){let o=q.resolve(r,e.root);if(Array.isArray(e.config))for(let s of e.config)t.push({options:{...w,name:e.name,...s},rootDir:o});else t.push({options:{...w,name:e.name,...e.config},rootDir:o})}}function Wn(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:{...w,...e},rootDir:r})}}function D(n){let r=q.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:",an=(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),o=v.resolve(v.dirname(e),r);if(r==="."){let i=v.join(v.dirname(e),"index.d.ts");if(n.has(i))return`${x}${i}`;o=v.dirname(e)}if(n.has(o))return`${x}${o}`;let s=`${o}.d.ts`;if(n.has(s))return`${x}${s}`;if(r.startsWith(".")){let i=v.join(o,"index.d.ts");if(n.has(i))return`${x}${i}`}return null},load(r){if(r.startsWith(x)){let t=r.slice(x.length),e=n.get(t);if(e)return S.add(t),e}return null}}};async function cn(n,r,t,e,o){let s=n.replace(/\.tsx?$/,".d.ts"),i=`${x}${s}`,a=o.data?.compilerOptions,c=D(e),p=T(t,c),g=A(t),f;try{f=await kn({input:i,onwarn(O,$){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(O.code??""))return;$(O)},plugins:[an(r),_n({tsconfig:o.path,compilerOptions:{...a?P.parseJsonConfigFileContent({compilerOptions:a},P.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:P.ScriptTarget.ESNext}})],external:(O)=>p.some(($)=>$.test(O))&&!g.some(($)=>$.test(O))});let{output:E}=await f.generate({});if(!E[0]?.code)throw new m("Generated bundle is empty");return E[0].code}catch(E){throw new m(`DTS bundling failed: ${u(E)}`)}finally{if(f)await f.close()}}import un from"node:fs";import pn from"node:path";import U from"node:path";function F(n){let r=U.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?U.resolve(r,n.data.compilerOptions.baseUrl):r}function ln(n){let r=new Map,t=n.data?.compilerOptions?.paths;if(!t)return r;let e=F(n);for(let[o,s]of Object.entries(t))if(Array.isArray(s)&&s.length){let i=o.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");r.set(`^${i}$`,U.join(e,a))}return r}function fn(n,r,t){for(let[e,o]of r){let s=new RegExp(e),i=n.match(s);if(i)return o.replace("$1",i[1]||"")}return t?U.join(t,n):null}var In=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Gn=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function gn(n,r){let t=new Set([n]),e=[n],o=ln(r),s=F(r);while(e.length){let i=e.pop();if(!i)continue;try{let a=await un.promises.readFile(i,"utf8"),c=qn(a);for(let p of c){let g=p.startsWith(".")?pn.resolve(pn.dirname(i),p):fn(p,o,s);if(!g)continue;let f=Pn(g);if(f&&!t.has(f))t.add(f),e.push(f)}}catch(a){l.warn(`Error processing ${i}: ${u(a)}`)}}return t}function qn(n){let r=new Set;for(let t of[In,Gn]){let e;while((e=t.exec(n))!==null)r.add(e[2])}return Array.from(r)}function Pn(n){let r=["",".ts",".tsx","/index.ts","/index.tsx"];for(let t of r){let e=`${n}${t}`;if(un.existsSync(e)&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}import Fn from"node:fs";import{isolatedDeclaration as Jn}from"oxc-transform";async function mn(n){let r=new Map;return await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.tsx?$/,".d.ts"),o=await Fn.promises.readFile(t,"utf8"),{code:s}=Jn(t,o);if(s)r.set(e,s)}catch(e){l.warn(`Failed to generate declaration for ${t}: ${u(e)}`)}})),r}import Y from"node:fs";import J from"node:path";import{isolatedDeclaration as Yn}from"oxc-transform";function dn(n,r){let t=J.resolve(n),e=J.resolve(t,r);if(!Y.existsSync(t))throw new m(`Root directory does not exist: ${t}`);if(!Y.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(J.relative(t,e).startsWith(".."))throw new m(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:t,absoluteEntry:e}}async function xn(n){let r=!1;if(await Promise.all([...n].map(async(t)=>{try{let e=t.replace(/\.d\.ts$/,".ts"),o=await Y.promises.readFile(e,"utf8"),{errors:s}=Yn(e,o);s.forEach((i)=>{if(!r)console.log(`
|
|
6
|
+
`);let a=i.labels[0],c=a?Kn(o,a.start):"",g=`${C(e)}${c}: ${Qn(i.message)}`;l.warn(g),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
|
|
9
|
-
`),
|
|
8
|
+
`)}function Kn(n,r){if(r===void 0)return"";let t=n.slice(0,r).split(`
|
|
9
|
+
`),e=t.length,o=t[t.length-1].length+1;return` (${e}:${o})`}function Qn(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function hn(n,r,t){let{absoluteRootDir:e,absoluteEntry:o}=dn(n,r),s=Z(t.preferredTsconfigPath),i=await gn(o,s),a=await mn(i);return cn(o,a,t,e,s)}function Zn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function R(n){let r=[],t=new Set;function e(o,s){if(t.has(o)){let i=z();r.push({name:`${o}_${i}`,path:s})}else r.push({name:o,path:s}),t.add(o)}if(Array.isArray(n))for(let o of n){let s=Zn(o);e(s,o)}else Object.entries(n).forEach(([o,s])=>{e(o,s)});return r}function wn(n,r){return`[dir]/${n}${r}`}function yn(n,r){return{name:"bunup:external-plugin",setup(t){t.onResolve({filter:/.*/},(e)=>{let o=e.path;if(n.some((i)=>i.test(o))&&!r.some((i)=>i.test(o)))return{path:o,external:!0};return null})}}}async function M(n,r){if(!n.entry||n.entry.length===0||!n.outDir)throw new h("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let t=D(r),e=t?.type,o=T(n,t),s=A(n),i=[yn(o,s)],a=R(n.entry),c=n.format.flatMap((p)=>a.map((g)=>{return zn(n,r,g,p,e,i)}));try{await Promise.all(c)}catch{throw new h("Build process encountered errors")}if(n.dts){let p=n.format.filter((f)=>{if(f==="iife"&&!N(e)&&n.format.includes("cjs"))return!1;return!0}),g=n.dts===!0?a:R(n.dts.entry);try{await Promise.all(g.map(async(f)=>{let E=await hn(r,f.path,n);await Promise.all(p.map(async(O)=>{let $=V(O,e),W=`${r}/${n.outDir}/${f.name}${$}`;await Bun.write(W,E);let Sn=Bun.file(W).size||0;l.progress("DTS",C(W),I(Sn),n.name)}))}))}catch(f){throw new m(`DTS build process encountered errors: ${u(f)}`)}}}async function zn(n,r,t,e,o,s){let i=X(e,o),a=on(n,r),c=await Bun.build({...a,entrypoints:[`${r}/${t.path}`],format:e,naming:{entry:wn(t.name,i)},splitting:tn(n.splitting,e),plugins:s,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 h(`Build failed for ${t} (${e})`);let p=`${r}/${n.outDir}/${t.name}${i}`,g=Bun.file(p).size||0;l.progress(e.toUpperCase(),C(p),I(g),n.name)}var On="https://bun.sh/docs/installation",$n="https://bunup.arshadyaseen.com/#cli-options";function y(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 Cn(n){return(r,t)=>{if(typeof r==="string")t[n]=r.split(",");else throw new d(`Option --${n} requires a string value`)}}function Xn(){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${
|
|
12
|
-
`),process.exit(0)}var
|
|
13
|
-
To install Bun, visit `+
|
|
11
|
+
`),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${$n}\x1B[0m
|
|
12
|
+
`),process.exit(0)}var Vn={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:y("minify")},watch:{flags:["w","watch"],handler:y("watch")},dts:{flags:["d","dts"],handler:y("dts")},external:{flags:["e","external"],handler:Cn("external")},sourcemap:{flags:["sm","sourcemap"],handler:H("sourcemap")},target:{flags:["t","target"],handler:H("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:Cn("noExternal")}},nr={help:{flags:["h","help"],handler:()=>Xn()}},L={};for(let n of Object.values(Vn))if(n)for(let r of n.flags)L[r]=n.handler;for(let n of Object.values(nr))for(let r of n.flags)L[r]=n.handler;function En(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function Bn(n){let r={},t={},e=0;while(e<n.length){let o=n[e];if(o.startsWith("--")){let s,i;if(o.includes("=")){let[a,c]=o.slice(2).split("=",2);s=a,i=c}else{s=o.slice(2);let a=n[e+1];if(i=a&&!a.startsWith("-")?a:!0,typeof i==="string")e++}if(s==="entry")if(typeof i==="string"){let a=En(i);if(t[a])l.warn(`Duplicate entry name '${a}' derived from '${i}'. Overwriting previous entry.`);t[a]=i}else throw new d("Option --entry requires a string value");else if(s.startsWith("entry.")){let a=s.slice(6);if(typeof i==="string"){if(t[a])l.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);t[a]=i}else throw new d(`Option --entry.${a} requires a string value`)}else{let a=L[s];if(a)a(i,r);else throw new d(`Unknown option: --${s}`)}}else if(o.startsWith("-")){let s=o.slice(1),i=n[e+1],a=i&&!i.startsWith("-")?i:!0;if(typeof a==="string")e++;let c=L[s];if(c)c(a,r);else throw new d(`Unknown option: -${s}`)}else{let s=En(o);if(t[s])l.warn(`Duplicate entry name '${s}' derived from positional argument '${o}'. Overwriting previous entry.`);t[s]=o}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 `+On)})();import K from"node:path";import rr from"chokidar";async function vn(n,r){let t=new Set,e=R(n.entry);e.forEach((c)=>{let p=K.resolve(r,c.path),g=K.dirname(p);t.add(g)});let o=rr.watch(Array.from(t),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),s=null,i=!1,a=async()=>{if(i)return;i=!0;try{await M({...n,entry:e.map((c)=>c.path),clean:!1},r),n.onBuildEnd?.()}catch(c){throw new b(`Build failed: ${u(c)}`)}finally{i=!1}};o.on("change",(c)=>{let p=K.relative(r,c);if(l.cli(`File changed: ${p}`),s)clearTimeout(s);s=setTimeout(()=>a(),300)}),o.on("error",(c)=>{throw new b(`Watcher error: ${u(c)}`)}),await a()}var S=new Set;async function tr(n=Bun.argv.slice(2)){let r=Bn(n),{configs:t,configFilePath:e}=await sn(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 o=performance.now();if(l.cli("Build started"),t.length===0){let a={...w,...r},c=process.cwd();if(a.clean)G(c,a.outDir);await bn(a,c)}else{for(let{options:a,rootDir:c}of t)if(a.clean)G(c,a.outDir);await Promise.all(t.map(async({options:a,rootDir:c})=>{let p={...w,...a,...r};await bn(p,c)}))}let s=performance.now()-o,i=nn(s);if(l.cli(`\u26A1\uFE0F Build completed in ${i}`),S.size>0)await xn(S),S.clear();if(!r.watch)process.exit(0)}async function bn(n,r){if(n.watch)await vn(n,r);else await M(n,r),n.onBuildEnd?.()}tr().catch((n)=>Q(n));export{tr as main,S as allFilesUsedToBundleDts};
|
package/build/index.d.mts
CHANGED
|
@@ -2,6 +2,13 @@ type WithOptional<
|
|
|
2
2
|
T,
|
|
3
3
|
K extends keyof T
|
|
4
4
|
> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
5
|
+
type DefineConfigOption = WithOptional<BunupOptions, "outDir" | "format">;
|
|
6
|
+
type DefineConfigOptions = DefineConfigOption | DefineConfigOption[];
|
|
7
|
+
type DefineWorkspaceOptions = {
|
|
8
|
+
name: string
|
|
9
|
+
root: string
|
|
10
|
+
config: DefineConfigOptions
|
|
11
|
+
}[];
|
|
5
12
|
|
|
6
13
|
type Format = "esm" | "cjs" | "iife";
|
|
7
14
|
type Target = "bun" | "node" | "browser";
|
|
@@ -161,9 +168,10 @@ interface BunupOptions {
|
|
|
161
168
|
onBuildEnd?: () => void | Promise<void>;
|
|
162
169
|
}
|
|
163
170
|
|
|
164
|
-
type DefineConfigOption = WithOptional<BunupOptions, "outDir" | "format">;
|
|
165
|
-
type DefineConfigOptions = DefineConfigOption | DefineConfigOption[];
|
|
166
171
|
declare function defineConfig(options: DefineConfigOptions): DefineConfigOptions;
|
|
172
|
+
declare function defineWorkspace(options: DefineWorkspaceOptions): DefineWorkspaceOptions;
|
|
173
|
+
|
|
174
|
+
type Options = Partial<BunupOptions>;
|
|
167
175
|
|
|
168
|
-
export { defineConfig };
|
|
169
|
-
export type {
|
|
176
|
+
export { defineConfig, defineWorkspace };
|
|
177
|
+
export type { Options };
|
package/build/index.d.ts
CHANGED
|
@@ -2,6 +2,13 @@ type WithOptional<
|
|
|
2
2
|
T,
|
|
3
3
|
K extends keyof T
|
|
4
4
|
> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
5
|
+
type DefineConfigOption = WithOptional<BunupOptions, "outDir" | "format">;
|
|
6
|
+
type DefineConfigOptions = DefineConfigOption | DefineConfigOption[];
|
|
7
|
+
type DefineWorkspaceOptions = {
|
|
8
|
+
name: string
|
|
9
|
+
root: string
|
|
10
|
+
config: DefineConfigOptions
|
|
11
|
+
}[];
|
|
5
12
|
|
|
6
13
|
type Format = "esm" | "cjs" | "iife";
|
|
7
14
|
type Target = "bun" | "node" | "browser";
|
|
@@ -161,9 +168,10 @@ interface BunupOptions {
|
|
|
161
168
|
onBuildEnd?: () => void | Promise<void>;
|
|
162
169
|
}
|
|
163
170
|
|
|
164
|
-
type DefineConfigOption = WithOptional<BunupOptions, "outDir" | "format">;
|
|
165
|
-
type DefineConfigOptions = DefineConfigOption | DefineConfigOption[];
|
|
166
171
|
declare function defineConfig(options: DefineConfigOptions): DefineConfigOptions;
|
|
172
|
+
declare function defineWorkspace(options: DefineWorkspaceOptions): DefineWorkspaceOptions;
|
|
173
|
+
|
|
174
|
+
type Options = Partial<BunupOptions>;
|
|
167
175
|
|
|
168
|
-
export { defineConfig };
|
|
169
|
-
export type {
|
|
176
|
+
export { defineConfig, defineWorkspace };
|
|
177
|
+
export type { Options };
|
package/build/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var
|
|
1
|
+
var D=require("node:module");var{defineProperty:p,getOwnPropertyNames:s,getOwnPropertyDescriptor:O}=Object,u=Object.prototype.hasOwnProperty;var t=new WeakMap,a=(e)=>{var n=t.get(e),o;if(n)return n;if(n=p({},"__esModule",{value:!0}),e&&typeof e==="object"||typeof e==="function")s(e).map((i)=>!u.call(n,i)&&p(n,i,{get:()=>e[i],enumerable:!(o=O(e,i))||o.enumerable}));return t.set(e,n),n};var c=(e,n)=>{for(var o in n)p(e,o,{get:n[o],enumerable:!0,configurable:!0,set:(i)=>n[o]=()=>i})};var g={};c(g,{defineWorkspace:()=>r,defineConfig:()=>f});module.exports=a(g);function f(e){return e}function r(e){return e}
|
package/build/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
function n(
|
|
1
|
+
function n(e){return e}function o(e){return e}export{o as defineWorkspace,n as defineConfig};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "bunup",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.2",
|
|
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",
|
|
@@ -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
|
|
21
|
+
"bunup": "^0.2.1",
|
|
22
22
|
"eslint": "^8.57.0",
|
|
23
23
|
"husky": "^9.1.6",
|
|
24
24
|
"prettier": "^3.2.5",
|
package/build/dtsWorker.js
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
var Xn=require("node:module");var In=Object.create;var{getPrototypeOf:Kn,defineProperty:N,getOwnPropertyNames:tn,getOwnPropertyDescriptor:Qn}=Object,rn=Object.prototype.hasOwnProperty;var p=(n,t,r)=>{r=n!=null?In(Kn(n)):{};let s=t||!n||!n.__esModule?N(r,"default",{value:n,enumerable:!0}):r;for(let e of tn(n))if(!rn.call(s,e))N(s,e,{get:()=>n[e],enumerable:!0});return s},nn=new WeakMap,Zn=(n)=>{var t=nn.get(n),r;if(t)return t;if(t=N({},"__esModule",{value:!0}),n&&typeof n==="object"||typeof n==="function")tn(n).map((s)=>!rn.call(t,s)&&N(t,s,{get:()=>n[s],enumerable:!(r=Qn(n,s))||r.enumerable}));return nn.set(n,t),t};var zn=(n,t)=>{for(var r in t)N(n,r,{get:t[r],enumerable:!0,configurable:!0,set:(s)=>t[r]=()=>s})};var lt={};zn(lt,{runDtsInWorker:()=>P});module.exports=Zn(lt);var C=require("node:worker_threads");var Z=p(require("node:fs")),Nn=p(require("node:path")),Sn=require("node:worker_threads");class v extends Error{constructor(n){super(n);this.name="BunupError"}}class d extends v{constructor(n){super(n);this.name="BunupBuildError"}}class x extends v{constructor(n){super(n);this.name="BunupDTSBuildError"}}class y extends v{constructor(n){super(n);this.name="BunupCLIError"}}class S extends v{constructor(n){super(n);this.name="BunupWatchError"}}var g=(n)=>{if(n instanceof Error)return n.message;return String(n)},kn=(n,t)=>{let r=g(n),s=t?`[${t}] `:"",e="ERROR";if(n instanceof d)e="BUILD ERROR";else if(n instanceof x)e="DTS ERROR";else if(n instanceof y)e="CLI ERROR";else if(n instanceof S)e="WATCH ERROR";else if(n instanceof v)e="BUNUP ERROR";if(console.error(`\x1B[31m[${e}]\x1B[0m ${s}${r}`),n instanceof Error&&n.stack)console.error("\x1B[2m"+n.stack.split(`
|
|
2
|
-
`).slice(1).join(`
|
|
3
|
-
`)+"\x1B[0m")},sn=(n,t)=>{kn(n,t),process.exit(1)};function X(n){return n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function en(n=8){return Math.random().toString(36).substring(2,2+n)}function on(n,t){switch(n){case"esm":return".mjs";case"cjs":return L(t)?".cjs":".js";case"iife":return".global.js"}}function an(n,t){switch(n){case"esm":return".d.mts";case"cjs":return L(t)?".d.cts":".d.ts";case"iife":return".d.ts"}}function L(n){return n==="module"}function U(n){return n>=1000?`${(n/1000).toFixed(2)}s`:`${Math.round(n)}ms`}function cn(n){if(!n)return[];return Array.from(new Set([...Object.keys(n.dependencies||{}),...Object.keys(n.peerDependencies||{})]))}function fn(n,t){return n===void 0?t==="esm":n}function W(n){if(n===0)return"0 B";let t=["B","KB","MB","GB"],r=Math.floor(Math.log(n)/Math.log(1024));if(r===0)return`${n} ${t[r]}`;return`${(n/Math.pow(1024,r)).toFixed(2)} ${t[r]}`}function q(n,t=3){return n.split("/").slice(-t).join("/")}function Pn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function j(n){let t=[],r=new Set;function s(e,o){if(r.has(e)){let i=en();t.push({name:`${e}_${i}`,path:o})}else t.push({name:e,path:o}),r.add(e)}if(Array.isArray(n))for(let e of n){let o=Pn(e);s(o,e)}else Object.entries(n).forEach(([e,o])=>{s(e,o)});return t}function ln(n,t){return`[dir]/${n}${t}`}function un(n){return n.map((t)=>typeof t==="string"?new RegExp(`^${X(t)}($|\\/|\\\\)`):t)}function G(n,t){return un(n.external||[]).concat(cn(t).map((r)=>new RegExp(`^${X(r)}($|\\/|\\\\)`)))}function M(n){return un(n.noExternal||[])}var A=p(require("node:fs")),k=p(require("node:path"));var f={MAX_LABEL_LENGTH:5,colors:{cli:"147",info:"245",warn:"179",error:"174",progress:{ESM:"172",CJS:"108",IIFE:"146",DTS:"110"},default:"252",size:"65"},labels:{cli:"BUNUP",info:"INFO",warn:"WARN",error:"ERROR"},formatMessage(n,t,r,s){let e=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-t.length));if(s){let[o,...i]=r.split(" ");return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${o} \x1B[38;5;${this.colors.size}m${s}\x1B[0m ${i.join(" ")}`}return`\x1B[38;5;${n}m[${t}]\x1B[0m ${e}${r}`},cli(n){let t=this.labels.cli;console.log(this.formatMessage(this.colors.cli,t,n))},info(n){console.log(`\x1B[38;5;${this.colors.info}m${n}\x1B[0m`)},warn(n){let t=this.labels.warn;console.warn(this.formatMessage(this.colors.warn,t,n))},error(n){let t=this.labels.error;console.error(this.formatMessage(this.colors.error,t,n))},progress(n,t,r){let s=String(n),e=this.colors.default;for(let[o,i]of Object.entries(this.colors.progress))if(s.includes(o)){e=i;break}console.log(this.formatMessage(e,s,t,r))}};function mn(n,t){return`${t?`${t.replace(/-/g,"_")}_`:""}${n}`.toUpperCase()}var b={entry:[],format:["cjs"],outDir:"dist",minify:!1,watch:!1,dts:!1,target:"node",external:[],clean:!0,sourcemap:"none"};function gn(n,t){return{outdir:`${t}/${n.outDir}`,minify:Vn(n),target:n.target,splitting:n.splitting,sourcemap:n.sourcemap}}function Vn(n){let{minify:t,minifyWhitespace:r,minifyIdentifiers:s,minifySyntax:e}=n,o=t===!0;return{whitespace:r??o,identifiers:s??o,syntax:e??o}}async function pn(n){let t=[],r="";for(let s of[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"]){let e=k.default.join(n,`bunup.config${s}`);try{if(!A.default.existsSync(e))continue;let o;if(r=e,s===".json"||s===".jsonc"){let i=A.default.readFileSync(e,"utf8"),a=JSON.parse(i);o=a.bunup||a}else{let i=await import(`file://${e}`);if(o=i.default||i,!o)f.warn(`No default export found in ${e}`),o={}}if(Array.isArray(o))for(let i of o)t.push({options:{...b,...i},rootDir:n});else t.push({options:{...b,...o},rootDir:n});break}catch(o){throw new d(`Failed to load config from ${e}: ${g(o)}`)}}return{configs:t,configFilePath:r}}function T(n){let t=k.default.join(n,"package.json");try{if(!A.default.existsSync(t))return null;let r=A.default.readFileSync(t,"utf8");return JSON.parse(r)}catch(r){return f.warn(`Failed to load package.json at ${t}: ${g(r)}`),null}}function xn(n,t){return{name:"bunup:external-plugin",setup(r){r.onResolve({filter:/.*/},(s)=>{let e=s.path;if(n.some((i)=>i.test(e))&&!t.some((i)=>i.test(e)))return{path:e,external:!0};return null})}}}async function _(n,t){if(!n.entry||n.entry.length===0||!n.outDir)throw new d("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let r=performance.now(),s=T(t),e=s?.type,o=G(n,s),i=M(n),a=[xn(o,i)],l=j(n.entry),m=n.format.flatMap((u)=>l.map((c)=>{return Dn(n,t,c,u,e,a)}));try{await Promise.all(m);let u=performance.now()-r,c=U(u);f.cli(`\uD83D\uDCE6 Build success in ${c}`)}catch{throw new d("Build process encountered errors")}if(n.dts){let u=n.format.filter(($)=>{if($==="iife"&&!L(e)&&n.format.includes("cjs"))return!1;return!0}),c=n.dts===!0?l:j(n.dts.entry);try{await P(t,c,u,n,e)}catch($){throw new x(`DTS build process encountered errors: ${g($)}`)}}}async function Dn(n,t,r,s,e,o){let i=on(s,e),a=gn(n,t),l=await Bun.build({...a,entrypoints:[`${t}/${r.path}`],format:s,naming:{entry:ln(r.name,i)},splitting:fn(n.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 d(`Build failed for ${r} (${s})`);let m=`${n.outDir}/${r.name}${i}`,u=Bun.file(m).size||0;f.progress(mn(s,n.name),m,W(u))}var $n="https://bun.sh/docs/installation",yn="https://bunup.arshadyaseen.com/#cli-options";function O(n){return(t,r)=>{r[n]=t===!0?!0:t==="true"}}function Y(n){return(t,r)=>{if(typeof t==="string")r[n]=t;else throw new y(`Option --${n} requires a string value`)}}function hn(n){return(t,r)=>{if(typeof t==="string")r[n]=t.split(",");else throw new y(`Option --${n} requires a string value`)}}function Fn(){console.log(`
|
|
4
|
-
Bunup - An extremely fast, zero-config bundler for JavaScript and TypeScript, powered by Bun.
|
|
5
|
-
`),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${yn}\x1B[0m
|
|
6
|
-
`),process.exit(0)}var nt={name:{flags:["n","name"],handler:Y("name")},format:{flags:["f","format"],handler:(n,t)=>{if(typeof n==="string")t.format=n.split(",");else throw new y("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:Y("outDir")},minify:{flags:["m","minify"],handler:O("minify")},watch:{flags:["w","watch"],handler:O("watch")},dts:{flags:["d","dts"],handler:O("dts")},external:{flags:["e","external"],handler:hn("external")},sourcemap:{flags:["sm","sourcemap"],handler:Y("sourcemap")},target:{flags:["t","target"],handler:Y("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:O("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:O("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:O("minifySyntax")},clean:{flags:["c","clean"],handler:O("clean")},splitting:{flags:["s","splitting"],handler:O("splitting")},noExternal:{flags:["ne","no-external"],handler:hn("noExternal")}},tt={help:{flags:["h","help"],handler:()=>Fn()}},J={};for(let n of Object.values(nt))if(n)for(let t of n.flags)J[t]=n.handler;for(let n of Object.values(tt))for(let t of n.flags)J[t]=n.handler;function wn(n){return n.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function dn(n){let t={},r={},s=0;while(s<n.length){let e=n[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=n[s+1];if(i=a&&!a.startsWith("-")?a:!0,typeof i==="string")s++}if(o==="entry")if(typeof i==="string"){let a=wn(i);if(r[a])f.warn(`Duplicate entry name '${a}' derived from '${i}'. Overwriting previous entry.`);r[a]=i}else throw new y("Option --entry requires a string value");else if(o.startsWith("entry.")){let a=o.slice(6);if(typeof i==="string"){if(r[a])f.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);r[a]=i}else throw new y(`Option --entry.${a} requires a string value`)}else{let a=J[o];if(a)a(i,t);else throw new y(`Unknown option: --${o}`)}}else if(e.startsWith("-")){let o=e.slice(1),i=n[s+1],a=i&&!i.startsWith("-")?i:!0;if(typeof a==="string")s++;let l=J[o];if(l)l(a,t);else throw new y(`Unknown option: -${o}`)}else{let o=wn(e);if(r[o])f.warn(`Duplicate entry name '${o}' derived from positional argument '${e}'. Overwriting previous entry.`);r[o]=e}s++}if(Object.keys(r).length>0)t.entry=r;return t}(()=>{if(typeof Bun==="undefined")throw new y(`Bunup requires Bun to run.
|
|
7
|
-
To install Bun, visit `+$n)})();var K=p(require("node:fs")),I=p(require("node:path")),Cn=require("oxc-transform");function On(n,t){let r=I.default.resolve(n),s=I.default.resolve(r,t);if(!K.default.existsSync(r))throw new x(`Root directory does not exist: ${r}`);if(!K.default.existsSync(s))throw new x(`Entry file does not exist: ${s}`);if(!s.endsWith(".ts"))throw new x(`Entry file must be a TypeScript file (.ts): ${s}`);if(I.default.relative(r,s).startsWith(".."))throw new x(`Entry file must be within rootDir: ${s}`);return{absoluteRootDir:r,absoluteEntry:s}}async function En(n){let t=!1;if(await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.d\.ts$/,".ts"),e=await K.default.promises.readFile(s,"utf8"),{errors:o}=Cn.isolatedDeclaration(s,e);o.forEach((i)=>{if(!t)console.log(`
|
|
8
|
-
`);let a=i.labels[0],l=a?rt(e,a.start):"",u=`${q(s)}${l}: ${st(i.message)}`;f.warn(u),t=!0})}catch{}})),t)f.info(`
|
|
9
|
-
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.
|
|
10
|
-
`)}function rt(n,t){if(t===void 0)return"";let r=n.slice(0,t).split(`
|
|
11
|
-
`),s=r.length,e=r[r.length-1].length+1;return` (${s}:${e})`}function st(n){return n.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}var Q=p(require("node:path")),Bn=p(require("chokidar"));async function Rn(n,t){let r=new Set,s=j(n.entry);s.forEach((l)=>{let m=Q.default.resolve(t,l.path),u=Q.default.dirname(m);r.add(u)});let e=Bn.default.watch(Array.from(r),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,n.outDir]}),o=null,i=!1,a=async()=>{if(i)return;i=!0;try{await _({...n,entry:s.map((l)=>l.path),clean:!1},t),n.onBuildEnd?.()}catch(l){throw new S(`Build failed: ${g(l)}`)}finally{i=!1}};e.on("change",(l)=>{let m=Q.default.relative(t,l);if(f.cli(`File changed: ${m}`),o)clearTimeout(o);o=setTimeout(()=>a(),300)}),e.on("error",(l)=>{throw new S(`Watcher error: ${g(l)}`)}),await a()}var B=new Set;async function et(n=Bun.argv.slice(2)){let t=dn(n),{configs:r,configFilePath:s}=await pn(process.cwd());if(s)f.cli(`Using config file: ${q(s,2)}`);let e=process.cwd();if(t.watch)f.cli("Starting watch mode"),f.cli("Watching for file changes");if(r.length===0){let o={...b,...t};if(o.clean)bn(e,o.outDir);await vn(o,e)}else{for(let{options:o,rootDir:i}of r)if(o.clean)bn(i,o.outDir);f.cli("Build started"),await Promise.all(r.map(async({options:o,rootDir:i})=>{let a={...b,...o,...t};await vn(a,i)}))}if(B.size>0)await En(B),B.clear();if(!t.watch)process.exit(0)}async function vn(n,t){if(n.watch)await Rn(n,t);else await _(n,t),n.onBuildEnd?.()}function bn(n,t){let r=Nn.default.join(n,t);if(Z.default.existsSync(r))try{Z.default.rmSync(r,{recursive:!0,force:!0})}catch(s){throw new d(`Failed to clean output directory: ${s}`)}Z.default.mkdirSync(r,{recursive:!0})}if(Sn.isMainThread)et().catch((n)=>sn(n));var jn=require("load-tsconfig");function An(n){try{return jn.loadTsConfig(".",n)}catch(t){return f.warn(`Failed to load tsconfig: ${g(t)}`),{path:n,data:{},files:[]}}}var Ln=require("rollup"),Un=p(require("rollup-plugin-dts")),z=p(require("typescript"));var R=p(require("path"));var h="\x00virtual:",ot=()=>{return global.allFilesUsedToBundleDts||B||new Set},Hn=(n)=>{return{name:"bunup:virtual-dts",resolveId(t,r){if(t.startsWith(h))return t;if(!r?.startsWith(h)||!t.startsWith("."))return null;let s=r.slice(h.length),e=R.default.resolve(R.default.dirname(s),t);if(t==="."){let i=R.default.join(R.default.dirname(s),"index.d.ts");if(n.has(i))return`${h}${i}`;e=R.default.dirname(s)}if(n.has(e))return`${h}${e}`;let o=`${e}.d.ts`;if(n.has(o))return`${h}${o}`;if(t.startsWith(".")){let i=R.default.join(e,"index.d.ts");if(n.has(i))return`${h}${i}`}return null},load(t){if(t.startsWith(h)){let r=t.slice(h.length),s=n.get(r);if(s)return ot().add(r),s}return null}}};async function Wn(n,t,r,s,e){let o=n.replace(/\.tsx?$/,".d.ts"),i=`${h}${o}`,a=e.data?.compilerOptions,l=T(s),m=G(r,l),u=M(r),c;try{c=await Ln.rollup({input:i,onwarn(w,E){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(w.code??""))return;E(w)},plugins:[Hn(t),Un.default({tsconfig:e.path,compilerOptions:{...a?z.default.parseJsonConfigFileContent({compilerOptions:a},z.default.sys,"./").options:{},declaration:!0,noEmit:!1,emitDeclarationOnly:!0,noEmitOnError:!0,checkJs:!1,declarationMap:!1,skipLibCheck:!0,preserveSymlinks:!1,target:z.default.ScriptTarget.ESNext}})],external:(w)=>m.some((E)=>E.test(w))&&!u.some((E)=>E.test(w))});let{output:$}=await c.generate({});if(!$[0]?.code)throw new x("Generated bundle is empty");return $[0].code}catch($){throw new x(`DTS bundling failed: ${g($)}`)}finally{if(c)await c.close()}}var F=p(require("node:fs")),D=p(require("node:path"));var H=p(require("node:path"));function V(n){let t=H.default.dirname(n.path||"");return n.data?.compilerOptions?.baseUrl?H.default.resolve(t,n.data.compilerOptions.baseUrl):t}function qn(n){let t=new Map,r=n.data?.compilerOptions?.paths;if(!r)return t;let s=V(n);for(let[e,o]of Object.entries(r))if(Array.isArray(o)&&o.length){let i=e.replace(/\*/g,"(.*)"),a=o[0].replace(/\*/g,"$1");t.set(`^${i}$`,H.default.join(s,a))}return t}function Gn(n,t,r){for(let[s,e]of t){let o=new RegExp(s),i=n.match(o);if(i)return e.replace("$1",i[1]||"")}return r?H.default.join(r,n):null}var it=/(?: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 Mn(n,t){let r=new Set([n]),s=[n],e=qn(t),o=V(t);while(s.length){let i=s.pop();if(!i)continue;try{let a=await F.default.promises.readFile(i,"utf8"),l=ct(a);for(let m of l){let u=m.startsWith(".")?D.default.resolve(D.default.dirname(i),m):Gn(m,e,o);if(!u)continue;let c=ft(u);if(c&&!r.has(c))r.add(c),s.push(c)}}catch(a){f.warn(`Error processing ${i}: ${g(a)}`)}}return r}function ct(n){let t=new Set;for(let r of[it,at]){let s;while((s=r.exec(n))!==null)t.add(s[2])}return Array.from(t)}function ft(n){let t=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of t){let s=`${n}${r}`;if(F.default.existsSync(s)&&(s.endsWith(".ts")||s.endsWith(".tsx")))return s}return null}var Tn=p(require("node:fs")),_n=require("oxc-transform");async function Yn(n){let t=new Map;return await Promise.all([...n].map(async(r)=>{try{let s=r.replace(/\.tsx?$/,".d.ts"),e=await Tn.default.promises.readFile(r,"utf8"),{code:o}=_n.isolatedDeclaration(r,e);if(o)t.set(s,o)}catch(s){f.warn(`Failed to generate declaration for ${r}: ${g(s)}`)}})),t}async function Jn(n,t,r){let{absoluteRootDir:s,absoluteEntry:e}=On(n,t),o=An(r.preferredTsconfigPath),i=await Mn(e,o),a=await Yn(i);return Wn(e,a,r,s,o)}async function P(n,t,r,s,e){return new Promise((o,i)=>{let{onBuildEnd:a,...l}=s,m={rootDir:n,entries:t,formats:r,options:l,packageType:e},u=new C.Worker(new URL("./dtsWorker.js",import.meta.url),{workerData:m});u.on("message",async(c)=>{if(c.success){let $=U(c.timeMs);if(f.progress("DTS",`Bundled types in ${$}`),c.filesUsed)c.filesUsed.forEach((w)=>B.add(w));o()}else i(new x(c.error||"Unknown DTS worker error"))}),u.on("error",i),u.on("exit",(c)=>{if(c!==0)i(new x(`DTS worker stopped with exit code ${c}`))})})}if(!C.isMainThread&&C.parentPort){let{rootDir:n,entries:t,formats:r,options:s,packageType:e}=C.workerData,o=performance.now(),i=new Set;global.allFilesUsedToBundleDts=i,f.progress("DTS","Bundling types"),(async()=>{try{await Promise.all(t.map(async(l)=>{let m=await Jn(n,l.path,s);await Promise.all(r.map(async(u)=>{let c=an(u,e),$=`${s.outDir}/${l.name}${c}`,w=`${n}/${$}`;await Bun.write(w,m);let E=Bun.file(w).size||0;f.progress("DTS",$,W(E))}))}));let a=performance.now()-o;C.parentPort?.postMessage({success:!0,timeMs:a,filesUsed:[...i]})}catch(a){C.parentPort?.postMessage({success:!1,error:g(a)})}})()}
|