unplugin-macros v0.13.0
unplugin-macros
Macros are a mechanism for running JavaScript functions at bundle-time. The value returned from these functions or variables are directly inlined into your bundle.
Installation
# npm
npm i -D unplugin-macros
# jsr
npx jsr add -D @unplugin/macros
// vite.config.ts
import Macros from 'unplugin-macros/vite'
export default defineConfig({
plugins: [Macros()],
})
// rollup.config.js
import Macros from 'unplugin-macros/rollup'
export default {
plugins: [Macros()],
}
Requires esbuild >= 0.15
// esbuild.config.js
import { build } from 'esbuild'
build({
plugins: [require('unplugin-macros/esbuild')()],
})
// webpack.config.js
module.exports = {
/* ... */
plugins: [require('unplugin-macros/webpack')()],
}
Usage
// main.js
import { getRandom, buildTime } from './macros' with { type: 'macro' }
getRandom() // Will be replaced with a random number at build time
buildTime // Will be replaced with the timestamp at the build time
// macros.js
export function getRandom() {
return Math.random()
}
export const buildTime = Date.now()
See more in Bun Macros.
TypeScript
Import Attributes syntax is supported in TypeScript >= 5.3, but you can replace with
keyword with assert
, which is supported in TypeScript >= 4.5.
ESLint
ESLint is not supported Import Attributes syntax yet, but you can use @babel/eslint-parser
or @typescript-eslint/parser
.
Options
Refer to docs.
Thanks
Thanks to Bun Macros.
Sponsors
License
22 days ago
22 days ago
22 days ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
2 months ago
4 months ago
6 months ago
5 months ago
8 months ago
8 months ago
8 months ago
8 months ago
9 months ago
10 months ago
10 months ago
10 months ago
10 months ago
10 months ago
10 months ago
10 months ago
10 months ago
11 months ago
11 months ago
11 months ago
11 months ago