bunup 0.3.52 → 0.3.55
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 +6 -6
- package/build/index.d.mts +4 -4
- package/build/index.d.ts +4 -4
- package/build/index.js +1 -1
- package/build/index.mjs +1 -1
- package/package.json +3 -3
package/build/cli.mjs
CHANGED
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
// @bun
|
|
3
3
|
import{build as Ht}from"rolldown";import{dts as Vt}from"rolldown-plugin-types";class E extends Error{constructor(t){super(t);this.name="BunupError"}}class x extends E{constructor(t){super(t);this.name="BunupBuildError"}}class m extends E{constructor(t){super(t);this.name="BunupDTSBuildError"}}class d extends E{constructor(t){super(t);this.name="BunupCLIError"}}class I extends E{constructor(t){super(t);this.name="BunupWatchError"}}var p=(t)=>{if(t instanceof Error)return t.message;return String(t)},V=(t,n)=>{let e=p(t),r=n?`[${n}] `:"",s="ERROR";if(t instanceof x)s="BUILD ERROR";else if(t instanceof m)s="DTS ERROR";else if(t instanceof d)s="CLI ERROR";else if(t instanceof I)s="WATCH ERROR";else if(t instanceof E)s="BUNUP ERROR";if(console.error(`\x1B[31m${s}\x1B[0m ${r}${e}`),t instanceof Error&&t.stack)console.error("\x1B[2m"+t.stack.split(`
|
|
4
4
|
`).slice(1).join(`
|
|
5
|
-
`)+"\x1B[0m")},tt=(t,n)=>{V(t,n),process.exit(1)};import et from"node:fs/promises";import Nt from"node:path";var $={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function nt(t,n){return{outdir:`${n}/${t.outDir}`,minify:_t(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function _t(t){let{minify:n,minifyWhitespace:e,minifyIdentifiers:r,minifySyntax:s}=t,i=n===!0;return{whitespace:e??i,identifiers:r??i,syntax:s??i}}function G(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function rt(t=8){return Math.random().toString(36).substring(2,2+t)}function st(t,n){switch(t){case"esm":return".mjs";case"cjs":return S(n)?".cjs":".js";case"iife":return".global.js"}}function it(t,n){switch(t){case"esm":return".d.mts";case"cjs":return S(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function S(t){return t==="module"}function L(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function ot(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function at(t,n){return t===void 0?n==="esm":t}function X(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],e=Math.floor(Math.log(t)/Math.log(1024));if(e===0)return`${t} ${n[e]}`;return`${(t/Math.pow(1024,e)).toFixed(2)} ${n[e]}`}function
|
|
6
|
-
`);let a=o.labels[0],c=a?Kt(s,a.start):"",g=`${
|
|
5
|
+
`)+"\x1B[0m")},tt=(t,n)=>{V(t,n),process.exit(1)};import et from"node:fs/promises";import Nt from"node:path";var $={entry:[],format:["cjs"],outDir:"dist",target:"node",clean:!0};function nt(t,n){return{outdir:`${n}/${t.outDir}`,minify:_t(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function _t(t){let{minify:n,minifyWhitespace:e,minifyIdentifiers:r,minifySyntax:s}=t,i=n===!0;return{whitespace:e??i,identifiers:r??i,syntax:s??i}}function G(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function rt(t=8){return Math.random().toString(36).substring(2,2+t)}function st(t,n){switch(t){case"esm":return".mjs";case"cjs":return S(n)?".cjs":".js";case"iife":return".global.js"}}function it(t,n){switch(t){case"esm":return".d.mts";case"cjs":return S(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function S(t){return t==="module"}function L(t){return t>=1000?`${(t/1000).toFixed(2)}s`:`${Math.round(t)}ms`}function ot(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function at(t,n){return t===void 0?n==="esm":t}function X(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],e=Math.floor(Math.log(t)/Math.log(1024));if(e===0)return`${t} ${n[e]}`;return`${(t/Math.pow(1024,e)).toFixed(2)} ${n[e]}`}function w(t,n=3){return t.split("/").slice(-n).join("/")}async function q(t,n){let e=Nt.join(t,n);try{await et.rm(e,{recursive:!0,force:!0})}catch(r){throw new x(`Failed to clean output directory: ${r}`)}await et.mkdir(e,{recursive:!0})}function Y(t){return t||$.outDir}function ct(t){return t===void 0?$.clean:t}function lt(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${G(n)}($|\\/|\\\\)`):n)}function j(t,n){return lt(t.external||[]).concat(ot(n).map((e)=>new RegExp(`^${G(e)}($|\\/|\\\\)`)))}function D(t){return lt(t.noExternal||[])}import kt from"node:path";import{ResolverFactory as Wt}from"oxc-resolver";import C from"node:path";var T="\x00dts:",ut=(t,n,e)=>{return{name:"bunup:virtual-dts",async resolveId(r,s){if(J(r))return r;if(!s||!J(s))return null;let i=await _(r,n,e,P(s));if(!i)return null;let o=O(i);if(t.has(o))return N(o);return null},load(r){if(r.startsWith(T)){let s=P(r),i=t.get(s);if(i)return v.add(s),i}return null}}};function O(t){return t.replace(/\.tsx?$/,".d.ts")}function K(t){let n=C.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?C.resolve(n,t.data.compilerOptions.baseUrl):n}function ft(t){let n=new Map,e=t.data?.compilerOptions?.paths;if(!e)return n;let r=K(t);for(let[s,i]of Object.entries(e))if(Array.isArray(i)&&i.length){let o=s.replace(/\*/g,"(.*)"),a=i[0].replace(/\*/g,"$1");n.set(`^${o}$`,C.join(r,a))}return n}function Ut(t,n,e){for(let[r,s]of n){let i=new RegExp(r),o=t.match(i);if(o)return s.replace("$1",o[1]||"")}return e?C.join(e,t):null}async function Ft(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let e of n){let r=`${t}${e}`;if(await Bun.file(r).exists()&&(r.endsWith(".ts")||r.endsWith(".tsx")))return r}return null}function _(t,n,e,r){let s=t.startsWith(".")?C.resolve(C.dirname(r||""),t):Ut(t,n,e);if(!s)return Promise.resolve(null);return Ft(s)}function J(t){return t.startsWith(T)}function P(t){return t.replace(T,"")}function N(t){return`${T}${t}`}var pt;function gt(t){return{name:"bunup:types-resolve",buildStart(){pt||=new Wt({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(n,e){if(e=e?P(e):void 0,/\0/.test(n))return;if(t){if(!t.some((o)=>{let a=!1;if(typeof o==="string")a=o===n||!!(e&&e.includes(o));else a=o.test(n)||!!(e&&o.test(e));return a}))return}let r=e?kt.dirname(e):process.cwd(),{path:s}=await pt.async(r,n);if(!s)return;if(/[cm]?jsx?$/.test(s)){let i=s.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(i).exists()?i:void 0}return s}}}async function mt(t,n,e,r,s,i){let o=O(t),a=N(o),c=j(e,r),u=D(e);try{let{output:g}=await Ht({input:a,output:{dir:e.outDir,inlineDynamicImports:!0},write:!1,onwarn(f,h){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(f.code??""))return;h(f)},plugins:[ut(n,s,i),typeof e.dts==="object"&&"resolve"in e.dts&>(typeof e.dts.resolve==="boolean"?void 0:e.dts.resolve),Vt()],external:(f)=>c.some((h)=>h.test(f))&&!u.some((h)=>h.test(f))});if(!g[0]?.code)throw new m("Generated bundle is empty");return g[0].code}catch(g){throw new m(`DTS bundling failed: ${p(g)}`)}}class B{static instance;loggedOnceMessages=new Set;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"};constructor(){}static getInstance(){if(!B.instance)B.instance=new B;return B.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(t){if(!t?.once)return!0;if(this.loggedOnceMessages.has(t.once))return!1;return this.loggedOnceMessages.add(t.once),!0}formatMessage({colorCode:t,label:n,message:e,size:r,identifier:s,muted:i}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length)),a=i?`\x1B[38;5;${this.colors.info}m${e}\x1B[0m`:e;if(r){let[u,...g]=a.split(" "),f=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-u.length)),h=s?` \x1B[48;5;${t};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${u}${f} \x1B[38;5;${this.colors.size}m${r}\x1B[0m ${g.join(" ")}${h}`}let c=s?` \x1B[48;5;${t};38;5;0m ${s} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${a}${c}`}output(t,n={},e=console.log){if(!this.shouldLog(n))return;if(n.verticalSpace)console.log("");if(e(t),n.verticalSpace)console.log("")}cli(t,n={}){let e=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:t,identifier:n.identifier,muted:n.muted});this.output(e,n)}info(t,n={}){let e=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:t,identifier:n.identifier,muted:n.muted});this.output(e,n)}warn(t,n={}){let e=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:t,identifier:n.identifier,muted:n.muted});this.output(e,n,console.warn)}error(t,n={}){let e=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:t,identifier:n.identifier,muted:n.muted});this.output(e,n,console.error)}progress(t,n,e,r){let s=String(t),i=this.colors.default,o,a,c={};if(typeof e==="string")o=e,a=r;else if(e)o=e.size,a=e.identifier,c=e;for(let[g,f]of Object.entries(this.colors.progress))if(s.includes(g)){i=f;break}let u=this.formatMessage({colorCode:i,label:s,message:n,size:o,identifier:a,muted:c.muted});this.output(u,c)}}var l=B.getInstance();var Gt=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Xt=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function dt(t,n,e){let r=new Set([t]),s=[t];while(s.length){let i=s.pop();if(!i)continue;try{let o=await Bun.file(i).text(),a=qt(o);for(let c of a){let u=await _(c,n,e,i);if(!u)continue;if(!r.has(u))r.add(u),s.push(u)}}catch(o){l.warn(`Error processing ${i}: ${p(o)}`)}}return r}function qt(t){let n=new Set;for(let e of[Gt,Xt]){let r;while((r=e.exec(t))!==null)n.add(r[2])}return Array.from(n)}import{isolatedDeclaration as Yt}from"oxc-transform";async function ht(t){let n=new Map;return await Promise.all([...t].map(async(e)=>{try{let r=O(e);if(!await Bun.file(e).exists())return;let i=await Bun.file(e).text(),{code:o}=Yt(e,i);if(o)n.set(r,o)}catch(r){l.warn(`Failed to generate declaration for ${e}: ${p(r)}`)}})),n}import xt from"node:fs/promises";import Q from"node:path";import{isolatedDeclaration as Jt}from"oxc-transform";async function wt(t,n){let e=Q.resolve(t),r=Q.resolve(e,n);if(!await xt.exists(e))throw new m(`Root directory does not exist: ${e}`);if(!await Bun.file(r).exists())throw new m(`Entry file does not exist: ${r}`);if(!r.endsWith(".ts"))throw new m(`Entry file must be a TypeScript file (.ts): ${r}`);if(Q.relative(e,r).startsWith(".."))throw new m(`Entry file must be within rootDir: ${r}`);return{absoluteRootDir:e,absoluteEntry:r}}async function bt(t){let n=!1;if(await Promise.all([...t].map(async(e)=>{try{let r=e.replace(/\.d\.ts$/,".ts"),s=await Bun.file(r).text(),{errors:i}=Jt(r,s);i.forEach((o)=>{if(!n)console.log(`
|
|
6
|
+
`);let a=o.labels[0],c=a?Kt(s,a.start):"",g=`${w(r)}${c}: ${Qt(o.message)}`;l.warn(g),n=!0})}catch{}})),n)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
8
|
`)}function Kt(t,n){if(n===void 0)return"";let e=t.slice(0,n).split(`
|
|
9
|
-
`),r=e.length,s=e[e.length-1].length+1;return` (${r}:${s})`}function Qt(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function yt(t,n,e,r,s){let{absoluteEntry:i}=await
|
|
9
|
+
`),r=e.length,s=e[e.length-1].length+1;return` (${r}:${s})`}function Qt(t){return t.replace(" with --isolatedDeclarations","").replace(" with --isolatedDeclaration","")}async function yt(t,n,e,r,s){let{absoluteEntry:i}=await wt(t,n),o=ft(r),a=K(r),c=await dt(i,o,a),u=await ht(c);return mt(i,u,e,s,o,a)}function M(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function A(t){let n=[],e=new Set,r={};function s(i,o){if(e.has(i)){let a=rt(),c=`${i}_${a}`;l.warn(`Output name conflict: "${i}" is used by multiple files.
|
|
10
10
|
Bunup uses filenames without extensions as output names by default.
|
|
11
11
|
|
|
12
12
|
${r[i]} -> ${i}.js
|
|
@@ -20,8 +20,8 @@ To fix this, use named entries in your configuration:
|
|
|
20
20
|
}
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
-
See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0}),n.push({name:c,path:o})}else n.push({name:i,path:o}),e.add(i),r[i]=o}if(Array.isArray(t))for(let i of t){let o=M(i);s(o,i)}else if(typeof t==="object")Object.entries(t).forEach(([i,o])=>{s(i,o)});else{let i=M(t);s(i,t)}return n}function Et(t,n){return`[dir]/${t}${n}`}import{loadTsConfig as Zt}from"load-tsconfig";function $t(t){try{return Zt(".",t)}catch(n){return l.warn(`Failed to load tsconfig: ${p(n)}`),{path:t,data:{},files:[]}}}import Z from"node:path";async function Ot(t){let n=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let e of n){let r=Z.join(t,`bunup.config${e}`);try{if(!await Bun.file(r).exists())continue;let i=await zt(r,e);if(!i)continue;return{configs:en(i,t),configFilePath:r}}catch(s){throw new x(`Failed to load config from ${r}: ${p(s)}`)}}return{configs:[],configFilePath:""}}async function zt(t,n){if(n===".json"||n===".jsonc")return tn(t);return nn(t)}async function tn(t){try{let n=await Bun.file(t).text(),e=JSON.parse(n);return e.bunup||e}catch(n){throw new Error(`Invalid JSON in config file. ${p(n)}`)}}async function nn(t){try{let n=await import(`file://${t}`),e=n.default||n;if(!e)return l.warn(`No export found in ${t}. Make sure you're exporting your configuration.`),{};return e}catch(n){throw new Error(`Failed to import config file. ${p(n)}`)}}function en(t,n){let e=[];if(rn(t))sn(t,n,e);else if(Array.isArray(t))on(t,n,e);else if(t&&typeof t==="object")e.push({options:t,rootDir:n});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return e}function rn(t){return Array.isArray(t)&&t.length>0&&t.every((n)=>typeof n==="object"&&n!==null&&("name"in n)&&("root"in n)&&("config"in n))}function sn(t,n,e){for(let r of t){let s=Z.resolve(n,r.root);if(Array.isArray(r.config))for(let i of r.config)e.push({options:{name:r.name,...i},rootDir:s});else e.push({options:{name:r.name,...r.config},rootDir:s})}}function on(t,n,e){for(let r of t){if(!r||typeof r!=="object")throw new Error("Invalid configuration item. Expected an object.");e.push({options:r,rootDir:n})}}async function vt(t){let n=Z.join(t,"package.json");try{if(!await Bun.file(n).exists())return{packageJson:null,path:n};let r=await Bun.file(n).text();return{packageJson:JSON.parse(r),path:n}}catch(e){return l.warn(`Failed to load package.json at ${n}: ${p(e)}`),{packageJson:null,path:n}}}function Ct(t,n){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(r)=>{let s=r.path;if(t.some((o)=>o.test(s))&&!n.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}var v=new Set;async function U(t,n){if(!t.entry||t.entry.length===0||!t.outDir)throw new x("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:e,path:r}=await vt(n);if(e)l.cli(`Using package.json: ${
|
|
23
|
+
See: https://bunup.arshadyaseen.com/#named-entries`,{muted:!0,verticalSpace:!0}),n.push({name:c,path:o})}else n.push({name:i,path:o}),e.add(i),r[i]=o}if(Array.isArray(t))for(let i of t){let o=M(i);s(o,i)}else if(typeof t==="object")Object.entries(t).forEach(([i,o])=>{s(i,o)});else{let i=M(t);s(i,t)}return n}function Et(t,n){return`[dir]/${t}${n}`}import{loadTsConfig as Zt}from"load-tsconfig";function $t(t){try{return Zt(".",t)}catch(n){return l.warn(`Failed to load tsconfig: ${p(n)}`),{path:t,data:{},files:[]}}}import Z from"node:path";async function Ot(t){let n=[".ts",".js",".mjs",".cjs",".mts",".cts",".json",".jsonc"];for(let e of n){let r=Z.join(t,`bunup.config${e}`);try{if(!await Bun.file(r).exists())continue;let i=await zt(r,e);if(!i)continue;return{configs:en(i,t),configFilePath:r}}catch(s){throw new x(`Failed to load config from ${r}: ${p(s)}`)}}return{configs:[],configFilePath:""}}async function zt(t,n){if(n===".json"||n===".jsonc")return tn(t);return nn(t)}async function tn(t){try{let n=await Bun.file(t).text(),e=JSON.parse(n);return e.bunup||e}catch(n){throw new Error(`Invalid JSON in config file. ${p(n)}`)}}async function nn(t){try{let n=await import(`file://${t}`),e=n.default||n;if(!e)return l.warn(`No export found in ${t}. Make sure you're exporting your configuration.`),{};return e}catch(n){throw new Error(`Failed to import config file. ${p(n)}`)}}function en(t,n){let e=[];if(rn(t))sn(t,n,e);else if(Array.isArray(t))on(t,n,e);else if(t&&typeof t==="object")e.push({options:t,rootDir:n});else throw new Error("Invalid configuration format. Expected an object, array, or workspace configuration.");return e}function rn(t){return Array.isArray(t)&&t.length>0&&t.every((n)=>typeof n==="object"&&n!==null&&("name"in n)&&("root"in n)&&("config"in n))}function sn(t,n,e){for(let r of t){let s=Z.resolve(n,r.root);if(Array.isArray(r.config))for(let i of r.config)e.push({options:{name:r.name,...i},rootDir:s});else e.push({options:{name:r.name,...r.config},rootDir:s})}}function on(t,n,e){for(let r of t){if(!r||typeof r!=="object")throw new Error("Invalid configuration item. Expected an object.");e.push({options:r,rootDir:n})}}async function vt(t){let n=Z.join(t,"package.json");try{if(!await Bun.file(n).exists())return{packageJson:null,path:n};let r=await Bun.file(n).text();return{packageJson:JSON.parse(r),path:n}}catch(e){return l.warn(`Failed to load package.json at ${n}: ${p(e)}`),{packageJson:null,path:n}}}function Ct(t,n){return{name:"bunup:external-plugin",setup(e){e.onResolve({filter:/.*/},(r)=>{let s=r.path;if(t.some((o)=>o.test(s))&&!n.some((o)=>o.test(s)))return{path:s,external:!0};return null})}}}var v=new Set;async function U(t,n){if(!t.entry||t.entry.length===0||!t.outDir)throw new x("Nothing to build. Please make sure you have provided a proper bunup configuration or cli arguments.");let{packageJson:e,path:r}=await vt(n);if(e)l.cli(`Using package.json: ${w(r,2)}`,{muted:!0,once:r,identifier:t.name});let s=e?.type,i=j(t,e),o=D(t),a=[Ct(i,o)],c=A(t.entry),u=nt(t,n),g=t.format.flatMap((f)=>c.map((h)=>{return an(t,n,h,f,s,a,u)}));if(await Promise.all(g),t.dts){let f=$t(t.preferredTsconfigPath);if(f.path)l.cli(`Using tsconfig: ${w(f.path,2)}`,{muted:!0,once:f.path,identifier:t.name});let h=t.format.filter((y)=>{if(y==="iife"&&!S(s)&&t.format.includes("cjs"))return!1;return!0}),It=typeof t.dts==="object"&&t.dts.entry?A(t.dts.entry):c;try{await Promise.all(It.map(async(y)=>{let St=await yt(n,y.path,t,f,e);await Promise.all(h.map(async(Lt)=>{let jt=it(Lt,s),H=`${n}/${t.outDir}/${y.name}${jt}`;await Bun.write(H,St);let Dt=Bun.file(H).size||0;l.progress("DTS",w(H),X(Dt),t.name)}))}))}catch(y){throw new m(p(y))}}}async function an(t,n,e,r,s,i,o){let a=st(r,s),c=await Bun.build({...o,entrypoints:[`${n}/${e.path}`],format:r,naming:{entry:Et(e.name,a)},splitting:at(t.splitting,r),plugins:i,throw:!1});if(!c.success)c.logs.forEach((f)=>{if(f.level==="error")throw new x(f.message);else if(f.level==="warning")l.warn(f.message);else if(f.level==="info")l.info(f.message)});let u=`${n}/${t.outDir}/${e.name}${a}`,g=Bun.file(u).size||0;l.progress(r.toUpperCase(),w(u),X(g),t.name)}var F="0.3.55";var Bt="https://bun.sh/docs/installation",Rt="https://bunup.arshadyaseen.com/#cli-options";function b(t){return(n,e)=>{e[t]=n===!0?!0:n==="true"}}function R(t){return(n,e)=>{if(typeof n==="string")e[t]=n;else throw new d(`Option --${t} requires a string value`)}}function Pt(t){return(n,e)=>{if(typeof n==="string")e[t]=n.split(",");else throw new d(`Option --${t} requires a string value`)}}function ln(){console.log(`
|
|
24
24
|
Bunup - An extremely fast, zero-config bundler for JavaScript and TypeScript, powered by Bun.
|
|
25
25
|
`),console.log("For more information on available options, visit:"),console.log(`\x1B[36m\x1B[4m${Rt}\x1B[0m
|
|
26
|
-
`),process.exit(0)}function un(){console.log(F),process.exit(0)}var fn={name:{flags:["n","name"],handler:R("name")},format:{flags:["f","format"],handler:(t,n)=>{if(typeof t==="string")n.format=t.split(",");else throw new d("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:R("outDir")},minify:{flags:["m","minify"],handler:
|
|
27
|
-
To install Bun, visit `+Bt)})();import W from"node:path";import gn from"chokidar";async function Mt(t,n){let e=new Set,r=A(t.entry);r.forEach((a)=>{let c=W.resolve(n,a.path),u=W.dirname(c);e.add(u)});let s=gn.watch(Array.from(e),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,W.join(n,t.outDir)]}),i=!1,o=async(a=!1)=>{if(i)return;i=!0;try{let c=performance.now();if(await U({...t,entry:r.map((u)=>u.path),clean:!1},n),t.onBuildSuccess?.(),!a)l.cli(`\uD83D\uDCE6 Rebuild finished in ${L(performance.now()-c)}`);await z()}catch(c){V(c)}finally{i=!1}};s.on("change",(a)=>{let c=W.relative(n,a);l.cli(`File changed: ${c}`,{muted:!0}),o()}),s.on("error",(a)=>{throw new I(`Watcher error: ${p(a)}`)}),await o(!0)}async function mn(t=Bun.argv.slice(2)){let n=Tt(t),{configs:e,configFilePath:r}=await Ot(process.cwd());if(l.cli(`Using bunup v${F} and bun v${Bun.version}`,{muted:!0}),r)l.cli(`Using config file: ${
|
|
26
|
+
`),process.exit(0)}function un(){console.log(F),process.exit(0)}var fn={name:{flags:["n","name"],handler:R("name")},format:{flags:["f","format"],handler:(t,n)=>{if(typeof t==="string")n.format=t.split(",");else throw new d("Option --format requires a string value")}},outDir:{flags:["o","out-dir"],handler:R("outDir")},minify:{flags:["m","minify"],handler:b("minify")},watch:{flags:["w","watch"],handler:b("watch")},dts:{flags:["d","dts"],handler:b("dts")},banner:{flags:["b","banner"],handler:R("banner")},footer:{flags:["f","footer"],handler:R("footer")},external:{flags:["e","external"],handler:Pt("external")},sourcemap:{flags:["sm","sourcemap"],handler:R("sourcemap")},target:{flags:["t","target"],handler:R("target")},minifyWhitespace:{flags:["mw","minify-whitespace"],handler:b("minifyWhitespace")},minifyIdentifiers:{flags:["mi","minify-identifiers"],handler:b("minifyIdentifiers")},minifySyntax:{flags:["ms","minify-syntax"],handler:b("minifySyntax")},clean:{flags:["c","clean"],handler:b("clean")},splitting:{flags:["s","splitting"],handler:b("splitting")},noExternal:{flags:["ne","no-external"],handler:Pt("noExternal")}},pn={help:{flags:["h","help"],handler:()=>ln()},version:{flags:["v","version"],handler:()=>un()}},k={};for(let t of Object.values(fn))if(t)for(let n of t.flags)k[n]=t.handler;for(let t of Object.values(pn))for(let n of t.flags)k[n]=t.handler;function Tt(t){let n={},e={},r=0;while(r<t.length){let s=t[r];if(s.startsWith("--")){let i,o;if(s.includes("=")){let[a,c]=s.slice(2).split("=",2);i=a,o=c}else{i=s.slice(2);let a=t[r+1];if(o=a&&!a.startsWith("-")?a:!0,typeof o==="string")r++}if(i==="entry")if(typeof o==="string"){let a=M(o);if(e[a])l.warn(`Duplicate entry name '${a}' derived from '${o}'. Overwriting previous entry.`);e[a]=o}else throw new d("Option --entry requires a string value");else if(i.startsWith("entry.")){let a=i.slice(6);if(typeof o==="string"){if(e[a])l.warn(`Duplicate entry name '${a}' provided via --entry.${a}. Overwriting previous entry.`);e[a]=o}else throw new d(`Option --entry.${a} requires a string value`)}else{let a=k[i];if(a)a(o,n);else throw new d(`Unknown option: --${i}`)}}else if(s.startsWith("-")){let i=s.slice(1),o=t[r+1],a=o&&!o.startsWith("-")?o:!0;if(typeof a==="string")r++;let c=k[i];if(c)c(a,n);else throw new d(`Unknown option: -${i}`)}else{let i=M(s);if(e[i])l.warn(`Duplicate entry name '${i}' derived from positional argument '${s}'. Overwriting previous entry.`);e[i]=s}r++}if(Object.keys(e).length>0)n.entry=e;return n}(()=>{if(typeof Bun==="undefined")throw new d(`Bunup requires Bun to run.
|
|
27
|
+
To install Bun, visit `+Bt)})();import W from"node:path";import gn from"chokidar";async function Mt(t,n){let e=new Set,r=A(t.entry);r.forEach((a)=>{let c=W.resolve(n,a.path),u=W.dirname(c);e.add(u)});let s=gn.watch(Array.from(e),{persistent:!0,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},ignoreInitial:!0,atomic:!0,ignorePermissionErrors:!0,ignored:[/[\\/]\.git[\\/]/,/[\\/]node_modules[\\/]/,W.join(n,t.outDir)]}),i=!1,o=async(a=!1)=>{if(i)return;i=!0;try{let c=performance.now();if(await U({...t,entry:r.map((u)=>u.path),clean:!1},n),t.onBuildSuccess?.(),!a)l.cli(`\uD83D\uDCE6 Rebuild finished in ${L(performance.now()-c)}`);await z()}catch(c){V(c)}finally{i=!1}};s.on("change",(a)=>{let c=W.relative(n,a);l.cli(`File changed: ${c}`,{muted:!0}),o()}),s.on("error",(a)=>{throw new I(`Watcher error: ${p(a)}`)}),await o(!0)}async function mn(t=Bun.argv.slice(2)){let n=Tt(t),{configs:e,configFilePath:r}=await Ot(process.cwd());if(l.cli(`Using bunup v${F} and bun v${Bun.version}`,{muted:!0}),r)l.cli(`Using config file: ${w(r,2)}`,{muted:!0});let s=performance.now();if(l.cli("Build started"),e.length===0){let a={...$,...n},c=process.cwd();if(a.clean)q(c,Y(a.outDir));await At(a,c)}else{for(let{options:a,rootDir:c}of e)if(ct(a.clean))q(c,Y(a.outDir));await Promise.all(e.map(async({options:a,rootDir:c})=>{let u={...$,...a,...n};await At(u,c)}))}let i=performance.now()-s,o=L(i);if(l.cli(`\u26A1\uFE0F Build completed in ${o}`),await z(),n.watch)l.cli("\uD83D\uDC40 Watching for file changes");if(!n.watch)process.exit(0);l.dispose()}async function z(){if(v.size>0)await bt(v),v.clear()}async function At(t,n){if(t.watch)await Mt(t,n);else await U(t,n),t.onBuildSuccess?.()}mn().catch((t)=>tt(t));export{z as validateDtsFiles,mn as main};
|
package/build/index.d.mts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
//#region \
|
|
2
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/options.d.ts
|
|
3
3
|
/**
|
|
4
4
|
* Entry point files for TypeScript declaration file generation
|
|
5
5
|
*
|
|
@@ -437,7 +437,7 @@ interface BunupOptions {
|
|
|
437
437
|
}
|
|
438
438
|
|
|
439
439
|
//#endregion
|
|
440
|
-
//#region \
|
|
440
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/types.d.ts
|
|
441
441
|
type PromiseOr<T> = Promise<T> | T;
|
|
442
442
|
type WithOptional<
|
|
443
443
|
T,
|
|
@@ -454,12 +454,12 @@ type DefineWorkspaceEntry = {
|
|
|
454
454
|
};
|
|
455
455
|
|
|
456
456
|
//#endregion
|
|
457
|
-
//#region \
|
|
457
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/define.d.ts
|
|
458
458
|
declare function defineConfig(options: DefineConfigEntry | DefineConfigEntry[]): DefineConfigEntry | DefineConfigEntry[];
|
|
459
459
|
declare function defineWorkspace(options: DefineWorkspaceEntry[]): DefineWorkspaceEntry[];
|
|
460
460
|
|
|
461
461
|
//#endregion
|
|
462
|
-
//#region \
|
|
462
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/build.d.ts
|
|
463
463
|
declare function build(options: BunupOptions, rootDir: string): Promise<void>;
|
|
464
464
|
|
|
465
465
|
//#endregion
|
package/build/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
|
|
2
|
-
//#region \
|
|
2
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/options.d.ts
|
|
3
3
|
/**
|
|
4
4
|
* Entry point files for TypeScript declaration file generation
|
|
5
5
|
*
|
|
@@ -437,7 +437,7 @@ interface BunupOptions {
|
|
|
437
437
|
}
|
|
438
438
|
|
|
439
439
|
//#endregion
|
|
440
|
-
//#region \
|
|
440
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/types.d.ts
|
|
441
441
|
type PromiseOr<T> = Promise<T> | T;
|
|
442
442
|
type WithOptional<
|
|
443
443
|
T,
|
|
@@ -454,12 +454,12 @@ type DefineWorkspaceEntry = {
|
|
|
454
454
|
};
|
|
455
455
|
|
|
456
456
|
//#endregion
|
|
457
|
-
//#region \
|
|
457
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/define.d.ts
|
|
458
458
|
declare function defineConfig(options: DefineConfigEntry | DefineConfigEntry[]): DefineConfigEntry | DefineConfigEntry[];
|
|
459
459
|
declare function defineWorkspace(options: DefineWorkspaceEntry[]): DefineWorkspaceEntry[];
|
|
460
460
|
|
|
461
461
|
//#endregion
|
|
462
|
-
//#region \
|
|
462
|
+
//#region \0dts:/home/runner/work/bunup/bunup/src/build.d.ts
|
|
463
463
|
declare function build(options: BunupOptions, rootDir: string): Promise<void>;
|
|
464
464
|
|
|
465
465
|
//#endregion
|
package/build/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var It=require("node:module");var Pt=Object.create;var{getPrototypeOf:Bt,defineProperty:C,getOwnPropertyNames:U,getOwnPropertyDescriptor:Dt}=Object,G=Object.prototype.hasOwnProperty;var x=(t,n,r)=>{r=t!=null?Pt(Bt(t)):{};let e=n||!t||!t.__esModule?C(r,"default",{value:t,enumerable:!0}):r;for(let i of U(t))if(!G.call(e,i))C(e,i,{get:()=>t[i],enumerable:!0});return e},F=new WeakMap,Ot=(t)=>{var n=F.get(t),r;if(n)return n;if(n=C({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")U(t).map((e)=>!G.call(n,e)&&C(n,e,{get:()=>t[e],enumerable:!(r=Dt(t,e))||r.enumerable}));return F.set(t,n),n};var At=(t,n)=>{for(var r in n)C(t,r,{get:n[r],enumerable:!0,configurable:!0,set:(e)=>n[r]=()=>e})};var Gt={};At(Gt,{defineWorkspace:()=>X,defineConfig:()=>V,build:()=>bt});module.exports=Ot(Gt);function V(t){return t}function X(t){return t}var it=require("rolldown"),ot=require("rolldown-plugin-types");class T extends Error{constructor(t){super(t);this.name="BunupError"}}class w extends T{constructor(t){super(t);this.name="BunupBuildError"}}class d extends T{constructor(t){super(t);this.name="BunupDTSBuildError"}}var m=(t)=>{if(t instanceof Error)return t.message;return String(t)};var Tt=x(require("node:fs/promises")),vt=x(require("node:path"));function k(t,n){return{outdir:`${n}/${t.outDir}`,minify:St(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function St(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=t,s=n===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function v(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function H(t=8){return Math.random().toString(36).substring(2,2+t)}function Y(t,n){switch(t){case"esm":return".mjs";case"cjs":return P(n)?".cjs":".js";case"iife":return".global.js"}}function J(t,n){switch(t){case"esm":return".d.mts";case"cjs":return P(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function P(t){return t==="module"}function q(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function K(t,n){return t===void 0?n==="esm":t}function j(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${n[r]}`;return`${(t/Math.pow(1024,r)).toFixed(2)} ${n[r]}`}function b(t,n=3){return t.split("/").slice(-n).join("/")}function Q(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${v(n)}($|\\/|\\\\)`):n)}function B(t,n){return Q(t.external||[]).concat(q(n).map((r)=>new RegExp(`^${v(r)}($|\\/|\\\\)`)))}function D(t){return Q(t.noExternal||[])}var rt=x(require("node:path")),et=require("oxc-resolver");var h=x(require("node:path"));var M="\x00dts:",Z=(t,n,r)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(L(e))return e;if(!i||!L(i))return null;let s=await O(e,n,r,R(i));if(!s)return null;let o=$(s);if(t.has(o))return A(o);return null},load(e){if(e.startsWith(M)){let i=R(e),s=t.get(i);if(s)return z.add(i),s}return null}}};function $(t){return t.replace(/\.tsx?$/,".d.ts")}function _(t){let n=h.default.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?h.default.resolve(n,t.data.compilerOptions.baseUrl):n}function tt(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=_(t);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");n.set(`^${o}$`,h.default.join(e,a))}return n}function jt(t,n,r){for(let[e,i]of n){let s=new RegExp(e),o=t.match(s);if(o)return i.replace("$1",o[1]||"")}return r?h.default.join(r,t):null}async function Lt(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function O(t,n,r,e){let i=t.startsWith(".")?h.default.resolve(h.default.dirname(e||""),t):jt(t,n,r);if(!i)return Promise.resolve(null);return Lt(i)}function L(t){return t.startsWith(M)}function R(t){return t.replace(M,"")}function A(t){return`${M}${t}`}var nt;function st(t){return{name:"bunup:types-resolve",buildStart(){nt||=new et.ResolverFactory({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(n,r){if(r=r?R(r):void 0,/\0/.test(n))return;if(t){if(!t.some((o)=>{let a=!1;if(typeof o==="string")a=o===n||!!(r&&r.includes(o));else a=o.test(n)||!!(r&&o.test(r));return a}))return}let e=r?rt.default.dirname(r):process.cwd(),{path:i}=await nt.async(e,n);if(!i)return;if(/[cm]?jsx?$/.test(i)){let s=i.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return i}}}async function at(t,n,r,e,i,s){let o=$(t),a=A(o),u=B(r,e),f=D(r);try{let{output:g}=await it.build({input:a,onwarn(c,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;p(c)},plugins:[Z(n,i,s),typeof r.dts==="object"&&"resolve"in r.dts&&st(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),ot.dts()],external:(c)=>u.some((p)=>p.test(c))&&!f.some((p)=>p.test(c))
|
|
1
|
+
var It=require("node:module");var Pt=Object.create;var{getPrototypeOf:Bt,defineProperty:C,getOwnPropertyNames:U,getOwnPropertyDescriptor:Dt}=Object,G=Object.prototype.hasOwnProperty;var x=(t,n,r)=>{r=t!=null?Pt(Bt(t)):{};let e=n||!t||!t.__esModule?C(r,"default",{value:t,enumerable:!0}):r;for(let i of U(t))if(!G.call(e,i))C(e,i,{get:()=>t[i],enumerable:!0});return e},F=new WeakMap,Ot=(t)=>{var n=F.get(t),r;if(n)return n;if(n=C({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")U(t).map((e)=>!G.call(n,e)&&C(n,e,{get:()=>t[e],enumerable:!(r=Dt(t,e))||r.enumerable}));return F.set(t,n),n};var At=(t,n)=>{for(var r in n)C(t,r,{get:n[r],enumerable:!0,configurable:!0,set:(e)=>n[r]=()=>e})};var Gt={};At(Gt,{defineWorkspace:()=>X,defineConfig:()=>V,build:()=>bt});module.exports=Ot(Gt);function V(t){return t}function X(t){return t}var it=require("rolldown"),ot=require("rolldown-plugin-types");class T extends Error{constructor(t){super(t);this.name="BunupError"}}class w extends T{constructor(t){super(t);this.name="BunupBuildError"}}class d extends T{constructor(t){super(t);this.name="BunupDTSBuildError"}}var m=(t)=>{if(t instanceof Error)return t.message;return String(t)};var Tt=x(require("node:fs/promises")),vt=x(require("node:path"));function k(t,n){return{outdir:`${n}/${t.outDir}`,minify:St(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function St(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=t,s=n===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function v(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function H(t=8){return Math.random().toString(36).substring(2,2+t)}function Y(t,n){switch(t){case"esm":return".mjs";case"cjs":return P(n)?".cjs":".js";case"iife":return".global.js"}}function J(t,n){switch(t){case"esm":return".d.mts";case"cjs":return P(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function P(t){return t==="module"}function q(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function K(t,n){return t===void 0?n==="esm":t}function j(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${n[r]}`;return`${(t/Math.pow(1024,r)).toFixed(2)} ${n[r]}`}function b(t,n=3){return t.split("/").slice(-n).join("/")}function Q(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${v(n)}($|\\/|\\\\)`):n)}function B(t,n){return Q(t.external||[]).concat(q(n).map((r)=>new RegExp(`^${v(r)}($|\\/|\\\\)`)))}function D(t){return Q(t.noExternal||[])}var rt=x(require("node:path")),et=require("oxc-resolver");var h=x(require("node:path"));var M="\x00dts:",Z=(t,n,r)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(L(e))return e;if(!i||!L(i))return null;let s=await O(e,n,r,R(i));if(!s)return null;let o=$(s);if(t.has(o))return A(o);return null},load(e){if(e.startsWith(M)){let i=R(e),s=t.get(i);if(s)return z.add(i),s}return null}}};function $(t){return t.replace(/\.tsx?$/,".d.ts")}function _(t){let n=h.default.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?h.default.resolve(n,t.data.compilerOptions.baseUrl):n}function tt(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=_(t);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");n.set(`^${o}$`,h.default.join(e,a))}return n}function jt(t,n,r){for(let[e,i]of n){let s=new RegExp(e),o=t.match(s);if(o)return i.replace("$1",o[1]||"")}return r?h.default.join(r,t):null}async function Lt(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function O(t,n,r,e){let i=t.startsWith(".")?h.default.resolve(h.default.dirname(e||""),t):jt(t,n,r);if(!i)return Promise.resolve(null);return Lt(i)}function L(t){return t.startsWith(M)}function R(t){return t.replace(M,"")}function A(t){return`${M}${t}`}var nt;function st(t){return{name:"bunup:types-resolve",buildStart(){nt||=new et.ResolverFactory({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(n,r){if(r=r?R(r):void 0,/\0/.test(n))return;if(t){if(!t.some((o)=>{let a=!1;if(typeof o==="string")a=o===n||!!(r&&r.includes(o));else a=o.test(n)||!!(r&&o.test(r));return a}))return}let e=r?rt.default.dirname(r):process.cwd(),{path:i}=await nt.async(e,n);if(!i)return;if(/[cm]?jsx?$/.test(i)){let s=i.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return i}}}async function at(t,n,r,e,i,s){let o=$(t),a=A(o),u=B(r,e),f=D(r);try{let{output:g}=await it.build({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(c,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;p(c)},plugins:[Z(n,i,s),typeof r.dts==="object"&&"resolve"in r.dts&&st(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),ot.dts()],external:(c)=>u.some((p)=>p.test(c))&&!f.some((p)=>p.test(c))});if(!g[0]?.code)throw new d("Generated bundle is empty");return g[0].code}catch(g){throw new d(`DTS bundling failed: ${m(g)}`)}}class y{static instance;loggedOnceMessages=new Set;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"};constructor(){}static getInstance(){if(!y.instance)y.instance=new y;return y.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(t){if(!t?.once)return!0;if(this.loggedOnceMessages.has(t.once))return!1;return this.loggedOnceMessages.add(t.once),!0}formatMessage({colorCode:t,label:n,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length)),a=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[f,...g]=a.split(" "),c=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-f.length)),p=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${f}${c} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${g.join(" ")}${p}`}let u=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${a}${u}`}output(t,n={},r=console.log){if(!this.shouldLog(n))return;if(n.verticalSpace)console.log("");if(r(t),n.verticalSpace)console.log("")}cli(t,n={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n)}info(t,n={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n)}warn(t,n={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n,console.warn)}error(t,n={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n,console.error)}progress(t,n,r,e){let i=String(t),s=this.colors.default,o,a,u={};if(typeof r==="string")o=r,a=e;else if(r)o=r.size,a=r.identifier,u=r;for(let[g,c]of Object.entries(this.colors.progress))if(i.includes(g)){s=c;break}let f=this.formatMessage({colorCode:s,label:i,message:n,size:o,identifier:a,muted:u.muted});this.output(f,u)}}var l=y.getInstance();var _t=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,Nt=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function ct(t,n,r){let e=new Set([t]),i=[t];while(i.length){let s=i.pop();if(!s)continue;try{let o=await Bun.file(s).text(),a=Wt(o);for(let u of a){let f=await O(u,n,r,s);if(!f)continue;if(!e.has(f))e.add(f),i.push(f)}}catch(o){l.warn(`Error processing ${s}: ${m(o)}`)}}return e}function Wt(t){let n=new Set;for(let r of[_t,Nt]){let e;while((e=r.exec(t))!==null)n.add(e[2])}return Array.from(n)}var ut=require("oxc-transform");async function ft(t){let n=new Map;return await Promise.all([...t].map(async(r)=>{try{let e=$(r);if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=ut.isolatedDeclaration(r,s);if(o)n.set(e,o)}catch(e){l.warn(`Failed to generate declaration for ${r}: ${m(e)}`)}})),n}var N=x(require("node:fs/promises")),I=x(require("node:path")),Ft=require("oxc-transform");async function lt(t,n){let r=I.default.resolve(t),e=I.default.resolve(r,n);if(!await N.default.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(I.default.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function gt(t,n,r,e,i){let{absoluteEntry:s}=await lt(t,n),o=tt(e),a=_(e),u=await ct(s,o,a),f=await ft(u);return at(s,f,r,i,o,a)}function mt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function W(t){let n=[],r=new Set,e={};function i(s,o){if(r.has(s)){let a=H(),u=`${s}_${a}`;l.warn(`Output name conflict: "${s}" is used by multiple files.
|
|
2
2
|
Bunup uses filenames without extensions as output names by default.
|
|
3
3
|
|
|
4
4
|
${e[s]} -> ${s}.js
|
package/build/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
function lt(t){return t}function gt(t){return t}import{build as Et}from"rolldown";import{dts as wt}from"rolldown-plugin-types";class A extends Error{constructor(t){super(t);this.name="BunupError"}}class h extends A{constructor(t){super(t);this.name="BunupBuildError"}}class d extends A{constructor(t){super(t);this.name="BunupDTSBuildError"}}var m=(t)=>{if(t instanceof Error)return t.message;return String(t)};import Tt from"node:fs/promises";import jt from"node:path";function _(t,n){return{outdir:`${n}/${t.outDir}`,minify:mt(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function mt(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=t,s=n===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function I(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function N(t=8){return Math.random().toString(36).substring(2,2+t)}function W(t,n){switch(t){case"esm":return".mjs";case"cjs":return R(n)?".cjs":".js";case"iife":return".global.js"}}function F(t,n){switch(t){case"esm":return".d.mts";case"cjs":return R(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function R(t){return t==="module"}function U(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function G(t,n){return t===void 0?n==="esm":t}function S(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${n[r]}`;return`${(t/Math.pow(1024,r)).toFixed(2)} ${n[r]}`}function E(t,n=3){return t.split("/").slice(-n).join("/")}function V(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${I(n)}($|\\/|\\\\)`):n)}function M(t,n){return V(t.external||[]).concat(U(n).map((r)=>new RegExp(`^${I(r)}($|\\/|\\\\)`)))}function P(t){return V(t.noExternal||[])}import xt from"node:path";import{ResolverFactory as ht}from"oxc-resolver";import b from"node:path";var C="\x00dts:",X=(t,n,r)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(T(e))return e;if(!i||!T(i))return null;let s=await B(e,n,r,y(i));if(!s)return null;let o=w(s);if(t.has(o))return D(o);return null},load(e){if(e.startsWith(C)){let i=y(e),s=t.get(i);if(s)return k.add(i),s}return null}}};function w(t){return t.replace(/\.tsx?$/,".d.ts")}function v(t){let n=b.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?b.resolve(n,t.data.compilerOptions.baseUrl):n}function H(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=v(t);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");n.set(`^${o}$`,b.join(e,a))}return n}function pt(t,n,r){for(let[e,i]of n){let s=new RegExp(e),o=t.match(s);if(o)return i.replace("$1",o[1]||"")}return r?b.join(r,t):null}async function dt(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function B(t,n,r,e){let i=t.startsWith(".")?b.resolve(b.dirname(e||""),t):pt(t,n,r);if(!i)return Promise.resolve(null);return dt(i)}function T(t){return t.startsWith(C)}function y(t){return t.replace(C,"")}function D(t){return`${C}${t}`}var Y;function J(t){return{name:"bunup:types-resolve",buildStart(){Y||=new ht({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(n,r){if(r=r?y(r):void 0,/\0/.test(n))return;if(t){if(!t.some((o)=>{let a=!1;if(typeof o==="string")a=o===n||!!(r&&r.includes(o));else a=o.test(n)||!!(r&&o.test(r));return a}))return}let e=r?xt.dirname(r):process.cwd(),{path:i}=await Y.async(e,n);if(!i)return;if(/[cm]?jsx?$/.test(i)){let s=i.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return i}}}async function q(t,n,r,e,i,s){let o=w(t),a=D(o),u=M(r,e),f=P(r);try{let{output:g}=await Et({input:a,onwarn(c,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;p(c)},plugins:[X(n,i,s),typeof r.dts==="object"&&"resolve"in r.dts&&J(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),wt()],external:(c)=>u.some((p)=>p.test(c))&&!f.some((p)=>p.test(c))
|
|
1
|
+
function lt(t){return t}function gt(t){return t}import{build as Et}from"rolldown";import{dts as wt}from"rolldown-plugin-types";class A extends Error{constructor(t){super(t);this.name="BunupError"}}class h extends A{constructor(t){super(t);this.name="BunupBuildError"}}class d extends A{constructor(t){super(t);this.name="BunupDTSBuildError"}}var m=(t)=>{if(t instanceof Error)return t.message;return String(t)};import Tt from"node:fs/promises";import jt from"node:path";function _(t,n){return{outdir:`${n}/${t.outDir}`,minify:mt(t),target:t.target,splitting:t.splitting,sourcemap:t.sourcemap,define:t.define,loader:t.loader,drop:t.drop,banner:t.banner,footer:t.footer}}function mt(t){let{minify:n,minifyWhitespace:r,minifyIdentifiers:e,minifySyntax:i}=t,s=n===!0;return{whitespace:r??s,identifiers:e??s,syntax:i??s}}function I(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function N(t=8){return Math.random().toString(36).substring(2,2+t)}function W(t,n){switch(t){case"esm":return".mjs";case"cjs":return R(n)?".cjs":".js";case"iife":return".global.js"}}function F(t,n){switch(t){case"esm":return".d.mts";case"cjs":return R(n)?".d.cts":".d.ts";case"iife":return".d.ts"}}function R(t){return t==="module"}function U(t){if(!t)return[];return Array.from(new Set([...Object.keys(t.dependencies||{}),...Object.keys(t.peerDependencies||{})]))}function G(t,n){return t===void 0?n==="esm":t}function S(t){if(t===0)return"0 B";let n=["B","KB","MB","GB"],r=Math.floor(Math.log(t)/Math.log(1024));if(r===0)return`${t} ${n[r]}`;return`${(t/Math.pow(1024,r)).toFixed(2)} ${n[r]}`}function E(t,n=3){return t.split("/").slice(-n).join("/")}function V(t){return t.map((n)=>typeof n==="string"?new RegExp(`^${I(n)}($|\\/|\\\\)`):n)}function M(t,n){return V(t.external||[]).concat(U(n).map((r)=>new RegExp(`^${I(r)}($|\\/|\\\\)`)))}function P(t){return V(t.noExternal||[])}import xt from"node:path";import{ResolverFactory as ht}from"oxc-resolver";import b from"node:path";var C="\x00dts:",X=(t,n,r)=>{return{name:"bunup:virtual-dts",async resolveId(e,i){if(T(e))return e;if(!i||!T(i))return null;let s=await B(e,n,r,y(i));if(!s)return null;let o=w(s);if(t.has(o))return D(o);return null},load(e){if(e.startsWith(C)){let i=y(e),s=t.get(i);if(s)return k.add(i),s}return null}}};function w(t){return t.replace(/\.tsx?$/,".d.ts")}function v(t){let n=b.dirname(t.path||"");return t.data?.compilerOptions?.baseUrl?b.resolve(n,t.data.compilerOptions.baseUrl):n}function H(t){let n=new Map,r=t.data?.compilerOptions?.paths;if(!r)return n;let e=v(t);for(let[i,s]of Object.entries(r))if(Array.isArray(s)&&s.length){let o=i.replace(/\*/g,"(.*)"),a=s[0].replace(/\*/g,"$1");n.set(`^${o}$`,b.join(e,a))}return n}function pt(t,n,r){for(let[e,i]of n){let s=new RegExp(e),o=t.match(s);if(o)return i.replace("$1",o[1]||"")}return r?b.join(r,t):null}async function dt(t){let n=["",".ts",".tsx","/index.ts","/index.tsx"];for(let r of n){let e=`${t}${r}`;if(await Bun.file(e).exists()&&(e.endsWith(".ts")||e.endsWith(".tsx")))return e}return null}function B(t,n,r,e){let i=t.startsWith(".")?b.resolve(b.dirname(e||""),t):pt(t,n,r);if(!i)return Promise.resolve(null);return dt(i)}function T(t){return t.startsWith(C)}function y(t){return t.replace(C,"")}function D(t){return`${C}${t}`}var Y;function J(t){return{name:"bunup:types-resolve",buildStart(){Y||=new ht({mainFields:["types"],conditionNames:["types","typings","import","require"],extensions:[".d.ts",".ts"],modules:["node_modules","node_modules/@types"]})},async resolveId(n,r){if(r=r?y(r):void 0,/\0/.test(n))return;if(t){if(!t.some((o)=>{let a=!1;if(typeof o==="string")a=o===n||!!(r&&r.includes(o));else a=o.test(n)||!!(r&&o.test(r));return a}))return}let e=r?xt.dirname(r):process.cwd(),{path:i}=await Y.async(e,n);if(!i)return;if(/[cm]?jsx?$/.test(i)){let s=i.replace(/\.([cm]?)jsx?$/,".d.$1ts");return await Bun.file(s).exists()?s:void 0}return i}}}async function q(t,n,r,e,i,s){let o=w(t),a=D(o),u=M(r,e),f=P(r);try{let{output:g}=await Et({input:a,output:{dir:r.outDir,inlineDynamicImports:!0},write:!1,onwarn(c,p){if(["UNRESOLVED_IMPORT","CIRCULAR_DEPENDENCY","EMPTY_BUNDLE"].includes(c.code??""))return;p(c)},plugins:[X(n,i,s),typeof r.dts==="object"&&"resolve"in r.dts&&J(typeof r.dts.resolve==="boolean"?void 0:r.dts.resolve),wt()],external:(c)=>u.some((p)=>p.test(c))&&!f.some((p)=>p.test(c))});if(!g[0]?.code)throw new d("Generated bundle is empty");return g[0].code}catch(g){throw new d(`DTS bundling failed: ${m(g)}`)}}class ${static instance;loggedOnceMessages=new Set;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"};constructor(){}static getInstance(){if(!$.instance)$.instance=new $;return $.instance}dispose(){this.loggedOnceMessages.clear()}shouldLog(t){if(!t?.once)return!0;if(this.loggedOnceMessages.has(t.once))return!1;return this.loggedOnceMessages.add(t.once),!0}formatMessage({colorCode:t,label:n,message:r,size:e,identifier:i,muted:s}){let o=" ".repeat(Math.max(0,this.MAX_LABEL_LENGTH-n.length)),a=s?`\x1B[38;5;${this.colors.info}m${r}\x1B[0m`:r;if(e){let[f,...g]=a.split(" "),c=" ".repeat(Math.max(0,this.MAX_MESSAGE_LENGTH-f.length)),p=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${f}${c} \x1B[38;5;${this.colors.size}m${e}\x1B[0m ${g.join(" ")}${p}`}let u=i?` \x1B[48;5;${t};38;5;0m ${i} \x1B[0m`:"";return`\x1B[38;5;${t}m${n}\x1B[0m ${o}${a}${u}`}output(t,n={},r=console.log){if(!this.shouldLog(n))return;if(n.verticalSpace)console.log("");if(r(t),n.verticalSpace)console.log("")}cli(t,n={}){let r=this.formatMessage({colorCode:this.colors.cli,label:this.labels.cli,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n)}info(t,n={}){let r=this.formatMessage({colorCode:this.colors.info,label:this.labels.info,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n)}warn(t,n={}){let r=this.formatMessage({colorCode:this.colors.warn,label:this.labels.warn,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n,console.warn)}error(t,n={}){let r=this.formatMessage({colorCode:this.colors.error,label:this.labels.error,message:t,identifier:n.identifier,muted:n.muted});this.output(r,n,console.error)}progress(t,n,r,e){let i=String(t),s=this.colors.default,o,a,u={};if(typeof r==="string")o=r,a=e;else if(r)o=r.size,a=r.identifier,u=r;for(let[g,c]of Object.entries(this.colors.progress))if(i.includes(g)){s=c;break}let f=this.formatMessage({colorCode:s,label:i,message:n,size:o,identifier:a,muted:u.muted});this.output(f,u)}}var l=$.getInstance();var bt=/(?:import|export)(?:[\s\n]*(?:type[\s\n]+)?(?:\*|\{[^}]*\}|[\w$]+)[\s\n]+from[\s\n]*|[\s\n]+)(["'`])([^'"]+)\1/g,$t=/import\s*\(\s*(["'`])([^'"]+)\1\s*\)/g;async function K(t,n,r){let e=new Set([t]),i=[t];while(i.length){let s=i.pop();if(!s)continue;try{let o=await Bun.file(s).text(),a=yt(o);for(let u of a){let f=await B(u,n,r,s);if(!f)continue;if(!e.has(f))e.add(f),i.push(f)}}catch(o){l.warn(`Error processing ${s}: ${m(o)}`)}}return e}function yt(t){let n=new Set;for(let r of[bt,$t]){let e;while((e=r.exec(t))!==null)n.add(e[2])}return Array.from(n)}import{isolatedDeclaration as Ct}from"oxc-transform";async function Q(t){let n=new Map;return await Promise.all([...t].map(async(r)=>{try{let e=w(r);if(!await Bun.file(r).exists())return;let s=await Bun.file(r).text(),{code:o}=Ct(r,s);if(o)n.set(e,o)}catch(e){l.warn(`Failed to generate declaration for ${r}: ${m(e)}`)}})),n}import Z from"node:fs/promises";import j from"node:path";import{isolatedDeclaration as bn}from"oxc-transform";async function z(t,n){let r=j.resolve(t),e=j.resolve(r,n);if(!await Z.exists(r))throw new d(`Root directory does not exist: ${r}`);if(!await Bun.file(e).exists())throw new d(`Entry file does not exist: ${e}`);if(!e.endsWith(".ts"))throw new d(`Entry file must be a TypeScript file (.ts): ${e}`);if(j.relative(r,e).startsWith(".."))throw new d(`Entry file must be within rootDir: ${e}`);return{absoluteRootDir:r,absoluteEntry:e}}async function tt(t,n,r,e,i){let{absoluteEntry:s}=await z(t,n),o=H(e),a=v(e),u=await K(s,o,a),f=await Q(u);return q(s,f,r,i,o,a)}function nt(t){return t.split("/").pop()?.split(".").slice(0,-1).join(".")||""}function L(t){let n=[],r=new Set,e={};function i(s,o){if(r.has(s)){let a=N(),u=`${s}_${a}`;l.warn(`Output name conflict: "${s}" is used by multiple files.
|
|
2
2
|
Bunup uses filenames without extensions as output names by default.
|
|
3
3
|
|
|
4
4
|
${e[s]} -> ${s}.js
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "bunup",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.55",
|
|
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,13 +18,13 @@
|
|
|
18
18
|
"@types/bun": "^1.2.5",
|
|
19
19
|
"@typescript-eslint/eslint-plugin": "^7.18.0",
|
|
20
20
|
"bumpp": "^10.1.0",
|
|
21
|
-
"bunup": "^0.3.
|
|
21
|
+
"bunup": "^0.3.52",
|
|
22
22
|
"eslint": "^8.57.1",
|
|
23
23
|
"husky": "^9.1.7",
|
|
24
24
|
"prettier": "^3.5.3",
|
|
25
25
|
"typescript": "^5.8.3",
|
|
26
26
|
"vitest": "^2.1.9",
|
|
27
|
-
"create-bunup": "0.3.
|
|
27
|
+
"create-bunup": "0.3.55"
|
|
28
28
|
},
|
|
29
29
|
"peerDependencies": {
|
|
30
30
|
"typescript": ">=4.5.0"
|