-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.mts
65 lines (61 loc) · 1.51 KB
/
server.mts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import esbuild, { type Plugin } from "esbuild";
import { purgePolyfills } from "unplugin-purge-polyfills";
const production = process.argv.includes("--production");
const watch = process.argv.includes("--watch");
const esbuildProblemMatcherPlugin: Plugin = {
name: "esbuild-problem-matcher",
setup(build) {
build.onStart(() => {
console.log("[watch] build started");
});
build.onEnd((result) => {
for (const { text, location } of result.errors) {
console.error(`✘ [ERROR] ${text}`);
if (location)
console.error(
` ${location.file}:${location.line}:${location.column}:`,
);
}
console.log("[watch] build finished");
});
},
};
const ctx = await esbuild.context({
entryPoints: ["src/server.ts"],
bundle: true,
format: "cjs",
minify: production,
sourcemap: !production,
sourcesContent: false,
platform: "node",
target: "node18",
outfile: "out/server.js",
external: ["vscode"],
logLevel: "silent",
plugins: [
/* add to the end of plugins array */
esbuildProblemMatcherPlugin,
purgePolyfills.esbuild({
replacements: {
"fs.realpath": {
default: `require("node:fs")`,
},
// picocolors useless because we replace ANSI by regexp
// so... why don't replace it?
// TODO: more elegant replacer
picocolors: {
default: `{
bold: (s) => s,
yellow: (s) => s
}`,
},
},
}),
],
});
if (watch) {
await ctx.watch();
} else {
await ctx.rebuild();
await ctx.dispose();
}