|
| 1 | +/* eslint-disable @typescript-eslint/no-var-requires, import/no-extraneous-dependencies */ |
| 2 | + |
| 3 | +const esbuild = require('esbuild'); |
| 4 | +// Automatically exclude all node_modules from the bundled version |
| 5 | +const {nodeExternalsPlugin} = require('esbuild-node-externals'); |
| 6 | +const {readdirSync} = require('fs'); |
| 7 | +const path = require('path'); |
| 8 | + |
| 9 | +const rulesDirectory = path.join(__dirname, 'src', 'rules'); |
| 10 | +const bundle = true; |
| 11 | +const minify = true; |
| 12 | +const platform = 'node'; |
| 13 | +const sourcemap = true; |
| 14 | +const target = 'node14'; |
| 15 | +const plugins = [nodeExternalsPlugin()]; |
| 16 | + |
| 17 | +readdirSync(rulesDirectory).forEach((file) => { |
| 18 | + const ruleFilePath = path.join(rulesDirectory, file); |
| 19 | + const beginIndex = 0; |
| 20 | + const endIndex = -3; |
| 21 | + const ruleFileNameWithoutExtension = file.slice(beginIndex, endIndex); |
| 22 | + |
| 23 | + esbuild |
| 24 | + .build({ |
| 25 | + entryPoints: [ruleFilePath], |
| 26 | + outfile: `dist/rules/${ruleFileNameWithoutExtension}.js`, |
| 27 | + bundle, |
| 28 | + minify, |
| 29 | + platform, |
| 30 | + sourcemap: false, |
| 31 | + target, |
| 32 | + plugins, |
| 33 | + }) |
| 34 | + // eslint-disable-next-line unicorn/no-process-exit |
| 35 | + .catch(() => process.exit(1)); |
| 36 | +}); |
| 37 | + |
| 38 | +esbuild |
| 39 | + .build({ |
| 40 | + entryPoints: ['./src/api.ts'], |
| 41 | + outfile: 'dist/api.js', |
| 42 | + bundle, |
| 43 | + minify, |
| 44 | + platform, |
| 45 | + sourcemap, |
| 46 | + target, |
| 47 | + plugins, |
| 48 | + }) |
| 49 | + // eslint-disable-next-line unicorn/no-process-exit |
| 50 | + .catch(() => process.exit(1)); |
| 51 | + |
| 52 | +esbuild |
| 53 | + .build({ |
| 54 | + entryPoints: ['./src/cli.ts'], |
| 55 | + outfile: 'dist/cli.js', |
| 56 | + bundle, |
| 57 | + minify, |
| 58 | + platform, |
| 59 | + sourcemap, |
| 60 | + target, |
| 61 | + plugins, |
| 62 | + }) |
| 63 | + // eslint-disable-next-line unicorn/no-process-exit |
| 64 | + .catch(() => process.exit(1)); |
0 commit comments