236 lines
8.3 KiB
JavaScript
236 lines
8.3 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = _default;
|
|
function _slash() {
|
|
const data = require("slash");
|
|
_slash = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
function _path() {
|
|
const data = require("path");
|
|
_path = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
function _fs() {
|
|
const data = require("fs");
|
|
_fs = function () {
|
|
return data;
|
|
};
|
|
return data;
|
|
}
|
|
var util = require("./util.js");
|
|
var watcher = require("./watcher.js");
|
|
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
const FILE_TYPE = Object.freeze({
|
|
NON_COMPILABLE: "NON_COMPILABLE",
|
|
COMPILED: "COMPILED",
|
|
IGNORED: "IGNORED",
|
|
ERR_COMPILATION: "ERR_COMPILATION"
|
|
});
|
|
function outputFileSync(filePath, data) {
|
|
(((v, w) => (v = v.split("."), w = w.split("."), +v[0] > +w[0] || v[0] == w[0] && +v[1] >= +w[1]))(process.versions.node, "10.12") ? _fs().mkdirSync : require("make-dir").sync)(_path().dirname(filePath), {
|
|
recursive: true
|
|
});
|
|
_fs().writeFileSync(filePath, data);
|
|
}
|
|
function _default(_x) {
|
|
return _ref.apply(this, arguments);
|
|
}
|
|
function _ref() {
|
|
_ref = _asyncToGenerator(function* ({
|
|
cliOptions,
|
|
babelOptions
|
|
}) {
|
|
function write(_x2, _x3) {
|
|
return _write.apply(this, arguments);
|
|
}
|
|
function _write() {
|
|
_write = _asyncToGenerator(function* (src, base) {
|
|
let relative = _path().relative(base, src);
|
|
if (!util.isCompilableExtension(relative, cliOptions.extensions)) {
|
|
return FILE_TYPE.NON_COMPILABLE;
|
|
}
|
|
relative = util.withExtension(relative, cliOptions.keepFileExtension ? _path().extname(relative) : cliOptions.outFileExtension);
|
|
const dest = getDest(relative, base);
|
|
try {
|
|
const res = yield util.compile(src, Object.assign({}, babelOptions, {
|
|
sourceFileName: _slash()(_path().relative(dest + "/..", src))
|
|
}));
|
|
if (!res) return FILE_TYPE.IGNORED;
|
|
if (res.map) {
|
|
let outputMap = false;
|
|
if (babelOptions.sourceMaps && babelOptions.sourceMaps !== "inline") {
|
|
outputMap = "external";
|
|
} else if (babelOptions.sourceMaps == null) {
|
|
outputMap = util.hasDataSourcemap(res.code) ? "external" : "both";
|
|
}
|
|
if (outputMap) {
|
|
const mapLoc = dest + ".map";
|
|
if (outputMap === "external") {
|
|
res.code = util.addSourceMappingUrl(res.code, mapLoc);
|
|
}
|
|
res.map.file = _path().basename(relative);
|
|
outputFileSync(mapLoc, JSON.stringify(res.map));
|
|
}
|
|
}
|
|
outputFileSync(dest, res.code);
|
|
util.chmod(src, dest);
|
|
if (cliOptions.verbose) {
|
|
console.log(_path().relative(process.cwd(), src) + " -> " + dest);
|
|
}
|
|
return FILE_TYPE.COMPILED;
|
|
} catch (err) {
|
|
if (cliOptions.watch) {
|
|
console.error(err);
|
|
return FILE_TYPE.ERR_COMPILATION;
|
|
}
|
|
throw err;
|
|
}
|
|
});
|
|
return _write.apply(this, arguments);
|
|
}
|
|
function getDest(filename, base) {
|
|
if (cliOptions.relative) {
|
|
return _path().join(base, cliOptions.outDir, filename);
|
|
}
|
|
return _path().join(cliOptions.outDir, filename);
|
|
}
|
|
function handleFile(_x4, _x5) {
|
|
return _handleFile.apply(this, arguments);
|
|
}
|
|
function _handleFile() {
|
|
_handleFile = _asyncToGenerator(function* (src, base) {
|
|
const written = yield write(src, base);
|
|
if (cliOptions.copyFiles && written === FILE_TYPE.NON_COMPILABLE || cliOptions.copyIgnored && written === FILE_TYPE.IGNORED) {
|
|
const filename = _path().relative(base, src);
|
|
const dest = getDest(filename, base);
|
|
outputFileSync(dest, _fs().readFileSync(src));
|
|
util.chmod(src, dest);
|
|
}
|
|
return written === FILE_TYPE.COMPILED;
|
|
});
|
|
return _handleFile.apply(this, arguments);
|
|
}
|
|
function handle(_x6) {
|
|
return _handle.apply(this, arguments);
|
|
}
|
|
function _handle() {
|
|
_handle = _asyncToGenerator(function* (filenameOrDir) {
|
|
if (!_fs().existsSync(filenameOrDir)) return 0;
|
|
const stat = _fs().statSync(filenameOrDir);
|
|
if (stat.isDirectory()) {
|
|
const dirname = filenameOrDir;
|
|
let count = 0;
|
|
const files = util.readdir(dirname, cliOptions.includeDotfiles);
|
|
for (const filename of files) {
|
|
const written = yield handleFile(filename, dirname);
|
|
if (written) count += 1;
|
|
}
|
|
return count;
|
|
} else {
|
|
const filename = filenameOrDir;
|
|
const written = yield handleFile(filename, _path().dirname(filename));
|
|
return written ? 1 : 0;
|
|
}
|
|
});
|
|
return _handle.apply(this, arguments);
|
|
}
|
|
let compiledFiles = 0;
|
|
let startTime = null;
|
|
const logSuccess = util.debounce(function () {
|
|
if (startTime === null) {
|
|
return;
|
|
}
|
|
const diff = process.hrtime(startTime);
|
|
console.log(`Successfully compiled ${compiledFiles} ${compiledFiles !== 1 ? "files" : "file"} with Babel (${diff[0] * 1e3 + Math.round(diff[1] / 1e6)}ms).`);
|
|
compiledFiles = 0;
|
|
startTime = null;
|
|
}, 100);
|
|
if (cliOptions.watch) watcher.enable({
|
|
enableGlobbing: true
|
|
});
|
|
if (!cliOptions.skipInitialBuild) {
|
|
if (cliOptions.deleteDirOnStart) {
|
|
util.deleteDir(cliOptions.outDir);
|
|
}
|
|
(((v, w) => (v = v.split("."), w = w.split("."), +v[0] > +w[0] || v[0] == w[0] && +v[1] >= +w[1]))(process.versions.node, "10.12") ? _fs().mkdirSync : require("make-dir").sync)(cliOptions.outDir, {
|
|
recursive: true
|
|
});
|
|
startTime = process.hrtime();
|
|
for (const filename of cliOptions.filenames) {
|
|
compiledFiles += yield handle(filename);
|
|
}
|
|
if (!cliOptions.quiet) {
|
|
logSuccess();
|
|
logSuccess.flush();
|
|
}
|
|
}
|
|
if (cliOptions.watch) {
|
|
let processing = 0;
|
|
const {
|
|
filenames
|
|
} = cliOptions;
|
|
let getBase;
|
|
if (filenames.length === 1) {
|
|
const base = filenames[0];
|
|
const absoluteBase = _path().resolve(base);
|
|
getBase = filename => {
|
|
return filename === absoluteBase ? _path().dirname(base) : base;
|
|
};
|
|
} else {
|
|
const filenameToBaseMap = new Map(filenames.map(filename => {
|
|
const absoluteFilename = _path().resolve(filename);
|
|
return [absoluteFilename, _path().dirname(filename)];
|
|
}));
|
|
const absoluteFilenames = new Map(filenames.map(filename => {
|
|
const absoluteFilename = _path().resolve(filename);
|
|
return [absoluteFilename, filename];
|
|
}));
|
|
const {
|
|
sep
|
|
} = _path();
|
|
getBase = filename => {
|
|
const base = filenameToBaseMap.get(filename);
|
|
if (base !== undefined) {
|
|
return base;
|
|
}
|
|
for (const [absoluteFilenameOrDir, relative] of absoluteFilenames) {
|
|
if (filename.startsWith(absoluteFilenameOrDir + sep)) {
|
|
filenameToBaseMap.set(filename, relative);
|
|
return relative;
|
|
}
|
|
}
|
|
return "";
|
|
};
|
|
}
|
|
filenames.forEach(filenameOrDir => {
|
|
watcher.watch(filenameOrDir);
|
|
});
|
|
watcher.startWatcher();
|
|
watcher.onFilesChange(_asyncToGenerator(function* (filenames) {
|
|
processing++;
|
|
if (startTime === null) startTime = process.hrtime();
|
|
try {
|
|
const written = yield Promise.all(filenames.map(filename => handleFile(filename, getBase(filename))));
|
|
compiledFiles += written.filter(Boolean).length;
|
|
} catch (err) {
|
|
console.error(err);
|
|
}
|
|
processing--;
|
|
if (processing === 0 && !cliOptions.quiet) logSuccess();
|
|
}));
|
|
}
|
|
});
|
|
return _ref.apply(this, arguments);
|
|
}
|
|
|
|
//# sourceMappingURL=dir.js.map
|