inital commit

This commit is contained in:
2026-01-01 15:25:19 +05:30
commit f0ae49465a
36361 changed files with 4894111 additions and 0 deletions

View File

@@ -0,0 +1,269 @@
import path from 'path';
import { validateTurboNextConfig } from '../../lib/turbopack-warning';
import { formatIssue, getTurbopackJsConfig, isPersistentCachingEnabled, isRelevantWarning } from '../../shared/lib/turbopack/utils';
import { NextBuildContext } from '../build-context';
import { createDefineEnv, loadBindings } from '../swc';
import { Sema } from 'next/dist/compiled/async-sema';
import { handleEntrypoints, handlePagesErrorRoute, handleRouteType } from '../handle-entrypoints';
import { TurbopackManifestLoader } from '../../shared/lib/turbopack/manifest-loader';
import { createProgress } from '../progress';
import * as Log from '../output/log';
import { promises as fs } from 'fs';
import { PHASE_PRODUCTION_BUILD } from '../../shared/lib/constants';
import loadConfig from '../../server/config';
import { hasCustomExportOutput } from '../../export/utils';
import { Telemetry } from '../../telemetry/storage';
import { setGlobal } from '../../trace';
const IS_TURBOPACK_BUILD = process.env.TURBOPACK && process.env.TURBOPACK_BUILD;
export async function turbopackBuild() {
var _config_experimental, _config_experimental_turbo, _config_experimental1, _config_experimental_turbo1;
if (!IS_TURBOPACK_BUILD) {
throw Object.defineProperty(new Error("next build doesn't support turbopack yet"), "__NEXT_ERROR_CODE", {
value: "E122",
enumerable: false,
configurable: true
});
}
await validateTurboNextConfig({
dir: NextBuildContext.dir,
isDev: false
});
const config = NextBuildContext.config;
const dir = NextBuildContext.dir;
const distDir = NextBuildContext.distDir;
const buildId = NextBuildContext.buildId;
const encryptionKey = NextBuildContext.encryptionKey;
const previewProps = NextBuildContext.previewProps;
const hasRewrites = NextBuildContext.hasRewrites;
const rewrites = NextBuildContext.rewrites;
const appDirOnly = NextBuildContext.appDirOnly;
const noMangling = NextBuildContext.noMangling;
const startTime = process.hrtime();
const bindings = await loadBindings(config == null ? void 0 : (_config_experimental = config.experimental) == null ? void 0 : _config_experimental.useWasmBinary);
const dev = false;
// const supportedBrowsers = await getSupportedBrowsers(dir, dev)
const supportedBrowsers = [
'last 1 Chrome versions, last 1 Firefox versions, last 1 Safari versions, last 1 Edge versions'
];
const persistentCaching = isPersistentCachingEnabled(config);
const project = await bindings.turbo.createProject({
projectPath: dir,
rootPath: ((_config_experimental1 = config.experimental) == null ? void 0 : (_config_experimental_turbo = _config_experimental1.turbo) == null ? void 0 : _config_experimental_turbo.root) || config.outputFileTracingRoot || dir,
distDir,
nextConfig: config,
jsConfig: await getTurbopackJsConfig(dir, config),
watch: {
enable: false
},
dev,
env: process.env,
defineEnv: createDefineEnv({
isTurbopack: true,
clientRouterFilters: NextBuildContext.clientRouterFilters,
config,
dev,
distDir,
fetchCacheKeyPrefix: config.experimental.fetchCacheKeyPrefix,
hasRewrites,
// Implemented separately in Turbopack, doesn't have to be passed here.
middlewareMatchers: undefined
}),
buildId,
encryptionKey,
previewProps,
browserslistQuery: supportedBrowsers.join(', '),
noMangling
}, {
persistentCaching,
memoryLimit: (_config_experimental_turbo1 = config.experimental.turbo) == null ? void 0 : _config_experimental_turbo1.memoryLimit,
dependencyTracking: persistentCaching
});
await fs.mkdir(path.join(distDir, 'server'), {
recursive: true
});
await fs.mkdir(path.join(distDir, 'static', buildId), {
recursive: true
});
await fs.writeFile(path.join(distDir, 'package.json'), JSON.stringify({
type: 'commonjs'
}, null, 2));
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const entrypointsSubscription = project.entrypointsSubscribe();
const currentEntrypoints = {
global: {
app: undefined,
document: undefined,
error: undefined,
middleware: undefined,
instrumentation: undefined
},
app: new Map(),
page: new Map()
};
const currentEntryIssues = new Map();
const manifestLoader = new TurbopackManifestLoader({
buildId,
distDir,
encryptionKey
});
const entrypointsResult = await entrypointsSubscription.next();
if (entrypointsResult.done) {
throw Object.defineProperty(new Error('Turbopack did not return any entrypoints'), "__NEXT_ERROR_CODE", {
value: "E275",
enumerable: false,
configurable: true
});
}
entrypointsSubscription.return == null ? void 0 : entrypointsSubscription.return.call(entrypointsSubscription).catch(()=>{});
const entrypoints = entrypointsResult.value;
const topLevelErrors = [];
for (const issue of entrypoints.issues){
topLevelErrors.push({
message: formatIssue(issue)
});
}
if (topLevelErrors.length > 0) {
throw Object.defineProperty(new Error(`Turbopack build failed with ${topLevelErrors.length} issues:\n${topLevelErrors.map((e)=>e.message).join('\n')}`), "__NEXT_ERROR_CODE", {
value: "E33",
enumerable: false,
configurable: true
});
}
await handleEntrypoints({
entrypoints,
currentEntrypoints,
currentEntryIssues,
manifestLoader,
productionRewrites: rewrites,
logErrors: false
});
const progress = createProgress(currentEntrypoints.page.size + currentEntrypoints.app.size + 1, 'Building');
const promises = [];
// Concurrency will start at INITIAL_CONCURRENCY and
// slowly ramp up to CONCURRENCY by increasing the
// concurrency by 1 every time a task is completed.
const INITIAL_CONCURRENCY = 5;
const CONCURRENCY = 10;
const sema = new Sema(INITIAL_CONCURRENCY);
let remainingRampup = CONCURRENCY - INITIAL_CONCURRENCY;
const enqueue = (fn)=>{
promises.push((async ()=>{
await sema.acquire();
try {
await fn();
} finally{
sema.release();
if (remainingRampup > 0) {
remainingRampup--;
sema.release();
}
progress.run();
}
})());
};
if (!appDirOnly) {
for (const [page, route] of currentEntrypoints.page){
enqueue(()=>handleRouteType({
page,
route,
currentEntryIssues,
entrypoints: currentEntrypoints,
manifestLoader,
productionRewrites: rewrites,
logErrors: false
}));
}
}
for (const [page, route] of currentEntrypoints.app){
enqueue(()=>handleRouteType({
page,
route,
currentEntryIssues,
entrypoints: currentEntrypoints,
manifestLoader,
productionRewrites: rewrites,
logErrors: false
}));
}
enqueue(()=>handlePagesErrorRoute({
currentEntryIssues,
entrypoints: currentEntrypoints,
manifestLoader,
productionRewrites: rewrites,
logErrors: false
}));
await Promise.all(promises);
await manifestLoader.writeManifests({
devRewrites: undefined,
productionRewrites: rewrites,
entrypoints: currentEntrypoints
});
const errors = [];
const warnings = [];
for (const [page, entryIssues] of currentEntryIssues){
for (const issue of entryIssues.values()){
if (issue.severity !== 'warning') {
errors.push({
page,
message: formatIssue(issue)
});
} else {
if (isRelevantWarning(issue)) {
warnings.push({
page,
message: formatIssue(issue)
});
}
}
}
}
const shutdownPromise = project.shutdown();
if (warnings.length > 0) {
Log.warn(`Turbopack build collected ${warnings.length} warnings:\n${warnings.map((e)=>{
return 'Page: ' + e.page + '\n' + e.message;
}).join('\n')}`);
}
if (errors.length > 0) {
throw Object.defineProperty(new Error(`Turbopack build failed with ${errors.length} errors:\n${errors.map((e)=>{
return 'Page: ' + e.page + '\n' + e.message;
}).join('\n')}`), "__NEXT_ERROR_CODE", {
value: "E425",
enumerable: false,
configurable: true
});
}
const time = process.hrtime(startTime);
return {
duration: time[0] + time[1] / 1e9,
buildTraceContext: undefined,
shutdownPromise
};
}
let shutdownPromise;
export async function workerMain(workerData) {
// setup new build context from the serialized data passed from the parent
Object.assign(NextBuildContext, workerData.buildContext);
/// load the config because it's not serializable
NextBuildContext.config = await loadConfig(PHASE_PRODUCTION_BUILD, NextBuildContext.dir);
// Matches handling in build/index.ts
// https://github.com/vercel/next.js/blob/84f347fc86f4efc4ec9f13615c215e4b9fb6f8f0/packages/next/src/build/index.ts#L815-L818
// Ensures the `config.distDir` option is matched.
if (hasCustomExportOutput(NextBuildContext.config)) {
NextBuildContext.config.distDir = '.next';
}
// Clone the telemetry for worker
const telemetry = new Telemetry({
distDir: NextBuildContext.config.distDir
});
setGlobal('telemetry', telemetry);
const result = await turbopackBuild();
shutdownPromise = result.shutdownPromise;
return result;
}
export async function waitForShutdown() {
if (shutdownPromise) {
await shutdownPromise;
}
}
//# sourceMappingURL=impl.js.map

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,64 @@
import path from 'path';
import { formatNodeOptions, getParsedNodeOptionsWithoutInspect } from '../../server/lib/utils';
import { Worker } from '../../lib/worker';
import { NextBuildContext } from '../build-context';
async function turbopackBuildWithWorker() {
const nodeOptions = getParsedNodeOptionsWithoutInspect();
try {
const worker = new Worker(path.join(__dirname, 'impl.js'), {
exposedMethods: [
'workerMain',
'waitForShutdown'
],
numWorkers: 1,
maxRetries: 0,
forkOptions: {
env: {
...process.env,
NEXT_PRIVATE_BUILD_WORKER: '1',
NODE_OPTIONS: formatNodeOptions(nodeOptions)
}
}
});
const { nextBuildSpan, ...prunedBuildContext } = NextBuildContext;
const result = await worker.workerMain({
buildContext: prunedBuildContext
});
// destroy worker when Turbopack has shutdown so it's not sticking around using memory
// We need to wait for shutdown to make sure persistent cache is flushed
result.shutdownPromise = worker.waitForShutdown().then(()=>{
worker.end();
});
return result;
} catch (err) {
// When the error is a serialized `Error` object we need to recreate the `Error` instance
// in order to keep the consistent error reporting behavior.
if (err.type === 'Error') {
const error = Object.defineProperty(new Error(err.message), "__NEXT_ERROR_CODE", {
value: "E394",
enumerable: false,
configurable: true
});
if (err.name) {
error.name = err.name;
}
if (err.cause) {
error.cause = err.cause;
}
error.message = err.message;
error.stack = err.stack;
throw error;
}
throw err;
}
}
export function turbopackBuild(withWorker) {
if (withWorker) {
return turbopackBuildWithWorker();
} else {
const build = require('./impl').turbopackBuild;
return build();
}
}
//# sourceMappingURL=index.js.map

View File

@@ -0,0 +1 @@
{"version":3,"sources":["../../../src/build/turbopack-build/index.ts"],"sourcesContent":["import path from 'path'\nimport {\n formatNodeOptions,\n getParsedNodeOptionsWithoutInspect,\n} from '../../server/lib/utils'\nimport { Worker } from '../../lib/worker'\nimport { NextBuildContext } from '../build-context'\n\nasync function turbopackBuildWithWorker() {\n const nodeOptions = getParsedNodeOptionsWithoutInspect()\n\n try {\n const worker = new Worker(path.join(__dirname, 'impl.js'), {\n exposedMethods: ['workerMain', 'waitForShutdown'],\n numWorkers: 1,\n maxRetries: 0,\n forkOptions: {\n env: {\n ...process.env,\n NEXT_PRIVATE_BUILD_WORKER: '1',\n NODE_OPTIONS: formatNodeOptions(nodeOptions),\n },\n },\n }) as Worker & typeof import('./impl')\n const { nextBuildSpan, ...prunedBuildContext } = NextBuildContext\n const result = await worker.workerMain({\n buildContext: prunedBuildContext,\n })\n\n // destroy worker when Turbopack has shutdown so it's not sticking around using memory\n // We need to wait for shutdown to make sure persistent cache is flushed\n result.shutdownPromise = worker.waitForShutdown().then(() => {\n worker.end()\n })\n\n return result\n } catch (err: any) {\n // When the error is a serialized `Error` object we need to recreate the `Error` instance\n // in order to keep the consistent error reporting behavior.\n if (err.type === 'Error') {\n const error = new Error(err.message)\n if (err.name) {\n error.name = err.name\n }\n if (err.cause) {\n error.cause = err.cause\n }\n error.message = err.message\n error.stack = err.stack\n throw error\n }\n throw err\n }\n}\n\nexport function turbopackBuild(\n withWorker: boolean\n): ReturnType<typeof import('./impl').turbopackBuild> {\n if (withWorker) {\n return turbopackBuildWithWorker()\n } else {\n const build = (require('./impl') as typeof import('./impl')).turbopackBuild\n return build()\n }\n}\n"],"names":["path","formatNodeOptions","getParsedNodeOptionsWithoutInspect","Worker","NextBuildContext","turbopackBuildWithWorker","nodeOptions","worker","join","__dirname","exposedMethods","numWorkers","maxRetries","forkOptions","env","process","NEXT_PRIVATE_BUILD_WORKER","NODE_OPTIONS","nextBuildSpan","prunedBuildContext","result","workerMain","buildContext","shutdownPromise","waitForShutdown","then","end","err","type","error","Error","message","name","cause","stack","turbopackBuild","withWorker","build","require"],"mappings":"AAAA,OAAOA,UAAU,OAAM;AACvB,SACEC,iBAAiB,EACjBC,kCAAkC,QAC7B,yBAAwB;AAC/B,SAASC,MAAM,QAAQ,mBAAkB;AACzC,SAASC,gBAAgB,QAAQ,mBAAkB;AAEnD,eAAeC;IACb,MAAMC,cAAcJ;IAEpB,IAAI;QACF,MAAMK,SAAS,IAAIJ,OAAOH,KAAKQ,IAAI,CAACC,WAAW,YAAY;YACzDC,gBAAgB;gBAAC;gBAAc;aAAkB;YACjDC,YAAY;YACZC,YAAY;YACZC,aAAa;gBACXC,KAAK;oBACH,GAAGC,QAAQD,GAAG;oBACdE,2BAA2B;oBAC3BC,cAAchB,kBAAkBK;gBAClC;YACF;QACF;QACA,MAAM,EAAEY,aAAa,EAAE,GAAGC,oBAAoB,GAAGf;QACjD,MAAMgB,SAAS,MAAMb,OAAOc,UAAU,CAAC;YACrCC,cAAcH;QAChB;QAEA,sFAAsF;QACtF,wEAAwE;QACxEC,OAAOG,eAAe,GAAGhB,OAAOiB,eAAe,GAAGC,IAAI,CAAC;YACrDlB,OAAOmB,GAAG;QACZ;QAEA,OAAON;IACT,EAAE,OAAOO,KAAU;QACjB,yFAAyF;QACzF,4DAA4D;QAC5D,IAAIA,IAAIC,IAAI,KAAK,SAAS;YACxB,MAAMC,QAAQ,qBAAsB,CAAtB,IAAIC,MAAMH,IAAII,OAAO,GAArB,qBAAA;uBAAA;4BAAA;8BAAA;YAAqB;YACnC,IAAIJ,IAAIK,IAAI,EAAE;gBACZH,MAAMG,IAAI,GAAGL,IAAIK,IAAI;YACvB;YACA,IAAIL,IAAIM,KAAK,EAAE;gBACbJ,MAAMI,KAAK,GAAGN,IAAIM,KAAK;YACzB;YACAJ,MAAME,OAAO,GAAGJ,IAAII,OAAO;YAC3BF,MAAMK,KAAK,GAAGP,IAAIO,KAAK;YACvB,MAAML;QACR;QACA,MAAMF;IACR;AACF;AAEA,OAAO,SAASQ,eACdC,UAAmB;IAEnB,IAAIA,YAAY;QACd,OAAO/B;IACT,OAAO;QACL,MAAMgC,QAAQ,AAACC,QAAQ,UAAsCH,cAAc;QAC3E,OAAOE;IACT;AACF"}