From 467820996f71b0c78f2000294cb6f3c0a8f3aca4 Mon Sep 17 00:00:00 2001 From: Drew Powers <1369770+drwpow@users.noreply.github.com> Date: Sat, 1 May 2021 10:09:23 -0600 Subject: [PATCH] Improve esbuild watch mode (#160) --- scripts/cmd/build.js | 87 +++++++++++++++++++++++++------------------- 1 file changed, 49 insertions(+), 38 deletions(-) diff --git a/scripts/cmd/build.js b/scripts/cmd/build.js index 5f7d6112dc..ea112f0189 100644 --- a/scripts/cmd/build.js +++ b/scripts/cmd/build.js @@ -1,54 +1,65 @@ import esbuild from 'esbuild'; import del from 'del'; import { promises as fs } from 'fs'; -import { resolve } from 'path'; +import { dim, green, red, yellow } from 'kleur/colors'; import glob from 'tiny-glob'; /** @type {import('esbuild').BuildOptions} */ const config = { - bundle: true, - minify: true, - sourcemap: 'inline', - format: 'esm', - platform: 'node', - target: 'node14' -} + bundle: true, + minify: true, + sourcemap: 'inline', + format: 'esm', + platform: 'node', + target: 'node14', +}; export default async function build(pattern, ...args) { - const isDev = args.pop() === 'IS_DEV'; - const entryPoints = await glob(pattern, { filesOnly: true, absolute: true }); - const { type = 'module', dependencies = {} } = await fs.readFile('./package.json').then(res => JSON.parse(res.toString())); - const format = type === 'module' ? 'esm' : 'cjs'; - const external = Object.keys(dependencies); - const outdir = 'dist'; - await clean(outdir); + const isDev = args.pop() === 'IS_DEV'; + const entryPoints = await glob(pattern, { filesOnly: true, absolute: true }); + const { type = 'module', dependencies = {} } = await fs.readFile('./package.json').then((res) => JSON.parse(res.toString())); + const format = type === 'module' ? 'esm' : 'cjs'; + const external = Object.keys(dependencies); + const outdir = 'dist'; + await clean(outdir); - if (!isDev) { - await esbuild.build({ - ...config, - entryPoints, - outdir, - external, - format - }); - return; - } - - const builder = await esbuild.build({ - ...config, - watch: true, - entryPoints, - outdir, - external, - format + if (!isDev) { + await esbuild.build({ + ...config, + entryPoints, + outdir, + external, + format, }); + return; + } - process.on('beforeExit', () => { - builder.stop?.(); - }) - + const builder = await esbuild.build({ + ...config, + watch: { + onRebuild(error, result) { + const date = new Date().toISOString(); + if (error || (result && result.errors.length)) { + console.error(dim(`[${date}] `) + red(error || result.errors.join('\n'))); + } else { + if (result.warnings.length) { + console.log(dim(`[${date}] `) + yellow('⚠ updated with warnings:\n' + result.warnings.join('\n'))); + } + console.log(dim(`[${date}] `) + green('✔ updated')); + } + }, + }, + entryPoints, + outdir, + external, + format, + }); + + process.on('beforeExit', () => { + builder.stop?.(); + }); } async function clean(outdir) { - return del(`!${outdir}/**/*.d.ts`); + return del(`!${outdir}/**/*.d.ts`); }