mirror of
https://github.com/idanoo/GoScrobble.git
synced 2024-11-23 00:45:16 +00:00
114 lines
5.2 KiB
JavaScript
114 lines
5.2 KiB
JavaScript
|
"use strict";
|
||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||
|
var path = require("path");
|
||
|
var TryPath = require("./try-path");
|
||
|
var MappingEntry = require("./mapping-entry");
|
||
|
var Filesystem = require("./filesystem");
|
||
|
/**
|
||
|
* See the sync version for docs.
|
||
|
*/
|
||
|
function createMatchPathAsync(absoluteBaseUrl, paths, mainFields, addMatchAll) {
|
||
|
if (mainFields === void 0) { mainFields = ["main"]; }
|
||
|
if (addMatchAll === void 0) { addMatchAll = true; }
|
||
|
var absolutePaths = MappingEntry.getAbsoluteMappingEntries(absoluteBaseUrl, paths, addMatchAll);
|
||
|
return function (requestedModule, readJson, fileExists, extensions, callback) {
|
||
|
return matchFromAbsolutePathsAsync(absolutePaths, requestedModule, readJson, fileExists, extensions, callback, mainFields);
|
||
|
};
|
||
|
}
|
||
|
exports.createMatchPathAsync = createMatchPathAsync;
|
||
|
/**
|
||
|
* See the sync version for docs.
|
||
|
*/
|
||
|
function matchFromAbsolutePathsAsync(absolutePathMappings, requestedModule, readJson, fileExists, extensions, callback, mainFields) {
|
||
|
if (readJson === void 0) { readJson = Filesystem.readJsonFromDiskAsync; }
|
||
|
if (fileExists === void 0) { fileExists = Filesystem.fileExistsAsync; }
|
||
|
if (extensions === void 0) { extensions = Object.keys(require.extensions); }
|
||
|
if (mainFields === void 0) { mainFields = ["main"]; }
|
||
|
var tryPaths = TryPath.getPathsToTry(extensions, absolutePathMappings, requestedModule);
|
||
|
if (!tryPaths) {
|
||
|
return callback();
|
||
|
}
|
||
|
findFirstExistingPath(tryPaths, readJson, fileExists, callback, 0, mainFields);
|
||
|
}
|
||
|
exports.matchFromAbsolutePathsAsync = matchFromAbsolutePathsAsync;
|
||
|
function findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index) {
|
||
|
if (index === void 0) { index = 0; }
|
||
|
if (index >= mainFields.length) {
|
||
|
return doneCallback(undefined, undefined);
|
||
|
}
|
||
|
var tryNext = function () {
|
||
|
return findFirstExistingMainFieldMappedFile(packageJson, mainFields, packageJsonPath, fileExistsAsync, doneCallback, index + 1);
|
||
|
};
|
||
|
var mainFieldMapping = packageJson[mainFields[index]];
|
||
|
if (typeof mainFieldMapping !== "string") {
|
||
|
// Skip mappings that are not pointers to replacement files
|
||
|
return tryNext();
|
||
|
}
|
||
|
var mappedFilePath = path.join(path.dirname(packageJsonPath), mainFieldMapping);
|
||
|
fileExistsAsync(mappedFilePath, function (err, exists) {
|
||
|
if (err) {
|
||
|
return doneCallback(err);
|
||
|
}
|
||
|
if (exists) {
|
||
|
return doneCallback(undefined, mappedFilePath);
|
||
|
}
|
||
|
return tryNext();
|
||
|
});
|
||
|
}
|
||
|
// Recursive loop to probe for physical files
|
||
|
function findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index, mainFields) {
|
||
|
if (index === void 0) { index = 0; }
|
||
|
if (mainFields === void 0) { mainFields = ["main"]; }
|
||
|
var tryPath = tryPaths[index];
|
||
|
if (tryPath.type === "file" ||
|
||
|
tryPath.type === "extension" ||
|
||
|
tryPath.type === "index") {
|
||
|
fileExists(tryPath.path, function (err, exists) {
|
||
|
if (err) {
|
||
|
return doneCallback(err);
|
||
|
}
|
||
|
if (exists) {
|
||
|
// Not sure why we don't just return the full path? Why strip it?
|
||
|
return doneCallback(undefined, TryPath.getStrippedPath(tryPath));
|
||
|
}
|
||
|
if (index === tryPaths.length - 1) {
|
||
|
return doneCallback();
|
||
|
}
|
||
|
// Continue with the next path
|
||
|
return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
|
||
|
});
|
||
|
}
|
||
|
else if (tryPath.type === "package") {
|
||
|
readJson(tryPath.path, function (err, packageJson) {
|
||
|
if (err) {
|
||
|
return doneCallback(err);
|
||
|
}
|
||
|
if (packageJson) {
|
||
|
return findFirstExistingMainFieldMappedFile(packageJson, mainFields, tryPath.path, fileExists, function (mainFieldErr, mainFieldMappedFile) {
|
||
|
if (mainFieldErr) {
|
||
|
return doneCallback(mainFieldErr);
|
||
|
}
|
||
|
if (mainFieldMappedFile) {
|
||
|
// Not sure why we don't just return the full path? Why strip it?
|
||
|
return doneCallback(undefined, Filesystem.removeExtension(mainFieldMappedFile));
|
||
|
}
|
||
|
// No field in package json was a valid option. Continue with the next path.
|
||
|
return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
|
||
|
});
|
||
|
}
|
||
|
// This is async code, we need to return unconditionally, otherwise the code still falls
|
||
|
// through and keeps recursing. While this might work in general, libraries that use neo-async
|
||
|
// like Webpack will actually not allow you to call the same callback twice.
|
||
|
//
|
||
|
// An example of where this caused issues:
|
||
|
// https://github.com/dividab/tsconfig-paths-webpack-plugin/issues/11
|
||
|
//
|
||
|
// Continue with the next path
|
||
|
return findFirstExistingPath(tryPaths, readJson, fileExists, doneCallback, index + 1, mainFields);
|
||
|
});
|
||
|
}
|
||
|
else {
|
||
|
TryPath.exhaustiveTypeException(tryPath.type);
|
||
|
}
|
||
|
}
|