Skip to content

Commit

Permalink
Fix issues with the new fork plugin (#11723)
Browse files Browse the repository at this point in the history
  • Loading branch information
gaearon authored Nov 30, 2017
1 parent e997756 commit 060581b
Showing 1 changed file with 31 additions and 7 deletions.
38 changes: 31 additions & 7 deletions scripts/rollup/plugins/use-forks-plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,39 +7,63 @@
'use strict';

const path = require('path');
const semver = require('semver');

function resolveRelatively(importee, importer) {
if (semver.gte(process.version, '8.9.0')) {
return require.resolve(importee, {
paths: [path.dirname(importer)],
});
} else {
// `paths` argument is not available in older Node.
// This works though.
// https://github.com/nodejs/node/issues/5963
const Module = require('module');
return Module._findPath(importee, [
path.dirname(importer),
...module.paths,
]);
}
}

let resolveCache = new Map();
function useForks(forks) {
let resolvedForks = {};
let resolvedForks = new Map();
Object.keys(forks).forEach(srcModule => {
const targetModule = forks[srcModule];
resolvedForks[require.resolve(srcModule)] = require.resolve(targetModule);
resolvedForks.set(
require.resolve(srcModule),
require.resolve(targetModule)
);
});
return {
resolveId(importee, importer) {
if (!importer || !importee) {
return null;
}
if (importee.startsWith('\u0000')) {
// Internal Rollup reference, ignore.
// Passing that to Node file functions can fatal.
return null;
}
let resolvedImportee = null;
let cacheKey = `${importer}:::${importee}`;
if (resolveCache.has(cacheKey)) {
// Avoid hitting file system if possible.
resolvedImportee = resolveCache.get(cacheKey);
} else {
try {
resolvedImportee = require.resolve(importee, {
paths: [path.dirname(importer)],
});
resolvedImportee = resolveRelatively(importee, importer);
} catch (err) {
// Not our fault, let Rollup fail later.
}
if (resolvedImportee) {
resolveCache.set(cacheKey, resolvedImportee);
}
}
if (resolvedImportee && resolvedForks.hasOwnProperty(resolvedImportee)) {
if (resolvedImportee && resolvedForks.has(resolvedImportee)) {
// We found a fork!
return resolvedForks[resolvedImportee];
return resolvedForks.get(resolvedImportee);
}
return null;
},
Expand Down

0 comments on commit 060581b

Please sign in to comment.