104 lines
2.7 KiB
JavaScript
104 lines
2.7 KiB
JavaScript
|
"use strict";
|
||
|
|
||
|
exports.__esModule = true;
|
||
|
exports.resolve = resolve;
|
||
|
exports.has = has;
|
||
|
exports.logMissing = logMissing;
|
||
|
exports.laterLogMissing = laterLogMissing;
|
||
|
|
||
|
var _path = _interopRequireDefault(require("path"));
|
||
|
|
||
|
var _lodash = _interopRequireDefault(require("lodash.debounce"));
|
||
|
|
||
|
var _resolve = _interopRequireDefault(require("resolve"));
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
|
||
|
const nativeRequireResolve = parseFloat(process.versions.node) >= 8.9;
|
||
|
|
||
|
function resolve(dirname, moduleName, absoluteImports) {
|
||
|
if (absoluteImports === false) return moduleName;
|
||
|
let basedir = dirname;
|
||
|
|
||
|
if (typeof absoluteImports === "string") {
|
||
|
basedir = _path.default.resolve(basedir, absoluteImports);
|
||
|
}
|
||
|
|
||
|
let modulePackage, moduleNestedPath;
|
||
|
let slash = moduleName.indexOf("/");
|
||
|
|
||
|
if (moduleName[0] === "@") {
|
||
|
slash = moduleName.indexOf("/", slash + 1);
|
||
|
}
|
||
|
|
||
|
if (slash === -1) {
|
||
|
modulePackage = moduleName;
|
||
|
moduleNestedPath = "";
|
||
|
} else {
|
||
|
modulePackage = moduleName.slice(0, slash);
|
||
|
moduleNestedPath = moduleName.slice(slash);
|
||
|
}
|
||
|
|
||
|
try {
|
||
|
let pkg;
|
||
|
|
||
|
if (nativeRequireResolve) {
|
||
|
// $FlowIgnore
|
||
|
pkg = require.resolve(`${modulePackage}/package.json`, {
|
||
|
paths: [basedir]
|
||
|
});
|
||
|
} else {
|
||
|
pkg = _resolve.default.sync(`${modulePackage}/package.json`, {
|
||
|
basedir
|
||
|
});
|
||
|
}
|
||
|
|
||
|
return _path.default.dirname(pkg) + moduleNestedPath;
|
||
|
} catch (err) {
|
||
|
if (err.code !== "MODULE_NOT_FOUND") throw err; // $FlowIgnore
|
||
|
|
||
|
throw Object.assign(new Error(`Failed to resolve "${moduleName}" relative to "${dirname}"`), {
|
||
|
code: "BABEL_POLYFILL_NOT_FOUND",
|
||
|
polyfill: moduleName,
|
||
|
dirname
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function has(basedir, name) {
|
||
|
try {
|
||
|
if (nativeRequireResolve) {
|
||
|
// $FlowIgnore
|
||
|
require.resolve(name, {
|
||
|
paths: [basedir]
|
||
|
});
|
||
|
} else {
|
||
|
_resolve.default.sync(name, {
|
||
|
basedir
|
||
|
});
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
} catch (_unused) {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function logMissing(missingDeps) {
|
||
|
if (missingDeps.size === 0) return;
|
||
|
const deps = Array.from(missingDeps).sort().join(" ");
|
||
|
console.warn("\nSome polyfills have been added but are not present in your dependencies.\n" + "Please run one of the following commands:\n" + `\tnpm install --save ${deps}\n` + `\tyarn add ${deps}\n`);
|
||
|
process.exitCode = 1;
|
||
|
}
|
||
|
|
||
|
let allMissingDeps = new Set();
|
||
|
const laterLogMissingDependencies = (0, _lodash.default)(() => {
|
||
|
logMissing(allMissingDeps);
|
||
|
allMissingDeps = new Set();
|
||
|
}, 100);
|
||
|
|
||
|
function laterLogMissing(missingDeps) {
|
||
|
if (missingDeps.size === 0) return;
|
||
|
missingDeps.forEach(name => allMissingDeps.add(name));
|
||
|
laterLogMissingDependencies();
|
||
|
}
|