next 15.3.0-canary.5 → 15.3.0-canary.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/dist/bin/next +3 -2
  2. package/dist/bin/next.map +1 -1
  3. package/dist/build/collect-build-traces.js +1 -1
  4. package/dist/build/collect-build-traces.js.map +1 -1
  5. package/dist/build/index.d.ts +1 -1
  6. package/dist/build/index.js +24 -11
  7. package/dist/build/index.js.map +1 -1
  8. package/dist/build/swc/index.js +1 -1
  9. package/dist/build/webpack-config.js +2 -2
  10. package/dist/cli/next-build.d.ts +1 -1
  11. package/dist/cli/next-build.js.map +1 -1
  12. package/dist/client/app-bootstrap.js +1 -1
  13. package/dist/client/components/react-dev-overlay/ui/components/code-frame/code-frame.d.ts +1 -1
  14. package/dist/client/components/react-dev-overlay/ui/components/code-frame/code-frame.js +30 -36
  15. package/dist/client/components/react-dev-overlay/ui/components/code-frame/code-frame.js.map +1 -1
  16. package/dist/client/components/react-dev-overlay/ui/components/code-frame/parse-code-frame.d.ts +8 -0
  17. package/dist/client/components/react-dev-overlay/ui/components/code-frame/parse-code-frame.js +90 -0
  18. package/dist/client/components/react-dev-overlay/ui/components/code-frame/parse-code-frame.js.map +1 -0
  19. package/dist/client/components/react-dev-overlay/ui/container/runtime-error/component-stack-pseudo-html.d.ts +1 -1
  20. package/dist/client/components/react-dev-overlay/ui/container/runtime-error/component-stack-pseudo-html.js +1 -1
  21. package/dist/client/components/react-dev-overlay/ui/container/runtime-error/component-stack-pseudo-html.js.map +1 -1
  22. package/dist/client/components/react-dev-overlay/ui/container/runtime-error/index.d.ts +1 -1
  23. package/dist/client/index.js +1 -1
  24. package/dist/compiled/next-server/app-page-experimental.runtime.dev.js +3 -3
  25. package/dist/compiled/next-server/app-page-experimental.runtime.dev.js.map +1 -1
  26. package/dist/compiled/next-server/app-page.runtime.dev.js +3 -3
  27. package/dist/compiled/next-server/app-page.runtime.dev.js.map +1 -1
  28. package/dist/esm/build/collect-build-traces.js +1 -1
  29. package/dist/esm/build/collect-build-traces.js.map +1 -1
  30. package/dist/esm/build/index.js +24 -11
  31. package/dist/esm/build/index.js.map +1 -1
  32. package/dist/esm/build/swc/index.js +1 -1
  33. package/dist/esm/build/webpack-config.js +2 -2
  34. package/dist/esm/client/app-bootstrap.js +1 -1
  35. package/dist/esm/client/components/react-dev-overlay/ui/components/code-frame/code-frame.js +30 -35
  36. package/dist/esm/client/components/react-dev-overlay/ui/components/code-frame/code-frame.js.map +1 -1
  37. package/dist/esm/client/components/react-dev-overlay/ui/components/code-frame/parse-code-frame.js +58 -0
  38. package/dist/esm/client/components/react-dev-overlay/ui/components/code-frame/parse-code-frame.js.map +1 -0
  39. package/dist/esm/client/components/react-dev-overlay/ui/container/runtime-error/component-stack-pseudo-html.js +1 -1
  40. package/dist/esm/client/components/react-dev-overlay/ui/container/runtime-error/component-stack-pseudo-html.js.map +1 -1
  41. package/dist/esm/client/index.js +1 -1
  42. package/dist/esm/server/config-schema.js +0 -1
  43. package/dist/esm/server/config-schema.js.map +1 -1
  44. package/dist/esm/server/config-shared.js +0 -1
  45. package/dist/esm/server/config-shared.js.map +1 -1
  46. package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
  47. package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
  48. package/dist/esm/server/lib/app-info-log.js +1 -1
  49. package/dist/esm/server/lib/start-server.js +1 -1
  50. package/dist/esm/shared/lib/canary-only.js +1 -1
  51. package/dist/server/config-schema.js +0 -1
  52. package/dist/server/config-schema.js.map +1 -1
  53. package/dist/server/config-shared.d.ts +0 -1
  54. package/dist/server/config-shared.js +0 -1
  55. package/dist/server/config-shared.js.map +1 -1
  56. package/dist/server/dev/hot-reloader-turbopack.js +1 -1
  57. package/dist/server/dev/hot-reloader-webpack.js +1 -1
  58. package/dist/server/lib/app-info-log.js +1 -1
  59. package/dist/server/lib/start-server.js +1 -1
  60. package/dist/shared/lib/canary-only.js +1 -1
  61. package/dist/telemetry/anonymous-meta.js +1 -1
  62. package/dist/telemetry/events/session-stopped.js +2 -2
  63. package/dist/telemetry/events/version.js +2 -2
  64. package/package.json +15 -15
@@ -116,7 +116,7 @@ export async function collectBuildTraces({ dir, config, distDir, edgeRuntimeRout
116
116
  ...isStandalone ? [] : [
117
117
  '**/next/dist/compiled/jest-worker/**/*'
118
118
  ],
119
- '**/next/dist/compiled/webpack/(bundle4|bundle5).js',
119
+ '**/next/dist/compiled/webpack/*',
120
120
  '**/node_modules/webpack5/**/*',
121
121
  '**/next/dist/server/lib/route-resolver*',
122
122
  'next/dist/compiled/semver/semver/**/*.js',
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/build/collect-build-traces.ts"],"sourcesContent":["import { Span } from '../trace'\nimport type { NextConfigComplete } from '../server/config-shared'\n\nimport {\n TRACE_IGNORES,\n type BuildTraceContext,\n getFilesMapFromReasons,\n} from './webpack/plugins/next-trace-entrypoints-plugin'\n\nimport path from 'path'\nimport fs from 'fs/promises'\nimport { nonNullable } from '../lib/non-nullable'\nimport * as ciEnvironment from '../server/ci-info'\nimport debugOriginal from 'next/dist/compiled/debug'\nimport picomatch from 'next/dist/compiled/picomatch'\nimport { defaultOverrides } from '../server/require-hook'\nimport { nodeFileTrace } from 'next/dist/compiled/@vercel/nft'\nimport { normalizePagePath } from '../shared/lib/page-path/normalize-page-path'\nimport { normalizeAppPath } from '../shared/lib/router/utils/app-paths'\nimport isError from '../lib/is-error'\nimport type { NodeFileTraceReasons } from '@vercel/nft'\nimport type { RoutesUsingEdgeRuntime } from './utils'\n\nconst debug = debugOriginal('next:build:build-traces')\n\nfunction shouldIgnore(\n file: string,\n serverIgnoreFn: (file: string) => boolean,\n reasons: NodeFileTraceReasons,\n cachedIgnoreFiles: Map<string, boolean>,\n children: Set<string> = new Set()\n) {\n if (cachedIgnoreFiles.has(file)) {\n return cachedIgnoreFiles.get(file)\n }\n\n if (serverIgnoreFn(file)) {\n cachedIgnoreFiles.set(file, true)\n return true\n }\n children.add(file)\n\n const reason = reasons.get(file)\n if (!reason || reason.parents.size === 0 || reason.type.includes('initial')) {\n cachedIgnoreFiles.set(file, false)\n return false\n }\n\n // if all parents are ignored the child file\n // should be ignored as well\n let allParentsIgnored = true\n\n for (const parent of reason.parents.values()) {\n if (!children.has(parent)) {\n children.add(parent)\n if (\n !shouldIgnore(\n parent,\n serverIgnoreFn,\n reasons,\n cachedIgnoreFiles,\n children\n )\n ) {\n allParentsIgnored = false\n break\n }\n }\n }\n\n cachedIgnoreFiles.set(file, allParentsIgnored)\n return allParentsIgnored\n}\n\nexport async function collectBuildTraces({\n dir,\n config,\n distDir,\n edgeRuntimeRoutes,\n staticPages,\n nextBuildSpan = new Span({ name: 'build' }),\n hasSsrAmpPages,\n buildTraceContext,\n outputFileTracingRoot,\n}: {\n dir: string\n distDir: string\n staticPages: string[]\n hasSsrAmpPages: boolean\n outputFileTracingRoot: string\n // pageInfos is serialized when this function runs in a worker.\n edgeRuntimeRoutes: RoutesUsingEdgeRuntime\n nextBuildSpan?: Span\n config: NextConfigComplete\n buildTraceContext?: BuildTraceContext\n}) {\n const startTime = Date.now()\n debug('starting build traces')\n\n const { outputFileTracingIncludes = {}, outputFileTracingExcludes = {} } =\n config\n const excludeGlobKeys = Object.keys(outputFileTracingExcludes)\n const includeGlobKeys = Object.keys(outputFileTracingIncludes)\n\n await nextBuildSpan\n .traceChild('node-file-trace-build', {\n isTurbotrace: 'false', // TODO(arlyon): remove this\n })\n .traceAsyncFn(async () => {\n const nextServerTraceOutput = path.join(\n distDir,\n 'next-server.js.nft.json'\n )\n const nextMinimalTraceOutput = path.join(\n distDir,\n 'next-minimal-server.js.nft.json'\n )\n const root = outputFileTracingRoot\n\n // Under standalone mode, we need to trace the extra IPC server and\n // worker files.\n const isStandalone = config.output === 'standalone'\n const sharedEntriesSet = Object.keys(defaultOverrides).map((value) =>\n require.resolve(value, {\n paths: [require.resolve('next/dist/server/require-hook')],\n })\n )\n\n const { cacheHandler } = config\n const { cacheHandlers } = config.experimental\n\n // ensure we trace any dependencies needed for custom\n // incremental cache handler\n if (cacheHandler) {\n sharedEntriesSet.push(\n require.resolve(\n path.isAbsolute(cacheHandler)\n ? cacheHandler\n : path.join(dir, cacheHandler)\n )\n )\n }\n\n if (cacheHandlers) {\n for (const handlerPath of Object.values(cacheHandlers)) {\n if (handlerPath) {\n sharedEntriesSet.push(\n require.resolve(\n path.isAbsolute(handlerPath)\n ? handlerPath\n : path.join(dir, handlerPath)\n )\n )\n }\n }\n }\n\n const serverEntries = [\n ...sharedEntriesSet,\n ...(isStandalone\n ? [\n require.resolve('next/dist/server/lib/start-server'),\n require.resolve('next/dist/server/next'),\n require.resolve('next/dist/server/require-hook'),\n ]\n : []),\n require.resolve('next/dist/server/next-server'),\n ].filter(Boolean) as string[]\n\n const minimalServerEntries = [\n ...sharedEntriesSet,\n require.resolve('next/dist/compiled/next-server/server.runtime.prod'),\n ].filter(Boolean)\n\n const additionalIgnores = new Set<string>()\n\n for (const glob of excludeGlobKeys) {\n if (picomatch(glob)('next-server')) {\n outputFileTracingExcludes[glob].forEach((exclude) => {\n additionalIgnores.add(exclude)\n })\n }\n }\n\n const makeIgnoreFn = (ignores: string[]) => {\n // pre compile the ignore globs\n const isMatch = picomatch(ignores, {\n contains: true,\n dot: true,\n })\n\n return (pathname: string) => {\n if (path.isAbsolute(pathname) && !pathname.startsWith(root)) {\n return true\n }\n\n return isMatch(pathname)\n }\n }\n\n const sharedIgnores = [\n '**/next/dist/compiled/next-server/**/*.dev.js',\n ...(isStandalone ? [] : ['**/next/dist/compiled/jest-worker/**/*']),\n '**/next/dist/compiled/webpack/(bundle4|bundle5).js',\n '**/node_modules/webpack5/**/*',\n '**/next/dist/server/lib/route-resolver*',\n 'next/dist/compiled/semver/semver/**/*.js',\n\n ...(ciEnvironment.hasNextSupport\n ? [\n // only ignore image-optimizer code when\n // this is being handled outside of next-server\n '**/next/dist/server/image-optimizer.js',\n ]\n : []),\n\n ...(!hasSsrAmpPages\n ? ['**/next/dist/compiled/@ampproject/toolbox-optimizer/**/*']\n : []),\n\n ...(isStandalone ? [] : TRACE_IGNORES),\n ...additionalIgnores,\n ]\n\n const sharedIgnoresFn = makeIgnoreFn(sharedIgnores)\n\n const serverIgnores = [\n ...sharedIgnores,\n '**/node_modules/react{,-dom,-dom-server-turbopack}/**/*.development.js',\n '**/*.d.ts',\n '**/*.map',\n '**/next/dist/pages/**/*',\n ...(ciEnvironment.hasNextSupport\n ? ['**/node_modules/sharp/**/*', '**/@img/sharp-libvips*/**/*']\n : []),\n ].filter(nonNullable)\n const serverIgnoreFn = makeIgnoreFn(serverIgnores)\n\n const minimalServerIgnores = [\n ...serverIgnores,\n '**/next/dist/compiled/edge-runtime/**/*',\n '**/next/dist/server/web/sandbox/**/*',\n '**/next/dist/server/post-process.js',\n ]\n const minimalServerIgnoreFn = makeIgnoreFn(minimalServerIgnores)\n\n const routesIgnores = [\n ...sharedIgnores,\n // server chunks are provided via next-trace-entrypoints-plugin plugin\n // as otherwise all chunks are traced here and included for all pages\n // whether they are needed or not\n '**/.next/server/chunks/**',\n '**/next/dist/server/optimize-amp.js',\n '**/next/dist/server/post-process.js',\n ].filter(nonNullable)\n\n const routeIgnoreFn = makeIgnoreFn(routesIgnores)\n\n const serverTracedFiles = new Set<string>()\n const minimalServerTracedFiles = new Set<string>()\n\n function addToTracedFiles(base: string, file: string, dest: Set<string>) {\n dest.add(\n path.relative(distDir, path.join(base, file)).replace(/\\\\/g, '/')\n )\n }\n\n if (isStandalone) {\n addToTracedFiles(\n '',\n require.resolve('next/dist/compiled/jest-worker/processChild'),\n serverTracedFiles\n )\n addToTracedFiles(\n '',\n require.resolve('next/dist/compiled/jest-worker/threadChild'),\n serverTracedFiles\n )\n }\n\n {\n const chunksToTrace: string[] = [\n ...(buildTraceContext?.chunksTrace?.action.input || []),\n ...serverEntries,\n ...minimalServerEntries,\n ]\n const result = await nodeFileTrace(chunksToTrace, {\n base: outputFileTracingRoot,\n processCwd: dir,\n mixedModules: true,\n async readFile(p) {\n try {\n return await fs.readFile(p, 'utf8')\n } catch (e) {\n if (isError(e) && (e.code === 'ENOENT' || e.code === 'EISDIR')) {\n // since tracing runs in parallel with static generation server\n // files might be removed from that step so tolerate ENOENT\n // errors gracefully\n return ''\n }\n throw e\n }\n },\n async readlink(p) {\n try {\n return await fs.readlink(p)\n } catch (e) {\n if (\n isError(e) &&\n (e.code === 'EINVAL' ||\n e.code === 'ENOENT' ||\n e.code === 'UNKNOWN')\n ) {\n return null\n }\n throw e\n }\n },\n async stat(p) {\n try {\n return await fs.stat(p)\n } catch (e) {\n if (isError(e) && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) {\n return null\n }\n throw e\n }\n },\n // handle shared ignores at top-level as it\n // avoids over-tracing when we don't need to\n // and speeds up total trace time\n ignore(p) {\n if (sharedIgnoresFn(p)) {\n return true\n }\n\n // if a chunk is attempting to be traced that isn't\n // in our initial list we need to ignore it to prevent\n // over tracing as webpack needs to be the source of\n // truth for which chunks should be included for each entry\n if (\n p.includes('.next/server/chunks') &&\n !chunksToTrace.includes(path.join(outputFileTracingRoot, p))\n ) {\n return true\n }\n return false\n },\n })\n const reasons = result.reasons\n const fileList = result.fileList\n for (const file of result.esmFileList) {\n fileList.add(file)\n }\n\n const parentFilesMap = getFilesMapFromReasons(fileList, reasons)\n const cachedLookupIgnore = new Map<string, boolean>()\n const cachedLookupIgnoreMinimal = new Map<string, boolean>()\n\n for (const [entries, tracedFiles] of [\n [serverEntries, serverTracedFiles],\n [minimalServerEntries, minimalServerTracedFiles],\n ] as Array<[string[], Set<string>]>) {\n for (const file of entries) {\n const curFiles = [\n ...(parentFilesMap\n .get(path.relative(outputFileTracingRoot, file))\n ?.keys() || []),\n ]\n tracedFiles.add(path.relative(distDir, file).replace(/\\\\/g, '/'))\n\n for (const curFile of curFiles || []) {\n const filePath = path.join(outputFileTracingRoot, curFile)\n\n if (\n !shouldIgnore(\n curFile,\n tracedFiles === minimalServerTracedFiles\n ? minimalServerIgnoreFn\n : serverIgnoreFn,\n reasons,\n tracedFiles === minimalServerTracedFiles\n ? cachedLookupIgnoreMinimal\n : cachedLookupIgnore\n )\n ) {\n tracedFiles.add(\n path.relative(distDir, filePath).replace(/\\\\/g, '/')\n )\n }\n }\n }\n }\n\n const { entryNameFilesMap } = buildTraceContext?.chunksTrace || {}\n\n const cachedLookupIgnoreRoutes = new Map<string, boolean>()\n\n await Promise.all(\n [\n ...(entryNameFilesMap\n ? Object.entries(entryNameFilesMap)\n : new Map()),\n ].map(async ([entryName, entryNameFiles]) => {\n const isApp = entryName.startsWith('app/')\n const isPages = entryName.startsWith('pages/')\n let route = entryName\n if (isApp) {\n route = normalizeAppPath(route.substring('app'.length))\n }\n if (isPages) {\n route = normalizePagePath(route.substring('pages'.length))\n }\n\n // we don't need to trace for automatically statically optimized\n // pages as they don't have server bundles, note there is\n // the caveat with flying shuttle mode as it needs this for\n // detecting changed entries\n if (staticPages.includes(route)) {\n return\n }\n const entryOutputPath = path.join(\n distDir,\n 'server',\n `${entryName}.js`\n )\n const traceOutputPath = `${entryOutputPath}.nft.json`\n const existingTrace = JSON.parse(\n await fs.readFile(traceOutputPath, 'utf8')\n ) as {\n version: number\n files: string[]\n fileHashes: Record<string, string>\n }\n const traceOutputDir = path.dirname(traceOutputPath)\n const curTracedFiles = new Set<string>()\n\n for (const file of [...entryNameFiles, entryOutputPath]) {\n const curFiles = [\n ...(parentFilesMap\n .get(path.relative(outputFileTracingRoot, file))\n ?.keys() || []),\n ]\n for (const curFile of curFiles || []) {\n if (\n !shouldIgnore(\n curFile,\n routeIgnoreFn,\n reasons,\n cachedLookupIgnoreRoutes\n )\n ) {\n const filePath = path.join(outputFileTracingRoot, curFile)\n const outputFile = path\n .relative(traceOutputDir, filePath)\n .replace(/\\\\/g, '/')\n curTracedFiles.add(outputFile)\n }\n }\n }\n\n for (const file of existingTrace.files || []) {\n curTracedFiles.add(file)\n }\n\n await fs.writeFile(\n traceOutputPath,\n JSON.stringify({\n ...existingTrace,\n files: [...curTracedFiles].sort(),\n })\n )\n })\n )\n }\n\n const moduleTypes = ['app-page', 'pages']\n\n for (const type of moduleTypes) {\n const modulePath = require.resolve(\n `next/dist/server/route-modules/${type}/module.compiled`\n )\n const relativeModulePath = path.relative(root, modulePath)\n\n const contextDir = path.join(\n path.dirname(modulePath),\n 'vendored',\n 'contexts'\n )\n\n for (const item of await fs.readdir(contextDir)) {\n const itemPath = path.relative(root, path.join(contextDir, item))\n if (!serverIgnoreFn(itemPath)) {\n addToTracedFiles(root, itemPath, serverTracedFiles)\n addToTracedFiles(root, itemPath, minimalServerTracedFiles)\n }\n }\n addToTracedFiles(root, relativeModulePath, serverTracedFiles)\n addToTracedFiles(root, relativeModulePath, minimalServerTracedFiles)\n }\n\n await Promise.all([\n fs.writeFile(\n nextServerTraceOutput,\n JSON.stringify({\n version: 1,\n files: Array.from(serverTracedFiles),\n } as {\n version: number\n files: string[]\n })\n ),\n fs.writeFile(\n nextMinimalTraceOutput,\n JSON.stringify({\n version: 1,\n files: Array.from(minimalServerTracedFiles),\n } as {\n version: number\n files: string[]\n })\n ),\n ])\n })\n\n // apply outputFileTracingIncludes/outputFileTracingExcludes after runTurbotrace\n const includeExcludeSpan = nextBuildSpan.traceChild('apply-include-excludes')\n await includeExcludeSpan.traceAsyncFn(async () => {\n const globOrig =\n require('next/dist/compiled/glob') as typeof import('next/dist/compiled/glob')\n const glob = (pattern: string): Promise<string[]> => {\n return new Promise((resolve, reject) => {\n globOrig(\n pattern,\n { cwd: dir, nodir: true, dot: true },\n (err, files) => {\n if (err) {\n return reject(err)\n }\n resolve(files)\n }\n )\n })\n }\n\n const { entryNameFilesMap } = buildTraceContext?.chunksTrace || {}\n\n await Promise.all(\n [\n ...(entryNameFilesMap ? Object.entries(entryNameFilesMap) : new Map()),\n ].map(async ([entryName]) => {\n const isApp = entryName.startsWith('app/')\n const isPages = entryName.startsWith('pages/')\n let route = entryName\n if (isApp) {\n route = normalizeAppPath(entryName)\n }\n if (isPages) {\n route = normalizePagePath(entryName)\n }\n\n if (staticPages.includes(route)) {\n return\n }\n\n // edge routes have no trace files\n if (edgeRuntimeRoutes.hasOwnProperty(route)) {\n return\n }\n\n const combinedIncludes = new Set<string>()\n const combinedExcludes = new Set<string>()\n for (const curGlob of includeGlobKeys) {\n const isMatch = picomatch(curGlob, { dot: true, contains: true })\n if (isMatch(route)) {\n for (const include of outputFileTracingIncludes[curGlob]) {\n combinedIncludes.add(include.replace(/\\\\/g, '/'))\n }\n }\n }\n\n for (const curGlob of excludeGlobKeys) {\n const isMatch = picomatch(curGlob, { dot: true, contains: true })\n if (isMatch(route)) {\n for (const exclude of outputFileTracingExcludes[curGlob]) {\n combinedExcludes.add(exclude)\n }\n }\n }\n\n if (!combinedIncludes?.size && !combinedExcludes?.size) {\n return\n }\n\n const traceFile = path.join(\n distDir,\n `server`,\n `${entryName}.js.nft.json`\n )\n const pageDir = path.dirname(traceFile)\n const traceContent = JSON.parse(await fs.readFile(traceFile, 'utf8'))\n const includes: string[] = []\n const resolvedTraceIncludes = new Map<string, string[]>()\n\n if (combinedIncludes?.size) {\n await Promise.all(\n [...combinedIncludes].map(async (includeGlob) => {\n const results = await glob(includeGlob)\n const resolvedInclude = resolvedTraceIncludes.get(\n includeGlob\n ) || [\n ...results.map((file) => {\n return path.relative(pageDir, path.join(dir, file))\n }),\n ]\n includes.push(...resolvedInclude)\n resolvedTraceIncludes.set(includeGlob, resolvedInclude)\n })\n )\n }\n const combined = new Set([...traceContent.files, ...includes])\n\n if (combinedExcludes?.size) {\n const resolvedGlobs = [...combinedExcludes].map((exclude) =>\n path.join(dir, exclude)\n )\n\n // pre compile before forEach\n const isMatch = picomatch(resolvedGlobs, {\n dot: true,\n contains: true,\n })\n\n combined.forEach((file) => {\n if (isMatch(path.join(pageDir, file))) {\n combined.delete(file)\n }\n })\n }\n\n // overwrite trace file with custom includes/excludes\n await fs.writeFile(\n traceFile,\n JSON.stringify({\n version: traceContent.version,\n files: [...combined],\n })\n )\n })\n )\n })\n\n debug(`finished build tracing ${Date.now() - startTime}ms`)\n}\n"],"names":["Span","TRACE_IGNORES","getFilesMapFromReasons","path","fs","nonNullable","ciEnvironment","debugOriginal","picomatch","defaultOverrides","nodeFileTrace","normalizePagePath","normalizeAppPath","isError","debug","shouldIgnore","file","serverIgnoreFn","reasons","cachedIgnoreFiles","children","Set","has","get","set","add","reason","parents","size","type","includes","allParentsIgnored","parent","values","collectBuildTraces","dir","config","distDir","edgeRuntimeRoutes","staticPages","nextBuildSpan","name","hasSsrAmpPages","buildTraceContext","outputFileTracingRoot","startTime","Date","now","outputFileTracingIncludes","outputFileTracingExcludes","excludeGlobKeys","Object","keys","includeGlobKeys","traceChild","isTurbotrace","traceAsyncFn","nextServerTraceOutput","join","nextMinimalTraceOutput","root","isStandalone","output","sharedEntriesSet","map","value","require","resolve","paths","cacheHandler","cacheHandlers","experimental","push","isAbsolute","handlerPath","serverEntries","filter","Boolean","minimalServerEntries","additionalIgnores","glob","forEach","exclude","makeIgnoreFn","ignores","isMatch","contains","dot","pathname","startsWith","sharedIgnores","hasNextSupport","sharedIgnoresFn","serverIgnores","minimalServerIgnores","minimalServerIgnoreFn","routesIgnores","routeIgnoreFn","serverTracedFiles","minimalServerTracedFiles","addToTracedFiles","base","dest","relative","replace","chunksToTrace","chunksTrace","action","input","result","processCwd","mixedModules","readFile","p","e","code","readlink","stat","ignore","fileList","esmFileList","parentFilesMap","cachedLookupIgnore","Map","cachedLookupIgnoreMinimal","entries","tracedFiles","curFiles","curFile","filePath","entryNameFilesMap","cachedLookupIgnoreRoutes","Promise","all","entryName","entryNameFiles","isApp","isPages","route","substring","length","entryOutputPath","traceOutputPath","existingTrace","JSON","parse","traceOutputDir","dirname","curTracedFiles","outputFile","files","writeFile","stringify","sort","moduleTypes","modulePath","relativeModulePath","contextDir","item","readdir","itemPath","version","Array","from","includeExcludeSpan","globOrig","pattern","reject","cwd","nodir","err","hasOwnProperty","combinedIncludes","combinedExcludes","curGlob","include","traceFile","pageDir","traceContent","resolvedTraceIncludes","includeGlob","results","resolvedInclude","combined","resolvedGlobs","delete"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/build/collect-build-traces.ts"],"sourcesContent":["import { Span } from '../trace'\nimport type { NextConfigComplete } from '../server/config-shared'\n\nimport {\n TRACE_IGNORES,\n type BuildTraceContext,\n getFilesMapFromReasons,\n} from './webpack/plugins/next-trace-entrypoints-plugin'\n\nimport path from 'path'\nimport fs from 'fs/promises'\nimport { nonNullable } from '../lib/non-nullable'\nimport * as ciEnvironment from '../server/ci-info'\nimport debugOriginal from 'next/dist/compiled/debug'\nimport picomatch from 'next/dist/compiled/picomatch'\nimport { defaultOverrides } from '../server/require-hook'\nimport { nodeFileTrace } from 'next/dist/compiled/@vercel/nft'\nimport { normalizePagePath } from '../shared/lib/page-path/normalize-page-path'\nimport { normalizeAppPath } from '../shared/lib/router/utils/app-paths'\nimport isError from '../lib/is-error'\nimport type { NodeFileTraceReasons } from '@vercel/nft'\nimport type { RoutesUsingEdgeRuntime } from './utils'\n\nconst debug = debugOriginal('next:build:build-traces')\n\nfunction shouldIgnore(\n file: string,\n serverIgnoreFn: (file: string) => boolean,\n reasons: NodeFileTraceReasons,\n cachedIgnoreFiles: Map<string, boolean>,\n children: Set<string> = new Set()\n) {\n if (cachedIgnoreFiles.has(file)) {\n return cachedIgnoreFiles.get(file)\n }\n\n if (serverIgnoreFn(file)) {\n cachedIgnoreFiles.set(file, true)\n return true\n }\n children.add(file)\n\n const reason = reasons.get(file)\n if (!reason || reason.parents.size === 0 || reason.type.includes('initial')) {\n cachedIgnoreFiles.set(file, false)\n return false\n }\n\n // if all parents are ignored the child file\n // should be ignored as well\n let allParentsIgnored = true\n\n for (const parent of reason.parents.values()) {\n if (!children.has(parent)) {\n children.add(parent)\n if (\n !shouldIgnore(\n parent,\n serverIgnoreFn,\n reasons,\n cachedIgnoreFiles,\n children\n )\n ) {\n allParentsIgnored = false\n break\n }\n }\n }\n\n cachedIgnoreFiles.set(file, allParentsIgnored)\n return allParentsIgnored\n}\n\nexport async function collectBuildTraces({\n dir,\n config,\n distDir,\n edgeRuntimeRoutes,\n staticPages,\n nextBuildSpan = new Span({ name: 'build' }),\n hasSsrAmpPages,\n buildTraceContext,\n outputFileTracingRoot,\n}: {\n dir: string\n distDir: string\n staticPages: string[]\n hasSsrAmpPages: boolean\n outputFileTracingRoot: string\n // pageInfos is serialized when this function runs in a worker.\n edgeRuntimeRoutes: RoutesUsingEdgeRuntime\n nextBuildSpan?: Span\n config: NextConfigComplete\n buildTraceContext?: BuildTraceContext\n}) {\n const startTime = Date.now()\n debug('starting build traces')\n\n const { outputFileTracingIncludes = {}, outputFileTracingExcludes = {} } =\n config\n const excludeGlobKeys = Object.keys(outputFileTracingExcludes)\n const includeGlobKeys = Object.keys(outputFileTracingIncludes)\n\n await nextBuildSpan\n .traceChild('node-file-trace-build', {\n isTurbotrace: 'false', // TODO(arlyon): remove this\n })\n .traceAsyncFn(async () => {\n const nextServerTraceOutput = path.join(\n distDir,\n 'next-server.js.nft.json'\n )\n const nextMinimalTraceOutput = path.join(\n distDir,\n 'next-minimal-server.js.nft.json'\n )\n const root = outputFileTracingRoot\n\n // Under standalone mode, we need to trace the extra IPC server and\n // worker files.\n const isStandalone = config.output === 'standalone'\n const sharedEntriesSet = Object.keys(defaultOverrides).map((value) =>\n require.resolve(value, {\n paths: [require.resolve('next/dist/server/require-hook')],\n })\n )\n\n const { cacheHandler } = config\n const { cacheHandlers } = config.experimental\n\n // ensure we trace any dependencies needed for custom\n // incremental cache handler\n if (cacheHandler) {\n sharedEntriesSet.push(\n require.resolve(\n path.isAbsolute(cacheHandler)\n ? cacheHandler\n : path.join(dir, cacheHandler)\n )\n )\n }\n\n if (cacheHandlers) {\n for (const handlerPath of Object.values(cacheHandlers)) {\n if (handlerPath) {\n sharedEntriesSet.push(\n require.resolve(\n path.isAbsolute(handlerPath)\n ? handlerPath\n : path.join(dir, handlerPath)\n )\n )\n }\n }\n }\n\n const serverEntries = [\n ...sharedEntriesSet,\n ...(isStandalone\n ? [\n require.resolve('next/dist/server/lib/start-server'),\n require.resolve('next/dist/server/next'),\n require.resolve('next/dist/server/require-hook'),\n ]\n : []),\n require.resolve('next/dist/server/next-server'),\n ].filter(Boolean) as string[]\n\n const minimalServerEntries = [\n ...sharedEntriesSet,\n require.resolve('next/dist/compiled/next-server/server.runtime.prod'),\n ].filter(Boolean)\n\n const additionalIgnores = new Set<string>()\n\n for (const glob of excludeGlobKeys) {\n if (picomatch(glob)('next-server')) {\n outputFileTracingExcludes[glob].forEach((exclude) => {\n additionalIgnores.add(exclude)\n })\n }\n }\n\n const makeIgnoreFn = (ignores: string[]) => {\n // pre compile the ignore globs\n const isMatch = picomatch(ignores, {\n contains: true,\n dot: true,\n })\n\n return (pathname: string) => {\n if (path.isAbsolute(pathname) && !pathname.startsWith(root)) {\n return true\n }\n\n return isMatch(pathname)\n }\n }\n\n const sharedIgnores = [\n '**/next/dist/compiled/next-server/**/*.dev.js',\n ...(isStandalone ? [] : ['**/next/dist/compiled/jest-worker/**/*']),\n '**/next/dist/compiled/webpack/*',\n '**/node_modules/webpack5/**/*',\n '**/next/dist/server/lib/route-resolver*',\n 'next/dist/compiled/semver/semver/**/*.js',\n\n ...(ciEnvironment.hasNextSupport\n ? [\n // only ignore image-optimizer code when\n // this is being handled outside of next-server\n '**/next/dist/server/image-optimizer.js',\n ]\n : []),\n\n ...(!hasSsrAmpPages\n ? ['**/next/dist/compiled/@ampproject/toolbox-optimizer/**/*']\n : []),\n\n ...(isStandalone ? [] : TRACE_IGNORES),\n ...additionalIgnores,\n ]\n\n const sharedIgnoresFn = makeIgnoreFn(sharedIgnores)\n\n const serverIgnores = [\n ...sharedIgnores,\n '**/node_modules/react{,-dom,-dom-server-turbopack}/**/*.development.js',\n '**/*.d.ts',\n '**/*.map',\n '**/next/dist/pages/**/*',\n ...(ciEnvironment.hasNextSupport\n ? ['**/node_modules/sharp/**/*', '**/@img/sharp-libvips*/**/*']\n : []),\n ].filter(nonNullable)\n const serverIgnoreFn = makeIgnoreFn(serverIgnores)\n\n const minimalServerIgnores = [\n ...serverIgnores,\n '**/next/dist/compiled/edge-runtime/**/*',\n '**/next/dist/server/web/sandbox/**/*',\n '**/next/dist/server/post-process.js',\n ]\n const minimalServerIgnoreFn = makeIgnoreFn(minimalServerIgnores)\n\n const routesIgnores = [\n ...sharedIgnores,\n // server chunks are provided via next-trace-entrypoints-plugin plugin\n // as otherwise all chunks are traced here and included for all pages\n // whether they are needed or not\n '**/.next/server/chunks/**',\n '**/next/dist/server/optimize-amp.js',\n '**/next/dist/server/post-process.js',\n ].filter(nonNullable)\n\n const routeIgnoreFn = makeIgnoreFn(routesIgnores)\n\n const serverTracedFiles = new Set<string>()\n const minimalServerTracedFiles = new Set<string>()\n\n function addToTracedFiles(base: string, file: string, dest: Set<string>) {\n dest.add(\n path.relative(distDir, path.join(base, file)).replace(/\\\\/g, '/')\n )\n }\n\n if (isStandalone) {\n addToTracedFiles(\n '',\n require.resolve('next/dist/compiled/jest-worker/processChild'),\n serverTracedFiles\n )\n addToTracedFiles(\n '',\n require.resolve('next/dist/compiled/jest-worker/threadChild'),\n serverTracedFiles\n )\n }\n\n {\n const chunksToTrace: string[] = [\n ...(buildTraceContext?.chunksTrace?.action.input || []),\n ...serverEntries,\n ...minimalServerEntries,\n ]\n const result = await nodeFileTrace(chunksToTrace, {\n base: outputFileTracingRoot,\n processCwd: dir,\n mixedModules: true,\n async readFile(p) {\n try {\n return await fs.readFile(p, 'utf8')\n } catch (e) {\n if (isError(e) && (e.code === 'ENOENT' || e.code === 'EISDIR')) {\n // since tracing runs in parallel with static generation server\n // files might be removed from that step so tolerate ENOENT\n // errors gracefully\n return ''\n }\n throw e\n }\n },\n async readlink(p) {\n try {\n return await fs.readlink(p)\n } catch (e) {\n if (\n isError(e) &&\n (e.code === 'EINVAL' ||\n e.code === 'ENOENT' ||\n e.code === 'UNKNOWN')\n ) {\n return null\n }\n throw e\n }\n },\n async stat(p) {\n try {\n return await fs.stat(p)\n } catch (e) {\n if (isError(e) && (e.code === 'ENOENT' || e.code === 'ENOTDIR')) {\n return null\n }\n throw e\n }\n },\n // handle shared ignores at top-level as it\n // avoids over-tracing when we don't need to\n // and speeds up total trace time\n ignore(p) {\n if (sharedIgnoresFn(p)) {\n return true\n }\n\n // if a chunk is attempting to be traced that isn't\n // in our initial list we need to ignore it to prevent\n // over tracing as webpack needs to be the source of\n // truth for which chunks should be included for each entry\n if (\n p.includes('.next/server/chunks') &&\n !chunksToTrace.includes(path.join(outputFileTracingRoot, p))\n ) {\n return true\n }\n return false\n },\n })\n const reasons = result.reasons\n const fileList = result.fileList\n for (const file of result.esmFileList) {\n fileList.add(file)\n }\n\n const parentFilesMap = getFilesMapFromReasons(fileList, reasons)\n const cachedLookupIgnore = new Map<string, boolean>()\n const cachedLookupIgnoreMinimal = new Map<string, boolean>()\n\n for (const [entries, tracedFiles] of [\n [serverEntries, serverTracedFiles],\n [minimalServerEntries, minimalServerTracedFiles],\n ] as Array<[string[], Set<string>]>) {\n for (const file of entries) {\n const curFiles = [\n ...(parentFilesMap\n .get(path.relative(outputFileTracingRoot, file))\n ?.keys() || []),\n ]\n tracedFiles.add(path.relative(distDir, file).replace(/\\\\/g, '/'))\n\n for (const curFile of curFiles || []) {\n const filePath = path.join(outputFileTracingRoot, curFile)\n\n if (\n !shouldIgnore(\n curFile,\n tracedFiles === minimalServerTracedFiles\n ? minimalServerIgnoreFn\n : serverIgnoreFn,\n reasons,\n tracedFiles === minimalServerTracedFiles\n ? cachedLookupIgnoreMinimal\n : cachedLookupIgnore\n )\n ) {\n tracedFiles.add(\n path.relative(distDir, filePath).replace(/\\\\/g, '/')\n )\n }\n }\n }\n }\n\n const { entryNameFilesMap } = buildTraceContext?.chunksTrace || {}\n\n const cachedLookupIgnoreRoutes = new Map<string, boolean>()\n\n await Promise.all(\n [\n ...(entryNameFilesMap\n ? Object.entries(entryNameFilesMap)\n : new Map()),\n ].map(async ([entryName, entryNameFiles]) => {\n const isApp = entryName.startsWith('app/')\n const isPages = entryName.startsWith('pages/')\n let route = entryName\n if (isApp) {\n route = normalizeAppPath(route.substring('app'.length))\n }\n if (isPages) {\n route = normalizePagePath(route.substring('pages'.length))\n }\n\n // we don't need to trace for automatically statically optimized\n // pages as they don't have server bundles, note there is\n // the caveat with flying shuttle mode as it needs this for\n // detecting changed entries\n if (staticPages.includes(route)) {\n return\n }\n const entryOutputPath = path.join(\n distDir,\n 'server',\n `${entryName}.js`\n )\n const traceOutputPath = `${entryOutputPath}.nft.json`\n const existingTrace = JSON.parse(\n await fs.readFile(traceOutputPath, 'utf8')\n ) as {\n version: number\n files: string[]\n fileHashes: Record<string, string>\n }\n const traceOutputDir = path.dirname(traceOutputPath)\n const curTracedFiles = new Set<string>()\n\n for (const file of [...entryNameFiles, entryOutputPath]) {\n const curFiles = [\n ...(parentFilesMap\n .get(path.relative(outputFileTracingRoot, file))\n ?.keys() || []),\n ]\n for (const curFile of curFiles || []) {\n if (\n !shouldIgnore(\n curFile,\n routeIgnoreFn,\n reasons,\n cachedLookupIgnoreRoutes\n )\n ) {\n const filePath = path.join(outputFileTracingRoot, curFile)\n const outputFile = path\n .relative(traceOutputDir, filePath)\n .replace(/\\\\/g, '/')\n curTracedFiles.add(outputFile)\n }\n }\n }\n\n for (const file of existingTrace.files || []) {\n curTracedFiles.add(file)\n }\n\n await fs.writeFile(\n traceOutputPath,\n JSON.stringify({\n ...existingTrace,\n files: [...curTracedFiles].sort(),\n })\n )\n })\n )\n }\n\n const moduleTypes = ['app-page', 'pages']\n\n for (const type of moduleTypes) {\n const modulePath = require.resolve(\n `next/dist/server/route-modules/${type}/module.compiled`\n )\n const relativeModulePath = path.relative(root, modulePath)\n\n const contextDir = path.join(\n path.dirname(modulePath),\n 'vendored',\n 'contexts'\n )\n\n for (const item of await fs.readdir(contextDir)) {\n const itemPath = path.relative(root, path.join(contextDir, item))\n if (!serverIgnoreFn(itemPath)) {\n addToTracedFiles(root, itemPath, serverTracedFiles)\n addToTracedFiles(root, itemPath, minimalServerTracedFiles)\n }\n }\n addToTracedFiles(root, relativeModulePath, serverTracedFiles)\n addToTracedFiles(root, relativeModulePath, minimalServerTracedFiles)\n }\n\n await Promise.all([\n fs.writeFile(\n nextServerTraceOutput,\n JSON.stringify({\n version: 1,\n files: Array.from(serverTracedFiles),\n } as {\n version: number\n files: string[]\n })\n ),\n fs.writeFile(\n nextMinimalTraceOutput,\n JSON.stringify({\n version: 1,\n files: Array.from(minimalServerTracedFiles),\n } as {\n version: number\n files: string[]\n })\n ),\n ])\n })\n\n // apply outputFileTracingIncludes/outputFileTracingExcludes after runTurbotrace\n const includeExcludeSpan = nextBuildSpan.traceChild('apply-include-excludes')\n await includeExcludeSpan.traceAsyncFn(async () => {\n const globOrig =\n require('next/dist/compiled/glob') as typeof import('next/dist/compiled/glob')\n const glob = (pattern: string): Promise<string[]> => {\n return new Promise((resolve, reject) => {\n globOrig(\n pattern,\n { cwd: dir, nodir: true, dot: true },\n (err, files) => {\n if (err) {\n return reject(err)\n }\n resolve(files)\n }\n )\n })\n }\n\n const { entryNameFilesMap } = buildTraceContext?.chunksTrace || {}\n\n await Promise.all(\n [\n ...(entryNameFilesMap ? Object.entries(entryNameFilesMap) : new Map()),\n ].map(async ([entryName]) => {\n const isApp = entryName.startsWith('app/')\n const isPages = entryName.startsWith('pages/')\n let route = entryName\n if (isApp) {\n route = normalizeAppPath(entryName)\n }\n if (isPages) {\n route = normalizePagePath(entryName)\n }\n\n if (staticPages.includes(route)) {\n return\n }\n\n // edge routes have no trace files\n if (edgeRuntimeRoutes.hasOwnProperty(route)) {\n return\n }\n\n const combinedIncludes = new Set<string>()\n const combinedExcludes = new Set<string>()\n for (const curGlob of includeGlobKeys) {\n const isMatch = picomatch(curGlob, { dot: true, contains: true })\n if (isMatch(route)) {\n for (const include of outputFileTracingIncludes[curGlob]) {\n combinedIncludes.add(include.replace(/\\\\/g, '/'))\n }\n }\n }\n\n for (const curGlob of excludeGlobKeys) {\n const isMatch = picomatch(curGlob, { dot: true, contains: true })\n if (isMatch(route)) {\n for (const exclude of outputFileTracingExcludes[curGlob]) {\n combinedExcludes.add(exclude)\n }\n }\n }\n\n if (!combinedIncludes?.size && !combinedExcludes?.size) {\n return\n }\n\n const traceFile = path.join(\n distDir,\n `server`,\n `${entryName}.js.nft.json`\n )\n const pageDir = path.dirname(traceFile)\n const traceContent = JSON.parse(await fs.readFile(traceFile, 'utf8'))\n const includes: string[] = []\n const resolvedTraceIncludes = new Map<string, string[]>()\n\n if (combinedIncludes?.size) {\n await Promise.all(\n [...combinedIncludes].map(async (includeGlob) => {\n const results = await glob(includeGlob)\n const resolvedInclude = resolvedTraceIncludes.get(\n includeGlob\n ) || [\n ...results.map((file) => {\n return path.relative(pageDir, path.join(dir, file))\n }),\n ]\n includes.push(...resolvedInclude)\n resolvedTraceIncludes.set(includeGlob, resolvedInclude)\n })\n )\n }\n const combined = new Set([...traceContent.files, ...includes])\n\n if (combinedExcludes?.size) {\n const resolvedGlobs = [...combinedExcludes].map((exclude) =>\n path.join(dir, exclude)\n )\n\n // pre compile before forEach\n const isMatch = picomatch(resolvedGlobs, {\n dot: true,\n contains: true,\n })\n\n combined.forEach((file) => {\n if (isMatch(path.join(pageDir, file))) {\n combined.delete(file)\n }\n })\n }\n\n // overwrite trace file with custom includes/excludes\n await fs.writeFile(\n traceFile,\n JSON.stringify({\n version: traceContent.version,\n files: [...combined],\n })\n )\n })\n )\n })\n\n debug(`finished build tracing ${Date.now() - startTime}ms`)\n}\n"],"names":["Span","TRACE_IGNORES","getFilesMapFromReasons","path","fs","nonNullable","ciEnvironment","debugOriginal","picomatch","defaultOverrides","nodeFileTrace","normalizePagePath","normalizeAppPath","isError","debug","shouldIgnore","file","serverIgnoreFn","reasons","cachedIgnoreFiles","children","Set","has","get","set","add","reason","parents","size","type","includes","allParentsIgnored","parent","values","collectBuildTraces","dir","config","distDir","edgeRuntimeRoutes","staticPages","nextBuildSpan","name","hasSsrAmpPages","buildTraceContext","outputFileTracingRoot","startTime","Date","now","outputFileTracingIncludes","outputFileTracingExcludes","excludeGlobKeys","Object","keys","includeGlobKeys","traceChild","isTurbotrace","traceAsyncFn","nextServerTraceOutput","join","nextMinimalTraceOutput","root","isStandalone","output","sharedEntriesSet","map","value","require","resolve","paths","cacheHandler","cacheHandlers","experimental","push","isAbsolute","handlerPath","serverEntries","filter","Boolean","minimalServerEntries","additionalIgnores","glob","forEach","exclude","makeIgnoreFn","ignores","isMatch","contains","dot","pathname","startsWith","sharedIgnores","hasNextSupport","sharedIgnoresFn","serverIgnores","minimalServerIgnores","minimalServerIgnoreFn","routesIgnores","routeIgnoreFn","serverTracedFiles","minimalServerTracedFiles","addToTracedFiles","base","dest","relative","replace","chunksToTrace","chunksTrace","action","input","result","processCwd","mixedModules","readFile","p","e","code","readlink","stat","ignore","fileList","esmFileList","parentFilesMap","cachedLookupIgnore","Map","cachedLookupIgnoreMinimal","entries","tracedFiles","curFiles","curFile","filePath","entryNameFilesMap","cachedLookupIgnoreRoutes","Promise","all","entryName","entryNameFiles","isApp","isPages","route","substring","length","entryOutputPath","traceOutputPath","existingTrace","JSON","parse","traceOutputDir","dirname","curTracedFiles","outputFile","files","writeFile","stringify","sort","moduleTypes","modulePath","relativeModulePath","contextDir","item","readdir","itemPath","version","Array","from","includeExcludeSpan","globOrig","pattern","reject","cwd","nodir","err","hasOwnProperty","combinedIncludes","combinedExcludes","curGlob","include","traceFile","pageDir","traceContent","resolvedTraceIncludes","includeGlob","results","resolvedInclude","combined","resolvedGlobs","delete"],"mappings":"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"}
@@ -300,7 +300,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
300
300
  const nextBuildSpan = trace('next-build', undefined, {
301
301
  buildMode: experimentalBuildMode,
302
302
  isTurboBuild: String(turboNextBuild),
303
- version: "15.3.0-canary.5"
303
+ version: "15.3.0-canary.6"
304
304
  });
305
305
  NextBuildContext.nextBuildSpan = nextBuildSpan;
306
306
  NextBuildContext.dir = dir;
@@ -332,6 +332,23 @@ export default async function build(dir, reactProductionProfiling = false, debug
332
332
  setGlobal('distDir', distDir);
333
333
  const buildId = await getBuildId(isGenerateMode, distDir, nextBuildSpan, config);
334
334
  NextBuildContext.buildId = buildId;
335
+ if (experimentalBuildMode === 'generate-env') {
336
+ if (turboNextBuild) {
337
+ Log.warn('generate-env is not needed with turbopack');
338
+ process.exit(0);
339
+ }
340
+ Log.info('Inlining static env ...');
341
+ await nextBuildSpan.traceChild('inline-static-env').traceAsyncFn(async ()=>{
342
+ await inlineStaticEnv({
343
+ distDir,
344
+ config
345
+ });
346
+ });
347
+ Log.info('Complete');
348
+ await flushAllTraces();
349
+ teardownTraceSubscriber();
350
+ process.exit(0);
351
+ }
335
352
  // when using compile mode static env isn't inlined so we
336
353
  // need to populate in normal runtime env
337
354
  if (isCompileMode || isGenerateMode) {
@@ -664,7 +681,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
664
681
  // Files outside of the distDir can be "type": "module"
665
682
  await writeFileUtf8(path.join(distDir, 'package.json'), '{"type": "commonjs"}');
666
683
  // These are written to distDir, so they need to come after creating and cleaning distDr.
667
- await recordFrameworkVersion("15.3.0-canary.5");
684
+ await recordFrameworkVersion("15.3.0-canary.6");
668
685
  await updateBuildDiagnostics({
669
686
  buildStage: 'start'
670
687
  });
@@ -1242,7 +1259,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
1242
1259
  cacheHandlers: normalizedCacheHandlers,
1243
1260
  trustHostHeader: ciEnvironment.hasNextSupport,
1244
1261
  // @ts-expect-error internal field TODO: fix this, should use a separate mechanism to pass the info.
1245
- isExperimentalCompile: isCompileMode || isGenerateMode && config.experimental.generateOnlyEnv
1262
+ isExperimentalCompile: isCompileMode
1246
1263
  }
1247
1264
  },
1248
1265
  appDir: dir,
@@ -1407,20 +1424,13 @@ export default async function build(dir, reactProductionProfiling = false, debug
1407
1424
  // we don't need to inline for turbopack build as
1408
1425
  // it will handle it's own caching separate of compile
1409
1426
  if (isGenerateMode && !turboNextBuild) {
1427
+ Log.info('Inlining static env ...');
1410
1428
  await nextBuildSpan.traceChild('inline-static-env').traceAsyncFn(async ()=>{
1411
1429
  await inlineStaticEnv({
1412
1430
  distDir,
1413
1431
  config
1414
1432
  });
1415
1433
  });
1416
- // users might only want to inline env during experimental generate
1417
- // instead of also prerendering e.g. for test mode so exit after
1418
- if (config.experimental.generateOnlyEnv) {
1419
- Log.info('Inlined static env, exiting due to experimental.generateOnlyEnv');
1420
- await flushAllTraces();
1421
- teardownTraceSubscriber();
1422
- process.exit(0);
1423
- }
1424
1434
  }
1425
1435
  const middlewareManifest = await readManifest(path.join(distDir, SERVER_DIRECTORY, MIDDLEWARE_MANIFEST));
1426
1436
  const prerenderManifest = {
@@ -2192,6 +2202,9 @@ export default async function build(dir, reactProductionProfiling = false, debug
2192
2202
  buildTracesSpinner.stopAndPersist();
2193
2203
  buildTracesSpinner = undefined;
2194
2204
  }
2205
+ if (isCompileMode) {
2206
+ Log.info(`Build ran with "compile" mode, to finalize the build run either "generate" or "generate-env" mode as well`);
2207
+ }
2195
2208
  if (config.output === 'export') {
2196
2209
  await writeFullyStaticExport(config, dir, enabledDirectories, configOutDir, nextBuildSpan);
2197
2210
  }