/
index.js
91 lines (75 loc) · 1.97 KB
/
index.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
const babelCore = require("babel-core");
const through2 = require("through2");
const gutil = require("gulp-util");
const applySourceMap = require("vinyl-sourcemaps-apply");
const babiliPreset = require("babel-preset-babili");
const { PluginError } = gutil;
const NAME = "gulp-babili";
module.exports = gulpBabili;
function gulpBabili(babiliOpts = {}, {
babel = babelCore,
babili = babiliPreset,
comments = /preserve|licen(s|c)e/
} = {}) {
return through2.obj(function (file, enc, callback) {
if (file.isNull()) {
return callback(null, file);
}
if (file.isStream()) {
return callback(new PluginError(NAME, "Streaming not supported"));
}
let inputSourceMap;
if (file.sourceMap && file.sourceMap.mappings) {
inputSourceMap = file.sourceMap;
}
const babelOpts = {
minified: true,
babelrc: false,
ast: false,
/* preset */
presets: [ [ babili, babiliOpts ] ],
/* sourcemaps */
sourceMaps: !!file.sourceMap,
inputSourceMap,
shouldPrintComment(contents) {
return shouldPrintComment(contents, comments);
},
/* file */
filename: file.path,
filenameRelative: file.relative,
};
const { result, success, error } = transform({
babel,
input: file.contents.toString(),
babelOpts
});
if (success) {
file.contents = new Buffer(result.code);
if (file.sourceMap) {
applySourceMap(file, result.map);
}
return callback(null, file);
}
callback(error);
});
}
function transform({ babel, input, babelOpts }) {
try {
return {
success: true,
result: babel.transform(input, babelOpts)
};
} catch (e) {
return {
success: false,
error: e
};
}
}
function shouldPrintComment(contents, predicate) {
switch (typeof predicate) {
case "function": return predicate(contents);
case "object": return predicate.test(contents);
default: return !!predicate;
}
}