next
Version:
The React Framework
120 lines (119 loc) • 5.34 kB
JavaScript
import * as Log from '../output/log';
import { NextBuildContext } from '../build-context';
import { Worker } from '../../lib/worker';
import origDebug from 'next/dist/compiled/debug';
import path from 'path';
import { exportTraceState, recordTraceEvents } from '../../trace';
import { formatNodeOptions, getParsedNodeOptionsWithoutInspect } from '../../server/lib/utils';
import { mergeUseCacheTrackers } from '../webpack/plugins/telemetry-plugin/use-cache-tracker-utils';
const debug = origDebug('next:build:webpack-build');
const ORDERED_COMPILER_NAMES = [
'server',
'edge-server',
'client'
];
let pluginState = {};
function deepMerge(target, source) {
const result = {
...target,
...source
};
for (const key of Object.keys(result)){
result[key] = Array.isArray(target[key]) ? target[key] = [
...target[key],
...source[key] || []
] : typeof target[key] == 'object' && typeof source[key] == 'object' ? deepMerge(target[key], source[key]) : result[key];
}
return result;
}
async function webpackBuildWithWorker(compilerNamesArg) {
const compilerNames = compilerNamesArg || ORDERED_COMPILER_NAMES;
const { nextBuildSpan, ...prunedBuildContext } = NextBuildContext;
prunedBuildContext.pluginState = pluginState;
const combinedResult = {
duration: 0,
buildTraceContext: {}
};
const nodeOptions = getParsedNodeOptionsWithoutInspect();
for (const compilerName of compilerNames){
var _curResult_buildTraceContext;
const worker = new Worker(path.join(__dirname, 'impl.js'), {
exposedMethods: [
'workerMain'
],
numWorkers: 1,
maxRetries: 0,
forkOptions: {
env: {
...process.env,
NEXT_PRIVATE_BUILD_WORKER: '1',
NODE_OPTIONS: formatNodeOptions(nodeOptions)
}
}
});
const curResult = await worker.workerMain({
buildContext: prunedBuildContext,
compilerName,
traceState: {
...exportTraceState(),
defaultParentSpanId: nextBuildSpan == null ? void 0 : nextBuildSpan.getId(),
shouldSaveTraceEvents: true
}
});
if (nextBuildSpan && curResult.debugTraceEvents) {
recordTraceEvents(curResult.debugTraceEvents);
}
// destroy worker so it's not sticking around using memory
await worker.end();
// Update plugin state
pluginState = deepMerge(pluginState, curResult.pluginState);
prunedBuildContext.pluginState = pluginState;
if (curResult.telemetryState) {
var _NextBuildContext_telemetryState;
NextBuildContext.telemetryState = {
...curResult.telemetryState,
useCacheTracker: mergeUseCacheTrackers((_NextBuildContext_telemetryState = NextBuildContext.telemetryState) == null ? void 0 : _NextBuildContext_telemetryState.useCacheTracker, curResult.telemetryState.useCacheTracker)
};
}
combinedResult.duration += curResult.duration;
if ((_curResult_buildTraceContext = curResult.buildTraceContext) == null ? void 0 : _curResult_buildTraceContext.entriesTrace) {
var _curResult_buildTraceContext1;
const { entryNameMap } = curResult.buildTraceContext.entriesTrace;
if (entryNameMap) {
combinedResult.buildTraceContext.entriesTrace = curResult.buildTraceContext.entriesTrace;
combinedResult.buildTraceContext.entriesTrace.entryNameMap = entryNameMap;
}
if ((_curResult_buildTraceContext1 = curResult.buildTraceContext) == null ? void 0 : _curResult_buildTraceContext1.chunksTrace) {
const { entryNameFilesMap } = curResult.buildTraceContext.chunksTrace;
if (entryNameFilesMap) {
combinedResult.buildTraceContext.chunksTrace = curResult.buildTraceContext.chunksTrace;
combinedResult.buildTraceContext.chunksTrace.entryNameFilesMap = entryNameFilesMap;
}
}
}
}
if (compilerNames.length === 3) {
Log.event('Compiled successfully');
}
return combinedResult;
}
export async function webpackBuild(withWorker, compilerNames) {
if (withWorker) {
debug('using separate compiler workers');
return await webpackBuildWithWorker(compilerNames);
} else {
debug('building all compilers in same process');
const webpackBuildImpl = require('./impl').webpackBuildImpl;
const curResult = await webpackBuildImpl(null, null);
// Mirror what happens in webpackBuildWithWorker
if (curResult.telemetryState) {
var _NextBuildContext_telemetryState;
NextBuildContext.telemetryState = {
...curResult.telemetryState,
useCacheTracker: mergeUseCacheTrackers((_NextBuildContext_telemetryState = NextBuildContext.telemetryState) == null ? void 0 : _NextBuildContext_telemetryState.useCacheTracker, curResult.telemetryState.useCacheTracker)
};
}
return curResult;
}
}
//# sourceMappingURL=index.js.map