-
Notifications
You must be signed in to change notification settings - Fork 54
/
esbuild.mjs
111 lines (102 loc) · 3.02 KB
/
esbuild.mjs
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/* eslint-disable no-console */
import globby from 'globby'
import esbuild from 'esbuild'
import fse from 'fs-extra'
import minimist from 'minimist'
import { lessLoader } from 'esbuild-plugin-less'
import inlineImportPlugin from 'esbuild-plugin-inline-import'
const args = minimist(process.argv.slice(2))
const isWatch = args.watch || args.w
const isTest = args.test || args.t
const isProduction = args.production
// Following the log format of https://github.com/connor4312/esbuild-problem-matchers
const status = (msg) => console.log(`${isWatch ? '[watch] ' : ''}${msg}`)
const firstBuildFinished = new Set()
let buildStartTime
/** @type {import('esbuild').Plugin} */
const watchPlugin = (type) => ({
name: 'watcher',
setup(build) {
build.onStart(() => {
buildStartTime = Date.now()
status(`${type} build started.`)
})
build.onEnd((result) => {
result.errors.forEach((error) =>
console.error(
`> ${error.location.file}:${error.location.line}:${error.location.column}: error: ${error.text}`
)
)
firstBuildFinished.add(type)
status(`${type} build finished in ${Date.now() - buildStartTime} ms.`)
if (firstBuildFinished.size === 2) {
// esbuild problem matcher extension is listening for this log, once this is logged, it will open the Extension Host
// So we have to assure only printing this when both extension and webview have been built
status(`build finished in ${Date.now() - buildStartTime} ms.`)
}
})
}
})
const resultHandler = async (result) => {
result.metafile &&
console.log(
await esbuild.analyzeMetafile(result.metafile, {
verbose: true
})
)
}
const outdir = './dist'
// clean old built files
fse.rmdirSync(outdir, { recursive: true })
/** @type {import('esbuild').BuildOptions} */
const commonOptions = {
bundle: true,
sourcemap: isProduction ? false : 'inline',
watch: isWatch,
loader: {
'.js': 'jsx',
'.png': 'dataurl',
'.jpg': 'dataurl',
'.svg': 'dataurl',
'.woff': 'dataurl',
'.woff2': 'dataurl'
},
define: {
'process.env.NODE_ENV': isProduction ? '"production"' : '"development"'
},
minify: isProduction
// metafile: true
}
// build extension (node app)
esbuild
.build({
...commonOptions,
outdir,
entryPoints: isTest ? globby.sync('test/**/*.ts') : ['src/extension.ts'],
external: isTest
? ['vscode', 'mocha', 'istanbul', 'electron']
: ['vscode', 'electron'],
format: 'cjs',
platform: 'node',
mainFields: ['module', 'main'],
plugins: [watchPlugin('extension'), inlineImportPlugin()]
})
.then(resultHandler)
.catch(() => {
process.exit(1)
})
// build webview (web app)
esbuild
.build({
...commonOptions,
outdir: `${outdir}/webview`,
entryPoints: ['src/webview/pages/index.tsx'],
target: ['chrome58'],
format: 'esm',
plugins: [lessLoader(), watchPlugin('webview')]
// publicPath: 'https://www.example.com/v1',
})
.then(resultHandler)
.catch(() => {
process.exit(1)
})