7f7e5ba5ea
Co-authored-by: Oliver King <oking3@uncc.edu>
197 lines
7.9 KiB
JavaScript
197 lines
7.9 KiB
JavaScript
"use strict";
|
|
var __assign = (this && this.__assign) || function () {
|
|
__assign = Object.assign || function(t) {
|
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
s = arguments[i];
|
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
t[p] = s[p];
|
|
}
|
|
return t;
|
|
};
|
|
return __assign.apply(this, arguments);
|
|
};
|
|
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
};
|
|
var __read = (this && this.__read) || function (o, n) {
|
|
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
if (!m) return o;
|
|
var i = m.call(o), r, ar = [], e;
|
|
try {
|
|
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
}
|
|
catch (error) { e = { error: error }; }
|
|
finally {
|
|
try {
|
|
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
}
|
|
finally { if (e) throw e.error; }
|
|
}
|
|
return ar;
|
|
};
|
|
var __spread = (this && this.__spread) || function () {
|
|
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
|
|
return ar;
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.__requireModule = exports.importer = exports.Importer = void 0;
|
|
var logger_1 = require("./logger");
|
|
var memoize_1 = require("./memoize");
|
|
var messages_1 = require("./messages");
|
|
var version_checkers_1 = require("./version-checkers");
|
|
var logger = logger_1.rootLogger.child({ namespace: 'Importer' });
|
|
var passThru = function (action) { return function (input) {
|
|
action();
|
|
return input;
|
|
}; };
|
|
var Importer = (function () {
|
|
function Importer(_patches) {
|
|
if (_patches === void 0) { _patches = {}; }
|
|
this._patches = _patches;
|
|
}
|
|
Object.defineProperty(Importer, "instance", {
|
|
get: function () {
|
|
logger.debug('creating Importer singleton');
|
|
return new Importer({
|
|
'@babel/core': [passThru(version_checkers_1.VersionCheckers.babelCore.warn)],
|
|
'babel-jest': [passThru(version_checkers_1.VersionCheckers.babelJest.warn)],
|
|
typescript: [passThru(version_checkers_1.VersionCheckers.typescript.warn)],
|
|
jest: [passThru(version_checkers_1.VersionCheckers.jest.warn)],
|
|
});
|
|
},
|
|
enumerable: false,
|
|
configurable: true
|
|
});
|
|
Importer.prototype.babelJest = function (why) {
|
|
return this._import(why, 'babel-jest');
|
|
};
|
|
Importer.prototype.babelCore = function (why) {
|
|
return this._import(why, '@babel/core');
|
|
};
|
|
Importer.prototype.typescript = function (why, which) {
|
|
return this._import(why, which);
|
|
};
|
|
Importer.prototype.tryThese = function (moduleName) {
|
|
var fallbacks = [];
|
|
for (var _i = 1; _i < arguments.length; _i++) {
|
|
fallbacks[_i - 1] = arguments[_i];
|
|
}
|
|
var name;
|
|
var loaded;
|
|
var tries = __spread([moduleName], fallbacks);
|
|
while ((name = tries.shift()) !== undefined) {
|
|
var req = requireWrapper(name);
|
|
var contextReq = __assign({}, req);
|
|
delete contextReq.exports;
|
|
if (req.exists) {
|
|
loaded = req;
|
|
if (loaded.error) {
|
|
logger.error({ requireResult: contextReq }, "failed loading module '" + name + "'", loaded.error.message);
|
|
}
|
|
else {
|
|
logger.debug({ requireResult: contextReq }, 'loaded module', name);
|
|
loaded.exports = this._patch(name, loaded.exports);
|
|
}
|
|
break;
|
|
}
|
|
else {
|
|
logger.debug({ requireResult: contextReq }, "module '" + name + "' not found");
|
|
continue;
|
|
}
|
|
}
|
|
return loaded;
|
|
};
|
|
Importer.prototype.tryTheseOr = function (moduleNames, missingResult, allowLoadError) {
|
|
if (allowLoadError === void 0) { allowLoadError = false; }
|
|
var args = Array.isArray(moduleNames) ? moduleNames : [moduleNames];
|
|
var result = this.tryThese.apply(this, __spread(args));
|
|
if (!result)
|
|
return missingResult;
|
|
if (!result.error)
|
|
return result.exports;
|
|
if (allowLoadError)
|
|
return missingResult;
|
|
throw result.error;
|
|
};
|
|
Importer.prototype._patch = function (name, unpatched) {
|
|
if (name in this._patches) {
|
|
logger.debug('patching', name);
|
|
return this._patches[name].reduce(function (mod, patcher) { return patcher(mod); }, unpatched);
|
|
}
|
|
return unpatched;
|
|
};
|
|
Importer.prototype._import = function (why, moduleName, _a) {
|
|
var _b = _a === void 0 ? {} : _a, _c = _b.alternatives, alternatives = _c === void 0 ? [] : _c, _d = _b.installTip, installTip = _d === void 0 ? moduleName : _d;
|
|
var res = this.tryThese.apply(this, __spread([moduleName], alternatives));
|
|
if (res && res.exists) {
|
|
if (!res.error)
|
|
return res.exports;
|
|
throw new Error(messages_1.interpolate("Loading module {{module}} failed with error: {{error}}", { module: res.given, error: res.error.message }));
|
|
}
|
|
var msg = alternatives.length ? "Unable to load any of these modules: {{module}}. {{reason}}. To fix it:\n{{fix}}" : "Unable to load the module {{module}}. {{reason}} To fix it:\n{{fix}}";
|
|
var loadModule = __spread([moduleName], alternatives).map(function (m) { return "\"" + m + "\""; }).join(', ');
|
|
if (typeof installTip === 'string') {
|
|
installTip = [{ module: installTip, label: "install \"" + installTip + "\"" }];
|
|
}
|
|
var fix = installTip
|
|
.map(function (tip) { return " " + (installTip.length === 1 ? '↳' : '•') + " " + messages_1.interpolate("{{label}}: `npm i -D {{module}}` (or `yarn add --dev {{module}}`)", tip); })
|
|
.join('\n');
|
|
throw new Error(messages_1.interpolate(msg, {
|
|
module: loadModule,
|
|
reason: why,
|
|
fix: fix,
|
|
}));
|
|
};
|
|
__decorate([
|
|
memoize_1.Memoize(function () {
|
|
var args = [];
|
|
for (var _i = 0; _i < arguments.length; _i++) {
|
|
args[_i] = arguments[_i];
|
|
}
|
|
return args.join(':');
|
|
})
|
|
], Importer.prototype, "tryThese", null);
|
|
__decorate([
|
|
memoize_1.Memoize(function (name) { return name; })
|
|
], Importer.prototype, "_patch", null);
|
|
__decorate([
|
|
memoize_1.Memoize()
|
|
], Importer, "instance", null);
|
|
return Importer;
|
|
}());
|
|
exports.Importer = Importer;
|
|
exports.importer = Importer.instance;
|
|
function requireWrapper(moduleName) {
|
|
var path;
|
|
var exists = false;
|
|
try {
|
|
path = resolveModule(moduleName);
|
|
exists = true;
|
|
}
|
|
catch (error) {
|
|
return { error: error, exists: exists, given: moduleName };
|
|
}
|
|
var result = { exists: exists, path: path, given: moduleName };
|
|
try {
|
|
result.exports = requireModule(path);
|
|
}
|
|
catch (error) {
|
|
try {
|
|
result.exports = requireModule(moduleName);
|
|
}
|
|
catch (error) {
|
|
result.error = error;
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
var requireModule = function (mod) { return require(mod); };
|
|
var resolveModule = function (mod) { return require.resolve(mod, { paths: [process.cwd(), __dirname] }); };
|
|
function __requireModule(localRequire, localResolve) {
|
|
requireModule = localRequire;
|
|
resolveModule = localResolve;
|
|
}
|
|
exports.__requireModule = __requireModule;
|