@parcel/core
Version:
245 lines (240 loc) • 9.98 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = applyRuntimes;
function _path() {
const data = _interopRequireDefault(require("path"));
_path = function () {
return data;
};
return data;
}
function _assert() {
const data = _interopRequireDefault(require("assert"));
_assert = function () {
return data;
};
return data;
}
function _nullthrows() {
const data = _interopRequireDefault(require("nullthrows"));
_nullthrows = function () {
return data;
};
return data;
}
var _AssetGraph = require("./AssetGraph");
var _BundleGraph = _interopRequireDefault(require("./public/BundleGraph"));
var _BundleGraph2 = _interopRequireWildcard(require("./BundleGraph"));
var _Bundle = require("./public/Bundle");
function _logger() {
const data = require("@parcel/logger");
_logger = function () {
return data;
};
return data;
}
function _rust() {
const data = require("@parcel/rust");
_rust = function () {
return data;
};
return data;
}
function _diagnostic() {
const data = _interopRequireWildcard(require("@parcel/diagnostic"));
_diagnostic = function () {
return data;
};
return data;
}
var _Dependency = require("./public/Dependency");
var _Environment = require("./Environment");
var _AssetGraphRequest = _interopRequireDefault(require("./requests/AssetGraphRequest"));
var _DevDepRequest = require("./requests/DevDepRequest");
var _projectPath = require("./projectPath");
function _profiler() {
const data = require("@parcel/profiler");
_profiler = function () {
return data;
};
return data;
}
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
async function applyRuntimes({
bundleGraph,
config,
options,
pluginOptions,
api,
optionsRef,
previousDevDeps,
devDepRequests,
configs
}) {
let runtimes = await config.getRuntimes();
let connections = [];
let bundles = bundleGraph.getBundles({
includeInline: true
});
let publicBundleGraph = new _BundleGraph.default(bundleGraph, _Bundle.NamedBundle.get.bind(_Bundle.NamedBundle), options);
for (let bundle of bundles) {
for (let runtime of runtimes) {
let measurement;
try {
var _configs$get;
const namedBundle = _Bundle.NamedBundle.get(bundle, bundleGraph, options);
measurement = _profiler().tracer.createMeasurement(runtime.name, 'applyRuntime', namedBundle.displayName);
let applied = await runtime.plugin.apply({
bundle: namedBundle,
bundleGraph: publicBundleGraph,
config: (_configs$get = configs.get(runtime.name)) === null || _configs$get === void 0 ? void 0 : _configs$get.result,
options: pluginOptions,
logger: new (_logger().PluginLogger)({
origin: runtime.name
}),
tracer: new (_profiler().PluginTracer)({
origin: runtime.name,
category: 'applyRuntime'
})
});
if (applied) {
let runtimeAssets = Array.isArray(applied) ? applied : [applied];
for (let {
code,
dependency,
filePath,
isEntry,
env,
shouldReplaceResolution
} of runtimeAssets) {
let sourceName = _path().default.join(_path().default.dirname(filePath), `runtime-${(0, _rust().hashString)(code)}${_path().default.extname(filePath)}`);
let assetGroup = {
code,
filePath: (0, _projectPath.toProjectPath)(options.projectRoot, sourceName),
env: (0, _Environment.mergeEnvironments)(options.projectRoot, bundle.env, env),
// Runtime assets should be considered source, as they should be
// e.g. compiled to run in the target environment
isSource: true
};
connections.push({
bundle,
assetGroup,
dependency,
isEntry,
shouldReplaceResolution
});
}
}
} catch (e) {
throw new (_diagnostic().default)({
diagnostic: (0, _diagnostic().errorToDiagnostic)(e, {
origin: runtime.name
})
});
} finally {
measurement && measurement.end();
}
}
}
// Add dev deps for runtime plugins AFTER running them, to account for lazy require().
for (let runtime of runtimes) {
let devDepRequest = await (0, _DevDepRequest.createDevDependency)({
specifier: runtime.name,
resolveFrom: runtime.resolveFrom
}, previousDevDeps, options);
devDepRequests.set(`${devDepRequest.specifier}:${(0, _projectPath.fromProjectPathRelative)(devDepRequest.resolveFrom)}`, devDepRequest);
await (0, _DevDepRequest.runDevDepRequest)(api, devDepRequest);
}
let {
assetGraph: runtimesAssetGraph,
changedAssets
} = await reconcileNewRuntimes(api, connections, optionsRef);
let runtimesGraph = _BundleGraph2.default.fromAssetGraph(runtimesAssetGraph, options.mode === 'production', bundleGraph._publicIdByAssetId, bundleGraph._assetPublicIds);
// Merge the runtimes graph into the main bundle graph.
bundleGraph.merge(runtimesGraph);
for (let [assetId, publicId] of runtimesGraph._publicIdByAssetId) {
bundleGraph._publicIdByAssetId.set(assetId, publicId);
bundleGraph._assetPublicIds.add(publicId);
}
for (let {
bundle,
assetGroup,
dependency,
isEntry,
shouldReplaceResolution
} of connections) {
let assetGroupNode = (0, _AssetGraph.nodeFromAssetGroup)(assetGroup);
let assetGroupAssetNodeIds = runtimesAssetGraph.getNodeIdsConnectedFrom(runtimesAssetGraph.getNodeIdByContentKey(assetGroupNode.id));
(0, _assert().default)(assetGroupAssetNodeIds.length === 1);
let runtimeNodeId = assetGroupAssetNodeIds[0];
let runtimeNode = (0, _nullthrows().default)(runtimesAssetGraph.getNode(runtimeNodeId));
(0, _assert().default)(runtimeNode.type === 'asset');
let resolution = dependency && bundleGraph.getResolvedAsset((0, _Dependency.dependencyToInternalDependency)(dependency), bundle);
let runtimesGraphRuntimeNodeId = runtimesGraph._graph.getNodeIdByContentKey(runtimeNode.id);
let duplicatedContentKeys = new Set();
runtimesGraph._graph.traverse((nodeId, _, actions) => {
let node = (0, _nullthrows().default)(runtimesGraph._graph.getNode(nodeId));
if (node.type !== 'dependency') {
return;
}
let assets = runtimesGraph._graph.getNodeIdsConnectedFrom(nodeId).map(assetNodeId => {
let assetNode = (0, _nullthrows().default)(runtimesGraph._graph.getNode(assetNodeId));
(0, _assert().default)(assetNode.type === 'asset');
return assetNode.value;
});
for (let asset of assets) {
if (bundleGraph.isAssetReachableFromBundle(asset, bundle) || (resolution === null || resolution === void 0 ? void 0 : resolution.id) === asset.id) {
duplicatedContentKeys.add(asset.id);
actions.skipChildren();
}
}
}, runtimesGraphRuntimeNodeId);
let bundleNodeId = bundleGraph._graph.getNodeIdByContentKey(bundle.id);
let bundleGraphRuntimeNodeId = bundleGraph._graph.getNodeIdByContentKey(runtimeNode.id); // the node id is not constant between graphs
runtimesGraph._graph.traverse((nodeId, _, actions) => {
let node = (0, _nullthrows().default)(runtimesGraph._graph.getNode(nodeId));
if (node.type === 'asset' || node.type === 'dependency') {
if (duplicatedContentKeys.has(node.id)) {
actions.skipChildren();
return;
}
const bundleGraphNodeId = bundleGraph._graph.getNodeIdByContentKey(node.id); // the node id is not constant between graphs
bundleGraph._graph.addEdge(bundleNodeId, bundleGraphNodeId, _BundleGraph2.bundleGraphEdgeTypes.contains);
}
}, runtimesGraphRuntimeNodeId);
if (isEntry) {
bundleGraph._graph.addEdge(bundleNodeId, bundleGraphRuntimeNodeId);
bundle.entryAssetIds.unshift(runtimeNode.id);
}
if (dependency == null) {
// Verify this asset won't become an island
(0, _assert().default)(bundleGraph._graph.getNodeIdsConnectedTo(bundleGraphRuntimeNodeId).length > 0, 'Runtime must have an inbound dependency or be an entry');
} else {
let dependencyNodeId = bundleGraph._graph.getNodeIdByContentKey(dependency.id);
bundleGraph._graph.addEdge(dependencyNodeId, bundleGraphRuntimeNodeId);
if (shouldReplaceResolution && resolution) {
let resolutionNodeId = bundleGraph._graph.getNodeIdByContentKey(resolution.id);
bundleGraph._graph.removeEdge(dependencyNodeId, resolutionNodeId);
bundleGraph._graph.addEdge(dependencyNodeId, resolutionNodeId);
// TODO: remove asset from bundle?
}
}
}
return changedAssets;
}
function reconcileNewRuntimes(api, connections, optionsRef) {
let assetGroups = connections.map(t => t.assetGroup);
let request = (0, _AssetGraphRequest.default)({
name: 'Runtimes',
assetGroups,
optionsRef
});
// rebuild the graph
return api.runRequest(request, {
force: true
});
}