X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=rollup.config.mjs;h=763a3e3c2a03dc87220846390705a64c0ab8308d;hb=be202c2c43686b8d46d7061622e17b6c173c9e33;hp=29cc1f96e86610346dc42757afe07c73fae0b560;hpb=9b121f9c11621140deabb4e061d23d019fe01bb3;p=poolifier.git diff --git a/rollup.config.mjs b/rollup.config.mjs index 29cc1f96..763a3e3c 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -1,15 +1,18 @@ 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 try { + // eslint-disable-next-line n/no-unsupported-features/node-builtins availableParallelism = os.availableParallelism() } catch { const cpus = os.cpus() @@ -20,9 +23,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,47 +37,48 @@ export default defineConfig([ output: [ { format: 'cjs', - ...(isDevelopmentBuild && { - dir: './lib', - sourcemap: true, - preserveModules: true, - preserveModulesRoot: './src' - }), - ...(!isDevelopmentBuild && { - file: './lib/index.js', - 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', - preserveModules: true, - preserveModulesRoot: './src' - }), - ...(!isDevelopmentBuild && { - file: './lib/index.mjs', - 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: isDevelopmentBuild - ? './tsconfig.development.json' - : './tsconfig.production.json' + tsconfig: './tsconfig.build.json', + compilerOptions: { + sourceMap: sourcemap + } }), del({ targets: ['./lib/*'] @@ -84,14 +89,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({