forked from carolinfiedler/webgl-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpugconfig.js
67 lines (47 loc) · 1.74 KB
/
pugconfig.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
/**
* This custom script is used to build/copy example sources for distribution:
* - copy specific assets such as style sheets or scripts (either 3rd party or custom ones)
* - compile specific pug templates and render to dist path
*/
const watch = process.argv.indexOf('--watch') > 1;
const fs = require('fs');
const path = require('path');
const copy = require('./copy.js');
const pug = require('pug');
const websiteDir = './website';
const distDir = './build';
const examples = require(websiteDir + '/examples.json');
const assets = [
['./data', distDir + '/data', ['*'], [], false],
[websiteDir, distDir, ['css/*.css', 'js/*.js', 'img/*.{svg,png,jpg}', 'fonts/*', '*.{svg,png,ico,xml,json}'], [], false],
['./node_modules/webgl-operate/dist', distDir + '/js', ['webgl-operate.{js,js.map}'], [], true]];
function render(template, target, object) {
const src = path.join(websiteDir, template + '.pug');
const dst = path.join(distDir, target + '.html');
if (!fs.existsSync(src)) {
console.log('skipped:', target);
return;
}
const html = pug.renderFile(src, object);
fs.writeFileSync(dst, html);
console.log('emitted:', dst);
}
var build_pending = false;
function build() {
assets.forEach((asset) => copy(asset[0], asset[1], asset[2], asset[3], asset[4]));
render('index', 'index', { 'examples': examples });
examples.forEach((example) => {
render(example.target, example.target, { 'example': example });
});
build_pending = false;
}
build(); // trigger initial build
if (watch) {
fs.watch(websiteDir, { recursive: true }, function () {
if (build_pending) {
return;
}
build_pending = true;
setTimeout(build, 100);
});
}