loader-runner
Version:
Runs (webpack) loaders
72 lines (60 loc) • 1.84 kB
JavaScript
;
const LoaderLoadingError = require("./LoaderLoadingError");
let url;
function handleResult(loader, module, callback) {
if (typeof module !== "function" && typeof module !== "object") {
return callback(
new LoaderLoadingError(
`Module '${loader.path}' is not a loader (export function or es6 module)`
)
);
}
loader.normal = typeof module === "function" ? module : module.default;
loader.pitch = module.pitch;
loader.raw = module.raw;
if (
typeof loader.normal !== "function" &&
typeof loader.pitch !== "function"
) {
return callback(
new LoaderLoadingError(
`Module '${loader.path}' is not a loader (must have normal or pitch function)`
)
);
}
callback();
}
function loadLoader(loader, callback) {
if (loader.type === "module") {
try {
if (url === undefined) url = require("url");
// eslint-disable-next-line n/no-unsupported-features/node-builtins
const loaderUrl = url.pathToFileURL(loader.path);
// Use `eval` so older parsers (and the main module resolver) don't
// need to recognize the dynamic `import()` syntax at load time.
// eslint-disable-next-line no-eval
const modulePromise = eval(
`import(${JSON.stringify(loaderUrl.toString())})`
);
modulePromise.then((module) => {
handleResult(loader, module, callback);
}, callback);
} catch (err) {
callback(err);
}
return;
}
let loadedModule;
try {
loadedModule = require(loader.path);
} catch (err) {
// It is possible for node to choke on a require if the FD descriptor
// limit has been reached. Give it a chance to recover by deferring.
if (err instanceof Error && err.code === "EMFILE") {
return setImmediate(loadLoader, loader, callback);
}
return callback(err);
}
return handleResult(loader, loadedModule, callback);
}
module.exports = loadLoader;