X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=rollup.config.mjs;h=9dcf125df6b274fdfd06fc95447e08ff8aba873a;hb=3d5424d527d95ae9141ac916b121510762f8b7f3;hp=aac1c8cdd00740db11a5c031b31b14c850049c17;hpb=890ed48b416b065663ab8523a4d2a69b3f9042e1;p=poolifier.git diff --git a/rollup.config.mjs b/rollup.config.mjs index aac1c8cd..9dcf125d 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -1,11 +1,13 @@ import * as os from 'node:os' -import { dts } from 'rollup-plugin-dts' +import { env } from 'node:process' + import terser from '@rollup/plugin-terser' import typescript from '@rollup/plugin-typescript' +import { defineConfig } from 'rollup' import analyze from 'rollup-plugin-analyzer' import command from 'rollup-plugin-command' import del from 'rollup-plugin-delete' -import { defineConfig } from 'rollup' +import { dts } from 'rollup-plugin-dts' const availableParallelism = () => { let availableParallelism = 1 @@ -20,9 +22,10 @@ const availableParallelism = () => { return availableParallelism } -const isDevelopmentBuild = process.env.BUILD === 'development' -const isAnalyzeBuild = process.env.ANALYZE -const isDocumentationBuild = process.env.DOCUMENTATION +const isDevelopmentBuild = env.BUILD === 'development' +const isAnalyzeBuild = Boolean(env.ANALYZE) +const isDocumentationBuild = Boolean(env.DOCUMENTATION) +const sourcemap = env.SOURCEMAP !== 'false' const maxWorkers = Math.floor(availableParallelism() / 2) @@ -33,48 +36,48 @@ export default defineConfig([ output: [ { format: 'cjs', - ...(isDevelopmentBuild && { - dir: './lib', - sourcemap: true, - preserveModules: true, - preserveModulesRoot: './src' - }), - ...(!isDevelopmentBuild && { - file: './lib/index.js', - sourcemap: true, - plugins: [terser({ maxWorkers })] + ...(isDevelopmentBuild + ? { + dir: './lib', + entryFileNames: '[name].cjs', + chunkFileNames: '[name]-[hash].cjs', + preserveModules: true, + preserveModulesRoot: './src' + } + : { + file: './lib/index.cjs', + plugins: [terser({ maxWorkers })] + }), + ...(sourcemap && { + sourcemap }) }, { format: 'esm', - ...(isDevelopmentBuild && { - dir: './lib', - sourcemap: true, - entryFileNames: '[name].mjs', - chunkFileNames: '[name]-[hash].mjs', - preserveModules: true, - preserveModulesRoot: './src' - }), - ...(!isDevelopmentBuild && { - file: './lib/index.mjs', - sourcemap: true, - plugins: [terser({ maxWorkers })] + ...(isDevelopmentBuild + ? { + dir: './lib', + entryFileNames: '[name].mjs', + chunkFileNames: '[name]-[hash].mjs', + preserveModules: true, + preserveModulesRoot: './src' + } + : { + file: './lib/index.mjs', + plugins: [terser({ maxWorkers })] + }), + ...(sourcemap && { + sourcemap }) } ], - external: [ - 'node:async_hooks', - 'node:cluster', - 'node:crypto', - 'node:events', - 'node:fs', - 'node:os', - 'node:perf_hooks', - 'node:worker_threads' - ], + external: [/^node:*/], plugins: [ typescript({ - tsconfig: './tsconfig.build.json' + tsconfig: './tsconfig.build.json', + compilerOptions: { + sourceMap: sourcemap + } }), del({ targets: ['./lib/*'] @@ -85,14 +88,9 @@ export default defineConfig([ }, { input: './lib/dts/index.d.ts', + strictDeprecations: true, output: [{ format: 'esm', file: './lib/index.d.ts' }], - external: [ - 'node:async_hooks', - 'node:cluster', - 'node:events', - 'node:perf_hooks', - 'node:worker_threads' - ], + external: [/^node:*/], plugins: [ dts(), del({