next 15.0.4-canary.21 → 15.0.4-canary.22

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.

Potentially problematic release.


This version of next might be problematic. Click here for more details.

Files changed (36) hide show
  1. package/dist/bin/next +1 -1
  2. package/dist/build/index.js +2 -2
  3. package/dist/build/swc/index.js +1 -1
  4. package/dist/build/webpack-config.js +2 -2
  5. package/dist/client/app-bootstrap.js +1 -1
  6. package/dist/client/index.js +1 -1
  7. package/dist/compiled/next-server/server.runtime.prod.js +1 -1
  8. package/dist/compiled/next-server/server.runtime.prod.js.map +1 -1
  9. package/dist/esm/build/index.js +2 -2
  10. package/dist/esm/build/swc/index.js +1 -1
  11. package/dist/esm/build/webpack-config.js +2 -2
  12. package/dist/esm/client/app-bootstrap.js +1 -1
  13. package/dist/esm/client/index.js +1 -1
  14. package/dist/esm/server/config.js +1 -1
  15. package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
  16. package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
  17. package/dist/esm/server/lib/app-info-log.js +1 -1
  18. package/dist/esm/server/lib/experimental/create-env-definitions.js +15 -3
  19. package/dist/esm/server/lib/experimental/create-env-definitions.js.map +1 -1
  20. package/dist/esm/server/lib/router-utils/setup-dev-bundler.js +9 -5
  21. package/dist/esm/server/lib/router-utils/setup-dev-bundler.js.map +1 -1
  22. package/dist/esm/server/lib/start-server.js +1 -1
  23. package/dist/server/config.js +1 -1
  24. package/dist/server/dev/hot-reloader-turbopack.js +1 -1
  25. package/dist/server/dev/hot-reloader-webpack.js +1 -1
  26. package/dist/server/lib/app-info-log.js +1 -1
  27. package/dist/server/lib/experimental/create-env-definitions.d.ts +3 -3
  28. package/dist/server/lib/experimental/create-env-definitions.js +15 -3
  29. package/dist/server/lib/experimental/create-env-definitions.js.map +1 -1
  30. package/dist/server/lib/router-utils/setup-dev-bundler.js +9 -5
  31. package/dist/server/lib/router-utils/setup-dev-bundler.js.map +1 -1
  32. package/dist/server/lib/start-server.js +1 -1
  33. package/dist/telemetry/anonymous-meta.js +1 -1
  34. package/dist/telemetry/events/session-stopped.js +2 -2
  35. package/dist/telemetry/events/version.js +2 -2
  36. package/package.json +15 -15
@@ -284,7 +284,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
284
284
  const nextBuildSpan = trace('next-build', undefined, {
285
285
  buildMode: experimentalBuildMode,
286
286
  isTurboBuild: String(turboNextBuild),
287
- version: "15.0.4-canary.21"
287
+ version: "15.0.4-canary.22"
288
288
  });
289
289
  NextBuildContext.nextBuildSpan = nextBuildSpan;
290
290
  NextBuildContext.dir = dir;
@@ -685,7 +685,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
685
685
  // Files outside of the distDir can be "type": "module"
686
686
  await writeFileUtf8(path.join(distDir, 'package.json'), '{"type": "commonjs"}');
687
687
  // These are written to distDir, so they need to come after creating and cleaning distDr.
688
- await recordFrameworkVersion("15.0.4-canary.21");
688
+ await recordFrameworkVersion("15.0.4-canary.22");
689
689
  await updateBuildDiagnostics({
690
690
  buildStage: 'start'
691
691
  });
@@ -11,7 +11,7 @@ import { isDeepStrictEqual } from 'util';
11
11
  import { getDefineEnv } from '../webpack/plugins/define-env-plugin';
12
12
  import { getReactCompilerLoader } from '../get-babel-loader-config';
13
13
  import { TurbopackInternalError } from '../../server/dev/turbopack-utils';
14
- const nextVersion = "15.0.4-canary.21";
14
+ const nextVersion = "15.0.4-canary.22";
15
15
  const ArchName = arch();
16
16
  const PlatformName = platform();
17
17
  function infoLog(...args) {
@@ -1403,7 +1403,7 @@ export default async function getBaseWebpackConfig(dir, { buildId, encryptionKey
1403
1403
  isClient && new CopyFilePlugin({
1404
1404
  // file path to build output of `@next/polyfill-nomodule`
1405
1405
  filePath: require.resolve('./polyfills/polyfill-nomodule'),
1406
- cacheKey: "15.0.4-canary.21",
1406
+ cacheKey: "15.0.4-canary.22",
1407
1407
  name: `static/chunks/polyfills${dev ? '' : '-[hash]'}.js`,
1408
1408
  minimize: false,
1409
1409
  info: {
@@ -1632,7 +1632,7 @@ export default async function getBaseWebpackConfig(dir, { buildId, encryptionKey
1632
1632
  // - Next.js location on disk (some loaders use absolute paths and some resolve options depend on absolute paths)
1633
1633
  // - Next.js version
1634
1634
  // - next.config.js keys that affect compilation
1635
- version: `${__dirname}|${"15.0.4-canary.21"}|${configVars}`,
1635
+ version: `${__dirname}|${"15.0.4-canary.22"}|${configVars}`,
1636
1636
  cacheDirectory: path.join(distDir, 'cache', 'webpack'),
1637
1637
  // For production builds, it's more efficient to compress all cache files together instead of compression each one individually.
1638
1638
  // So we disable compression here and allow the build runner to take care of compressing the cache as a whole.
@@ -3,7 +3,7 @@
3
3
  * sure the following scripts are executed in the correct order:
4
4
  * - Polyfills
5
5
  * - next/script with `beforeInteractive` strategy
6
- */ const version = "15.0.4-canary.21";
6
+ */ const version = "15.0.4-canary.22";
7
7
  window.next = {
8
8
  version,
9
9
  appDir: true
@@ -26,7 +26,7 @@ import { SearchParamsContext, PathParamsContext } from '../shared/lib/hooks-clie
26
26
  import { onRecoverableError } from './react-client-callbacks/shared';
27
27
  import tracer from './tracing/tracer';
28
28
  import reportToSocket from './tracing/report-to-socket';
29
- export const version = "15.0.4-canary.21";
29
+ export const version = "15.0.4-canary.22";
30
30
  export let router;
31
31
  export const emitter = mitt();
32
32
  const looseToArray = (input)=>[].slice.call(input);
@@ -155,7 +155,7 @@ function assignDefaults(dir, userConfig, silent) {
155
155
  if (((_result_experimental = result.experimental) == null ? void 0 : _result_experimental.allowDevelopmentBuild) && process.env.NODE_ENV !== 'development') {
156
156
  throw new Error(`The experimental.allowDevelopmentBuild option requires NODE_ENV to be explicitly set to 'development'.`);
157
157
  }
158
- if (!((_process_env___NEXT_VERSION = "15.0.4-canary.21") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_SKIP_CANARY_CHECK) {
158
+ if (!((_process_env___NEXT_VERSION = "15.0.4-canary.22") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_SKIP_CANARY_CHECK) {
159
159
  var _result_experimental7, _result_experimental8, _result_experimental_turbo3, _result_experimental9, _result_experimental10;
160
160
  // Prevents usage of certain experimental features outside of canary
161
161
  if ((_result_experimental7 = result.experimental) == null ? void 0 : _result_experimental7.ppr) {
@@ -48,7 +48,7 @@ export async function createHotReloaderTurbopack(opts, serverFields, distDir, re
48
48
  }
49
49
  const hasRewrites = opts.fsChecker.rewrites.afterFiles.length > 0 || opts.fsChecker.rewrites.beforeFiles.length > 0 || opts.fsChecker.rewrites.fallback.length > 0;
50
50
  const hotReloaderSpan = trace('hot-reloader', undefined, {
51
- version: "15.0.4-canary.21"
51
+ version: "15.0.4-canary.22"
52
52
  });
53
53
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
54
54
  // of the current `next dev` invocation.
@@ -184,7 +184,7 @@ export default class HotReloaderWebpack {
184
184
  this.previewProps = previewProps;
185
185
  this.rewrites = rewrites;
186
186
  this.hotReloaderSpan = trace('hot-reloader', undefined, {
187
- version: "15.0.4-canary.21"
187
+ version: "15.0.4-canary.22"
188
188
  });
189
189
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
190
190
  // of the current `next dev` invocation.
@@ -4,7 +4,7 @@ import { bold, purple } from '../../lib/picocolors';
4
4
  import { PHASE_DEVELOPMENT_SERVER, PHASE_PRODUCTION_BUILD } from '../../shared/lib/constants';
5
5
  import loadConfig, { getEnabledExperimentalFeatures } from '../config';
6
6
  export function logStartInfo({ networkUrl, appUrl, envInfo, expFeatureInfo, maxExperimentalFeatures = Infinity }) {
7
- Log.bootstrap(`${bold(purple(`${Log.prefixes.ready} Next.js ${"15.0.4-canary.21"}`))}${process.env.TURBOPACK ? ' (Turbopack)' : ''}`);
7
+ Log.bootstrap(`${bold(purple(`${Log.prefixes.ready} Next.js ${"15.0.4-canary.22"}`))}${process.env.TURBOPACK ? ' (Turbopack)' : ''}`);
8
8
  if (appUrl) {
9
9
  Log.bootstrap(`- Local: ${appUrl}`);
10
10
  }
@@ -1,12 +1,24 @@
1
1
  import { join } from 'node:path';
2
2
  import { writeFile } from 'node:fs/promises';
3
- export async function createEnvDefinitions({ distDir, env }) {
4
- const envKeysStr = Object.keys(env).map((key)=>` ${key}?: string`).join('\n');
3
+ export async function createEnvDefinitions({ distDir, loadedEnvFiles }) {
4
+ const envLines = [];
5
+ const seenKeys = new Set();
6
+ // env files are in order of priority
7
+ for (const { path, env } of loadedEnvFiles){
8
+ for(const key in env){
9
+ if (!seenKeys.has(key)) {
10
+ envLines.push(` /** Loaded from \`${path}\` */`);
11
+ envLines.push(` ${key}?: string`);
12
+ seenKeys.add(key);
13
+ }
14
+ }
15
+ }
16
+ const envStr = envLines.join('\n');
5
17
  const definitionStr = `// Type definitions for Next.js environment variables
6
18
  declare global {
7
19
  namespace NodeJS {
8
20
  interface ProcessEnv {
9
- ${envKeysStr}
21
+ ${envStr}
10
22
  }
11
23
  }
12
24
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/server/lib/experimental/create-env-definitions.ts"],"sourcesContent":["import type { Env } from '@next/env'\nimport { join } from 'node:path'\nimport { writeFile } from 'node:fs/promises'\n\nexport async function createEnvDefinitions({\n distDir,\n env,\n}: {\n distDir: string\n env: Env\n}) {\n const envKeysStr = Object.keys(env)\n .map((key) => ` ${key}?: string`)\n .join('\\n')\n\n const definitionStr = `// Type definitions for Next.js environment variables\ndeclare global {\n namespace NodeJS {\n interface ProcessEnv {\n${envKeysStr}\n }\n }\n}\nexport {}`\n\n if (process.env.NODE_ENV === 'test') {\n return definitionStr\n }\n\n try {\n // we expect the types directory to already exist\n const envDtsPath = join(distDir, 'types', 'env.d.ts')\n // do not await, this is not essential for further process\n writeFile(envDtsPath, definitionStr, 'utf-8')\n } catch (e) {\n console.error('Failed to write env.d.ts:', e)\n }\n}\n"],"names":["join","writeFile","createEnvDefinitions","distDir","env","envKeysStr","Object","keys","map","key","definitionStr","process","NODE_ENV","envDtsPath","e","console","error"],"mappings":"AACA,SAASA,IAAI,QAAQ,YAAW;AAChC,SAASC,SAAS,QAAQ,mBAAkB;AAE5C,OAAO,eAAeC,qBAAqB,EACzCC,OAAO,EACPC,GAAG,EAIJ;IACC,MAAMC,aAAaC,OAAOC,IAAI,CAACH,KAC5BI,GAAG,CAAC,CAACC,MAAQ,CAAC,MAAM,EAAEA,IAAI,SAAS,CAAC,EACpCT,IAAI,CAAC;IAER,MAAMU,gBAAgB,CAAC;;;;AAIzB,EAAEL,WAAW;;;;SAIJ,CAAC;IAER,IAAIM,QAAQP,GAAG,CAACQ,QAAQ,KAAK,QAAQ;QACnC,OAAOF;IACT;IAEA,IAAI;QACF,iDAAiD;QACjD,MAAMG,aAAab,KAAKG,SAAS,SAAS;QAC1C,0DAA0D;QAC1DF,UAAUY,YAAYH,eAAe;IACvC,EAAE,OAAOI,GAAG;QACVC,QAAQC,KAAK,CAAC,6BAA6BF;IAC7C;AACF"}
1
+ {"version":3,"sources":["../../../../src/server/lib/experimental/create-env-definitions.ts"],"sourcesContent":["import type { LoadedEnvFiles } from '@next/env'\nimport { join } from 'node:path'\nimport { writeFile } from 'node:fs/promises'\n\nexport async function createEnvDefinitions({\n distDir,\n loadedEnvFiles,\n}: {\n distDir: string\n loadedEnvFiles: LoadedEnvFiles\n}) {\n const envLines = []\n const seenKeys = new Set()\n // env files are in order of priority\n for (const { path, env } of loadedEnvFiles) {\n for (const key in env) {\n if (!seenKeys.has(key)) {\n envLines.push(` /** Loaded from \\`${path}\\` */`)\n envLines.push(` ${key}?: string`)\n seenKeys.add(key)\n }\n }\n }\n const envStr = envLines.join('\\n')\n\n const definitionStr = `// Type definitions for Next.js environment variables\ndeclare global {\n namespace NodeJS {\n interface ProcessEnv {\n${envStr}\n }\n }\n}\nexport {}`\n\n if (process.env.NODE_ENV === 'test') {\n return definitionStr\n }\n\n try {\n // we expect the types directory to already exist\n const envDtsPath = join(distDir, 'types', 'env.d.ts')\n // do not await, this is not essential for further process\n writeFile(envDtsPath, definitionStr, 'utf-8')\n } catch (e) {\n console.error('Failed to write env.d.ts:', e)\n }\n}\n"],"names":["join","writeFile","createEnvDefinitions","distDir","loadedEnvFiles","envLines","seenKeys","Set","path","env","key","has","push","add","envStr","definitionStr","process","NODE_ENV","envDtsPath","e","console","error"],"mappings":"AACA,SAASA,IAAI,QAAQ,YAAW;AAChC,SAASC,SAAS,QAAQ,mBAAkB;AAE5C,OAAO,eAAeC,qBAAqB,EACzCC,OAAO,EACPC,cAAc,EAIf;IACC,MAAMC,WAAW,EAAE;IACnB,MAAMC,WAAW,IAAIC;IACrB,qCAAqC;IACrC,KAAK,MAAM,EAAEC,IAAI,EAAEC,GAAG,EAAE,IAAIL,eAAgB;QAC1C,IAAK,MAAMM,OAAOD,IAAK;YACrB,IAAI,CAACH,SAASK,GAAG,CAACD,MAAM;gBACtBL,SAASO,IAAI,CAAC,CAAC,wBAAwB,EAAEJ,KAAK,KAAK,CAAC;gBACpDH,SAASO,IAAI,CAAC,CAAC,MAAM,EAAEF,IAAI,SAAS,CAAC;gBACrCJ,SAASO,GAAG,CAACH;YACf;QACF;IACF;IACA,MAAMI,SAAST,SAASL,IAAI,CAAC;IAE7B,MAAMe,gBAAgB,CAAC;;;;AAIzB,EAAED,OAAO;;;;SAIA,CAAC;IAER,IAAIE,QAAQP,GAAG,CAACQ,QAAQ,KAAK,QAAQ;QACnC,OAAOF;IACT;IAEA,IAAI;QACF,iDAAiD;QACjD,MAAMG,aAAalB,KAAKG,SAAS,SAAS;QAC1C,0DAA0D;QAC1DF,UAAUiB,YAAYH,eAAe;IACvC,EAAE,OAAOI,GAAG;QACVC,QAAQC,KAAK,CAAC,6BAA6BF;IAC7C;AACF"}
@@ -376,17 +376,21 @@ async function startWatcher(opts) {
376
376
  var _hotReloader_activeWebpackConfigs;
377
377
  if (envChange) {
378
378
  var _nextConfig_experimental;
379
- const { parsedEnv } = loadEnvConfig(dir, true, Log, true, (envFilePath)=>{
379
+ const { loadedEnvFiles } = loadEnvConfig(dir, process.env.NODE_ENV === 'development', Log, true, (envFilePath)=>{
380
380
  Log.info(`Reload env: ${envFilePath}`);
381
381
  });
382
382
  if (usingTypeScript && ((_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.typedEnv)) {
383
383
  // do not await, this is not essential for further process
384
384
  createEnvDefinitions({
385
385
  distDir,
386
- env: {
387
- ...parsedEnv,
388
- ...nextConfig.env
389
- }
386
+ loadedEnvFiles: [
387
+ ...loadedEnvFiles,
388
+ {
389
+ path: nextConfig.configFileName,
390
+ env: nextConfig.env,
391
+ contents: ''
392
+ }
393
+ ]
390
394
  });
391
395
  }
392
396
  await propagateServerField(opts, 'loadEnvConfig', [
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/server/lib/router-utils/setup-dev-bundler.ts"],"sourcesContent":["import type { NextConfigComplete } from '../../config-shared'\nimport type { FilesystemDynamicRoute } from './filesystem'\nimport type { UnwrapPromise } from '../../../lib/coalesced-function'\nimport {\n getPageStaticInfo,\n type MiddlewareMatcher,\n} from '../../../build/analysis/get-page-static-info'\nimport type { MiddlewareRouteMatch } from '../../../shared/lib/router/utils/middleware-route-matcher'\nimport type { PropagateToWorkersField } from './types'\nimport type { NextJsHotReloaderInterface } from '../../dev/hot-reloader-types'\n\nimport { createDefineEnv } from '../../../build/swc'\nimport type { Project } from '../../../build/swc/types'\nimport fs from 'fs'\nimport { mkdir } from 'fs/promises'\nimport url from 'url'\nimport path from 'path'\nimport qs from 'querystring'\nimport Watchpack from 'next/dist/compiled/watchpack'\nimport { loadEnvConfig } from '@next/env'\nimport isError, { type NextError } from '../../../lib/is-error'\nimport findUp from 'next/dist/compiled/find-up'\nimport { buildCustomRoute } from './filesystem'\nimport * as Log from '../../../build/output/log'\nimport HotReloaderWebpack from '../../dev/hot-reloader-webpack'\nimport { setGlobal } from '../../../trace/shared'\nimport type { Telemetry } from '../../../telemetry/storage'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport loadJsConfig from '../../../build/load-jsconfig'\nimport { createValidFileMatcher } from '../find-page-file'\nimport { eventCliSession } from '../../../telemetry/events'\nimport { getDefineEnv } from '../../../build/webpack/plugins/define-env-plugin'\nimport { logAppDirError } from '../../dev/log-app-dir-error'\nimport { getSortedRoutes } from '../../../shared/lib/router/utils'\nimport {\n getStaticInfoIncludingLayouts,\n sortByPageExts,\n} from '../../../build/entries'\nimport { verifyTypeScriptSetup } from '../../../lib/verify-typescript-setup'\nimport { verifyPartytownSetup } from '../../../lib/verify-partytown-setup'\nimport { getRouteRegex } from '../../../shared/lib/router/utils/route-regex'\nimport { normalizeAppPath } from '../../../shared/lib/router/utils/app-paths'\nimport { buildDataRoute } from './build-data-route'\nimport { getRouteMatcher } from '../../../shared/lib/router/utils/route-matcher'\nimport { normalizePathSep } from '../../../shared/lib/page-path/normalize-path-sep'\nimport { createClientRouterFilter } from '../../../lib/create-client-router-filter'\nimport { absolutePathToPage } from '../../../shared/lib/page-path/absolute-path-to-page'\nimport { generateInterceptionRoutesRewrites } from '../../../lib/generate-interception-routes-rewrites'\n\nimport {\n CLIENT_STATIC_FILES_PATH,\n COMPILER_NAMES,\n DEV_CLIENT_PAGES_MANIFEST,\n DEV_CLIENT_MIDDLEWARE_MANIFEST,\n PHASE_DEVELOPMENT_SERVER,\n} from '../../../shared/lib/constants'\n\nimport { getMiddlewareRouteMatcher } from '../../../shared/lib/router/utils/middleware-route-matcher'\n\nimport {\n isMiddlewareFile,\n NestedMiddlewareError,\n isInstrumentationHookFile,\n getPossibleMiddlewareFilenames,\n getPossibleInstrumentationHookFilenames,\n} from '../../../build/utils'\nimport {\n createOriginalStackFrame,\n getSourceMapFromCompilation,\n getSourceMapFromFile,\n parseStack,\n} from '../../../client/components/react-dev-overlay/server/middleware'\nimport {\n batchedTraceSource,\n createOriginalStackFrame as createOriginalTurboStackFrame,\n} from '../../../client/components/react-dev-overlay/server/middleware-turbopack'\nimport type { OriginalStackFrameResponse } from '../../../client/components/react-dev-overlay/server/shared'\nimport { devPageFiles } from '../../../build/webpack/plugins/next-types-plugin/shared'\nimport type { LazyRenderServerInstance } from '../router-server'\nimport { HMR_ACTIONS_SENT_TO_BROWSER } from '../../dev/hot-reloader-types'\nimport { PAGE_TYPES } from '../../../lib/page-types'\nimport { createHotReloaderTurbopack } from '../../dev/hot-reloader-turbopack'\nimport { getErrorSource } from '../../../shared/lib/error-source'\nimport type { StackFrame } from 'next/dist/compiled/stacktrace-parser'\nimport { generateEncryptionKeyBase64 } from '../../app-render/encryption-utils-server'\nimport {\n ModuleBuildError,\n TurbopackInternalError,\n} from '../../dev/turbopack-utils'\nimport { isMetadataRouteFile } from '../../../lib/metadata/is-metadata-route'\nimport { normalizeMetadataPageToRoute } from '../../../lib/metadata/get-metadata-route'\nimport { createEnvDefinitions } from '../experimental/create-env-definitions'\nimport { JsConfigPathsPlugin } from '../../../build/webpack/plugins/jsconfig-paths-plugin'\nimport { store as consoleStore } from '../../../build/output/store'\n\nexport type SetupOpts = {\n renderServer: LazyRenderServerInstance\n dir: string\n turbo?: boolean\n appDir?: string\n pagesDir?: string\n telemetry: Telemetry\n isCustomServer?: boolean\n fsChecker: UnwrapPromise<\n ReturnType<typeof import('./filesystem').setupFsCheck>\n >\n nextConfig: NextConfigComplete\n port: number\n onCleanup: (listener: () => Promise<void>) => void\n resetFetch: () => void\n}\n\nexport type ServerFields = {\n actualMiddlewareFile?: string | undefined\n actualInstrumentationHookFile?: string | undefined\n appPathRoutes?: Record<string, string | string[]>\n middleware?:\n | {\n page: string\n match: MiddlewareRouteMatch\n matchers?: MiddlewareMatcher[]\n }\n | undefined\n hasAppNotFound?: boolean\n interceptionRoutes?: ReturnType<\n typeof import('./filesystem').buildCustomRoute\n >[]\n setAppIsrStatus?: (key: string, value: boolean) => void\n resetFetch?: () => void\n}\n\nasync function verifyTypeScript(opts: SetupOpts) {\n let usingTypeScript = false\n const verifyResult = await verifyTypeScriptSetup({\n dir: opts.dir,\n distDir: opts.nextConfig.distDir,\n intentDirs: [opts.pagesDir, opts.appDir].filter(Boolean) as string[],\n typeCheckPreflight: false,\n tsconfigPath: opts.nextConfig.typescript.tsconfigPath,\n disableStaticImages: opts.nextConfig.images.disableStaticImages,\n hasAppDir: !!opts.appDir,\n hasPagesDir: !!opts.pagesDir,\n })\n\n if (verifyResult.version) {\n usingTypeScript = true\n }\n return usingTypeScript\n}\n\nexport async function propagateServerField(\n opts: SetupOpts,\n field: PropagateToWorkersField,\n args: any\n) {\n await opts.renderServer?.instance?.propagateServerField(opts.dir, field, args)\n}\n\nasync function startWatcher(opts: SetupOpts) {\n const { nextConfig, appDir, pagesDir, dir, resetFetch } = opts\n const { useFileSystemPublicRoutes } = nextConfig\n const usingTypeScript = await verifyTypeScript(opts)\n\n const distDir = path.join(opts.dir, opts.nextConfig.distDir)\n\n // we ensure the types directory exists here\n if (usingTypeScript) {\n const distTypesDir = path.join(distDir, 'types')\n if (!fs.existsSync(distTypesDir)) {\n await mkdir(distTypesDir, { recursive: true })\n }\n }\n\n setGlobal('distDir', distDir)\n setGlobal('phase', PHASE_DEVELOPMENT_SERVER)\n\n const validFileMatcher = createValidFileMatcher(\n nextConfig.pageExtensions,\n appDir\n )\n\n const serverFields: ServerFields = {}\n\n // Update logging state once based on next.config.js when initializing\n consoleStore.setState({\n logging: nextConfig.logging !== false,\n })\n\n const hotReloader: NextJsHotReloaderInterface = opts.turbo\n ? await createHotReloaderTurbopack(opts, serverFields, distDir, resetFetch)\n : new HotReloaderWebpack(opts.dir, {\n appDir,\n pagesDir,\n distDir,\n config: opts.nextConfig,\n buildId: 'development',\n encryptionKey: await generateEncryptionKeyBase64({\n isBuild: false,\n distDir,\n }),\n telemetry: opts.telemetry,\n rewrites: opts.fsChecker.rewrites,\n previewProps: opts.fsChecker.prerenderManifest.preview,\n resetFetch,\n })\n\n await hotReloader.start()\n\n if (opts.nextConfig.experimental.nextScriptWorkers) {\n await verifyPartytownSetup(\n opts.dir,\n path.join(distDir, CLIENT_STATIC_FILES_PATH)\n )\n }\n\n opts.fsChecker.ensureCallback(async function ensure(item) {\n if (item.type === 'appFile' || item.type === 'pageFile') {\n await hotReloader.ensurePage({\n clientOnly: false,\n page: item.itemPath,\n isApp: item.type === 'appFile',\n definition: undefined,\n })\n }\n })\n\n let resolved = false\n let prevSortedRoutes: string[] = []\n\n await new Promise<void>(async (resolve, reject) => {\n if (pagesDir) {\n // Watchpack doesn't emit an event for an empty directory\n fs.readdir(pagesDir, (_, files) => {\n if (files?.length) {\n return\n }\n\n if (!resolved) {\n resolve()\n resolved = true\n }\n })\n }\n\n const pages = pagesDir ? [pagesDir] : []\n const app = appDir ? [appDir] : []\n const directories = [...pages, ...app]\n\n const rootDir = pagesDir || appDir\n const files = [\n ...getPossibleMiddlewareFilenames(\n path.join(rootDir!, '..'),\n nextConfig.pageExtensions\n ),\n ...getPossibleInstrumentationHookFilenames(\n path.join(rootDir!, '..'),\n nextConfig.pageExtensions\n ),\n ]\n let nestedMiddleware: string[] = []\n\n const envFiles = [\n '.env.development.local',\n '.env.local',\n '.env.development',\n '.env',\n ].map((file) => path.join(dir, file))\n\n files.push(...envFiles)\n\n // tsconfig/jsconfig paths hot-reloading\n const tsconfigPaths = [\n path.join(dir, 'tsconfig.json'),\n path.join(dir, 'jsconfig.json'),\n ] as const\n files.push(...tsconfigPaths)\n\n const wp = new Watchpack({\n ignored: (pathname: string) => {\n return (\n !files.some((file) => file.startsWith(pathname)) &&\n !directories.some(\n (d) => pathname.startsWith(d) || d.startsWith(pathname)\n )\n )\n },\n })\n const fileWatchTimes = new Map()\n let enabledTypeScript = usingTypeScript\n let previousClientRouterFilters: any\n let previousConflictingPagePaths: Set<string> = new Set()\n\n wp.on('aggregated', async () => {\n let middlewareMatchers: MiddlewareMatcher[] | undefined\n const routedPages: string[] = []\n const knownFiles = wp.getTimeInfoEntries()\n const appPaths: Record<string, string[]> = {}\n const pageNameSet = new Set<string>()\n const conflictingAppPagePaths = new Set<string>()\n const appPageFilePaths = new Map<string, string>()\n const pagesPageFilePaths = new Map<string, string>()\n const pagesWithUnsupportedSegments = new Map<string, string[]>()\n\n let envChange = false\n let tsconfigChange = false\n let conflictingPageChange = 0\n let hasRootAppNotFound = false\n\n const { appFiles, pageFiles } = opts.fsChecker\n\n appFiles.clear()\n pageFiles.clear()\n devPageFiles.clear()\n pagesWithUnsupportedSegments.clear()\n\n const sortedKnownFiles: string[] = [...knownFiles.keys()].sort(\n sortByPageExts(nextConfig.pageExtensions)\n )\n\n for (const fileName of sortedKnownFiles) {\n if (\n !files.includes(fileName) &&\n !directories.some((d) => fileName.startsWith(d))\n ) {\n continue\n }\n const meta = knownFiles.get(fileName)\n\n const watchTime = fileWatchTimes.get(fileName)\n // If the file is showing up for the first time or the meta.timestamp is changed since last time\n const watchTimeChange =\n watchTime === undefined ||\n (watchTime && watchTime !== meta?.timestamp)\n fileWatchTimes.set(fileName, meta?.timestamp)\n\n if (envFiles.includes(fileName)) {\n if (watchTimeChange) {\n envChange = true\n }\n continue\n }\n\n if (tsconfigPaths.includes(fileName)) {\n if (fileName.endsWith('tsconfig.json')) {\n enabledTypeScript = true\n }\n if (watchTimeChange) {\n tsconfigChange = true\n }\n continue\n }\n\n if (\n meta?.accuracy === undefined ||\n !validFileMatcher.isPageFile(fileName)\n ) {\n continue\n }\n\n const isAppPath = Boolean(\n appDir &&\n normalizePathSep(fileName).startsWith(\n normalizePathSep(appDir) + '/'\n )\n )\n const isPagePath = Boolean(\n pagesDir &&\n normalizePathSep(fileName).startsWith(\n normalizePathSep(pagesDir) + '/'\n )\n )\n\n const rootFile = absolutePathToPage(fileName, {\n dir: dir,\n extensions: nextConfig.pageExtensions,\n keepIndex: false,\n pagesType: PAGE_TYPES.ROOT,\n })\n\n if (isMiddlewareFile(rootFile)) {\n const staticInfo = await getStaticInfoIncludingLayouts({\n pageFilePath: fileName,\n config: nextConfig,\n appDir: appDir,\n page: rootFile,\n isDev: true,\n isInsideAppDir: isAppPath,\n pageExtensions: nextConfig.pageExtensions,\n })\n if (nextConfig.output === 'export') {\n Log.error(\n 'Middleware cannot be used with \"output: export\". See more info here: https://nextjs.org/docs/advanced-features/static-html-export'\n )\n continue\n }\n serverFields.actualMiddlewareFile = rootFile\n await propagateServerField(\n opts,\n 'actualMiddlewareFile',\n serverFields.actualMiddlewareFile\n )\n middlewareMatchers = staticInfo.middleware?.matchers || [\n { regexp: '.*', originalSource: '/:path*' },\n ]\n continue\n }\n if (isInstrumentationHookFile(rootFile)) {\n serverFields.actualInstrumentationHookFile = rootFile\n await propagateServerField(\n opts,\n 'actualInstrumentationHookFile',\n serverFields.actualInstrumentationHookFile\n )\n continue\n }\n\n if (fileName.endsWith('.ts') || fileName.endsWith('.tsx')) {\n enabledTypeScript = true\n }\n\n if (!(isAppPath || isPagePath)) {\n continue\n }\n\n // Collect all current filenames for the TS plugin to use\n devPageFiles.add(fileName)\n\n let pageName = absolutePathToPage(fileName, {\n dir: isAppPath ? appDir! : pagesDir!,\n extensions: nextConfig.pageExtensions,\n keepIndex: isAppPath,\n pagesType: isAppPath ? PAGE_TYPES.APP : PAGE_TYPES.PAGES,\n })\n\n if (\n isAppPath &&\n appDir &&\n isMetadataRouteFile(\n fileName.replace(appDir, ''),\n nextConfig.pageExtensions,\n true\n )\n ) {\n const staticInfo = await getPageStaticInfo({\n pageFilePath: fileName,\n nextConfig: {},\n page: pageName,\n isDev: true,\n pageType: PAGE_TYPES.APP,\n })\n\n pageName = normalizeMetadataPageToRoute(\n pageName,\n !!(staticInfo.generateSitemaps || staticInfo.generateImageMetadata)\n )\n }\n\n if (\n !isAppPath &&\n pageName.startsWith('/api/') &&\n nextConfig.output === 'export'\n ) {\n Log.error(\n 'API Routes cannot be used with \"output: export\". See more info here: https://nextjs.org/docs/advanced-features/static-html-export'\n )\n continue\n }\n\n if (isAppPath) {\n const isRootNotFound = validFileMatcher.isRootNotFound(fileName)\n hasRootAppNotFound = true\n\n if (isRootNotFound) {\n continue\n }\n if (!isRootNotFound && !validFileMatcher.isAppRouterPage(fileName)) {\n continue\n }\n // Ignore files/directories starting with `_` in the app directory\n if (normalizePathSep(pageName).includes('/_')) {\n continue\n }\n\n const originalPageName = pageName\n pageName = normalizeAppPath(pageName).replace(/%5F/g, '_')\n if (!appPaths[pageName]) {\n appPaths[pageName] = []\n }\n appPaths[pageName].push(originalPageName)\n\n if (useFileSystemPublicRoutes) {\n appFiles.add(pageName)\n }\n\n if (routedPages.includes(pageName)) {\n continue\n }\n } else {\n if (useFileSystemPublicRoutes) {\n pageFiles.add(pageName)\n // always add to nextDataRoutes for now but in future only add\n // entries that actually use getStaticProps/getServerSideProps\n opts.fsChecker.nextDataRoutes.add(pageName)\n }\n }\n ;(isAppPath ? appPageFilePaths : pagesPageFilePaths).set(\n pageName,\n fileName\n )\n\n if (appDir && pageNameSet.has(pageName)) {\n conflictingAppPagePaths.add(pageName)\n } else {\n pageNameSet.add(pageName)\n }\n\n /**\n * If there is a middleware that is not declared in the root we will\n * warn without adding it so it doesn't make its way into the system.\n */\n if (/[\\\\\\\\/]_middleware$/.test(pageName)) {\n nestedMiddleware.push(pageName)\n continue\n }\n\n routedPages.push(pageName)\n }\n\n const numConflicting = conflictingAppPagePaths.size\n conflictingPageChange = numConflicting - previousConflictingPagePaths.size\n\n if (conflictingPageChange !== 0) {\n if (numConflicting > 0) {\n let errorMessage = `Conflicting app and page file${\n numConflicting === 1 ? ' was' : 's were'\n } found, please remove the conflicting files to continue:\\n`\n\n for (const p of conflictingAppPagePaths) {\n const appPath = path.relative(dir, appPageFilePaths.get(p)!)\n const pagesPath = path.relative(dir, pagesPageFilePaths.get(p)!)\n errorMessage += ` \"${pagesPath}\" - \"${appPath}\"\\n`\n }\n hotReloader.setHmrServerError(new Error(errorMessage))\n } else if (numConflicting === 0) {\n hotReloader.clearHmrServerError()\n await propagateServerField(opts, 'reloadMatchers', undefined)\n }\n }\n\n previousConflictingPagePaths = conflictingAppPagePaths\n\n let clientRouterFilters: any\n if (nextConfig.experimental.clientRouterFilter) {\n clientRouterFilters = createClientRouterFilter(\n Object.keys(appPaths),\n nextConfig.experimental.clientRouterFilterRedirects\n ? ((nextConfig as any)._originalRedirects || []).filter(\n (r: any) => !r.internal\n )\n : [],\n nextConfig.experimental.clientRouterFilterAllowedRate\n )\n\n if (\n !previousClientRouterFilters ||\n JSON.stringify(previousClientRouterFilters) !==\n JSON.stringify(clientRouterFilters)\n ) {\n envChange = true\n previousClientRouterFilters = clientRouterFilters\n }\n }\n\n if (!usingTypeScript && enabledTypeScript) {\n // we tolerate the error here as this is best effort\n // and the manual install command will be shown\n await verifyTypeScript(opts)\n .then(() => {\n tsconfigChange = true\n })\n .catch(() => {})\n }\n\n if (envChange || tsconfigChange) {\n if (envChange) {\n const { parsedEnv } = loadEnvConfig(\n dir,\n true,\n Log,\n true,\n (envFilePath) => {\n Log.info(`Reload env: ${envFilePath}`)\n }\n )\n\n if (usingTypeScript && nextConfig.experimental?.typedEnv) {\n // do not await, this is not essential for further process\n createEnvDefinitions({\n distDir,\n env: { ...parsedEnv, ...nextConfig.env },\n })\n }\n\n await propagateServerField(opts, 'loadEnvConfig', [\n { dev: true, forceReload: true, silent: true },\n ])\n }\n let tsconfigResult:\n | UnwrapPromise<ReturnType<typeof loadJsConfig>>\n | undefined\n\n if (tsconfigChange) {\n try {\n tsconfigResult = await loadJsConfig(dir, nextConfig)\n } catch (_) {\n /* do we want to log if there are syntax errors in tsconfig while editing? */\n }\n }\n\n if (hotReloader.turbopackProject) {\n const hasRewrites =\n opts.fsChecker.rewrites.afterFiles.length > 0 ||\n opts.fsChecker.rewrites.beforeFiles.length > 0 ||\n opts.fsChecker.rewrites.fallback.length > 0\n\n await hotReloader.turbopackProject.update({\n defineEnv: createDefineEnv({\n isTurbopack: true,\n clientRouterFilters,\n config: nextConfig,\n dev: true,\n distDir,\n fetchCacheKeyPrefix:\n opts.nextConfig.experimental.fetchCacheKeyPrefix,\n hasRewrites,\n // TODO: Implement\n middlewareMatchers: undefined,\n }),\n })\n }\n\n hotReloader.activeWebpackConfigs?.forEach((config, idx) => {\n const isClient = idx === 0\n const isNodeServer = idx === 1\n const isEdgeServer = idx === 2\n const hasRewrites =\n opts.fsChecker.rewrites.afterFiles.length > 0 ||\n opts.fsChecker.rewrites.beforeFiles.length > 0 ||\n opts.fsChecker.rewrites.fallback.length > 0\n\n if (tsconfigChange) {\n config.resolve?.plugins?.forEach((plugin: any) => {\n // look for the JsConfigPathsPlugin and update with\n // the latest paths/baseUrl config\n if (plugin instanceof JsConfigPathsPlugin && tsconfigResult) {\n const { resolvedBaseUrl, jsConfig } = tsconfigResult\n const currentResolvedBaseUrl = plugin.resolvedBaseUrl\n const resolvedUrlIndex = config.resolve?.modules?.findIndex(\n (item) => item === currentResolvedBaseUrl?.baseUrl\n )\n\n if (resolvedBaseUrl) {\n if (\n resolvedBaseUrl.baseUrl !== currentResolvedBaseUrl?.baseUrl\n ) {\n // remove old baseUrl and add new one\n if (resolvedUrlIndex && resolvedUrlIndex > -1) {\n config.resolve?.modules?.splice(resolvedUrlIndex, 1)\n }\n\n // If the resolvedBaseUrl is implicit we only remove the previous value.\n // Only add the baseUrl if it's explicitly set in tsconfig/jsconfig\n if (!resolvedBaseUrl.isImplicit) {\n config.resolve?.modules?.push(resolvedBaseUrl.baseUrl)\n }\n }\n }\n\n if (jsConfig?.compilerOptions?.paths && resolvedBaseUrl) {\n Object.keys(plugin.paths).forEach((key) => {\n delete plugin.paths[key]\n })\n Object.assign(plugin.paths, jsConfig.compilerOptions.paths)\n plugin.resolvedBaseUrl = resolvedBaseUrl\n }\n }\n })\n }\n\n if (envChange) {\n config.plugins?.forEach((plugin: any) => {\n // we look for the DefinePlugin definitions so we can\n // update them on the active compilers\n if (\n plugin &&\n typeof plugin.definitions === 'object' &&\n plugin.definitions.__NEXT_DEFINE_ENV\n ) {\n const newDefine = getDefineEnv({\n isTurbopack: false,\n clientRouterFilters,\n config: nextConfig,\n dev: true,\n distDir,\n fetchCacheKeyPrefix:\n opts.nextConfig.experimental.fetchCacheKeyPrefix,\n hasRewrites,\n isClient,\n isEdgeServer,\n isNodeOrEdgeCompilation: isNodeServer || isEdgeServer,\n isNodeServer,\n middlewareMatchers: undefined,\n })\n\n Object.keys(plugin.definitions).forEach((key) => {\n if (!(key in newDefine)) {\n delete plugin.definitions[key]\n }\n })\n Object.assign(plugin.definitions, newDefine)\n }\n })\n }\n })\n await hotReloader.invalidate({\n reloadAfterInvalidation: envChange,\n })\n }\n\n if (nestedMiddleware.length > 0) {\n Log.error(\n new NestedMiddlewareError(\n nestedMiddleware,\n dir,\n (pagesDir || appDir)!\n ).message\n )\n nestedMiddleware = []\n }\n\n // Make sure to sort parallel routes to make the result deterministic.\n serverFields.appPathRoutes = Object.fromEntries(\n Object.entries(appPaths).map(([k, v]) => [k, v.sort()])\n )\n await propagateServerField(\n opts,\n 'appPathRoutes',\n serverFields.appPathRoutes\n )\n\n // TODO: pass this to fsChecker/next-dev-server?\n serverFields.middleware = middlewareMatchers\n ? {\n match: null as any,\n page: '/',\n matchers: middlewareMatchers,\n }\n : undefined\n\n await propagateServerField(opts, 'middleware', serverFields.middleware)\n serverFields.hasAppNotFound = hasRootAppNotFound\n\n opts.fsChecker.middlewareMatcher = serverFields.middleware?.matchers\n ? getMiddlewareRouteMatcher(serverFields.middleware?.matchers)\n : undefined\n\n const interceptionRoutes = generateInterceptionRoutesRewrites(\n Object.keys(appPaths),\n opts.nextConfig.basePath\n ).map((item) =>\n buildCustomRoute(\n 'before_files_rewrite',\n item,\n opts.nextConfig.basePath,\n opts.nextConfig.experimental.caseSensitiveRoutes\n )\n )\n\n opts.fsChecker.rewrites.beforeFiles.push(...interceptionRoutes)\n\n const exportPathMap =\n (typeof nextConfig.exportPathMap === 'function' &&\n (await nextConfig.exportPathMap?.(\n {},\n {\n dev: true,\n dir: opts.dir,\n outDir: null,\n distDir: distDir,\n buildId: 'development',\n }\n ))) ||\n {}\n\n const exportPathMapEntries = Object.entries(exportPathMap || {})\n\n if (exportPathMapEntries.length > 0) {\n opts.fsChecker.exportPathMapRoutes = exportPathMapEntries.map(\n ([key, value]) =>\n buildCustomRoute(\n 'before_files_rewrite',\n {\n source: key,\n destination: `${value.page}${\n value.query ? '?' : ''\n }${qs.stringify(value.query)}`,\n },\n opts.nextConfig.basePath,\n opts.nextConfig.experimental.caseSensitiveRoutes\n )\n )\n }\n\n try {\n // we serve a separate manifest with all pages for the client in\n // dev mode so that we can match a page after a rewrite on the client\n // before it has been built and is populated in the _buildManifest\n const sortedRoutes = getSortedRoutes(routedPages)\n\n opts.fsChecker.dynamicRoutes = sortedRoutes.map(\n (page): FilesystemDynamicRoute => {\n const regex = getRouteRegex(page)\n return {\n regex: regex.re.toString(),\n match: getRouteMatcher(regex),\n page,\n }\n }\n )\n\n const dataRoutes: typeof opts.fsChecker.dynamicRoutes = []\n\n for (const page of sortedRoutes) {\n const route = buildDataRoute(page, 'development')\n const routeRegex = getRouteRegex(route.page)\n dataRoutes.push({\n ...route,\n regex: routeRegex.re.toString(),\n match: getRouteMatcher({\n // TODO: fix this in the manifest itself, must also be fixed in\n // upstream builder that relies on this\n re: opts.nextConfig.i18n\n ? new RegExp(\n route.dataRouteRegex.replace(\n `/development/`,\n `/development/(?<nextLocale>[^/]+?)/`\n )\n )\n : new RegExp(route.dataRouteRegex),\n groups: routeRegex.groups,\n }),\n })\n }\n opts.fsChecker.dynamicRoutes.unshift(...dataRoutes)\n\n if (!prevSortedRoutes?.every((val, idx) => val === sortedRoutes[idx])) {\n const addedRoutes = sortedRoutes.filter(\n (route) => !prevSortedRoutes.includes(route)\n )\n const removedRoutes = prevSortedRoutes.filter(\n (route) => !sortedRoutes.includes(route)\n )\n\n // emit the change so clients fetch the update\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.DEV_PAGES_MANIFEST_UPDATE,\n data: [\n {\n devPagesManifest: true,\n },\n ],\n })\n\n addedRoutes.forEach((route) => {\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.ADDED_PAGE,\n data: [route],\n })\n })\n\n removedRoutes.forEach((route) => {\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.REMOVED_PAGE,\n data: [route],\n })\n })\n }\n prevSortedRoutes = sortedRoutes\n\n if (!resolved) {\n resolve()\n resolved = true\n }\n } catch (e) {\n if (!resolved) {\n reject(e)\n resolved = true\n } else {\n Log.warn('Failed to reload dynamic routes:', e)\n }\n } finally {\n // Reload the matchers. The filesystem would have been written to,\n // and the matchers need to re-scan it to update the router.\n await propagateServerField(opts, 'reloadMatchers', undefined)\n }\n })\n\n wp.watch({ directories: [dir], startTime: 0 })\n })\n\n const clientPagesManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${DEV_CLIENT_PAGES_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(clientPagesManifestPath)\n\n const devMiddlewareManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${DEV_CLIENT_MIDDLEWARE_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(devMiddlewareManifestPath)\n\n async function requestHandler(req: IncomingMessage, res: ServerResponse) {\n const parsedUrl = url.parse(req.url || '/')\n\n if (parsedUrl.pathname?.includes(clientPagesManifestPath)) {\n res.statusCode = 200\n res.setHeader('Content-Type', 'application/json; charset=utf-8')\n res.end(\n JSON.stringify({\n pages: prevSortedRoutes.filter(\n (route) => !opts.fsChecker.appFiles.has(route)\n ),\n })\n )\n return { finished: true }\n }\n\n if (parsedUrl.pathname?.includes(devMiddlewareManifestPath)) {\n res.statusCode = 200\n res.setHeader('Content-Type', 'application/json; charset=utf-8')\n res.end(JSON.stringify(serverFields.middleware?.matchers || []))\n return { finished: true }\n }\n return { finished: false }\n }\n\n async function logErrorWithOriginalStack(\n err: unknown,\n type?: 'unhandledRejection' | 'uncaughtException' | 'warning' | 'app-dir'\n ) {\n let usedOriginalStack = false\n\n if (isError(err) && err.stack) {\n try {\n const frames = parseStack(err.stack!)\n // Filter out internal edge related runtime stack\n const frame = frames.find(\n ({ file }) =>\n !file?.startsWith('eval') &&\n !file?.includes('web/adapter') &&\n !file?.includes('web/globals') &&\n !file?.includes('sandbox/context') &&\n !file?.includes('<anonymous>')\n )\n\n let originalFrame: OriginalStackFrameResponse | null = null\n let isEdgeCompiler = false\n const frameFile = frame?.file\n if (frame?.lineNumber && frameFile) {\n if (hotReloader.turbopackProject) {\n try {\n originalFrame = await createOriginalTurboStackFrame(\n hotReloader.turbopackProject,\n {\n file: frameFile,\n methodName: frame.methodName,\n line: frame.lineNumber ?? 0,\n column: frame.column ?? undefined,\n isServer: true,\n }\n )\n } catch {}\n } else {\n const moduleId = frameFile.replace(\n /^(webpack-internal:\\/\\/\\/|file:\\/\\/)/,\n ''\n )\n const modulePath = frameFile.replace(\n /^(webpack-internal:\\/\\/\\/|file:\\/\\/)(\\(.*\\)\\/)?/,\n ''\n )\n\n const src = getErrorSource(err as Error)\n isEdgeCompiler = src === COMPILER_NAMES.edgeServer\n const compilation = (\n isEdgeCompiler\n ? hotReloader.edgeServerStats?.compilation\n : hotReloader.serverStats?.compilation\n )!\n\n const sourceMap = await (frame.file?.startsWith(path.sep) ||\n frame.file?.startsWith('file:')\n ? getSourceMapFromFile(frame.file)\n : getSourceMapFromCompilation(moduleId, compilation))\n\n if (sourceMap) {\n try {\n originalFrame = await createOriginalStackFrame({\n source: {\n type: 'bundle',\n sourceMap,\n compilation,\n moduleId,\n modulePath,\n },\n frame,\n rootDirectory: opts.dir,\n errorMessage: err.message,\n })\n } catch {}\n }\n }\n\n if (\n originalFrame?.originalCodeFrame &&\n originalFrame.originalStackFrame\n ) {\n const { originalCodeFrame, originalStackFrame } = originalFrame\n const { file, lineNumber, column, methodName } = originalStackFrame\n\n Log[type === 'warning' ? 'warn' : 'error'](\n `${file} (${lineNumber}:${column}) @ ${methodName}`\n )\n\n let errorToLog\n if (isEdgeCompiler) {\n errorToLog = err.message\n } else if (isError(err) && hotReloader.turbopackProject) {\n const stack = await traceTurbopackErrorStack(\n hotReloader.turbopackProject,\n err,\n frames\n )\n\n const error: NextError = new Error(err.message)\n error.stack = stack\n error.digest = err.digest\n errorToLog = error\n } else {\n errorToLog = err\n }\n\n logError(errorToLog, type)\n console[type === 'warning' ? 'warn' : 'error'](originalCodeFrame)\n usedOriginalStack = true\n }\n }\n } catch (_) {\n // failed to load original stack using source maps\n // this un-actionable by users so we don't show the\n // internal error and only show the provided stack\n }\n }\n\n if (!usedOriginalStack) {\n logError(err, type)\n }\n }\n\n return {\n serverFields,\n hotReloader,\n requestHandler,\n logErrorWithOriginalStack,\n\n async ensureMiddleware(requestUrl?: string) {\n if (!serverFields.actualMiddlewareFile) return\n return hotReloader.ensurePage({\n page: serverFields.actualMiddlewareFile,\n clientOnly: false,\n definition: undefined,\n url: requestUrl,\n })\n },\n }\n}\n\nfunction logError(\n err: unknown,\n type?: 'unhandledRejection' | 'uncaughtException' | 'warning' | 'app-dir'\n) {\n if (err instanceof ModuleBuildError) {\n // Errors that may come from issues from the user's code\n Log.error(err.message)\n } else if (err instanceof TurbopackInternalError) {\n // An internal Turbopack error that has been handled by next-swc, written\n // to disk and a simplified message shown to user on the Rust side.\n } else if (type === 'warning') {\n Log.warn(err)\n } else if (type === 'app-dir') {\n logAppDirError(err)\n } else if (type) {\n Log.error(`${type}:`, err)\n } else {\n Log.error(err)\n }\n}\n\nexport async function setupDevBundler(opts: SetupOpts) {\n const isSrcDir = path\n .relative(opts.dir, opts.pagesDir || opts.appDir || '')\n .startsWith('src')\n\n const result = await startWatcher(opts)\n\n opts.telemetry.record(\n eventCliSession(\n path.join(opts.dir, opts.nextConfig.distDir),\n opts.nextConfig,\n {\n webpackVersion: 5,\n isSrcDir,\n turboFlag: !!opts.turbo,\n cliCommand: 'dev',\n appDir: !!opts.appDir,\n pagesDir: !!opts.pagesDir,\n isCustomServer: !!opts.isCustomServer,\n hasNowJson: !!(await findUp('now.json', { cwd: opts.dir })),\n }\n )\n )\n return result\n}\n\nexport type DevBundler = Awaited<ReturnType<typeof setupDevBundler>>\n\n// Returns a trace rewritten through Turbopack's sourcemaps\nasync function traceTurbopackErrorStack(\n project: Project,\n error: Error,\n frames: StackFrame[]\n): Promise<string> {\n let originalFrames = await Promise.all(\n frames.map(async (f) => {\n try {\n const traced = await batchedTraceSource(project, {\n file: f.file!,\n methodName: f.methodName,\n line: f.lineNumber ?? 0,\n column: f.column ?? undefined,\n isServer: true,\n })\n\n return traced?.frame ?? f\n } catch {\n return f\n }\n })\n )\n\n return (\n error.name +\n ': ' +\n error.message +\n '\\n' +\n originalFrames\n .map((f) => {\n if (f == null) {\n return null\n }\n\n let line = ' at'\n if (f.methodName != null) {\n line += ' ' + f.methodName\n }\n\n if (f.file != null) {\n const file =\n f.file.startsWith('/') ||\n // Built-in \"filenames\" like `<anonymous>` shouldn't be made relative\n f.file.startsWith('<') ||\n f.file.startsWith('node:')\n ? f.file\n : `./${f.file}`\n\n line += ` (${file}`\n if (f.lineNumber != null) {\n line += ':' + f.lineNumber\n\n if (f.column != null) {\n line += ':' + f.column\n }\n }\n line += ')'\n }\n\n return line\n })\n .filter(Boolean)\n .join('\\n')\n )\n}\n"],"names":["getPageStaticInfo","createDefineEnv","fs","mkdir","url","path","qs","Watchpack","loadEnvConfig","isError","findUp","buildCustomRoute","Log","HotReloaderWebpack","setGlobal","loadJsConfig","createValidFileMatcher","eventCliSession","getDefineEnv","logAppDirError","getSortedRoutes","getStaticInfoIncludingLayouts","sortByPageExts","verifyTypeScriptSetup","verifyPartytownSetup","getRouteRegex","normalizeAppPath","buildDataRoute","getRouteMatcher","normalizePathSep","createClientRouterFilter","absolutePathToPage","generateInterceptionRoutesRewrites","CLIENT_STATIC_FILES_PATH","COMPILER_NAMES","DEV_CLIENT_PAGES_MANIFEST","DEV_CLIENT_MIDDLEWARE_MANIFEST","PHASE_DEVELOPMENT_SERVER","getMiddlewareRouteMatcher","isMiddlewareFile","NestedMiddlewareError","isInstrumentationHookFile","getPossibleMiddlewareFilenames","getPossibleInstrumentationHookFilenames","createOriginalStackFrame","getSourceMapFromCompilation","getSourceMapFromFile","parseStack","batchedTraceSource","createOriginalTurboStackFrame","devPageFiles","HMR_ACTIONS_SENT_TO_BROWSER","PAGE_TYPES","createHotReloaderTurbopack","getErrorSource","generateEncryptionKeyBase64","ModuleBuildError","TurbopackInternalError","isMetadataRouteFile","normalizeMetadataPageToRoute","createEnvDefinitions","JsConfigPathsPlugin","store","consoleStore","verifyTypeScript","opts","usingTypeScript","verifyResult","dir","distDir","nextConfig","intentDirs","pagesDir","appDir","filter","Boolean","typeCheckPreflight","tsconfigPath","typescript","disableStaticImages","images","hasAppDir","hasPagesDir","version","propagateServerField","field","args","renderServer","instance","startWatcher","resetFetch","useFileSystemPublicRoutes","join","distTypesDir","existsSync","recursive","validFileMatcher","pageExtensions","serverFields","setState","logging","hotReloader","turbo","config","buildId","encryptionKey","isBuild","telemetry","rewrites","fsChecker","previewProps","prerenderManifest","preview","start","experimental","nextScriptWorkers","ensureCallback","ensure","item","type","ensurePage","clientOnly","page","itemPath","isApp","definition","undefined","resolved","prevSortedRoutes","Promise","resolve","reject","readdir","_","files","length","pages","app","directories","rootDir","nestedMiddleware","envFiles","map","file","push","tsconfigPaths","wp","ignored","pathname","some","startsWith","d","fileWatchTimes","Map","enabledTypeScript","previousClientRouterFilters","previousConflictingPagePaths","Set","on","middlewareMatchers","routedPages","knownFiles","getTimeInfoEntries","appPaths","pageNameSet","conflictingAppPagePaths","appPageFilePaths","pagesPageFilePaths","pagesWithUnsupportedSegments","envChange","tsconfigChange","conflictingPageChange","hasRootAppNotFound","appFiles","pageFiles","clear","sortedKnownFiles","keys","sort","fileName","includes","meta","get","watchTime","watchTimeChange","timestamp","set","endsWith","accuracy","isPageFile","isAppPath","isPagePath","rootFile","extensions","keepIndex","pagesType","ROOT","staticInfo","pageFilePath","isDev","isInsideAppDir","output","error","actualMiddlewareFile","middleware","matchers","regexp","originalSource","actualInstrumentationHookFile","add","pageName","APP","PAGES","replace","pageType","generateSitemaps","generateImageMetadata","isRootNotFound","isAppRouterPage","originalPageName","nextDataRoutes","has","test","numConflicting","size","errorMessage","p","appPath","relative","pagesPath","setHmrServerError","Error","clearHmrServerError","clientRouterFilters","clientRouterFilter","Object","clientRouterFilterRedirects","_originalRedirects","r","internal","clientRouterFilterAllowedRate","JSON","stringify","then","catch","parsedEnv","envFilePath","info","typedEnv","env","dev","forceReload","silent","tsconfigResult","turbopackProject","hasRewrites","afterFiles","beforeFiles","fallback","update","defineEnv","isTurbopack","fetchCacheKeyPrefix","activeWebpackConfigs","forEach","idx","isClient","isNodeServer","isEdgeServer","plugins","plugin","jsConfig","resolvedBaseUrl","currentResolvedBaseUrl","resolvedUrlIndex","modules","findIndex","baseUrl","splice","isImplicit","compilerOptions","paths","key","assign","definitions","__NEXT_DEFINE_ENV","newDefine","isNodeOrEdgeCompilation","invalidate","reloadAfterInvalidation","message","appPathRoutes","fromEntries","entries","k","v","match","hasAppNotFound","middlewareMatcher","interceptionRoutes","basePath","caseSensitiveRoutes","exportPathMap","outDir","exportPathMapEntries","exportPathMapRoutes","value","source","destination","query","sortedRoutes","dynamicRoutes","regex","re","toString","dataRoutes","route","routeRegex","i18n","RegExp","dataRouteRegex","groups","unshift","every","val","addedRoutes","removedRoutes","send","action","DEV_PAGES_MANIFEST_UPDATE","data","devPagesManifest","ADDED_PAGE","REMOVED_PAGE","e","warn","watch","startTime","clientPagesManifestPath","devVirtualFsItems","devMiddlewareManifestPath","requestHandler","req","res","parsedUrl","parse","statusCode","setHeader","end","finished","logErrorWithOriginalStack","err","usedOriginalStack","stack","frames","frame","find","originalFrame","isEdgeCompiler","frameFile","lineNumber","methodName","line","column","isServer","moduleId","modulePath","src","edgeServer","compilation","edgeServerStats","serverStats","sourceMap","sep","rootDirectory","originalCodeFrame","originalStackFrame","errorToLog","traceTurbopackErrorStack","digest","logError","console","ensureMiddleware","requestUrl","setupDevBundler","isSrcDir","result","record","webpackVersion","turboFlag","cliCommand","isCustomServer","hasNowJson","cwd","project","originalFrames","all","f","traced","name"],"mappings":"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"}
1
+ {"version":3,"sources":["../../../../src/server/lib/router-utils/setup-dev-bundler.ts"],"sourcesContent":["import type { NextConfigComplete } from '../../config-shared'\nimport type { FilesystemDynamicRoute } from './filesystem'\nimport type { UnwrapPromise } from '../../../lib/coalesced-function'\nimport {\n getPageStaticInfo,\n type MiddlewareMatcher,\n} from '../../../build/analysis/get-page-static-info'\nimport type { MiddlewareRouteMatch } from '../../../shared/lib/router/utils/middleware-route-matcher'\nimport type { PropagateToWorkersField } from './types'\nimport type { NextJsHotReloaderInterface } from '../../dev/hot-reloader-types'\n\nimport { createDefineEnv } from '../../../build/swc'\nimport type { Project } from '../../../build/swc/types'\nimport fs from 'fs'\nimport { mkdir } from 'fs/promises'\nimport url from 'url'\nimport path from 'path'\nimport qs from 'querystring'\nimport Watchpack from 'next/dist/compiled/watchpack'\nimport { loadEnvConfig } from '@next/env'\nimport isError, { type NextError } from '../../../lib/is-error'\nimport findUp from 'next/dist/compiled/find-up'\nimport { buildCustomRoute } from './filesystem'\nimport * as Log from '../../../build/output/log'\nimport HotReloaderWebpack from '../../dev/hot-reloader-webpack'\nimport { setGlobal } from '../../../trace/shared'\nimport type { Telemetry } from '../../../telemetry/storage'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport loadJsConfig from '../../../build/load-jsconfig'\nimport { createValidFileMatcher } from '../find-page-file'\nimport { eventCliSession } from '../../../telemetry/events'\nimport { getDefineEnv } from '../../../build/webpack/plugins/define-env-plugin'\nimport { logAppDirError } from '../../dev/log-app-dir-error'\nimport { getSortedRoutes } from '../../../shared/lib/router/utils'\nimport {\n getStaticInfoIncludingLayouts,\n sortByPageExts,\n} from '../../../build/entries'\nimport { verifyTypeScriptSetup } from '../../../lib/verify-typescript-setup'\nimport { verifyPartytownSetup } from '../../../lib/verify-partytown-setup'\nimport { getRouteRegex } from '../../../shared/lib/router/utils/route-regex'\nimport { normalizeAppPath } from '../../../shared/lib/router/utils/app-paths'\nimport { buildDataRoute } from './build-data-route'\nimport { getRouteMatcher } from '../../../shared/lib/router/utils/route-matcher'\nimport { normalizePathSep } from '../../../shared/lib/page-path/normalize-path-sep'\nimport { createClientRouterFilter } from '../../../lib/create-client-router-filter'\nimport { absolutePathToPage } from '../../../shared/lib/page-path/absolute-path-to-page'\nimport { generateInterceptionRoutesRewrites } from '../../../lib/generate-interception-routes-rewrites'\n\nimport {\n CLIENT_STATIC_FILES_PATH,\n COMPILER_NAMES,\n DEV_CLIENT_PAGES_MANIFEST,\n DEV_CLIENT_MIDDLEWARE_MANIFEST,\n PHASE_DEVELOPMENT_SERVER,\n} from '../../../shared/lib/constants'\n\nimport { getMiddlewareRouteMatcher } from '../../../shared/lib/router/utils/middleware-route-matcher'\n\nimport {\n isMiddlewareFile,\n NestedMiddlewareError,\n isInstrumentationHookFile,\n getPossibleMiddlewareFilenames,\n getPossibleInstrumentationHookFilenames,\n} from '../../../build/utils'\nimport {\n createOriginalStackFrame,\n getSourceMapFromCompilation,\n getSourceMapFromFile,\n parseStack,\n} from '../../../client/components/react-dev-overlay/server/middleware'\nimport {\n batchedTraceSource,\n createOriginalStackFrame as createOriginalTurboStackFrame,\n} from '../../../client/components/react-dev-overlay/server/middleware-turbopack'\nimport type { OriginalStackFrameResponse } from '../../../client/components/react-dev-overlay/server/shared'\nimport { devPageFiles } from '../../../build/webpack/plugins/next-types-plugin/shared'\nimport type { LazyRenderServerInstance } from '../router-server'\nimport { HMR_ACTIONS_SENT_TO_BROWSER } from '../../dev/hot-reloader-types'\nimport { PAGE_TYPES } from '../../../lib/page-types'\nimport { createHotReloaderTurbopack } from '../../dev/hot-reloader-turbopack'\nimport { getErrorSource } from '../../../shared/lib/error-source'\nimport type { StackFrame } from 'next/dist/compiled/stacktrace-parser'\nimport { generateEncryptionKeyBase64 } from '../../app-render/encryption-utils-server'\nimport {\n ModuleBuildError,\n TurbopackInternalError,\n} from '../../dev/turbopack-utils'\nimport { isMetadataRouteFile } from '../../../lib/metadata/is-metadata-route'\nimport { normalizeMetadataPageToRoute } from '../../../lib/metadata/get-metadata-route'\nimport { createEnvDefinitions } from '../experimental/create-env-definitions'\nimport { JsConfigPathsPlugin } from '../../../build/webpack/plugins/jsconfig-paths-plugin'\nimport { store as consoleStore } from '../../../build/output/store'\n\nexport type SetupOpts = {\n renderServer: LazyRenderServerInstance\n dir: string\n turbo?: boolean\n appDir?: string\n pagesDir?: string\n telemetry: Telemetry\n isCustomServer?: boolean\n fsChecker: UnwrapPromise<\n ReturnType<typeof import('./filesystem').setupFsCheck>\n >\n nextConfig: NextConfigComplete\n port: number\n onCleanup: (listener: () => Promise<void>) => void\n resetFetch: () => void\n}\n\nexport type ServerFields = {\n actualMiddlewareFile?: string | undefined\n actualInstrumentationHookFile?: string | undefined\n appPathRoutes?: Record<string, string | string[]>\n middleware?:\n | {\n page: string\n match: MiddlewareRouteMatch\n matchers?: MiddlewareMatcher[]\n }\n | undefined\n hasAppNotFound?: boolean\n interceptionRoutes?: ReturnType<\n typeof import('./filesystem').buildCustomRoute\n >[]\n setAppIsrStatus?: (key: string, value: boolean) => void\n resetFetch?: () => void\n}\n\nasync function verifyTypeScript(opts: SetupOpts) {\n let usingTypeScript = false\n const verifyResult = await verifyTypeScriptSetup({\n dir: opts.dir,\n distDir: opts.nextConfig.distDir,\n intentDirs: [opts.pagesDir, opts.appDir].filter(Boolean) as string[],\n typeCheckPreflight: false,\n tsconfigPath: opts.nextConfig.typescript.tsconfigPath,\n disableStaticImages: opts.nextConfig.images.disableStaticImages,\n hasAppDir: !!opts.appDir,\n hasPagesDir: !!opts.pagesDir,\n })\n\n if (verifyResult.version) {\n usingTypeScript = true\n }\n return usingTypeScript\n}\n\nexport async function propagateServerField(\n opts: SetupOpts,\n field: PropagateToWorkersField,\n args: any\n) {\n await opts.renderServer?.instance?.propagateServerField(opts.dir, field, args)\n}\n\nasync function startWatcher(opts: SetupOpts) {\n const { nextConfig, appDir, pagesDir, dir, resetFetch } = opts\n const { useFileSystemPublicRoutes } = nextConfig\n const usingTypeScript = await verifyTypeScript(opts)\n\n const distDir = path.join(opts.dir, opts.nextConfig.distDir)\n\n // we ensure the types directory exists here\n if (usingTypeScript) {\n const distTypesDir = path.join(distDir, 'types')\n if (!fs.existsSync(distTypesDir)) {\n await mkdir(distTypesDir, { recursive: true })\n }\n }\n\n setGlobal('distDir', distDir)\n setGlobal('phase', PHASE_DEVELOPMENT_SERVER)\n\n const validFileMatcher = createValidFileMatcher(\n nextConfig.pageExtensions,\n appDir\n )\n\n const serverFields: ServerFields = {}\n\n // Update logging state once based on next.config.js when initializing\n consoleStore.setState({\n logging: nextConfig.logging !== false,\n })\n\n const hotReloader: NextJsHotReloaderInterface = opts.turbo\n ? await createHotReloaderTurbopack(opts, serverFields, distDir, resetFetch)\n : new HotReloaderWebpack(opts.dir, {\n appDir,\n pagesDir,\n distDir,\n config: opts.nextConfig,\n buildId: 'development',\n encryptionKey: await generateEncryptionKeyBase64({\n isBuild: false,\n distDir,\n }),\n telemetry: opts.telemetry,\n rewrites: opts.fsChecker.rewrites,\n previewProps: opts.fsChecker.prerenderManifest.preview,\n resetFetch,\n })\n\n await hotReloader.start()\n\n if (opts.nextConfig.experimental.nextScriptWorkers) {\n await verifyPartytownSetup(\n opts.dir,\n path.join(distDir, CLIENT_STATIC_FILES_PATH)\n )\n }\n\n opts.fsChecker.ensureCallback(async function ensure(item) {\n if (item.type === 'appFile' || item.type === 'pageFile') {\n await hotReloader.ensurePage({\n clientOnly: false,\n page: item.itemPath,\n isApp: item.type === 'appFile',\n definition: undefined,\n })\n }\n })\n\n let resolved = false\n let prevSortedRoutes: string[] = []\n\n await new Promise<void>(async (resolve, reject) => {\n if (pagesDir) {\n // Watchpack doesn't emit an event for an empty directory\n fs.readdir(pagesDir, (_, files) => {\n if (files?.length) {\n return\n }\n\n if (!resolved) {\n resolve()\n resolved = true\n }\n })\n }\n\n const pages = pagesDir ? [pagesDir] : []\n const app = appDir ? [appDir] : []\n const directories = [...pages, ...app]\n\n const rootDir = pagesDir || appDir\n const files = [\n ...getPossibleMiddlewareFilenames(\n path.join(rootDir!, '..'),\n nextConfig.pageExtensions\n ),\n ...getPossibleInstrumentationHookFilenames(\n path.join(rootDir!, '..'),\n nextConfig.pageExtensions\n ),\n ]\n let nestedMiddleware: string[] = []\n\n const envFiles = [\n '.env.development.local',\n '.env.local',\n '.env.development',\n '.env',\n ].map((file) => path.join(dir, file))\n\n files.push(...envFiles)\n\n // tsconfig/jsconfig paths hot-reloading\n const tsconfigPaths = [\n path.join(dir, 'tsconfig.json'),\n path.join(dir, 'jsconfig.json'),\n ] as const\n files.push(...tsconfigPaths)\n\n const wp = new Watchpack({\n ignored: (pathname: string) => {\n return (\n !files.some((file) => file.startsWith(pathname)) &&\n !directories.some(\n (d) => pathname.startsWith(d) || d.startsWith(pathname)\n )\n )\n },\n })\n const fileWatchTimes = new Map()\n let enabledTypeScript = usingTypeScript\n let previousClientRouterFilters: any\n let previousConflictingPagePaths: Set<string> = new Set()\n\n wp.on('aggregated', async () => {\n let middlewareMatchers: MiddlewareMatcher[] | undefined\n const routedPages: string[] = []\n const knownFiles = wp.getTimeInfoEntries()\n const appPaths: Record<string, string[]> = {}\n const pageNameSet = new Set<string>()\n const conflictingAppPagePaths = new Set<string>()\n const appPageFilePaths = new Map<string, string>()\n const pagesPageFilePaths = new Map<string, string>()\n const pagesWithUnsupportedSegments = new Map<string, string[]>()\n\n let envChange = false\n let tsconfigChange = false\n let conflictingPageChange = 0\n let hasRootAppNotFound = false\n\n const { appFiles, pageFiles } = opts.fsChecker\n\n appFiles.clear()\n pageFiles.clear()\n devPageFiles.clear()\n pagesWithUnsupportedSegments.clear()\n\n const sortedKnownFiles: string[] = [...knownFiles.keys()].sort(\n sortByPageExts(nextConfig.pageExtensions)\n )\n\n for (const fileName of sortedKnownFiles) {\n if (\n !files.includes(fileName) &&\n !directories.some((d) => fileName.startsWith(d))\n ) {\n continue\n }\n const meta = knownFiles.get(fileName)\n\n const watchTime = fileWatchTimes.get(fileName)\n // If the file is showing up for the first time or the meta.timestamp is changed since last time\n const watchTimeChange =\n watchTime === undefined ||\n (watchTime && watchTime !== meta?.timestamp)\n fileWatchTimes.set(fileName, meta?.timestamp)\n\n if (envFiles.includes(fileName)) {\n if (watchTimeChange) {\n envChange = true\n }\n continue\n }\n\n if (tsconfigPaths.includes(fileName)) {\n if (fileName.endsWith('tsconfig.json')) {\n enabledTypeScript = true\n }\n if (watchTimeChange) {\n tsconfigChange = true\n }\n continue\n }\n\n if (\n meta?.accuracy === undefined ||\n !validFileMatcher.isPageFile(fileName)\n ) {\n continue\n }\n\n const isAppPath = Boolean(\n appDir &&\n normalizePathSep(fileName).startsWith(\n normalizePathSep(appDir) + '/'\n )\n )\n const isPagePath = Boolean(\n pagesDir &&\n normalizePathSep(fileName).startsWith(\n normalizePathSep(pagesDir) + '/'\n )\n )\n\n const rootFile = absolutePathToPage(fileName, {\n dir: dir,\n extensions: nextConfig.pageExtensions,\n keepIndex: false,\n pagesType: PAGE_TYPES.ROOT,\n })\n\n if (isMiddlewareFile(rootFile)) {\n const staticInfo = await getStaticInfoIncludingLayouts({\n pageFilePath: fileName,\n config: nextConfig,\n appDir: appDir,\n page: rootFile,\n isDev: true,\n isInsideAppDir: isAppPath,\n pageExtensions: nextConfig.pageExtensions,\n })\n if (nextConfig.output === 'export') {\n Log.error(\n 'Middleware cannot be used with \"output: export\". See more info here: https://nextjs.org/docs/advanced-features/static-html-export'\n )\n continue\n }\n serverFields.actualMiddlewareFile = rootFile\n await propagateServerField(\n opts,\n 'actualMiddlewareFile',\n serverFields.actualMiddlewareFile\n )\n middlewareMatchers = staticInfo.middleware?.matchers || [\n { regexp: '.*', originalSource: '/:path*' },\n ]\n continue\n }\n if (isInstrumentationHookFile(rootFile)) {\n serverFields.actualInstrumentationHookFile = rootFile\n await propagateServerField(\n opts,\n 'actualInstrumentationHookFile',\n serverFields.actualInstrumentationHookFile\n )\n continue\n }\n\n if (fileName.endsWith('.ts') || fileName.endsWith('.tsx')) {\n enabledTypeScript = true\n }\n\n if (!(isAppPath || isPagePath)) {\n continue\n }\n\n // Collect all current filenames for the TS plugin to use\n devPageFiles.add(fileName)\n\n let pageName = absolutePathToPage(fileName, {\n dir: isAppPath ? appDir! : pagesDir!,\n extensions: nextConfig.pageExtensions,\n keepIndex: isAppPath,\n pagesType: isAppPath ? PAGE_TYPES.APP : PAGE_TYPES.PAGES,\n })\n\n if (\n isAppPath &&\n appDir &&\n isMetadataRouteFile(\n fileName.replace(appDir, ''),\n nextConfig.pageExtensions,\n true\n )\n ) {\n const staticInfo = await getPageStaticInfo({\n pageFilePath: fileName,\n nextConfig: {},\n page: pageName,\n isDev: true,\n pageType: PAGE_TYPES.APP,\n })\n\n pageName = normalizeMetadataPageToRoute(\n pageName,\n !!(staticInfo.generateSitemaps || staticInfo.generateImageMetadata)\n )\n }\n\n if (\n !isAppPath &&\n pageName.startsWith('/api/') &&\n nextConfig.output === 'export'\n ) {\n Log.error(\n 'API Routes cannot be used with \"output: export\". See more info here: https://nextjs.org/docs/advanced-features/static-html-export'\n )\n continue\n }\n\n if (isAppPath) {\n const isRootNotFound = validFileMatcher.isRootNotFound(fileName)\n hasRootAppNotFound = true\n\n if (isRootNotFound) {\n continue\n }\n if (!isRootNotFound && !validFileMatcher.isAppRouterPage(fileName)) {\n continue\n }\n // Ignore files/directories starting with `_` in the app directory\n if (normalizePathSep(pageName).includes('/_')) {\n continue\n }\n\n const originalPageName = pageName\n pageName = normalizeAppPath(pageName).replace(/%5F/g, '_')\n if (!appPaths[pageName]) {\n appPaths[pageName] = []\n }\n appPaths[pageName].push(originalPageName)\n\n if (useFileSystemPublicRoutes) {\n appFiles.add(pageName)\n }\n\n if (routedPages.includes(pageName)) {\n continue\n }\n } else {\n if (useFileSystemPublicRoutes) {\n pageFiles.add(pageName)\n // always add to nextDataRoutes for now but in future only add\n // entries that actually use getStaticProps/getServerSideProps\n opts.fsChecker.nextDataRoutes.add(pageName)\n }\n }\n ;(isAppPath ? appPageFilePaths : pagesPageFilePaths).set(\n pageName,\n fileName\n )\n\n if (appDir && pageNameSet.has(pageName)) {\n conflictingAppPagePaths.add(pageName)\n } else {\n pageNameSet.add(pageName)\n }\n\n /**\n * If there is a middleware that is not declared in the root we will\n * warn without adding it so it doesn't make its way into the system.\n */\n if (/[\\\\\\\\/]_middleware$/.test(pageName)) {\n nestedMiddleware.push(pageName)\n continue\n }\n\n routedPages.push(pageName)\n }\n\n const numConflicting = conflictingAppPagePaths.size\n conflictingPageChange = numConflicting - previousConflictingPagePaths.size\n\n if (conflictingPageChange !== 0) {\n if (numConflicting > 0) {\n let errorMessage = `Conflicting app and page file${\n numConflicting === 1 ? ' was' : 's were'\n } found, please remove the conflicting files to continue:\\n`\n\n for (const p of conflictingAppPagePaths) {\n const appPath = path.relative(dir, appPageFilePaths.get(p)!)\n const pagesPath = path.relative(dir, pagesPageFilePaths.get(p)!)\n errorMessage += ` \"${pagesPath}\" - \"${appPath}\"\\n`\n }\n hotReloader.setHmrServerError(new Error(errorMessage))\n } else if (numConflicting === 0) {\n hotReloader.clearHmrServerError()\n await propagateServerField(opts, 'reloadMatchers', undefined)\n }\n }\n\n previousConflictingPagePaths = conflictingAppPagePaths\n\n let clientRouterFilters: any\n if (nextConfig.experimental.clientRouterFilter) {\n clientRouterFilters = createClientRouterFilter(\n Object.keys(appPaths),\n nextConfig.experimental.clientRouterFilterRedirects\n ? ((nextConfig as any)._originalRedirects || []).filter(\n (r: any) => !r.internal\n )\n : [],\n nextConfig.experimental.clientRouterFilterAllowedRate\n )\n\n if (\n !previousClientRouterFilters ||\n JSON.stringify(previousClientRouterFilters) !==\n JSON.stringify(clientRouterFilters)\n ) {\n envChange = true\n previousClientRouterFilters = clientRouterFilters\n }\n }\n\n if (!usingTypeScript && enabledTypeScript) {\n // we tolerate the error here as this is best effort\n // and the manual install command will be shown\n await verifyTypeScript(opts)\n .then(() => {\n tsconfigChange = true\n })\n .catch(() => {})\n }\n\n if (envChange || tsconfigChange) {\n if (envChange) {\n const { loadedEnvFiles } = loadEnvConfig(\n dir,\n process.env.NODE_ENV === 'development',\n Log,\n true,\n (envFilePath) => {\n Log.info(`Reload env: ${envFilePath}`)\n }\n )\n\n if (usingTypeScript && nextConfig.experimental?.typedEnv) {\n // do not await, this is not essential for further process\n createEnvDefinitions({\n distDir,\n loadedEnvFiles: [\n ...loadedEnvFiles,\n {\n path: nextConfig.configFileName,\n env: nextConfig.env,\n contents: '',\n },\n ],\n })\n }\n\n await propagateServerField(opts, 'loadEnvConfig', [\n { dev: true, forceReload: true, silent: true },\n ])\n }\n let tsconfigResult:\n | UnwrapPromise<ReturnType<typeof loadJsConfig>>\n | undefined\n\n if (tsconfigChange) {\n try {\n tsconfigResult = await loadJsConfig(dir, nextConfig)\n } catch (_) {\n /* do we want to log if there are syntax errors in tsconfig while editing? */\n }\n }\n\n if (hotReloader.turbopackProject) {\n const hasRewrites =\n opts.fsChecker.rewrites.afterFiles.length > 0 ||\n opts.fsChecker.rewrites.beforeFiles.length > 0 ||\n opts.fsChecker.rewrites.fallback.length > 0\n\n await hotReloader.turbopackProject.update({\n defineEnv: createDefineEnv({\n isTurbopack: true,\n clientRouterFilters,\n config: nextConfig,\n dev: true,\n distDir,\n fetchCacheKeyPrefix:\n opts.nextConfig.experimental.fetchCacheKeyPrefix,\n hasRewrites,\n // TODO: Implement\n middlewareMatchers: undefined,\n }),\n })\n }\n\n hotReloader.activeWebpackConfigs?.forEach((config, idx) => {\n const isClient = idx === 0\n const isNodeServer = idx === 1\n const isEdgeServer = idx === 2\n const hasRewrites =\n opts.fsChecker.rewrites.afterFiles.length > 0 ||\n opts.fsChecker.rewrites.beforeFiles.length > 0 ||\n opts.fsChecker.rewrites.fallback.length > 0\n\n if (tsconfigChange) {\n config.resolve?.plugins?.forEach((plugin: any) => {\n // look for the JsConfigPathsPlugin and update with\n // the latest paths/baseUrl config\n if (plugin instanceof JsConfigPathsPlugin && tsconfigResult) {\n const { resolvedBaseUrl, jsConfig } = tsconfigResult\n const currentResolvedBaseUrl = plugin.resolvedBaseUrl\n const resolvedUrlIndex = config.resolve?.modules?.findIndex(\n (item) => item === currentResolvedBaseUrl?.baseUrl\n )\n\n if (resolvedBaseUrl) {\n if (\n resolvedBaseUrl.baseUrl !== currentResolvedBaseUrl?.baseUrl\n ) {\n // remove old baseUrl and add new one\n if (resolvedUrlIndex && resolvedUrlIndex > -1) {\n config.resolve?.modules?.splice(resolvedUrlIndex, 1)\n }\n\n // If the resolvedBaseUrl is implicit we only remove the previous value.\n // Only add the baseUrl if it's explicitly set in tsconfig/jsconfig\n if (!resolvedBaseUrl.isImplicit) {\n config.resolve?.modules?.push(resolvedBaseUrl.baseUrl)\n }\n }\n }\n\n if (jsConfig?.compilerOptions?.paths && resolvedBaseUrl) {\n Object.keys(plugin.paths).forEach((key) => {\n delete plugin.paths[key]\n })\n Object.assign(plugin.paths, jsConfig.compilerOptions.paths)\n plugin.resolvedBaseUrl = resolvedBaseUrl\n }\n }\n })\n }\n\n if (envChange) {\n config.plugins?.forEach((plugin: any) => {\n // we look for the DefinePlugin definitions so we can\n // update them on the active compilers\n if (\n plugin &&\n typeof plugin.definitions === 'object' &&\n plugin.definitions.__NEXT_DEFINE_ENV\n ) {\n const newDefine = getDefineEnv({\n isTurbopack: false,\n clientRouterFilters,\n config: nextConfig,\n dev: true,\n distDir,\n fetchCacheKeyPrefix:\n opts.nextConfig.experimental.fetchCacheKeyPrefix,\n hasRewrites,\n isClient,\n isEdgeServer,\n isNodeOrEdgeCompilation: isNodeServer || isEdgeServer,\n isNodeServer,\n middlewareMatchers: undefined,\n })\n\n Object.keys(plugin.definitions).forEach((key) => {\n if (!(key in newDefine)) {\n delete plugin.definitions[key]\n }\n })\n Object.assign(plugin.definitions, newDefine)\n }\n })\n }\n })\n await hotReloader.invalidate({\n reloadAfterInvalidation: envChange,\n })\n }\n\n if (nestedMiddleware.length > 0) {\n Log.error(\n new NestedMiddlewareError(\n nestedMiddleware,\n dir,\n (pagesDir || appDir)!\n ).message\n )\n nestedMiddleware = []\n }\n\n // Make sure to sort parallel routes to make the result deterministic.\n serverFields.appPathRoutes = Object.fromEntries(\n Object.entries(appPaths).map(([k, v]) => [k, v.sort()])\n )\n await propagateServerField(\n opts,\n 'appPathRoutes',\n serverFields.appPathRoutes\n )\n\n // TODO: pass this to fsChecker/next-dev-server?\n serverFields.middleware = middlewareMatchers\n ? {\n match: null as any,\n page: '/',\n matchers: middlewareMatchers,\n }\n : undefined\n\n await propagateServerField(opts, 'middleware', serverFields.middleware)\n serverFields.hasAppNotFound = hasRootAppNotFound\n\n opts.fsChecker.middlewareMatcher = serverFields.middleware?.matchers\n ? getMiddlewareRouteMatcher(serverFields.middleware?.matchers)\n : undefined\n\n const interceptionRoutes = generateInterceptionRoutesRewrites(\n Object.keys(appPaths),\n opts.nextConfig.basePath\n ).map((item) =>\n buildCustomRoute(\n 'before_files_rewrite',\n item,\n opts.nextConfig.basePath,\n opts.nextConfig.experimental.caseSensitiveRoutes\n )\n )\n\n opts.fsChecker.rewrites.beforeFiles.push(...interceptionRoutes)\n\n const exportPathMap =\n (typeof nextConfig.exportPathMap === 'function' &&\n (await nextConfig.exportPathMap?.(\n {},\n {\n dev: true,\n dir: opts.dir,\n outDir: null,\n distDir: distDir,\n buildId: 'development',\n }\n ))) ||\n {}\n\n const exportPathMapEntries = Object.entries(exportPathMap || {})\n\n if (exportPathMapEntries.length > 0) {\n opts.fsChecker.exportPathMapRoutes = exportPathMapEntries.map(\n ([key, value]) =>\n buildCustomRoute(\n 'before_files_rewrite',\n {\n source: key,\n destination: `${value.page}${\n value.query ? '?' : ''\n }${qs.stringify(value.query)}`,\n },\n opts.nextConfig.basePath,\n opts.nextConfig.experimental.caseSensitiveRoutes\n )\n )\n }\n\n try {\n // we serve a separate manifest with all pages for the client in\n // dev mode so that we can match a page after a rewrite on the client\n // before it has been built and is populated in the _buildManifest\n const sortedRoutes = getSortedRoutes(routedPages)\n\n opts.fsChecker.dynamicRoutes = sortedRoutes.map(\n (page): FilesystemDynamicRoute => {\n const regex = getRouteRegex(page)\n return {\n regex: regex.re.toString(),\n match: getRouteMatcher(regex),\n page,\n }\n }\n )\n\n const dataRoutes: typeof opts.fsChecker.dynamicRoutes = []\n\n for (const page of sortedRoutes) {\n const route = buildDataRoute(page, 'development')\n const routeRegex = getRouteRegex(route.page)\n dataRoutes.push({\n ...route,\n regex: routeRegex.re.toString(),\n match: getRouteMatcher({\n // TODO: fix this in the manifest itself, must also be fixed in\n // upstream builder that relies on this\n re: opts.nextConfig.i18n\n ? new RegExp(\n route.dataRouteRegex.replace(\n `/development/`,\n `/development/(?<nextLocale>[^/]+?)/`\n )\n )\n : new RegExp(route.dataRouteRegex),\n groups: routeRegex.groups,\n }),\n })\n }\n opts.fsChecker.dynamicRoutes.unshift(...dataRoutes)\n\n if (!prevSortedRoutes?.every((val, idx) => val === sortedRoutes[idx])) {\n const addedRoutes = sortedRoutes.filter(\n (route) => !prevSortedRoutes.includes(route)\n )\n const removedRoutes = prevSortedRoutes.filter(\n (route) => !sortedRoutes.includes(route)\n )\n\n // emit the change so clients fetch the update\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.DEV_PAGES_MANIFEST_UPDATE,\n data: [\n {\n devPagesManifest: true,\n },\n ],\n })\n\n addedRoutes.forEach((route) => {\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.ADDED_PAGE,\n data: [route],\n })\n })\n\n removedRoutes.forEach((route) => {\n hotReloader.send({\n action: HMR_ACTIONS_SENT_TO_BROWSER.REMOVED_PAGE,\n data: [route],\n })\n })\n }\n prevSortedRoutes = sortedRoutes\n\n if (!resolved) {\n resolve()\n resolved = true\n }\n } catch (e) {\n if (!resolved) {\n reject(e)\n resolved = true\n } else {\n Log.warn('Failed to reload dynamic routes:', e)\n }\n } finally {\n // Reload the matchers. The filesystem would have been written to,\n // and the matchers need to re-scan it to update the router.\n await propagateServerField(opts, 'reloadMatchers', undefined)\n }\n })\n\n wp.watch({ directories: [dir], startTime: 0 })\n })\n\n const clientPagesManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${DEV_CLIENT_PAGES_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(clientPagesManifestPath)\n\n const devMiddlewareManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${DEV_CLIENT_MIDDLEWARE_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(devMiddlewareManifestPath)\n\n async function requestHandler(req: IncomingMessage, res: ServerResponse) {\n const parsedUrl = url.parse(req.url || '/')\n\n if (parsedUrl.pathname?.includes(clientPagesManifestPath)) {\n res.statusCode = 200\n res.setHeader('Content-Type', 'application/json; charset=utf-8')\n res.end(\n JSON.stringify({\n pages: prevSortedRoutes.filter(\n (route) => !opts.fsChecker.appFiles.has(route)\n ),\n })\n )\n return { finished: true }\n }\n\n if (parsedUrl.pathname?.includes(devMiddlewareManifestPath)) {\n res.statusCode = 200\n res.setHeader('Content-Type', 'application/json; charset=utf-8')\n res.end(JSON.stringify(serverFields.middleware?.matchers || []))\n return { finished: true }\n }\n return { finished: false }\n }\n\n async function logErrorWithOriginalStack(\n err: unknown,\n type?: 'unhandledRejection' | 'uncaughtException' | 'warning' | 'app-dir'\n ) {\n let usedOriginalStack = false\n\n if (isError(err) && err.stack) {\n try {\n const frames = parseStack(err.stack!)\n // Filter out internal edge related runtime stack\n const frame = frames.find(\n ({ file }) =>\n !file?.startsWith('eval') &&\n !file?.includes('web/adapter') &&\n !file?.includes('web/globals') &&\n !file?.includes('sandbox/context') &&\n !file?.includes('<anonymous>')\n )\n\n let originalFrame: OriginalStackFrameResponse | null = null\n let isEdgeCompiler = false\n const frameFile = frame?.file\n if (frame?.lineNumber && frameFile) {\n if (hotReloader.turbopackProject) {\n try {\n originalFrame = await createOriginalTurboStackFrame(\n hotReloader.turbopackProject,\n {\n file: frameFile,\n methodName: frame.methodName,\n line: frame.lineNumber ?? 0,\n column: frame.column ?? undefined,\n isServer: true,\n }\n )\n } catch {}\n } else {\n const moduleId = frameFile.replace(\n /^(webpack-internal:\\/\\/\\/|file:\\/\\/)/,\n ''\n )\n const modulePath = frameFile.replace(\n /^(webpack-internal:\\/\\/\\/|file:\\/\\/)(\\(.*\\)\\/)?/,\n ''\n )\n\n const src = getErrorSource(err as Error)\n isEdgeCompiler = src === COMPILER_NAMES.edgeServer\n const compilation = (\n isEdgeCompiler\n ? hotReloader.edgeServerStats?.compilation\n : hotReloader.serverStats?.compilation\n )!\n\n const sourceMap = await (frame.file?.startsWith(path.sep) ||\n frame.file?.startsWith('file:')\n ? getSourceMapFromFile(frame.file)\n : getSourceMapFromCompilation(moduleId, compilation))\n\n if (sourceMap) {\n try {\n originalFrame = await createOriginalStackFrame({\n source: {\n type: 'bundle',\n sourceMap,\n compilation,\n moduleId,\n modulePath,\n },\n frame,\n rootDirectory: opts.dir,\n errorMessage: err.message,\n })\n } catch {}\n }\n }\n\n if (\n originalFrame?.originalCodeFrame &&\n originalFrame.originalStackFrame\n ) {\n const { originalCodeFrame, originalStackFrame } = originalFrame\n const { file, lineNumber, column, methodName } = originalStackFrame\n\n Log[type === 'warning' ? 'warn' : 'error'](\n `${file} (${lineNumber}:${column}) @ ${methodName}`\n )\n\n let errorToLog\n if (isEdgeCompiler) {\n errorToLog = err.message\n } else if (isError(err) && hotReloader.turbopackProject) {\n const stack = await traceTurbopackErrorStack(\n hotReloader.turbopackProject,\n err,\n frames\n )\n\n const error: NextError = new Error(err.message)\n error.stack = stack\n error.digest = err.digest\n errorToLog = error\n } else {\n errorToLog = err\n }\n\n logError(errorToLog, type)\n console[type === 'warning' ? 'warn' : 'error'](originalCodeFrame)\n usedOriginalStack = true\n }\n }\n } catch (_) {\n // failed to load original stack using source maps\n // this un-actionable by users so we don't show the\n // internal error and only show the provided stack\n }\n }\n\n if (!usedOriginalStack) {\n logError(err, type)\n }\n }\n\n return {\n serverFields,\n hotReloader,\n requestHandler,\n logErrorWithOriginalStack,\n\n async ensureMiddleware(requestUrl?: string) {\n if (!serverFields.actualMiddlewareFile) return\n return hotReloader.ensurePage({\n page: serverFields.actualMiddlewareFile,\n clientOnly: false,\n definition: undefined,\n url: requestUrl,\n })\n },\n }\n}\n\nfunction logError(\n err: unknown,\n type?: 'unhandledRejection' | 'uncaughtException' | 'warning' | 'app-dir'\n) {\n if (err instanceof ModuleBuildError) {\n // Errors that may come from issues from the user's code\n Log.error(err.message)\n } else if (err instanceof TurbopackInternalError) {\n // An internal Turbopack error that has been handled by next-swc, written\n // to disk and a simplified message shown to user on the Rust side.\n } else if (type === 'warning') {\n Log.warn(err)\n } else if (type === 'app-dir') {\n logAppDirError(err)\n } else if (type) {\n Log.error(`${type}:`, err)\n } else {\n Log.error(err)\n }\n}\n\nexport async function setupDevBundler(opts: SetupOpts) {\n const isSrcDir = path\n .relative(opts.dir, opts.pagesDir || opts.appDir || '')\n .startsWith('src')\n\n const result = await startWatcher(opts)\n\n opts.telemetry.record(\n eventCliSession(\n path.join(opts.dir, opts.nextConfig.distDir),\n opts.nextConfig,\n {\n webpackVersion: 5,\n isSrcDir,\n turboFlag: !!opts.turbo,\n cliCommand: 'dev',\n appDir: !!opts.appDir,\n pagesDir: !!opts.pagesDir,\n isCustomServer: !!opts.isCustomServer,\n hasNowJson: !!(await findUp('now.json', { cwd: opts.dir })),\n }\n )\n )\n return result\n}\n\nexport type DevBundler = Awaited<ReturnType<typeof setupDevBundler>>\n\n// Returns a trace rewritten through Turbopack's sourcemaps\nasync function traceTurbopackErrorStack(\n project: Project,\n error: Error,\n frames: StackFrame[]\n): Promise<string> {\n let originalFrames = await Promise.all(\n frames.map(async (f) => {\n try {\n const traced = await batchedTraceSource(project, {\n file: f.file!,\n methodName: f.methodName,\n line: f.lineNumber ?? 0,\n column: f.column ?? undefined,\n isServer: true,\n })\n\n return traced?.frame ?? f\n } catch {\n return f\n }\n })\n )\n\n return (\n error.name +\n ': ' +\n error.message +\n '\\n' +\n originalFrames\n .map((f) => {\n if (f == null) {\n return null\n }\n\n let line = ' at'\n if (f.methodName != null) {\n line += ' ' + f.methodName\n }\n\n if (f.file != null) {\n const file =\n f.file.startsWith('/') ||\n // Built-in \"filenames\" like `<anonymous>` shouldn't be made relative\n f.file.startsWith('<') ||\n f.file.startsWith('node:')\n ? f.file\n : `./${f.file}`\n\n line += ` (${file}`\n if (f.lineNumber != null) {\n line += ':' + f.lineNumber\n\n if (f.column != null) {\n line += ':' + f.column\n }\n }\n line += ')'\n }\n\n return line\n })\n .filter(Boolean)\n .join('\\n')\n )\n}\n"],"names":["getPageStaticInfo","createDefineEnv","fs","mkdir","url","path","qs","Watchpack","loadEnvConfig","isError","findUp","buildCustomRoute","Log","HotReloaderWebpack","setGlobal","loadJsConfig","createValidFileMatcher","eventCliSession","getDefineEnv","logAppDirError","getSortedRoutes","getStaticInfoIncludingLayouts","sortByPageExts","verifyTypeScriptSetup","verifyPartytownSetup","getRouteRegex","normalizeAppPath","buildDataRoute","getRouteMatcher","normalizePathSep","createClientRouterFilter","absolutePathToPage","generateInterceptionRoutesRewrites","CLIENT_STATIC_FILES_PATH","COMPILER_NAMES","DEV_CLIENT_PAGES_MANIFEST","DEV_CLIENT_MIDDLEWARE_MANIFEST","PHASE_DEVELOPMENT_SERVER","getMiddlewareRouteMatcher","isMiddlewareFile","NestedMiddlewareError","isInstrumentationHookFile","getPossibleMiddlewareFilenames","getPossibleInstrumentationHookFilenames","createOriginalStackFrame","getSourceMapFromCompilation","getSourceMapFromFile","parseStack","batchedTraceSource","createOriginalTurboStackFrame","devPageFiles","HMR_ACTIONS_SENT_TO_BROWSER","PAGE_TYPES","createHotReloaderTurbopack","getErrorSource","generateEncryptionKeyBase64","ModuleBuildError","TurbopackInternalError","isMetadataRouteFile","normalizeMetadataPageToRoute","createEnvDefinitions","JsConfigPathsPlugin","store","consoleStore","verifyTypeScript","opts","usingTypeScript","verifyResult","dir","distDir","nextConfig","intentDirs","pagesDir","appDir","filter","Boolean","typeCheckPreflight","tsconfigPath","typescript","disableStaticImages","images","hasAppDir","hasPagesDir","version","propagateServerField","field","args","renderServer","instance","startWatcher","resetFetch","useFileSystemPublicRoutes","join","distTypesDir","existsSync","recursive","validFileMatcher","pageExtensions","serverFields","setState","logging","hotReloader","turbo","config","buildId","encryptionKey","isBuild","telemetry","rewrites","fsChecker","previewProps","prerenderManifest","preview","start","experimental","nextScriptWorkers","ensureCallback","ensure","item","type","ensurePage","clientOnly","page","itemPath","isApp","definition","undefined","resolved","prevSortedRoutes","Promise","resolve","reject","readdir","_","files","length","pages","app","directories","rootDir","nestedMiddleware","envFiles","map","file","push","tsconfigPaths","wp","ignored","pathname","some","startsWith","d","fileWatchTimes","Map","enabledTypeScript","previousClientRouterFilters","previousConflictingPagePaths","Set","on","middlewareMatchers","routedPages","knownFiles","getTimeInfoEntries","appPaths","pageNameSet","conflictingAppPagePaths","appPageFilePaths","pagesPageFilePaths","pagesWithUnsupportedSegments","envChange","tsconfigChange","conflictingPageChange","hasRootAppNotFound","appFiles","pageFiles","clear","sortedKnownFiles","keys","sort","fileName","includes","meta","get","watchTime","watchTimeChange","timestamp","set","endsWith","accuracy","isPageFile","isAppPath","isPagePath","rootFile","extensions","keepIndex","pagesType","ROOT","staticInfo","pageFilePath","isDev","isInsideAppDir","output","error","actualMiddlewareFile","middleware","matchers","regexp","originalSource","actualInstrumentationHookFile","add","pageName","APP","PAGES","replace","pageType","generateSitemaps","generateImageMetadata","isRootNotFound","isAppRouterPage","originalPageName","nextDataRoutes","has","test","numConflicting","size","errorMessage","p","appPath","relative","pagesPath","setHmrServerError","Error","clearHmrServerError","clientRouterFilters","clientRouterFilter","Object","clientRouterFilterRedirects","_originalRedirects","r","internal","clientRouterFilterAllowedRate","JSON","stringify","then","catch","loadedEnvFiles","process","env","NODE_ENV","envFilePath","info","typedEnv","configFileName","contents","dev","forceReload","silent","tsconfigResult","turbopackProject","hasRewrites","afterFiles","beforeFiles","fallback","update","defineEnv","isTurbopack","fetchCacheKeyPrefix","activeWebpackConfigs","forEach","idx","isClient","isNodeServer","isEdgeServer","plugins","plugin","jsConfig","resolvedBaseUrl","currentResolvedBaseUrl","resolvedUrlIndex","modules","findIndex","baseUrl","splice","isImplicit","compilerOptions","paths","key","assign","definitions","__NEXT_DEFINE_ENV","newDefine","isNodeOrEdgeCompilation","invalidate","reloadAfterInvalidation","message","appPathRoutes","fromEntries","entries","k","v","match","hasAppNotFound","middlewareMatcher","interceptionRoutes","basePath","caseSensitiveRoutes","exportPathMap","outDir","exportPathMapEntries","exportPathMapRoutes","value","source","destination","query","sortedRoutes","dynamicRoutes","regex","re","toString","dataRoutes","route","routeRegex","i18n","RegExp","dataRouteRegex","groups","unshift","every","val","addedRoutes","removedRoutes","send","action","DEV_PAGES_MANIFEST_UPDATE","data","devPagesManifest","ADDED_PAGE","REMOVED_PAGE","e","warn","watch","startTime","clientPagesManifestPath","devVirtualFsItems","devMiddlewareManifestPath","requestHandler","req","res","parsedUrl","parse","statusCode","setHeader","end","finished","logErrorWithOriginalStack","err","usedOriginalStack","stack","frames","frame","find","originalFrame","isEdgeCompiler","frameFile","lineNumber","methodName","line","column","isServer","moduleId","modulePath","src","edgeServer","compilation","edgeServerStats","serverStats","sourceMap","sep","rootDirectory","originalCodeFrame","originalStackFrame","errorToLog","traceTurbopackErrorStack","digest","logError","console","ensureMiddleware","requestUrl","setupDevBundler","isSrcDir","result","record","webpackVersion","turboFlag","cliCommand","isCustomServer","hasNowJson","cwd","project","originalFrames","all","f","traced","name"],"mappings":"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"}
@@ -42,7 +42,7 @@ export async function getRequestHandlers({ dir, port, isDev, onCleanup, server,
42
42
  export async function startServer(serverOptions) {
43
43
  const { dir, isDev, hostname, minimalMode, allowRetry, keepAliveTimeout, selfSignedCertificate } = serverOptions;
44
44
  let { port } = serverOptions;
45
- process.title = `next-server (v${"15.0.4-canary.21"})`;
45
+ process.title = `next-server (v${"15.0.4-canary.22"})`;
46
46
  let handlersReady = ()=>{};
47
47
  let handlersError = ()=>{};
48
48
  let handlersPromise = new Promise((resolve, reject)=>{
@@ -234,7 +234,7 @@ function assignDefaults(dir, userConfig, silent) {
234
234
  if (((_result_experimental = result.experimental) == null ? void 0 : _result_experimental.allowDevelopmentBuild) && process.env.NODE_ENV !== 'development') {
235
235
  throw new Error(`The experimental.allowDevelopmentBuild option requires NODE_ENV to be explicitly set to 'development'.`);
236
236
  }
237
- if (!((_process_env___NEXT_VERSION = "15.0.4-canary.21") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_SKIP_CANARY_CHECK) {
237
+ if (!((_process_env___NEXT_VERSION = "15.0.4-canary.22") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_SKIP_CANARY_CHECK) {
238
238
  var _result_experimental7, _result_experimental8, _result_experimental_turbo3, _result_experimental9, _result_experimental10;
239
239
  // Prevents usage of certain experimental features outside of canary
240
240
  if ((_result_experimental7 = result.experimental) == null ? void 0 : _result_experimental7.ppr) {
@@ -104,7 +104,7 @@ async function createHotReloaderTurbopack(opts, serverFields, distDir, resetFetc
104
104
  }
105
105
  const hasRewrites = opts.fsChecker.rewrites.afterFiles.length > 0 || opts.fsChecker.rewrites.beforeFiles.length > 0 || opts.fsChecker.rewrites.fallback.length > 0;
106
106
  const hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
107
- version: "15.0.4-canary.21"
107
+ version: "15.0.4-canary.22"
108
108
  });
109
109
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
110
110
  // of the current `next dev` invocation.
@@ -260,7 +260,7 @@ class HotReloaderWebpack {
260
260
  this.previewProps = previewProps;
261
261
  this.rewrites = rewrites;
262
262
  this.hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
263
- version: "15.0.4-canary.21"
263
+ version: "15.0.4-canary.22"
264
264
  });
265
265
  // Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
266
266
  // of the current `next dev` invocation.
@@ -67,7 +67,7 @@ function _interop_require_wildcard(obj, nodeInterop) {
67
67
  return newObj;
68
68
  }
69
69
  function logStartInfo({ networkUrl, appUrl, envInfo, expFeatureInfo, maxExperimentalFeatures = Infinity }) {
70
- _log.bootstrap(`${(0, _picocolors.bold)((0, _picocolors.purple)(`${_log.prefixes.ready} Next.js ${"15.0.4-canary.21"}`))}${process.env.TURBOPACK ? ' (Turbopack)' : ''}`);
70
+ _log.bootstrap(`${(0, _picocolors.bold)((0, _picocolors.purple)(`${_log.prefixes.ready} Next.js ${"15.0.4-canary.22"}`))}${process.env.TURBOPACK ? ' (Turbopack)' : ''}`);
71
71
  if (appUrl) {
72
72
  _log.bootstrap(`- Local: ${appUrl}`);
73
73
  }
@@ -1,5 +1,5 @@
1
- import type { Env } from '@next/env';
2
- export declare function createEnvDefinitions({ distDir, env, }: {
1
+ import type { LoadedEnvFiles } from '@next/env';
2
+ export declare function createEnvDefinitions({ distDir, loadedEnvFiles, }: {
3
3
  distDir: string;
4
- env: Env;
4
+ loadedEnvFiles: LoadedEnvFiles;
5
5
  }): Promise<string | undefined>;