forked from mapbox/mapbox-gl-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
rollup.config.js
107 lines (97 loc) · 3.89 KB
/
rollup.config.js
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
/* eslint-disable flowtype/require-valid-file-annotation */
import fs from 'fs';
import path from 'path';
import {fileURLToPath} from 'url';
import {readFile} from 'node:fs/promises';
import {plugins} from './build/rollup_plugins.js';
import banner from './build/banner.js';
const {BUILD, MINIFY} = process.env;
const minified = MINIFY === 'true';
const bench = BUILD === 'bench';
const production = BUILD === 'production' || bench;
function buildType(build, minified) {
switch (build) {
case 'production':
if (minified) return 'dist/mapbox-gl.js';
return 'dist/mapbox-gl-unminified.js';
case 'bench':
return 'dist/mapbox-gl-bench.js';
case 'dev':
return 'dist/mapbox-gl-dev.js';
default:
return 'dist/mapbox-gl-dev.js';
}
}
const outputFile = buildType(BUILD, MINIFY);
export default ({watch}) => {
return [{
// First, use code splitting to bundle GL JS into three "chunks":
// - rollup/build/index.js: the main module, plus all its dependencies not shared by the worker module
// - rollup/build/worker.js: the worker module, plus all dependencies not shared by the main module
// - rollup/build/shared.js: the set of modules that are dependencies of both the main module and the worker module
//
// This is also where we do all of our source transformations: removing
// flow annotations, transpiling ES6 features using buble, inlining shader
// sources as strings, etc.
input: ['src/index.js', 'src/source/worker.js'],
output: {
dir: 'rollup/build/mapboxgl',
format: 'amd',
sourcemap: 'inline',
indent: false,
chunkFileNames: 'shared.js',
minifyInternalExports: production
},
onwarn: production ? onwarn : false,
treeshake: production,
plugins: plugins({minified, production, bench})
}, {
// Next, bundle together the three "chunks" produced in the previous pass
// into a single, final bundle. See rollup/bundle_prelude.js and
// rollup/mapboxgl.js for details.
input: 'rollup/mapboxgl.js',
output: {
name: 'mapboxgl',
file: outputFile,
format: 'umd',
sourcemap: production ? true : 'inline',
indent: false,
intro: fs.readFileSync(fileURLToPath(new URL('./rollup/bundle_prelude.js', import.meta.url)), 'utf8'),
banner
},
treeshake: false,
plugins: [
// Ingest the sourcemaps produced in the first step of the build.
// This is the only reason we use Rollup for this second pass
sourcemaps({watch}),
]
}];
};
function sourcemaps({watch}) {
const base64SourceMapRegExp = /\/\/# sourceMappingURL=data:[^,]+,([^ ]+)/;
return {
name: 'sourcemaps',
async load(id) {
const code = await readFile(id, {encoding: 'utf8'});
const match = base64SourceMapRegExp.exec(code);
if (!match) return;
const base64EncodedSourceMap = match[1];
const decodedSourceMap = Buffer.from(base64EncodedSourceMap, 'base64').toString('utf-8');
const map = JSON.parse(decodedSourceMap);
// Starting with Rollup 4.x, we need to explicitly watch files
// if their content is returned by the load hook.
// https://github.com/rollup/rollup/pull/5150
if (watch) this.addWatchFile(id);
return {code, map};
}
};
}
function onwarn(warning) {
const styleSpecPath = path.resolve('src', 'style-spec');
if (warning.code === 'CIRCULAR_DEPENDENCY') {
// Ignore circular dependencies in style-spec and throw on all others
if (!warning.ids[0].startsWith(styleSpecPath)) throw new Error(warning.message);
} else {
console.error(`(!) ${warning.message}`);
}
}