next 15.6.0-canary.2 → 15.6.0-canary.4
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.
- package/dist/bin/next +1 -1
- package/dist/build/adapter/build-complete.js +1 -1
- package/dist/build/adapter/build-complete.js.map +1 -1
- package/dist/build/index.js +9 -5
- package/dist/build/index.js.map +1 -1
- package/dist/build/swc/index.js +1 -1
- package/dist/build/templates/app-page.js +5 -1
- package/dist/build/templates/app-page.js.map +1 -1
- package/dist/build/webpack/loaders/devtool/devtool-style-inject.js +31 -26
- package/dist/build/webpack/loaders/devtool/devtool-style-inject.js.map +1 -1
- package/dist/build/webpack-config.js +2 -2
- package/dist/client/app-bootstrap.js +1 -1
- package/dist/client/index.js +1 -1
- package/dist/compiled/next-devtools/index.js +1 -1
- package/dist/compiled/next-devtools/index.js.map +1 -1
- package/dist/compiled/next-server/server.runtime.prod.js +5 -5
- package/dist/compiled/next-server/server.runtime.prod.js.map +1 -1
- package/dist/esm/build/adapter/build-complete.js +1 -1
- package/dist/esm/build/adapter/build-complete.js.map +1 -1
- package/dist/esm/build/index.js +9 -5
- package/dist/esm/build/index.js.map +1 -1
- package/dist/esm/build/swc/index.js +1 -1
- package/dist/esm/build/templates/app-page.js +5 -1
- package/dist/esm/build/templates/app-page.js.map +1 -1
- package/dist/esm/build/webpack/loaders/devtool/devtool-style-inject.js +31 -26
- package/dist/esm/build/webpack/loaders/devtool/devtool-style-inject.js.map +1 -1
- package/dist/esm/build/webpack-config.js +2 -2
- package/dist/esm/client/app-bootstrap.js +1 -1
- package/dist/esm/client/index.js +1 -1
- package/dist/esm/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/esm/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/esm/server/lib/app-info-log.js +1 -1
- package/dist/esm/server/lib/router-utils/setup-dev-bundler.js +1 -1
- package/dist/esm/server/lib/router-utils/setup-dev-bundler.js.map +1 -1
- package/dist/esm/server/lib/start-server.js +1 -1
- package/dist/esm/server/node-environment-extensions/unhandled-rejection.js +50 -1
- package/dist/esm/server/node-environment-extensions/unhandled-rejection.js.map +1 -1
- package/dist/esm/shared/lib/canary-only.js +1 -1
- package/dist/server/dev/hot-reloader-turbopack.js +1 -1
- package/dist/server/dev/hot-reloader-webpack.js +1 -1
- package/dist/server/lib/app-info-log.js +1 -1
- package/dist/server/lib/router-utils/setup-dev-bundler.js +1 -1
- package/dist/server/lib/router-utils/setup-dev-bundler.js.map +1 -1
- package/dist/server/lib/start-server.js +1 -1
- package/dist/server/node-environment-extensions/unhandled-rejection.js +50 -1
- package/dist/server/node-environment-extensions/unhandled-rejection.js.map +1 -1
- package/dist/shared/lib/canary-only.js +1 -1
- package/dist/telemetry/anonymous-meta.js +1 -1
- package/dist/telemetry/events/session-stopped.js +2 -2
- package/dist/telemetry/events/version.js +2 -2
- package/package.json +15 -15
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/server/node-environment-extensions/unhandled-rejection.tsx"],"sourcesContent":["/**\n * Manages unhandled rejection listeners to intelligently filter rejections\n * from aborted prerenders when cache components are enabled.\n *\n * THE PROBLEM:\n * When we abort prerenders we expect to find numerous unhandled promise rejections due to\n * things like awaiting Request data like `headers()`. The rejections are fine and should\n * not be construed as problematic so we need to avoid the appearance of a problem by\n * omitting them from the logged output.\n *\n * THE STRATEGY:\n * 1. Install a filtering unhandled rejection handler\n * 2. Intercept process event methods to capture new handlers in our internal queue\n * 3. For each rejection, check if it comes from an aborted prerender context\n * 4. If yes, suppress it. If no, delegate to all handlers in our queue\n * 5. This provides precise filtering without time-based windows\n *\n * This ensures we suppress noisy prerender-related rejections while preserving\n * normal error logging for genuine unhandled rejections.\n */\n\nimport { workUnitAsyncStorage } from '../app-render/work-unit-async-storage.external'\n\ntype ListenerMetadata = {\n listener: NodeJS.UnhandledRejectionListener\n once: boolean\n}\n\nlet filterInstalled = false\n\n// We store the proxied listeners for unhandled rejections here.\nlet underlyingListeners: Array<NodeJS.UnhandledRejectionListener> = []\n// We store a unique pointer to each event listener registration to track\n// details like whether the listener is a once listener.\nlet listenerMetadata: Array<ListenerMetadata> = []\n\nlet originalProcessOn: typeof process.on\nlet originalProcessAddListener: typeof process.addListener\nlet originalProcessOnce: typeof process.once\nlet originalProcessRemoveListener: typeof process.removeListener\nlet originalProcessRemoveAllListeners: typeof process.removeAllListeners\nlet originalProcessListeners: typeof process.listeners\nlet originalProcessPrependListener: typeof process.prependListener\nlet originalProcessPrependOnceListener: typeof process.prependOnceListener\nlet originalProcessOff: typeof process.off\n\nlet didWarnPrepend = false\nlet didWarnRemoveAll = false\n\n/**\n * Installs a filtering unhandled rejection handler that intelligently suppresses\n * rejections from aborted prerender contexts.\n *\n * This should be called once during server startup to install the global filter.\n */\nfunction installUnhandledRejectionFilter(): void {\n if (filterInstalled) {\n return\n }\n\n // Capture existing handlers\n underlyingListeners = Array.from(process.listeners('unhandledRejection'))\n // We assume all existing handlers are not \"once\"\n listenerMetadata = underlyingListeners.map((l) => ({\n listener: l,\n once: false,\n }))\n\n // Store the original process methods\n originalProcessOn = process.on\n originalProcessAddListener = process.addListener\n originalProcessOnce = process.once\n originalProcessOff = process.off\n originalProcessRemoveListener = process.removeListener\n originalProcessRemoveAllListeners = process.removeAllListeners\n originalProcessListeners = process.listeners\n originalProcessPrependListener = process.prependListener\n originalProcessPrependOnceListener = process.prependOnceListener\n\n // Helper function to create a patched method that preserves toString behavior\n function patchMethod<T extends Function>(original: T, patchedImpl: T): T {\n // Preserve the original toString behavior\n Object.defineProperty(patchedImpl, 'toString', {\n value: original.toString.bind(original),\n writable: true,\n configurable: true,\n })\n return patchedImpl\n }\n\n // Intercept process.on to capture new unhandled rejection handlers\n process.on = patchMethod(originalProcessOn, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n // Add new handlers to our internal queue instead of the process\n underlyingListeners.push(listener as NodeJS.UnhandledRejectionListener)\n listenerMetadata.push({ listener, once: false })\n return process\n }\n // For other events, use the original method\n return originalProcessOn.call(process, event, listener)\n } as typeof process.on)\n\n // Intercept process.addListener (alias for process.on)\n process.addListener = patchMethod(\n originalProcessAddListener,\n process.on as typeof originalProcessAddListener\n )\n\n // Intercept process.once for one-time handlers\n process.once = patchMethod(originalProcessOnce, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n underlyingListeners.push(listener)\n listenerMetadata.push({ listener, once: true })\n return process\n }\n // For other events, use the original method\n return originalProcessOnce.call(process, event, listener)\n } as typeof process.once)\n\n // Intercept process.prependListener for handlers that should go first\n process.prependListener = patchMethod(\n originalProcessPrependListener,\n function (event: string | symbol, listener: (...args: any[]) => void) {\n if (event === 'unhandledRejection') {\n if (didWarnPrepend === false) {\n didWarnPrepend = true\n console.warn(\n 'Warning: `prependListener(\"unhandledRejection\")` called, but Next.js maintains the first listener ' +\n 'which filters out unnecessary events from aborted prerenders. Your handler will be second.'\n )\n }\n // Add new handlers to the beginning of our internal queue\n underlyingListeners.unshift(\n listener as NodeJS.UnhandledRejectionListener\n )\n listenerMetadata.unshift({ listener, once: false })\n return process\n }\n // For other events, use the original method\n return originalProcessPrependListener.call(\n process,\n event as any,\n listener\n )\n } as typeof process.prependListener\n )\n\n // Intercept process.prependOnceListener for one-time handlers that should go first\n process.prependOnceListener = patchMethod(\n originalProcessPrependOnceListener,\n function (event: string | symbol, listener: (...args: any[]) => void) {\n if (event === 'unhandledRejection') {\n if (didWarnPrepend === false) {\n didWarnPrepend = true\n console.warn(\n 'Warning: `prependOnceListener(\"unhandledRejection\")` called, but Next.js maintains the first listener ' +\n 'which filters out unnecessary events from aborted prerenders. Your handler will be second.'\n )\n }\n // Add to the beginning of our internal queue\n underlyingListeners.unshift(listener)\n listenerMetadata.unshift({ listener, once: true })\n return process\n }\n // For other events, use the original method\n return originalProcessPrependOnceListener.call(\n process,\n event as any,\n listener\n )\n } as typeof process.prependOnceListener\n )\n\n // Intercept process.removeListener\n process.removeListener = patchMethod(originalProcessRemoveListener, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n // Check if they're trying to remove our filtering handler\n if (listener === filteringUnhandledRejectionHandler) {\n uninstallUnhandledRejectionFilter()\n return process\n }\n\n const index = underlyingListeners.lastIndexOf(listener)\n if (index > -1) {\n underlyingListeners.splice(index, 1)\n listenerMetadata.splice(index, 1)\n }\n return process\n }\n // For other events, use the original method\n return originalProcessRemoveListener.call(process, event, listener)\n } as typeof process.removeListener)\n\n // Intercept process.off (alias for process.removeListener)\n process.off = patchMethod(\n originalProcessOff,\n process.removeListener as typeof originalProcessOff\n )\n\n // Intercept process.removeAllListeners\n process.removeAllListeners = patchMethod(\n originalProcessRemoveAllListeners,\n function (event?: string | symbol) {\n if (event === 'unhandledRejection') {\n if (didWarnRemoveAll === false) {\n didWarnRemoveAll = true\n console.warn(\n 'Warning: `removeAllListeners(\"unhandledRejection\")` called. Next.js maintains an `unhandledRejection` listener ' +\n 'to filter out unnecessary rejection warnings caused by aborting prerenders early. It is not recommended that you ' +\n 'uninstall this behavior, but if you want to you must call `process.removeListener(\"unhandledRejection\", listener)`. ' +\n 'You can acquire the listener from `process.listeners(\"unhandledRejection\")[0]`.'\n )\n }\n underlyingListeners.length = 0\n listenerMetadata.length = 0\n return process\n }\n\n // For other specific events, use the original method\n if (event !== undefined) {\n return originalProcessRemoveAllListeners.call(process, event)\n }\n\n // If no event specified (removeAllListeners()), uninstall our patch completely\n console.warn(\n 'Warning: `removeAllListeners()` called - uninstalling Next.js unhandled rejection filter. ' +\n 'You will observe `unhandledRejection` logs from prerendering which are not problematic.'\n )\n uninstallUnhandledRejectionFilter()\n return originalProcessRemoveAllListeners.call(process)\n } as typeof process.removeAllListeners\n )\n\n // Intercept process.listeners to return our internal handlers for unhandled rejection\n process.listeners = patchMethod(originalProcessListeners, function (\n event: string | symbol\n ) {\n if (event === 'unhandledRejection') {\n return [filteringUnhandledRejectionHandler, ...underlyingListeners]\n }\n return originalProcessListeners.call(process, event as any)\n } as typeof process.listeners)\n\n // Remove all existing handlers\n originalProcessRemoveAllListeners.call(process, 'unhandledRejection')\n\n // Install our filtering handler\n originalProcessOn.call(\n process,\n 'unhandledRejection',\n filteringUnhandledRejectionHandler\n )\n\n originalProcessOn.call(process, 'rejectionHandled', noopRejectionHandled)\n\n filterInstalled = true\n}\n\n/**\n * Uninstalls the unhandled rejection filter and restores original process methods.\n * This is called when someone explicitly removes our filtering handler.\n * @internal\n */\nfunction uninstallUnhandledRejectionFilter(): void {\n if (!filterInstalled) {\n return\n }\n\n // Restore original process methods\n process.on = originalProcessOn\n process.addListener = originalProcessAddListener\n process.once = originalProcessOnce\n process.prependListener = originalProcessPrependListener\n process.prependOnceListener = originalProcessPrependOnceListener\n process.removeListener = originalProcessRemoveListener\n process.off = originalProcessOff\n process.removeAllListeners = originalProcessRemoveAllListeners\n process.listeners = originalProcessListeners\n\n // Remove our filtering handler\n originalProcessRemoveListener.call(\n process,\n 'unhandledRejection',\n filteringUnhandledRejectionHandler\n )\n\n originalProcessRemoveListener.call(\n process,\n 'rejectionHandled',\n noopRejectionHandled\n )\n\n // Re-register all the handlers that were in our internal queue\n for (const meta of listenerMetadata) {\n if (meta.once) {\n originalProcessOnce.call(process, 'unhandledRejection', meta.listener)\n } else {\n originalProcessOn.call(process, 'unhandledRejection', meta.listener)\n }\n }\n\n // Reset state\n filterInstalled = false\n underlyingListeners.length = 0\n listenerMetadata.length = 0\n}\n\n/**\n * The filtering handler that decides whether to suppress or delegate unhandled rejections.\n */\nfunction filteringUnhandledRejectionHandler(\n reason: any,\n promise: Promise<any>\n): void {\n const capturedListenerMetadata = Array.from(listenerMetadata)\n\n const workUnitStore = workUnitAsyncStorage.getStore()\n\n if (workUnitStore) {\n switch (workUnitStore.type) {\n case 'prerender':\n case 'prerender-client':\n case 'prerender-runtime': {\n const signal = workUnitStore.renderSignal\n if (signal.aborted) {\n // This unhandledRejection is from async work spawned in a now\n // aborted prerender. We don't need to report this.\n return\n }\n break\n }\n case 'prerender-ppr':\n case 'prerender-legacy':\n case 'request':\n case 'cache':\n case 'private-cache':\n case 'unstable-cache':\n break\n default:\n workUnitStore satisfies never\n }\n }\n\n // Not from an aborted prerender, delegate to original handlers\n if (capturedListenerMetadata.length === 0) {\n // We need to log something because the default behavior when there is\n // no event handler installed is to trigger an Unhandled Exception.\n // We don't do that here b/c we don't want to rely on this implicit default\n // to kill the process since it can be disabled by installing a userland listener\n // and you may also choose to run Next.js with args such that unhandled rejections\n // do not automatically terminate the process.\n console.error('Unhandled Rejection:', reason)\n } else {\n try {\n for (const meta of capturedListenerMetadata) {\n if (meta.once) {\n // This is a once listener. we remove it from our set before we call it\n const index = listenerMetadata.indexOf(meta)\n if (index !== -1) {\n underlyingListeners.splice(index, 1)\n listenerMetadata.splice(index, 1)\n }\n }\n const listener = meta.listener\n listener(reason, promise)\n }\n } catch (error) {\n // If any handlers error we produce an Uncaught Exception\n setImmediate(() => {\n throw error\n })\n }\n }\n}\n\nfunction noopRejectionHandled() {}\n\n// Install the filter when this module is imported\ninstallUnhandledRejectionFilter()\n"],"names":["workUnitAsyncStorage","filterInstalled","underlyingListeners","listenerMetadata","originalProcessOn","originalProcessAddListener","originalProcessOnce","originalProcessRemoveListener","originalProcessRemoveAllListeners","originalProcessListeners","originalProcessPrependListener","originalProcessPrependOnceListener","originalProcessOff","didWarnPrepend","didWarnRemoveAll","installUnhandledRejectionFilter","Array","from","process","listeners","map","l","listener","once","on","addListener","off","removeListener","removeAllListeners","prependListener","prependOnceListener","patchMethod","original","patchedImpl","Object","defineProperty","value","toString","bind","writable","configurable","event","push","call","console","warn","unshift","filteringUnhandledRejectionHandler","uninstallUnhandledRejectionFilter","index","lastIndexOf","splice","length","undefined","noopRejectionHandled","meta","reason","promise","capturedListenerMetadata","workUnitStore","getStore","type","signal","renderSignal","aborted","error","indexOf","setImmediate"],"mappings":"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","ignoreList":[0]}
|
1
|
+
{"version":3,"sources":["../../../src/server/node-environment-extensions/unhandled-rejection.tsx"],"sourcesContent":["/**\n * Manages unhandled rejection listeners to intelligently filter rejections\n * from aborted prerenders when cache components are enabled.\n *\n * THE PROBLEM:\n * When we abort prerenders we expect to find numerous unhandled promise rejections due to\n * things like awaiting Request data like `headers()`. The rejections are fine and should\n * not be construed as problematic so we need to avoid the appearance of a problem by\n * omitting them from the logged output.\n *\n * THE STRATEGY:\n * 1. Install a filtering unhandled rejection handler\n * 2. Intercept process event methods to capture new handlers in our internal queue\n * 3. For each rejection, check if it comes from an aborted prerender context\n * 4. If yes, suppress it. If no, delegate to all handlers in our queue\n * 5. This provides precise filtering without time-based windows\n *\n * This ensures we suppress noisy prerender-related rejections while preserving\n * normal error logging for genuine unhandled rejections.\n */\n\nimport { workUnitAsyncStorage } from '../app-render/work-unit-async-storage.external'\n\nconst MODE:\n | 'enabled'\n | 'debug'\n | 'true'\n | 'false'\n | '1'\n | '0'\n | ''\n | string\n | undefined = process.env.NEXT_USE_UNHANDLED_REJECTION_FILTER\n\nlet ENABLE_UHR_FILTER = false\nlet DEBUG_UHR_FILTER = false\n\nswitch (MODE) {\n case 'debug':\n DEBUG_UHR_FILTER = true\n // fallthrough\n case 'enabled':\n case 'true':\n case '1':\n ENABLE_UHR_FILTER = true\n break\n case 'false':\n case 'disabled':\n case '0':\n case '':\n case undefined:\n break\n default:\n if (typeof MODE === 'string') {\n console.error(\n `NEXT_USE_UNHANDLED_REJECTION_FILTER has an unrecognized value: ${JSON.stringify(MODE)}. Use \"enabled\", \"disabled\", or \"debug\" or omit the environment variable altogether`\n )\n }\n}\n\nconst debug = DEBUG_UHR_FILTER\n ? (...args: any[]) =>\n console.log('[UNHANDLED REJECTION DEBUG]', ...args, new Error().stack)\n : undefined\n\ntype ListenerMetadata = {\n listener: NodeJS.UnhandledRejectionListener\n once: boolean\n}\n\nlet filterInstalled = false\n\n// We store the proxied listeners for unhandled rejections here.\nlet underlyingListeners: Array<NodeJS.UnhandledRejectionListener> = []\n// We store a unique pointer to each event listener registration to track\n// details like whether the listener is a once listener.\nlet listenerMetadata: Array<ListenerMetadata> = []\n\nlet originalProcessOn: typeof process.on\nlet originalProcessAddListener: typeof process.addListener\nlet originalProcessOnce: typeof process.once\nlet originalProcessRemoveListener: typeof process.removeListener\nlet originalProcessRemoveAllListeners: typeof process.removeAllListeners\nlet originalProcessListeners: typeof process.listeners\nlet originalProcessPrependListener: typeof process.prependListener\nlet originalProcessPrependOnceListener: typeof process.prependOnceListener\nlet originalProcessOff: typeof process.off\n\nlet didWarnPrepend = false\nlet didWarnRemoveAll = false\n\n/**\n * Installs a filtering unhandled rejection handler that intelligently suppresses\n * rejections from aborted prerender contexts.\n *\n * This should be called once during server startup to install the global filter.\n */\nfunction installUnhandledRejectionFilter(): void {\n if (filterInstalled) {\n debug?.('unexpected second install')\n return\n }\n\n debug?.(\n 'installUnhandledRejectionFilter',\n process.listeners('unhandledRejection').map((l) => l.toString())\n )\n\n // Capture existing handlers\n underlyingListeners = Array.from(process.listeners('unhandledRejection'))\n // We assume all existing handlers are not \"once\"\n listenerMetadata = underlyingListeners.map((l) => ({\n listener: l,\n once: false,\n }))\n\n // Store the original process methods\n originalProcessOn = process.on\n originalProcessAddListener = process.addListener\n originalProcessOnce = process.once\n originalProcessOff = process.off\n originalProcessRemoveListener = process.removeListener\n originalProcessRemoveAllListeners = process.removeAllListeners\n originalProcessListeners = process.listeners\n originalProcessPrependListener = process.prependListener\n originalProcessPrependOnceListener = process.prependOnceListener\n\n // Helper function to create a patched method that preserves toString behavior\n function patchMethod<T extends Function>(original: T, patchedImpl: T): T {\n // Preserve the original toString behavior\n Object.defineProperty(patchedImpl, 'toString', {\n value: original.toString.bind(original),\n writable: true,\n configurable: true,\n })\n return patchedImpl\n }\n\n // Intercept process.on to capture new unhandled rejection handlers\n process.on = patchMethod(originalProcessOn, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n debug?.('process.on/addListener', listener.toString())\n // Add new handlers to our internal queue instead of the process\n underlyingListeners.push(listener as NodeJS.UnhandledRejectionListener)\n listenerMetadata.push({ listener, once: false })\n return process\n }\n // For other events, use the original method\n return originalProcessOn.call(process, event, listener)\n } as typeof process.on)\n\n // Intercept process.addListener (alias for process.on)\n process.addListener = patchMethod(\n originalProcessAddListener,\n process.on as typeof originalProcessAddListener\n )\n\n // Intercept process.once for one-time handlers\n process.once = patchMethod(originalProcessOnce, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n debug?.('process.once', listener.toString())\n underlyingListeners.push(listener)\n listenerMetadata.push({ listener, once: true })\n return process\n }\n // For other events, use the original method\n return originalProcessOnce.call(process, event, listener)\n } as typeof process.once)\n\n // Intercept process.prependListener for handlers that should go first\n process.prependListener = patchMethod(\n originalProcessPrependListener,\n function (event: string | symbol, listener: (...args: any[]) => void) {\n if (event === 'unhandledRejection') {\n debug?.('process.prependListener', listener.toString())\n if (didWarnPrepend === false) {\n didWarnPrepend = true\n console.warn(\n 'Warning: `prependListener(\"unhandledRejection\")` called, but Next.js maintains the first listener ' +\n 'which filters out unnecessary events from aborted prerenders. Your handler will be second.'\n )\n }\n // Add new handlers to the beginning of our internal queue\n underlyingListeners.unshift(\n listener as NodeJS.UnhandledRejectionListener\n )\n listenerMetadata.unshift({ listener, once: false })\n return process\n }\n // For other events, use the original method\n return originalProcessPrependListener.call(\n process,\n event as any,\n listener\n )\n } as typeof process.prependListener\n )\n\n // Intercept process.prependOnceListener for one-time handlers that should go first\n process.prependOnceListener = patchMethod(\n originalProcessPrependOnceListener,\n function (event: string | symbol, listener: (...args: any[]) => void) {\n if (event === 'unhandledRejection') {\n debug?.('process.prependOnceListener', listener.toString())\n if (didWarnPrepend === false) {\n didWarnPrepend = true\n console.warn(\n 'Warning: `prependOnceListener(\"unhandledRejection\")` called, but Next.js maintains the first listener ' +\n 'which filters out unnecessary events from aborted prerenders. Your handler will be second.'\n )\n }\n // Add to the beginning of our internal queue\n underlyingListeners.unshift(listener)\n listenerMetadata.unshift({ listener, once: true })\n return process\n }\n // For other events, use the original method\n return originalProcessPrependOnceListener.call(\n process,\n event as any,\n listener\n )\n } as typeof process.prependOnceListener\n )\n\n // Intercept process.removeListener\n process.removeListener = patchMethod(originalProcessRemoveListener, function (\n event: string | symbol,\n listener: (...args: any[]) => void\n ) {\n if (event === 'unhandledRejection') {\n debug?.('process.removeListener', listener.toString())\n // Check if they're trying to remove our filtering handler\n if (listener === filteringUnhandledRejectionHandler) {\n uninstallUnhandledRejectionFilter()\n return process\n }\n\n const index = underlyingListeners.lastIndexOf(listener)\n if (index > -1) {\n debug?.('process.removeListener match found', index)\n underlyingListeners.splice(index, 1)\n listenerMetadata.splice(index, 1)\n } else {\n debug?.('process.removeListener match not found', index)\n }\n return process\n }\n // For other events, use the original method\n return originalProcessRemoveListener.call(process, event, listener)\n } as typeof process.removeListener)\n\n // Intercept process.off (alias for process.removeListener)\n process.off = patchMethod(\n originalProcessOff,\n process.removeListener as typeof originalProcessOff\n )\n\n // Intercept process.removeAllListeners\n process.removeAllListeners = patchMethod(\n originalProcessRemoveAllListeners,\n function (event?: string | symbol) {\n if (event === 'unhandledRejection') {\n debug?.(\n 'process.removeAllListeners',\n underlyingListeners.map((l) => l.toString())\n )\n if (didWarnRemoveAll === false) {\n didWarnRemoveAll = true\n console.warn(\n 'Warning: `removeAllListeners(\"unhandledRejection\")` called. Next.js maintains an `unhandledRejection` listener ' +\n 'to filter out unnecessary rejection warnings caused by aborting prerenders early. It is not recommended that you ' +\n 'uninstall this behavior, but if you want to you must call `process.removeListener(\"unhandledRejection\", listener)`. ' +\n 'You can acquire the listener from `process.listeners(\"unhandledRejection\")[0]`.'\n )\n }\n underlyingListeners.length = 0\n listenerMetadata.length = 0\n return process\n }\n\n // For other specific events, use the original method\n if (event !== undefined) {\n return originalProcessRemoveAllListeners.call(process, event)\n }\n\n // If no event specified (removeAllListeners()), uninstall our patch completely\n console.warn(\n 'Warning: `removeAllListeners()` called - uninstalling Next.js unhandled rejection filter. ' +\n 'You will observe `unhandledRejection` logs from prerendering which are not problematic.'\n )\n uninstallUnhandledRejectionFilter()\n return originalProcessRemoveAllListeners.call(process)\n } as typeof process.removeAllListeners\n )\n\n // Intercept process.listeners to return our internal handlers for unhandled rejection\n process.listeners = patchMethod(originalProcessListeners, function (\n event: string | symbol\n ) {\n if (event === 'unhandledRejection') {\n debug?.(\n 'process.listeners',\n [filteringUnhandledRejectionHandler, ...underlyingListeners].map((l) =>\n l.toString()\n )\n )\n return [filteringUnhandledRejectionHandler, ...underlyingListeners]\n }\n return originalProcessListeners.call(process, event as any)\n } as typeof process.listeners)\n\n // Remove all existing handlers\n originalProcessRemoveAllListeners.call(process, 'unhandledRejection')\n\n // Install our filtering handler\n originalProcessOn.call(\n process,\n 'unhandledRejection',\n filteringUnhandledRejectionHandler\n )\n\n originalProcessOn.call(process, 'rejectionHandled', noopRejectionHandled)\n\n filterInstalled = true\n\n debug?.(\n 'after install actual listeners',\n originalProcessListeners\n .call(process, 'unhandledRejection' as any)\n .map((l) => l.toString())\n )\n\n debug?.(\n 'after install listeners',\n process.listeners('unhandledRejection').map((l) => l.toString())\n )\n}\n\n/**\n * Uninstalls the unhandled rejection filter and restores original process methods.\n * This is called when someone explicitly removes our filtering handler.\n * @internal\n */\nfunction uninstallUnhandledRejectionFilter(): void {\n if (!filterInstalled) {\n debug?.('unexpected second uninstall')\n return\n }\n\n debug?.(\n 'uninstallUnhandledRejectionFilter',\n [filteringUnhandledRejectionHandler, ...underlyingListeners].map((l) =>\n l.toString()\n )\n )\n\n // Restore original process methods\n process.on = originalProcessOn\n process.addListener = originalProcessAddListener\n process.once = originalProcessOnce\n process.prependListener = originalProcessPrependListener\n process.prependOnceListener = originalProcessPrependOnceListener\n process.removeListener = originalProcessRemoveListener\n process.off = originalProcessOff\n process.removeAllListeners = originalProcessRemoveAllListeners\n process.listeners = originalProcessListeners\n\n // Remove our filtering handler\n originalProcessRemoveListener.call(\n process,\n 'unhandledRejection',\n filteringUnhandledRejectionHandler\n )\n\n originalProcessRemoveListener.call(\n process,\n 'rejectionHandled',\n noopRejectionHandled\n )\n\n // Re-register all the handlers that were in our internal queue\n for (const meta of listenerMetadata) {\n if (meta.once) {\n originalProcessOnce.call(process, 'unhandledRejection', meta.listener)\n } else {\n originalProcessOn.call(process, 'unhandledRejection', meta.listener)\n }\n }\n\n // Reset state\n filterInstalled = false\n underlyingListeners.length = 0\n listenerMetadata.length = 0\n\n debug?.(\n 'after uninstall',\n process.listeners('unhandledRejection').map((l) => l.toString())\n )\n}\n\n/**\n * The filtering handler that decides whether to suppress or delegate unhandled rejections.\n */\nfunction filteringUnhandledRejectionHandler(\n reason: any,\n promise: Promise<any>\n): void {\n const capturedListenerMetadata = Array.from(listenerMetadata)\n\n const workUnitStore = workUnitAsyncStorage.getStore()\n\n if (workUnitStore) {\n switch (workUnitStore.type) {\n case 'prerender':\n case 'prerender-client':\n case 'prerender-runtime': {\n const signal = workUnitStore.renderSignal\n if (signal.aborted) {\n // This unhandledRejection is from async work spawned in a now\n // aborted prerender. We don't need to report this.\n return\n }\n break\n }\n case 'prerender-ppr':\n case 'prerender-legacy':\n case 'request':\n case 'cache':\n case 'private-cache':\n case 'unstable-cache':\n break\n default:\n workUnitStore satisfies never\n }\n }\n\n // Not from an aborted prerender, delegate to original handlers\n if (capturedListenerMetadata.length === 0) {\n // We need to log something because the default behavior when there is\n // no event handler installed is to trigger an Unhandled Exception.\n // We don't do that here b/c we don't want to rely on this implicit default\n // to kill the process since it can be disabled by installing a userland listener\n // and you may also choose to run Next.js with args such that unhandled rejections\n // do not automatically terminate the process.\n console.error('Unhandled Rejection:', reason)\n } else {\n try {\n for (const meta of capturedListenerMetadata) {\n if (meta.once) {\n // This is a once listener. we remove it from our set before we call it\n const index = listenerMetadata.indexOf(meta)\n if (index !== -1) {\n underlyingListeners.splice(index, 1)\n listenerMetadata.splice(index, 1)\n }\n }\n const listener = meta.listener\n listener(reason, promise)\n }\n } catch (error) {\n // If any handlers error we produce an Uncaught Exception\n setImmediate(() => {\n throw error\n })\n }\n }\n}\n\nfunction noopRejectionHandled() {}\n\n// Install the filter when this module is imported\nif (ENABLE_UHR_FILTER) {\n installUnhandledRejectionFilter()\n}\n"],"names":["workUnitAsyncStorage","MODE","process","env","NEXT_USE_UNHANDLED_REJECTION_FILTER","ENABLE_UHR_FILTER","DEBUG_UHR_FILTER","undefined","console","error","JSON","stringify","debug","args","log","Error","stack","filterInstalled","underlyingListeners","listenerMetadata","originalProcessOn","originalProcessAddListener","originalProcessOnce","originalProcessRemoveListener","originalProcessRemoveAllListeners","originalProcessListeners","originalProcessPrependListener","originalProcessPrependOnceListener","originalProcessOff","didWarnPrepend","didWarnRemoveAll","installUnhandledRejectionFilter","listeners","map","l","toString","Array","from","listener","once","on","addListener","off","removeListener","removeAllListeners","prependListener","prependOnceListener","patchMethod","original","patchedImpl","Object","defineProperty","value","bind","writable","configurable","event","push","call","warn","unshift","filteringUnhandledRejectionHandler","uninstallUnhandledRejectionFilter","index","lastIndexOf","splice","length","noopRejectionHandled","meta","reason","promise","capturedListenerMetadata","workUnitStore","getStore","type","signal","renderSignal","aborted","indexOf","setImmediate"],"mappings":"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","ignoreList":[0]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
export function isStableBuild() {
|
2
2
|
var _process_env___NEXT_VERSION;
|
3
|
-
return !((_process_env___NEXT_VERSION = "15.6.0-canary.
|
3
|
+
return !((_process_env___NEXT_VERSION = "15.6.0-canary.4") == null ? void 0 : _process_env___NEXT_VERSION.includes('canary')) && !process.env.__NEXT_TEST_MODE && !process.env.NEXT_PRIVATE_LOCAL_DEV;
|
4
4
|
}
|
5
5
|
export class CanaryOnlyError extends Error {
|
6
6
|
constructor(arg){
|
@@ -146,7 +146,7 @@ async function createHotReloaderTurbopack(opts, serverFields, distDir, resetFetc
|
|
146
146
|
}
|
147
147
|
const hasRewrites = opts.fsChecker.rewrites.afterFiles.length > 0 || opts.fsChecker.rewrites.beforeFiles.length > 0 || opts.fsChecker.rewrites.fallback.length > 0;
|
148
148
|
const hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
|
149
|
-
version: "15.6.0-canary.
|
149
|
+
version: "15.6.0-canary.4"
|
150
150
|
});
|
151
151
|
// Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
|
152
152
|
// of the current `next dev` invocation.
|
@@ -226,7 +226,7 @@ class HotReloaderWebpack {
|
|
226
226
|
this.previewProps = previewProps;
|
227
227
|
this.rewrites = rewrites;
|
228
228
|
this.hotReloaderSpan = (0, _trace.trace)('hot-reloader', undefined, {
|
229
|
-
version: "15.6.0-canary.
|
229
|
+
version: "15.6.0-canary.4"
|
230
230
|
});
|
231
231
|
// Ensure the hotReloaderSpan is flushed immediately as it's the parentSpan for all processing
|
232
232
|
// of the current `next dev` invocation.
|
@@ -82,7 +82,7 @@ function logStartInfo({ networkUrl, appUrl, envInfo, experimentalFeatures, logBu
|
|
82
82
|
bundlerSuffix = ' (webpack)';
|
83
83
|
}
|
84
84
|
}
|
85
|
-
_log.bootstrap(`${(0, _picocolors.bold)((0, _picocolors.purple)(`${_log.prefixes.ready} Next.js ${"15.6.0-canary.
|
85
|
+
_log.bootstrap(`${(0, _picocolors.bold)((0, _picocolors.purple)(`${_log.prefixes.ready} Next.js ${"15.6.0-canary.4"}`))}${bundlerSuffix}`);
|
86
86
|
if (appUrl) {
|
87
87
|
_log.bootstrap(`- Local: ${appUrl}`);
|
88
88
|
}
|
@@ -354,7 +354,7 @@ async function startWatcher(opts) {
|
|
354
354
|
await propagateServerField(opts, 'actualMiddlewareFile', serverFields.actualMiddlewareFile);
|
355
355
|
middlewareMatchers = ((_staticInfo_middleware = staticInfo.middleware) == null ? void 0 : _staticInfo_middleware.matchers) || [
|
356
356
|
{
|
357
|
-
regexp: '
|
357
|
+
regexp: '^/.*$',
|
358
358
|
originalSource: '/:path*'
|
359
359
|
}
|
360
360
|
];
|
@@ -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 type { MiddlewareMatcher } from '../../../build/analysis/get-page-static-info'\nimport type { RoutesManifest } from '../../../build'\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 fs from 'fs'\nimport url from 'url'\nimport path from 'path'\nimport qs from 'querystring'\nimport Watchpack from 'next/dist/compiled/watchpack'\nimport findUp from 'next/dist/compiled/find-up'\nimport { buildCustomRoute } from './filesystem'\nimport * as Log from '../../../build/output/log'\nimport { setGlobal } from '../../../trace/shared'\nimport type { Telemetry } from '../../../telemetry/storage'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport { createValidFileMatcher } from '../find-page-file'\nimport {\n EVENT_BUILD_FEATURE_USAGE,\n eventCliSession,\n} from '../../../telemetry/events'\nimport { getSortedRoutes } from '../../../shared/lib/router/utils'\nimport { sortByPageExts } from '../../../build/sort-by-page-exts'\nimport { verifyTypeScriptSetup } from '../../../lib/verify-typescript-setup'\nimport { verifyPartytownSetup } from '../../../lib/verify-partytown-setup'\nimport { getNamedRouteRegex } 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 DEV_CLIENT_PAGES_MANIFEST,\n DEV_CLIENT_MIDDLEWARE_MANIFEST,\n PHASE_DEVELOPMENT_SERVER,\n TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST,\n ROUTES_MANIFEST,\n PRERENDER_MANIFEST,\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 { devPageFiles } from '../../../build/webpack/plugins/next-types-plugin/shared'\nimport type { LazyRenderServerInstance } from '../router-server'\nimport { HMR_MESSAGE_SENT_TO_BROWSER } from '../../dev/hot-reloader-types'\nimport { PAGE_TYPES } from '../../../lib/page-types'\nimport { generateEncryptionKeyBase64 } from '../../app-render/encryption-utils-server'\nimport {\n isMetadataRouteFile,\n isStaticMetadataFile,\n} 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'\nimport {\n isPersistentCachingEnabled,\n ModuleBuildError,\n} from '../../../shared/lib/turbopack/utils'\nimport { getDefineEnv } from '../../../build/define-env'\nimport { TurbopackInternalError } from '../../../shared/lib/turbopack/internal-error'\nimport { normalizePath } from '../../../lib/normalize-path'\nimport { JSON_CONTENT_TYPE_HEADER } from '../../../lib/constants'\nimport {\n createRouteTypesManifest,\n writeRouteTypesManifest,\n writeValidatorFile,\n} from './route-types-utils'\nimport { isParallelRouteSegment } from '../../../shared/lib/segment'\nimport { ensureLeadingSlash } from '../../../shared/lib/page-path/ensure-leading-slash'\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 onDevServerCleanup: ((listener: () => Promise<void>) => void) | undefined\n resetFetch: () => void\n}\n\nexport interface DevRoutesManifest {\n version: number\n caseSensitive: RoutesManifest['caseSensitive']\n basePath: RoutesManifest['basePath']\n rewrites: RoutesManifest['rewrites']\n redirects: RoutesManifest['redirects']\n headers: RoutesManifest['headers']\n i18n: RoutesManifest['i18n']\n skipMiddlewareUrlNormalize: RoutesManifest['skipMiddlewareUrlNormalize']\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 setIsrStatus?: (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(\n opts: SetupOpts & {\n isSrcDir: boolean\n }\n) {\n const { nextConfig, appDir, pagesDir, dir, resetFetch } = opts\n const { useFileSystemPublicRoutes } = nextConfig\n\n const distDir = path.join(opts.dir, opts.nextConfig.distDir)\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 (async () => {\n const createHotReloaderTurbopack = (\n require('../../dev/hot-reloader-turbopack') as typeof import('../../dev/hot-reloader-turbopack')\n ).createHotReloaderTurbopack\n return await createHotReloaderTurbopack(\n opts,\n serverFields,\n distDir,\n resetFetch\n )\n })()\n : await (async () => {\n const HotReloaderWebpack = (\n require('../../dev/hot-reloader-webpack') as typeof import('../../dev/hot-reloader-webpack')\n ).default\n return new HotReloaderWebpack(opts.dir, {\n isSrcDir: opts.isSrcDir,\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\n await hotReloader.start()\n\n // have to write this after starting hot-reloader since that\n // cleans the dist dir\n const distTypesDir = path.join(distDir, 'types')\n await writeRouteTypesManifest(\n {\n appRoutes: {},\n pageRoutes: {},\n layoutRoutes: {},\n appRouteHandlerRoutes: {},\n redirectRoutes: {},\n rewriteRoutes: {},\n appPagePaths: new Set(),\n pagesRouterPagePaths: new Set(),\n layoutPaths: new Set(),\n appRouteHandlers: new Set(),\n pageApiRoutes: new Set(),\n filePathToRoute: new Map(),\n },\n path.join(distTypesDir, 'routes.d.ts'),\n opts.nextConfig\n )\n\n const usingTypeScript = await verifyTypeScript(opts)\n\n const routesManifestPath = path.join(distDir, ROUTES_MANIFEST)\n const routesManifest: DevRoutesManifest = {\n version: 3,\n caseSensitive: !!nextConfig.experimental.caseSensitiveRoutes,\n basePath: nextConfig.basePath,\n rewrites: opts.fsChecker.rewrites,\n redirects: opts.fsChecker.redirects,\n headers: opts.fsChecker.headers,\n i18n: nextConfig.i18n || undefined,\n skipMiddlewareUrlNormalize: nextConfig.skipMiddlewareUrlNormalize,\n }\n await fs.promises.writeFile(\n routesManifestPath,\n JSON.stringify(routesManifest)\n )\n\n const prerenderManifestPath = path.join(distDir, PRERENDER_MANIFEST)\n await fs.promises.writeFile(\n prerenderManifestPath,\n JSON.stringify(opts.fsChecker.prerenderManifest, null, 2)\n )\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 // Watchpack default is 200ms which adds 200ms of dead time on bootup.\n aggregateTimeout: 5, // Matches webpack-config.ts.\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 const routeTypesFilePath = path.join(distDir, 'types', 'routes.d.ts')\n const validatorFilePath = path.join(distDir, 'types', 'validator.ts')\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 appRouteHandlers: Array<{ route: string; filePath: string }> = []\n const pageApiRoutes: Array<{ route: string; filePath: string }> = []\n\n const pageRoutes: Array<{ route: string; filePath: string }> = []\n const appRoutes: Array<{ route: string; filePath: string }> = []\n const layoutRoutes: Array<{ route: string; filePath: string }> = []\n const slots: Array<{ name: string; parent: string }> = []\n\n let envChange = false\n let tsconfigChange = false\n let conflictingPageChange = 0\n let hasRootAppNotFound = false\n\n const { appFiles, pageFiles, staticMetadataFiles } = opts.fsChecker\n\n appFiles.clear()\n pageFiles.clear()\n staticMetadataFiles.clear()\n devPageFiles.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 getStaticInfoIncludingLayouts = (\n require('../../../build/get-static-info-including-layouts') as typeof import('../../../build/get-static-info-including-layouts')\n ).getStaticInfoIncludingLayouts\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 getPageStaticInfo = (\n require('../../../build/analysis/get-page-static-info') as typeof import('../../../build/analysis/get-page-static-info')\n ).getPageStaticInfo\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\n // Ignore files/directories starting with `_` in the app directory\n if (normalizePathSep(pageName).includes('/_')) {\n continue\n }\n\n // Record parallel route slots for layout typing\n // May run multiple times (e.g. if a parallel route\n // has both a layout and a page, and children) but that's fine\n const segments = normalizePathSep(pageName).split('/')\n for (let i = segments.length - 1; i >= 0; i--) {\n const segment = segments[i]\n if (isParallelRouteSegment(segment)) {\n const parentPath = normalizeAppPath(\n segments.slice(0, i).join('/')\n )\n\n const slotName = segment.slice(1)\n // check if the slot already exists\n if (\n slots.some(\n (s) => s.name === slotName && s.parent === parentPath\n )\n )\n continue\n\n slots.push({\n name: slotName,\n parent: parentPath,\n })\n break\n }\n }\n\n // Record layouts\n if (validFileMatcher.isAppLayoutPage(fileName)) {\n layoutRoutes.push({\n route: ensureLeadingSlash(\n normalizeAppPath(normalizePathSep(pageName)).replace(\n /\\/layout$/,\n ''\n )\n ),\n filePath: fileName,\n })\n }\n\n if (!validFileMatcher.isAppRouterPage(fileName)) {\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(\n opts.turbo\n ? // Turbopack outputs the correct path which is normalized with the `_`.\n originalPageName.replace(/%5F/g, '_')\n : originalPageName\n )\n\n if (useFileSystemPublicRoutes) {\n // Static metadata files will be served from filesystem.\n if (appDir && isStaticMetadataFile(fileName.replace(appDir, ''))) {\n staticMetadataFiles.set(pageName, fileName)\n } else {\n appFiles.add(pageName)\n }\n }\n\n if (validFileMatcher.isAppRouterRoute(fileName)) {\n appRouteHandlers.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n } else {\n appRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\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 if (pageName.startsWith('/api/')) {\n pageApiRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n } else {\n pageRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n }\n }\n\n // Record pages\n if (isAppPath) {\n appPageFilePaths.set(pageName, fileName)\n } else {\n pagesPageFilePaths.set(pageName, 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 loadEnvConfig = (\n require('@next/env') as typeof import('@next/env')\n ).loadEnvConfig\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<\n ReturnType<typeof import('../../../build/load-jsconfig').default>\n >\n | undefined\n\n // This is not relevant for Turbopack because tsconfig/jsconfig is handled internally.\n if (!hotReloader.turbopackProject) {\n if (tsconfigChange) {\n try {\n const loadJsConfig = (\n require('../../../build/load-jsconfig') as typeof import('../../../build/load-jsconfig')\n ).default\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\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 const rootPath =\n opts.nextConfig.turbopack?.root ||\n opts.nextConfig.outputFileTracingRoot ||\n opts.dir\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 projectPath: opts.dir,\n rewrites: opts.fsChecker.rewrites,\n }),\n rootPath,\n projectPath: normalizePath(path.relative(rootPath, dir)),\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 isNodeServer,\n middlewareMatchers: undefined,\n projectPath: opts.dir,\n rewrites: opts.fsChecker.rewrites,\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 = getNamedRouteRegex(page, {\n prefixRouteKeys: true,\n })\n return {\n regex: regex.re.toString(),\n namedRegex: regex.namedRegex,\n routeKeys: regex.routeKeys,\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 = getNamedRouteRegex(route.page, {\n prefixRouteKeys: true,\n })\n dataRoutes.push({\n ...route,\n regex: routeRegex.re.toString(),\n namedRegex: routeRegex.namedRegex,\n routeKeys: routeRegex.routeKeys,\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 type: HMR_MESSAGE_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 type: HMR_MESSAGE_SENT_TO_BROWSER.ADDED_PAGE,\n data: [route],\n })\n })\n\n removedRoutes.forEach((route) => {\n hotReloader.send({\n type: HMR_MESSAGE_SENT_TO_BROWSER.REMOVED_PAGE,\n data: [route],\n })\n })\n }\n prevSortedRoutes = sortedRoutes\n\n if (usingTypeScript) {\n const routeTypesManifest = await createRouteTypesManifest({\n dir,\n pageRoutes,\n appRoutes,\n layoutRoutes,\n slots,\n redirects: opts.nextConfig.redirects,\n rewrites: opts.nextConfig.rewrites,\n // Ensure relative paths in validator.ts are computed from validatorFilePath,\n // matching behavior of build and CLI typegen.\n validatorFilePath,\n appRouteHandlers,\n pageApiRoutes,\n })\n\n await writeRouteTypesManifest(\n routeTypesManifest,\n routeTypesFilePath,\n opts.nextConfig\n )\n await writeValidatorFile(routeTypesManifest, validatorFilePath)\n }\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 const devTurbopackMiddlewareManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(devTurbopackMiddlewareManifestPath)\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', JSON_CONTENT_TYPE_HEADER)\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 (\n parsedUrl.pathname?.includes(devMiddlewareManifestPath) ||\n parsedUrl.pathname?.includes(devTurbopackMiddlewareManifestPath)\n ) {\n res.statusCode = 200\n res.setHeader('Content-Type', JSON_CONTENT_TYPE_HEADER)\n res.end(JSON.stringify(serverFields.middleware?.matchers || []))\n return { finished: true }\n }\n return { finished: false }\n }\n\n function logErrorWithOriginalStack(\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 Log.error(err)\n } else if (type) {\n Log.error(`${type}:`, err)\n } else {\n Log.error(err)\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\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({\n ...opts,\n isSrcDir,\n })\n\n opts.telemetry.record(\n eventCliSession(opts.nextConfig, {\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 // Track build features for dev server here:\n opts.telemetry.record({\n eventName: EVENT_BUILD_FEATURE_USAGE,\n payload: {\n featureName: 'turbopackPersistentCaching',\n invocationCount: isPersistentCachingEnabled(opts.nextConfig) ? 1 : 0,\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\n"],"names":["propagateServerField","setupDevBundler","verifyTypeScript","opts","usingTypeScript","verifyResult","verifyTypeScriptSetup","dir","distDir","nextConfig","intentDirs","pagesDir","appDir","filter","Boolean","typeCheckPreflight","tsconfigPath","typescript","disableStaticImages","images","hasAppDir","hasPagesDir","version","field","args","renderServer","instance","startWatcher","resetFetch","useFileSystemPublicRoutes","path","join","setGlobal","PHASE_DEVELOPMENT_SERVER","validFileMatcher","createValidFileMatcher","pageExtensions","serverFields","consoleStore","setState","logging","hotReloader","turbo","createHotReloaderTurbopack","require","HotReloaderWebpack","default","isSrcDir","config","buildId","encryptionKey","generateEncryptionKeyBase64","isBuild","telemetry","rewrites","fsChecker","previewProps","prerenderManifest","preview","start","distTypesDir","writeRouteTypesManifest","appRoutes","pageRoutes","layoutRoutes","appRouteHandlerRoutes","redirectRoutes","rewriteRoutes","appPagePaths","Set","pagesRouterPagePaths","layoutPaths","appRouteHandlers","pageApiRoutes","filePathToRoute","Map","routesManifestPath","ROUTES_MANIFEST","routesManifest","caseSensitive","experimental","caseSensitiveRoutes","basePath","redirects","headers","i18n","undefined","skipMiddlewareUrlNormalize","fs","promises","writeFile","JSON","stringify","prerenderManifestPath","PRERENDER_MANIFEST","nextScriptWorkers","verifyPartytownSetup","CLIENT_STATIC_FILES_PATH","ensureCallback","ensure","item","type","ensurePage","clientOnly","page","itemPath","isApp","definition","resolved","prevSortedRoutes","Promise","resolve","reject","readdir","_","files","length","pages","app","directories","rootDir","getPossibleMiddlewareFilenames","getPossibleInstrumentationHookFilenames","nestedMiddleware","envFiles","map","file","push","tsconfigPaths","wp","Watchpack","aggregateTimeout","ignored","pathname","some","startsWith","d","fileWatchTimes","enabledTypeScript","previousClientRouterFilters","previousConflictingPagePaths","routeTypesFilePath","validatorFilePath","on","middlewareMatchers","routedPages","knownFiles","getTimeInfoEntries","appPaths","pageNameSet","conflictingAppPagePaths","appPageFilePaths","pagesPageFilePaths","slots","envChange","tsconfigChange","conflictingPageChange","hasRootAppNotFound","appFiles","pageFiles","staticMetadataFiles","clear","devPageFiles","sortedKnownFiles","keys","sort","sortByPageExts","fileName","includes","meta","get","watchTime","watchTimeChange","timestamp","set","endsWith","accuracy","isPageFile","isAppPath","normalizePathSep","isPagePath","rootFile","absolutePathToPage","extensions","keepIndex","pagesType","PAGE_TYPES","ROOT","isMiddlewareFile","staticInfo","getStaticInfoIncludingLayouts","pageFilePath","isDev","isInsideAppDir","output","Log","error","actualMiddlewareFile","middleware","matchers","regexp","originalSource","isInstrumentationHookFile","actualInstrumentationHookFile","add","pageName","APP","PAGES","isMetadataRouteFile","replace","getPageStaticInfo","pageType","normalizeMetadataPageToRoute","generateSitemaps","generateImageMetadata","isRootNotFound","segments","split","i","segment","isParallelRouteSegment","parentPath","normalizeAppPath","slice","slotName","s","name","parent","isAppLayoutPage","route","ensureLeadingSlash","filePath","isAppRouterPage","originalPageName","isStaticMetadataFile","isAppRouterRoute","nextDataRoutes","has","test","numConflicting","size","errorMessage","p","appPath","relative","pagesPath","setHmrServerError","Error","clearHmrServerError","clientRouterFilters","clientRouterFilter","createClientRouterFilter","Object","clientRouterFilterRedirects","_originalRedirects","r","internal","clientRouterFilterAllowedRate","then","catch","loadEnvConfig","loadedEnvFiles","process","env","NODE_ENV","envFilePath","info","typedEnv","createEnvDefinitions","configFileName","contents","dev","forceReload","silent","tsconfigResult","turbopackProject","loadJsConfig","hasRewrites","afterFiles","beforeFiles","fallback","rootPath","turbopack","root","outputFileTracingRoot","update","defineEnv","createDefineEnv","isTurbopack","fetchCacheKeyPrefix","projectPath","normalizePath","activeWebpackConfigs","forEach","idx","isClient","isNodeServer","isEdgeServer","plugins","plugin","JsConfigPathsPlugin","jsConfig","resolvedBaseUrl","currentResolvedBaseUrl","resolvedUrlIndex","modules","findIndex","baseUrl","splice","isImplicit","compilerOptions","paths","key","assign","definitions","__NEXT_DEFINE_ENV","newDefine","getDefineEnv","invalidate","reloadAfterInvalidation","NestedMiddlewareError","message","appPathRoutes","fromEntries","entries","k","v","match","hasAppNotFound","middlewareMatcher","getMiddlewareRouteMatcher","interceptionRoutes","generateInterceptionRoutesRewrites","buildCustomRoute","exportPathMap","outDir","exportPathMapEntries","exportPathMapRoutes","value","source","destination","query","qs","sortedRoutes","getSortedRoutes","dynamicRoutes","regex","getNamedRouteRegex","prefixRouteKeys","re","toString","namedRegex","routeKeys","getRouteMatcher","dataRoutes","buildDataRoute","routeRegex","RegExp","dataRouteRegex","groups","unshift","every","val","addedRoutes","removedRoutes","send","HMR_MESSAGE_SENT_TO_BROWSER","DEV_PAGES_MANIFEST_UPDATE","data","devPagesManifest","ADDED_PAGE","REMOVED_PAGE","routeTypesManifest","createRouteTypesManifest","writeValidatorFile","e","warn","watch","startTime","clientPagesManifestPath","DEV_CLIENT_PAGES_MANIFEST","devVirtualFsItems","devMiddlewareManifestPath","DEV_CLIENT_MIDDLEWARE_MANIFEST","devTurbopackMiddlewareManifestPath","TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST","requestHandler","req","res","parsedUrl","url","parse","statusCode","setHeader","JSON_CONTENT_TYPE_HEADER","end","finished","logErrorWithOriginalStack","err","ModuleBuildError","TurbopackInternalError","ensureMiddleware","requestUrl","result","record","eventCliSession","webpackVersion","turboFlag","cliCommand","isCustomServer","hasNowJson","findUp","cwd","eventName","EVENT_BUILD_FEATURE_USAGE","payload","featureName","invocationCount","isPersistentCachingEnabled"],"mappings":";;;;;;;;;;;;;;;IAyJsBA,oBAAoB;eAApBA;;IAyhCAC,eAAe;eAAfA;;;qBAzqCU;2DACjB;4DACC;6DACC;oEACF;kEACO;+DACH;4BACc;6DACZ;wBACK;8BAGa;wBAIhC;uBACyB;gCACD;uCACO;sCACD;4BACF;0BACF;gCACF;8BACC;kCACC;0CACQ;oCACN;oDACgB;2BAU5C;wCAEmC;wBAQnC;yBACsB;kCAEe;2BACjB;uCACiB;iCAIrC;kCACsC;sCACR;qCACD;uBACE;wBAI/B;2BACsB;+BACU;+BACT;4BACW;iCAKlC;yBACgC;oCACJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiDnC,eAAeC,iBAAiBC,IAAe;IAC7C,IAAIC,kBAAkB;IACtB,MAAMC,eAAe,MAAMC,IAAAA,4CAAqB,EAAC;QAC/CC,KAAKJ,KAAKI,GAAG;QACbC,SAASL,KAAKM,UAAU,CAACD,OAAO;QAChCE,YAAY;YAACP,KAAKQ,QAAQ;YAAER,KAAKS,MAAM;SAAC,CAACC,MAAM,CAACC;QAChDC,oBAAoB;QACpBC,cAAcb,KAAKM,UAAU,CAACQ,UAAU,CAACD,YAAY;QACrDE,qBAAqBf,KAAKM,UAAU,CAACU,MAAM,CAACD,mBAAmB;QAC/DE,WAAW,CAAC,CAACjB,KAAKS,MAAM;QACxBS,aAAa,CAAC,CAAClB,KAAKQ,QAAQ;IAC9B;IAEA,IAAIN,aAAaiB,OAAO,EAAE;QACxBlB,kBAAkB;IACpB;IACA,OAAOA;AACT;AAEO,eAAeJ,qBACpBG,IAAe,EACfoB,KAA8B,EAC9BC,IAAS;QAEHrB,6BAAAA;IAAN,QAAMA,qBAAAA,KAAKsB,YAAY,sBAAjBtB,8BAAAA,mBAAmBuB,QAAQ,qBAA3BvB,4BAA6BH,oBAAoB,CAACG,KAAKI,GAAG,EAAEgB,OAAOC;AAC3E;AAEA,eAAeG,aACbxB,IAEC;IAED,MAAM,EAAEM,UAAU,EAAEG,MAAM,EAAED,QAAQ,EAAEJ,GAAG,EAAEqB,UAAU,EAAE,GAAGzB;IAC1D,MAAM,EAAE0B,yBAAyB,EAAE,GAAGpB;IAEtC,MAAMD,UAAUsB,aAAI,CAACC,IAAI,CAAC5B,KAAKI,GAAG,EAAEJ,KAAKM,UAAU,CAACD,OAAO;IAE3DwB,IAAAA,iBAAS,EAAC,WAAWxB;IACrBwB,IAAAA,iBAAS,EAAC,SAASC,mCAAwB;IAE3C,MAAMC,mBAAmBC,IAAAA,oCAAsB,EAC7C1B,WAAW2B,cAAc,EACzBxB;IAGF,MAAMyB,eAA6B,CAAC;IAEpC,sEAAsE;IACtEC,YAAY,CAACC,QAAQ,CAAC;QACpBC,SAAS/B,WAAW+B,OAAO,KAAK;IAClC;IAEA,MAAMC,cAA0CtC,KAAKuC,KAAK,GACtD,MAAM,AAAC,CAAA;QACL,MAAMC,6BAA6B,AACjCC,QAAQ,oCACRD,0BAA0B;QAC5B,OAAO,MAAMA,2BACXxC,MACAkC,cACA7B,SACAoB;IAEJ,CAAA,MACA,MAAM,AAAC,CAAA;QACL,MAAMiB,qBAAqB,AACzBD,QAAQ,kCACRE,OAAO;QACT,OAAO,IAAID,mBAAmB1C,KAAKI,GAAG,EAAE;YACtCwC,UAAU5C,KAAK4C,QAAQ;YACvBnC;YACAD;YACAH;YACAwC,QAAQ7C,KAAKM,UAAU;YACvBwC,SAAS;YACTC,eAAe,MAAMC,IAAAA,kDAA2B,EAAC;gBAC/CC,SAAS;gBACT5C;YACF;YACA6C,WAAWlD,KAAKkD,SAAS;YACzBC,UAAUnD,KAAKoD,SAAS,CAACD,QAAQ;YACjCE,cAAcrD,KAAKoD,SAAS,CAACE,iBAAiB,CAACC,OAAO;YACtD9B;QACF;IACF,CAAA;IAEJ,MAAMa,YAAYkB,KAAK;IAEvB,4DAA4D;IAC5D,sBAAsB;IACtB,MAAMC,eAAe9B,aAAI,CAACC,IAAI,CAACvB,SAAS;IACxC,MAAMqD,IAAAA,wCAAuB,EAC3B;QACEC,WAAW,CAAC;QACZC,YAAY,CAAC;QACbC,cAAc,CAAC;QACfC,uBAAuB,CAAC;QACxBC,gBAAgB,CAAC;QACjBC,eAAe,CAAC;QAChBC,cAAc,IAAIC;QAClBC,sBAAsB,IAAID;QAC1BE,aAAa,IAAIF;QACjBG,kBAAkB,IAAIH;QACtBI,eAAe,IAAIJ;QACnBK,iBAAiB,IAAIC;IACvB,GACA7C,aAAI,CAACC,IAAI,CAAC6B,cAAc,gBACxBzD,KAAKM,UAAU;IAGjB,MAAML,kBAAkB,MAAMF,iBAAiBC;IAE/C,MAAMyE,qBAAqB9C,aAAI,CAACC,IAAI,CAACvB,SAASqE,0BAAe;IAC7D,MAAMC,iBAAoC;QACxCxD,SAAS;QACTyD,eAAe,CAAC,CAACtE,WAAWuE,YAAY,CAACC,mBAAmB;QAC5DC,UAAUzE,WAAWyE,QAAQ;QAC7B5B,UAAUnD,KAAKoD,SAAS,CAACD,QAAQ;QACjC6B,WAAWhF,KAAKoD,SAAS,CAAC4B,SAAS;QACnCC,SAASjF,KAAKoD,SAAS,CAAC6B,OAAO;QAC/BC,MAAM5E,WAAW4E,IAAI,IAAIC;QACzBC,4BAA4B9E,WAAW8E,0BAA0B;IACnE;IACA,MAAMC,WAAE,CAACC,QAAQ,CAACC,SAAS,CACzBd,oBACAe,KAAKC,SAAS,CAACd;IAGjB,MAAMe,wBAAwB/D,aAAI,CAACC,IAAI,CAACvB,SAASsF,6BAAkB;IACnE,MAAMN,WAAE,CAACC,QAAQ,CAACC,SAAS,CACzBG,uBACAF,KAAKC,SAAS,CAACzF,KAAKoD,SAAS,CAACE,iBAAiB,EAAE,MAAM;IAGzD,IAAItD,KAAKM,UAAU,CAACuE,YAAY,CAACe,iBAAiB,EAAE;QAClD,MAAMC,IAAAA,0CAAoB,EACxB7F,KAAKI,GAAG,EACRuB,aAAI,CAACC,IAAI,CAACvB,SAASyF,mCAAwB;IAE/C;IAEA9F,KAAKoD,SAAS,CAAC2C,cAAc,CAAC,eAAeC,OAAOC,IAAI;QACtD,IAAIA,KAAKC,IAAI,KAAK,aAAaD,KAAKC,IAAI,KAAK,YAAY;YACvD,MAAM5D,YAAY6D,UAAU,CAAC;gBAC3BC,YAAY;gBACZC,MAAMJ,KAAKK,QAAQ;gBACnBC,OAAON,KAAKC,IAAI,KAAK;gBACrBM,YAAYrB;YACd;QACF;IACF;IAEA,IAAIsB,WAAW;IACf,IAAIC,mBAA6B,EAAE;IAEnC,MAAM,IAAIC,QAAc,OAAOC,SAASC;QACtC,IAAIrG,UAAU;YACZ,yDAAyD;YACzD6E,WAAE,CAACyB,OAAO,CAACtG,UAAU,CAACuG,GAAGC;gBACvB,IAAIA,yBAAAA,MAAOC,MAAM,EAAE;oBACjB;gBACF;gBAEA,IAAI,CAACR,UAAU;oBACbG;oBACAH,WAAW;gBACb;YACF;QACF;QAEA,MAAMS,QAAQ1G,WAAW;YAACA;SAAS,GAAG,EAAE;QACxC,MAAM2G,MAAM1G,SAAS;YAACA;SAAO,GAAG,EAAE;QAClC,MAAM2G,cAAc;eAAIF;eAAUC;SAAI;QAEtC,MAAME,UAAU7G,YAAYC;QAC5B,MAAMuG,QAAQ;eACTM,IAAAA,sCAA8B,EAC/B3F,aAAI,CAACC,IAAI,CAACyF,SAAU,OACpB/G,WAAW2B,cAAc;eAExBsF,IAAAA,+CAAuC,EACxC5F,aAAI,CAACC,IAAI,CAACyF,SAAU,OACpB/G,WAAW2B,cAAc;SAE5B;QACD,IAAIuF,mBAA6B,EAAE;QAEnC,MAAMC,WAAW;YACf;YACA;YACA;YACA;SACD,CAACC,GAAG,CAAC,CAACC,OAAShG,aAAI,CAACC,IAAI,CAACxB,KAAKuH;QAE/BX,MAAMY,IAAI,IAAIH;QAEd,wCAAwC;QACxC,MAAMI,gBAAgB;YACpBlG,aAAI,CAACC,IAAI,CAACxB,KAAK;YACfuB,aAAI,CAACC,IAAI,CAACxB,KAAK;SAChB;QACD4G,MAAMY,IAAI,IAAIC;QAEd,MAAMC,KAAK,IAAIC,kBAAS,CAAC;YACvB,sEAAsE;YACtEC,kBAAkB;YAClBC,SAAS,CAACC;gBACR,OACE,CAAClB,MAAMmB,IAAI,CAAC,CAACR,OAASA,KAAKS,UAAU,CAACF,cACtC,CAACd,YAAYe,IAAI,CACf,CAACE,IAAMH,SAASE,UAAU,CAACC,MAAMA,EAAED,UAAU,CAACF;YAGpD;QACF;QACA,MAAMI,iBAAiB,IAAI9D;QAC3B,IAAI+D,oBAAoBtI;QACxB,IAAIuI;QACJ,IAAIC,+BAA4C,IAAIvE;QAEpD,MAAMwE,qBAAqB/G,aAAI,CAACC,IAAI,CAACvB,SAAS,SAAS;QACvD,MAAMsI,oBAAoBhH,aAAI,CAACC,IAAI,CAACvB,SAAS,SAAS;QAEtDyH,GAAGc,EAAE,CAAC,cAAc;gBA6kBiB1G,0BACLA;YA7kB9B,IAAI2G;YACJ,MAAMC,cAAwB,EAAE;YAChC,MAAMC,aAAajB,GAAGkB,kBAAkB;YACxC,MAAMC,WAAqC,CAAC;YAC5C,MAAMC,cAAc,IAAIhF;YACxB,MAAMiF,0BAA0B,IAAIjF;YACpC,MAAMkF,mBAAmB,IAAI5E;YAC7B,MAAM6E,qBAAqB,IAAI7E;YAC/B,MAAMH,mBAA+D,EAAE;YACvE,MAAMC,gBAA4D,EAAE;YAEpE,MAAMV,aAAyD,EAAE;YACjE,MAAMD,YAAwD,EAAE;YAChE,MAAME,eAA2D,EAAE;YACnE,MAAMyF,QAAiD,EAAE;YAEzD,IAAIC,YAAY;YAChB,IAAIC,iBAAiB;YACrB,IAAIC,wBAAwB;YAC5B,IAAIC,qBAAqB;YAEzB,MAAM,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,mBAAmB,EAAE,GAAG7J,KAAKoD,SAAS;YAEnEuG,SAASG,KAAK;YACdF,UAAUE,KAAK;YACfD,oBAAoBC,KAAK;YACzBC,qBAAY,CAACD,KAAK;YAElB,MAAME,mBAA6B;mBAAIjB,WAAWkB,IAAI;aAAG,CAACC,IAAI,CAC5DC,IAAAA,8BAAc,EAAC7J,WAAW2B,cAAc;YAG1C,KAAK,MAAMmI,YAAYJ,iBAAkB;gBACvC,IACE,CAAChD,MAAMqD,QAAQ,CAACD,aAChB,CAAChD,YAAYe,IAAI,CAAC,CAACE,IAAM+B,SAAShC,UAAU,CAACC,KAC7C;oBACA;gBACF;gBACA,MAAMiC,OAAOvB,WAAWwB,GAAG,CAACH;gBAE5B,MAAMI,YAAYlC,eAAeiC,GAAG,CAACH;gBACrC,gGAAgG;gBAChG,MAAMK,kBACJD,cAAcrF,aACbqF,aAAaA,eAAcF,wBAAAA,KAAMI,SAAS;gBAC7CpC,eAAeqC,GAAG,CAACP,UAAUE,wBAAAA,KAAMI,SAAS;gBAE5C,IAAIjD,SAAS4C,QAAQ,CAACD,WAAW;oBAC/B,IAAIK,iBAAiB;wBACnBlB,YAAY;oBACd;oBACA;gBACF;gBAEA,IAAI1B,cAAcwC,QAAQ,CAACD,WAAW;oBACpC,IAAIA,SAASQ,QAAQ,CAAC,kBAAkB;wBACtCrC,oBAAoB;oBACtB;oBACA,IAAIkC,iBAAiB;wBACnBjB,iBAAiB;oBACnB;oBACA;gBACF;gBAEA,IACEc,CAAAA,wBAAAA,KAAMO,QAAQ,MAAK1F,aACnB,CAACpD,iBAAiB+I,UAAU,CAACV,WAC7B;oBACA;gBACF;gBAEA,MAAMW,YAAYpK,QAChBF,UACEuK,IAAAA,kCAAgB,EAACZ,UAAUhC,UAAU,CACnC4C,IAAAA,kCAAgB,EAACvK,UAAU;gBAGjC,MAAMwK,aAAatK,QACjBH,YACEwK,IAAAA,kCAAgB,EAACZ,UAAUhC,UAAU,CACnC4C,IAAAA,kCAAgB,EAACxK,YAAY;gBAInC,MAAM0K,WAAWC,IAAAA,sCAAkB,EAACf,UAAU;oBAC5ChK,KAAKA;oBACLgL,YAAY9K,WAAW2B,cAAc;oBACrCoJ,WAAW;oBACXC,WAAWC,qBAAU,CAACC,IAAI;gBAC5B;gBAEA,IAAIC,IAAAA,wBAAgB,EAACP,WAAW;wBAyBTQ;oBAxBrB,MAAMC,gCAAgC,AACpClJ,QAAQ,oDACRkJ,6BAA6B;oBAC/B,MAAMD,aAAa,MAAMC,8BAA8B;wBACrDC,cAAcxB;wBACdvH,QAAQvC;wBACRG,QAAQA;wBACR4F,MAAM6E;wBACNW,OAAO;wBACPC,gBAAgBf;wBAChB9I,gBAAgB3B,WAAW2B,cAAc;oBAC3C;oBACA,IAAI3B,WAAWyL,MAAM,KAAK,UAAU;wBAClCC,KAAIC,KAAK,CACP;wBAEF;oBACF;oBACA/J,aAAagK,oBAAoB,GAAGhB;oBACpC,MAAMrL,qBACJG,MACA,wBACAkC,aAAagK,oBAAoB;oBAEnCrD,qBAAqB6C,EAAAA,yBAAAA,WAAWS,UAAU,qBAArBT,uBAAuBU,QAAQ,KAAI;wBACtD;4BAAEC,QAAQ;4BAAMC,gBAAgB;wBAAU;qBAC3C;oBACD;gBACF;gBACA,IAAIC,IAAAA,iCAAyB,EAACrB,WAAW;oBACvChJ,aAAasK,6BAA6B,GAAGtB;oBAC7C,MAAMrL,qBACJG,MACA,iCACAkC,aAAasK,6BAA6B;oBAE5C;gBACF;gBAEA,IAAIpC,SAASQ,QAAQ,CAAC,UAAUR,SAASQ,QAAQ,CAAC,SAAS;oBACzDrC,oBAAoB;gBACtB;gBAEA,IAAI,CAAEwC,CAAAA,aAAaE,UAAS,GAAI;oBAC9B;gBACF;gBAEA,yDAAyD;gBACzDlB,qBAAY,CAAC0C,GAAG,CAACrC;gBAEjB,IAAIsC,WAAWvB,IAAAA,sCAAkB,EAACf,UAAU;oBAC1ChK,KAAK2K,YAAYtK,SAAUD;oBAC3B4K,YAAY9K,WAAW2B,cAAc;oBACrCoJ,WAAWN;oBACXO,WAAWP,YAAYQ,qBAAU,CAACoB,GAAG,GAAGpB,qBAAU,CAACqB,KAAK;gBAC1D;gBAEA,IACE7B,aACAtK,UACAoM,IAAAA,oCAAmB,EACjBzC,SAAS0C,OAAO,CAACrM,QAAQ,KACzBH,WAAW2B,cAAc,EACzB,OAEF;oBACA,MAAM8K,oBAAoB,AACxBtK,QAAQ,gDACRsK,iBAAiB;oBACnB,MAAMrB,aAAa,MAAMqB,kBAAkB;wBACzCnB,cAAcxB;wBACd9J,YAAY,CAAC;wBACb+F,MAAMqG;wBACNb,OAAO;wBACPmB,UAAUzB,qBAAU,CAACoB,GAAG;oBAC1B;oBAEAD,WAAWO,IAAAA,8CAA4B,EACrCP,UACA,CAAC,CAAEhB,CAAAA,WAAWwB,gBAAgB,IAAIxB,WAAWyB,qBAAqB,AAAD;gBAErE;gBAEA,IACE,CAACpC,aACD2B,SAAStE,UAAU,CAAC,YACpB9H,WAAWyL,MAAM,KAAK,UACtB;oBACAC,KAAIC,KAAK,CACP;oBAEF;gBACF;gBAEA,IAAIlB,WAAW;oBACb,MAAMqC,iBAAiBrL,iBAAiBqL,cAAc,CAAChD;oBACvDV,qBAAqB;oBAErB,IAAI0D,gBAAgB;wBAClB;oBACF;oBAEA,kEAAkE;oBAClE,IAAIpC,IAAAA,kCAAgB,EAAC0B,UAAUrC,QAAQ,CAAC,OAAO;wBAC7C;oBACF;oBAEA,gDAAgD;oBAChD,mDAAmD;oBACnD,8DAA8D;oBAC9D,MAAMgD,WAAWrC,IAAAA,kCAAgB,EAAC0B,UAAUY,KAAK,CAAC;oBAClD,IAAK,IAAIC,IAAIF,SAASpG,MAAM,GAAG,GAAGsG,KAAK,GAAGA,IAAK;wBAC7C,MAAMC,UAAUH,QAAQ,CAACE,EAAE;wBAC3B,IAAIE,IAAAA,+BAAsB,EAACD,UAAU;4BACnC,MAAME,aAAaC,IAAAA,0BAAgB,EACjCN,SAASO,KAAK,CAAC,GAAGL,GAAG3L,IAAI,CAAC;4BAG5B,MAAMiM,WAAWL,QAAQI,KAAK,CAAC;4BAC/B,mCAAmC;4BACnC,IACEtE,MAAMnB,IAAI,CACR,CAAC2F,IAAMA,EAAEC,IAAI,KAAKF,YAAYC,EAAEE,MAAM,KAAKN,aAG7C;4BAEFpE,MAAM1B,IAAI,CAAC;gCACTmG,MAAMF;gCACNG,QAAQN;4BACV;4BACA;wBACF;oBACF;oBAEA,iBAAiB;oBACjB,IAAI3L,iBAAiBkM,eAAe,CAAC7D,WAAW;wBAC9CvG,aAAa+D,IAAI,CAAC;4BAChBsG,OAAOC,IAAAA,sCAAkB,EACvBR,IAAAA,0BAAgB,EAAC3C,IAAAA,kCAAgB,EAAC0B,WAAWI,OAAO,CAClD,aACA;4BAGJsB,UAAUhE;wBACZ;oBACF;oBAEA,IAAI,CAACrI,iBAAiBsM,eAAe,CAACjE,WAAW;wBAC/C;oBACF;oBAEA,MAAMkE,mBAAmB5B;oBACzBA,WAAWiB,IAAAA,0BAAgB,EAACjB,UAAUI,OAAO,CAAC,QAAQ;oBACtD,IAAI,CAAC7D,QAAQ,CAACyD,SAAS,EAAE;wBACvBzD,QAAQ,CAACyD,SAAS,GAAG,EAAE;oBACzB;oBACAzD,QAAQ,CAACyD,SAAS,CAAC9E,IAAI,CACrB5H,KAAKuC,KAAK,GAEN+L,iBAAiBxB,OAAO,CAAC,QAAQ,OACjCwB;oBAGN,IAAI5M,2BAA2B;wBAC7B,wDAAwD;wBACxD,IAAIjB,UAAU8N,IAAAA,qCAAoB,EAACnE,SAAS0C,OAAO,CAACrM,QAAQ,MAAM;4BAChEoJ,oBAAoBc,GAAG,CAAC+B,UAAUtC;wBACpC,OAAO;4BACLT,SAAS8C,GAAG,CAACC;wBACf;oBACF;oBAEA,IAAI3K,iBAAiByM,gBAAgB,CAACpE,WAAW;wBAC/C/F,iBAAiBuD,IAAI,CAAC;4BACpBsG,OAAOlD,IAAAA,kCAAgB,EAAC0B;4BACxB0B,UAAUhE;wBACZ;oBACF,OAAO;wBACLzG,UAAUiE,IAAI,CAAC;4BACbsG,OAAOlD,IAAAA,kCAAgB,EAAC0B;4BACxB0B,UAAUhE;wBACZ;oBACF;oBAEA,IAAItB,YAAYuB,QAAQ,CAACqC,WAAW;wBAClC;oBACF;gBACF,OAAO;oBACL,IAAIhL,2BAA2B;wBAC7BkI,UAAU6C,GAAG,CAACC;wBACd,8DAA8D;wBAC9D,8DAA8D;wBAC9D1M,KAAKoD,SAAS,CAACqL,cAAc,CAAChC,GAAG,CAACC;oBACpC;oBAEA,IAAIA,SAAStE,UAAU,CAAC,UAAU;wBAChC9D,cAAcsD,IAAI,CAAC;4BACjBsG,OAAOlD,IAAAA,kCAAgB,EAAC0B;4BACxB0B,UAAUhE;wBACZ;oBACF,OAAO;wBACLxG,WAAWgE,IAAI,CAAC;4BACdsG,OAAOlD,IAAAA,kCAAgB,EAAC0B;4BACxB0B,UAAUhE;wBACZ;oBACF;gBACF;gBAEA,eAAe;gBACf,IAAIW,WAAW;oBACb3B,iBAAiBuB,GAAG,CAAC+B,UAAUtC;gBACjC,OAAO;oBACLf,mBAAmBsB,GAAG,CAAC+B,UAAUtC;gBACnC;gBAEA,IAAI3J,UAAUyI,YAAYwF,GAAG,CAAChC,WAAW;oBACvCvD,wBAAwBsD,GAAG,CAACC;gBAC9B,OAAO;oBACLxD,YAAYuD,GAAG,CAACC;gBAClB;gBAEA;;;SAGC,GACD,IAAI,sBAAsBiC,IAAI,CAACjC,WAAW;oBACxClF,iBAAiBI,IAAI,CAAC8E;oBACtB;gBACF;gBAEA5D,YAAYlB,IAAI,CAAC8E;YACnB;YAEA,MAAMkC,iBAAiBzF,wBAAwB0F,IAAI;YACnDpF,wBAAwBmF,iBAAiBnG,6BAA6BoG,IAAI;YAE1E,IAAIpF,0BAA0B,GAAG;gBAC/B,IAAImF,iBAAiB,GAAG;oBACtB,IAAIE,eAAe,CAAC,6BAA6B,EAC/CF,mBAAmB,IAAI,SAAS,SACjC,0DAA0D,CAAC;oBAE5D,KAAK,MAAMG,KAAK5F,wBAAyB;wBACvC,MAAM6F,UAAUrN,aAAI,CAACsN,QAAQ,CAAC7O,KAAKgJ,iBAAiBmB,GAAG,CAACwE;wBACxD,MAAMG,YAAYvN,aAAI,CAACsN,QAAQ,CAAC7O,KAAKiJ,mBAAmBkB,GAAG,CAACwE;wBAC5DD,gBAAgB,CAAC,GAAG,EAAEI,UAAU,KAAK,EAAEF,QAAQ,GAAG,CAAC;oBACrD;oBACA1M,YAAY6M,iBAAiB,CAAC,qBAAuB,CAAvB,IAAIC,MAAMN,eAAV,qBAAA;+BAAA;oCAAA;sCAAA;oBAAsB;gBACtD,OAAO,IAAIF,mBAAmB,GAAG;oBAC/BtM,YAAY+M,mBAAmB;oBAC/B,MAAMxP,qBAAqBG,MAAM,kBAAkBmF;gBACrD;YACF;YAEAsD,+BAA+BU;YAE/B,IAAImG;YACJ,IAAIhP,WAAWuE,YAAY,CAAC0K,kBAAkB,EAAE;gBAC9CD,sBAAsBE,IAAAA,kDAAwB,EAC5CC,OAAOxF,IAAI,CAAChB,WACZ3I,WAAWuE,YAAY,CAAC6K,2BAA2B,GAC/C,AAAC,CAAA,AAACpP,WAAmBqP,kBAAkB,IAAI,EAAE,AAAD,EAAGjP,MAAM,CACnD,CAACkP,IAAW,CAACA,EAAEC,QAAQ,IAEzB,EAAE,EACNvP,WAAWuE,YAAY,CAACiL,6BAA6B;gBAGvD,IACE,CAACtH,+BACDhD,KAAKC,SAAS,CAAC+C,iCACbhD,KAAKC,SAAS,CAAC6J,sBACjB;oBACA/F,YAAY;oBACZf,8BAA8B8G;gBAChC;YACF;YAEA,IAAI,CAACrP,mBAAmBsI,mBAAmB;gBACzC,oDAAoD;gBACpD,+CAA+C;gBAC/C,MAAMxI,iBAAiBC,MACpB+P,IAAI,CAAC;oBACJvG,iBAAiB;gBACnB,GACCwG,KAAK,CAAC,KAAO;YAClB;YAEA,IAAIzG,aAAaC,gBAAgB;oBAoF/BlH;gBAnFA,IAAIiH,WAAW;wBAcUjJ;oBAbvB,MAAM2P,gBAAgB,AACpBxN,QAAQ,aACRwN,aAAa;oBACf,MAAM,EAAEC,cAAc,EAAE,GAAGD,cACzB7P,KACA+P,QAAQC,GAAG,CAACC,QAAQ,KAAK,eACzBrE,MACA,MACA,CAACsE;wBACCtE,KAAIuE,IAAI,CAAC,CAAC,YAAY,EAAED,aAAa;oBACvC;oBAGF,IAAIrQ,qBAAmBK,2BAAAA,WAAWuE,YAAY,qBAAvBvE,yBAAyBkQ,QAAQ,GAAE;wBACxD,0DAA0D;wBAC1DC,IAAAA,0CAAoB,EAAC;4BACnBpQ;4BACA6P,gBAAgB;mCACXA;gCACH;oCACEvO,MAAMrB,WAAWoQ,cAAc;oCAC/BN,KAAK9P,WAAW8P,GAAG;oCACnBO,UAAU;gCACZ;6BACD;wBACH;oBACF;oBAEA,MAAM9Q,qBAAqBG,MAAM,iBAAiB;wBAChD;4BAAE4Q,KAAK;4BAAMC,aAAa;4BAAMC,QAAQ;wBAAK;qBAC9C;gBACH;gBACA,IAAIC;gBAMJ,sFAAsF;gBACtF,IAAI,CAACzO,YAAY0O,gBAAgB,EAAE;oBACjC,IAAIxH,gBAAgB;wBAClB,IAAI;4BACF,MAAMyH,eAAe,AACnBxO,QAAQ,gCACRE,OAAO;4BACToO,iBAAiB,MAAME,aAAa7Q,KAAKE;wBAC3C,EAAE,OAAOyG,GAAG;wBACV,2EAA2E,GAC7E;oBACF;gBACF;gBAEA,IAAIzE,YAAY0O,gBAAgB,EAAE;wBAO9BhR;oBANF,MAAMkR,cACJlR,KAAKoD,SAAS,CAACD,QAAQ,CAACgO,UAAU,CAAClK,MAAM,GAAG,KAC5CjH,KAAKoD,SAAS,CAACD,QAAQ,CAACiO,WAAW,CAACnK,MAAM,GAAG,KAC7CjH,KAAKoD,SAAS,CAACD,QAAQ,CAACkO,QAAQ,CAACpK,MAAM,GAAG;oBAE5C,MAAMqK,WACJtR,EAAAA,6BAAAA,KAAKM,UAAU,CAACiR,SAAS,qBAAzBvR,2BAA2BwR,IAAI,KAC/BxR,KAAKM,UAAU,CAACmR,qBAAqB,IACrCzR,KAAKI,GAAG;oBACV,MAAMkC,YAAY0O,gBAAgB,CAACU,MAAM,CAAC;wBACxCC,WAAWC,IAAAA,oBAAe,EAAC;4BACzBC,aAAa;4BACbvC;4BACAzM,QAAQvC;4BACRsQ,KAAK;4BACLvQ;4BACAyR,qBACE9R,KAAKM,UAAU,CAACuE,YAAY,CAACiN,mBAAmB;4BAClDZ;4BACA,kBAAkB;4BAClBrI,oBAAoB1D;4BACpB4M,aAAa/R,KAAKI,GAAG;4BACrB+C,UAAUnD,KAAKoD,SAAS,CAACD,QAAQ;wBACnC;wBACAmO;wBACAS,aAAaC,IAAAA,4BAAa,EAACrQ,aAAI,CAACsN,QAAQ,CAACqC,UAAUlR;oBACrD;gBACF;iBAEAkC,oCAAAA,YAAY2P,oBAAoB,qBAAhC3P,kCAAkC4P,OAAO,CAAC,CAACrP,QAAQsP;oBACjD,MAAMC,WAAWD,QAAQ;oBACzB,MAAME,eAAeF,QAAQ;oBAC7B,MAAMG,eAAeH,QAAQ;oBAC7B,MAAMjB,cACJlR,KAAKoD,SAAS,CAACD,QAAQ,CAACgO,UAAU,CAAClK,MAAM,GAAG,KAC5CjH,KAAKoD,SAAS,CAACD,QAAQ,CAACiO,WAAW,CAACnK,MAAM,GAAG,KAC7CjH,KAAKoD,SAAS,CAACD,QAAQ,CAACkO,QAAQ,CAACpK,MAAM,GAAG;oBAE5C,IAAIuC,gBAAgB;4BAClB3G,yBAAAA;yBAAAA,kBAAAA,OAAO+D,OAAO,sBAAd/D,0BAAAA,gBAAgB0P,OAAO,qBAAvB1P,wBAAyBqP,OAAO,CAAC,CAACM;4BAChC,mDAAmD;4BACnD,kCAAkC;4BAClC,IAAIA,kBAAkBC,wCAAmB,IAAI1B,gBAAgB;oCAGlClO,yBAAAA,iBAqBrB6P;gCAvBJ,MAAM,EAAEC,eAAe,EAAED,QAAQ,EAAE,GAAG3B;gCACtC,MAAM6B,yBAAyBJ,OAAOG,eAAe;gCACrD,MAAME,oBAAmBhQ,kBAAAA,OAAO+D,OAAO,sBAAd/D,0BAAAA,gBAAgBiQ,OAAO,qBAAvBjQ,wBAAyBkQ,SAAS,CACzD,CAAC9M,OAASA,UAAS2M,0CAAAA,uBAAwBI,OAAO;gCAGpD,IAAIL,iBAAiB;oCACnB,IACEA,gBAAgBK,OAAO,MAAKJ,0CAAAA,uBAAwBI,OAAO,GAC3D;wCACA,qCAAqC;wCACrC,IAAIH,oBAAoBA,mBAAmB,CAAC,GAAG;gDAC7ChQ,0BAAAA;6CAAAA,mBAAAA,OAAO+D,OAAO,sBAAd/D,2BAAAA,iBAAgBiQ,OAAO,qBAAvBjQ,yBAAyBoQ,MAAM,CAACJ,kBAAkB;wCACpD;wCAEA,wEAAwE;wCACxE,mEAAmE;wCACnE,IAAI,CAACF,gBAAgBO,UAAU,EAAE;gDAC/BrQ,0BAAAA;6CAAAA,mBAAAA,OAAO+D,OAAO,sBAAd/D,2BAAAA,iBAAgBiQ,OAAO,qBAAvBjQ,yBAAyB+E,IAAI,CAAC+K,gBAAgBK,OAAO;wCACvD;oCACF;gCACF;gCAEA,IAAIN,CAAAA,6BAAAA,4BAAAA,SAAUS,eAAe,qBAAzBT,0BAA2BU,KAAK,KAAIT,iBAAiB;oCACvDlD,OAAOxF,IAAI,CAACuI,OAAOY,KAAK,EAAElB,OAAO,CAAC,CAACmB;wCACjC,OAAOb,OAAOY,KAAK,CAACC,IAAI;oCAC1B;oCACA5D,OAAO6D,MAAM,CAACd,OAAOY,KAAK,EAAEV,SAASS,eAAe,CAACC,KAAK;oCAC1DZ,OAAOG,eAAe,GAAGA;gCAC3B;4BACF;wBACF;oBACF;oBAEA,IAAIpJ,WAAW;4BACb1G;yBAAAA,kBAAAA,OAAO0P,OAAO,qBAAd1P,gBAAgBqP,OAAO,CAAC,CAACM;4BACvB,qDAAqD;4BACrD,sCAAsC;4BACtC,IACEA,UACA,OAAOA,OAAOe,WAAW,KAAK,YAC9Bf,OAAOe,WAAW,CAACC,iBAAiB,EACpC;gCACA,MAAMC,YAAYC,IAAAA,uBAAY,EAAC;oCAC7B7B,aAAa;oCACbvC;oCACAzM,QAAQvC;oCACRsQ,KAAK;oCACLvQ;oCACAyR,qBACE9R,KAAKM,UAAU,CAACuE,YAAY,CAACiN,mBAAmB;oCAClDZ;oCACAkB;oCACAE;oCACAD;oCACAxJ,oBAAoB1D;oCACpB4M,aAAa/R,KAAKI,GAAG;oCACrB+C,UAAUnD,KAAKoD,SAAS,CAACD,QAAQ;gCACnC;gCAEAsM,OAAOxF,IAAI,CAACuI,OAAOe,WAAW,EAAErB,OAAO,CAAC,CAACmB;oCACvC,IAAI,CAAEA,CAAAA,OAAOI,SAAQ,GAAI;wCACvB,OAAOjB,OAAOe,WAAW,CAACF,IAAI;oCAChC;gCACF;gCACA5D,OAAO6D,MAAM,CAACd,OAAOe,WAAW,EAAEE;4BACpC;wBACF;oBACF;gBACF;gBACA,MAAMnR,YAAYqR,UAAU,CAAC;oBAC3BC,yBAAyBrK;gBAC3B;YACF;YAEA,IAAI/B,iBAAiBP,MAAM,GAAG,GAAG;gBAC/B+E,KAAIC,KAAK,CACP,qBAIC,CAJD,IAAI4H,6BAAqB,CACvBrM,kBACApH,KACCI,YAAYC,SAHf,qBAAA;2BAAA;gCAAA;kCAAA;gBAIA,GAAEqT,OAAO;gBAEXtM,mBAAmB,EAAE;YACvB;YAEA,sEAAsE;YACtEtF,aAAa6R,aAAa,GAAGtE,OAAOuE,WAAW,CAC7CvE,OAAOwE,OAAO,CAAChL,UAAUvB,GAAG,CAAC,CAAC,CAACwM,GAAGC,EAAE,GAAK;oBAACD;oBAAGC,EAAEjK,IAAI;iBAAG;YAExD,MAAMrK,qBACJG,MACA,iBACAkC,aAAa6R,aAAa;YAG5B,gDAAgD;YAChD7R,aAAaiK,UAAU,GAAGtD,qBACtB;gBACEuL,OAAO;gBACP/N,MAAM;gBACN+F,UAAUvD;YACZ,IACA1D;YAEJ,MAAMtF,qBAAqBG,MAAM,cAAckC,aAAaiK,UAAU;YACtEjK,aAAamS,cAAc,GAAG3K;YAE9B1J,KAAKoD,SAAS,CAACkR,iBAAiB,GAAGpS,EAAAA,2BAAAA,aAAaiK,UAAU,qBAAvBjK,yBAAyBkK,QAAQ,IAChEmI,IAAAA,iDAAyB,GAACrS,4BAAAA,aAAaiK,UAAU,qBAAvBjK,0BAAyBkK,QAAQ,IAC3DjH;YAEJ,MAAMqP,qBAAqBC,IAAAA,sEAAkC,EAC3DhF,OAAOxF,IAAI,CAAChB,WACZjJ,KAAKM,UAAU,CAACyE,QAAQ,EACxB2C,GAAG,CAAC,CAACzB,OACLyO,IAAAA,4BAAgB,EACd,wBACAzO,MACAjG,KAAKM,UAAU,CAACyE,QAAQ,EACxB/E,KAAKM,UAAU,CAACuE,YAAY,CAACC,mBAAmB;YAIpD9E,KAAKoD,SAAS,CAACD,QAAQ,CAACiO,WAAW,CAACxJ,IAAI,IAAI4M;YAE5C,MAAMG,gBACJ,AAAC,OAAOrU,WAAWqU,aAAa,KAAK,cAClC,OAAMrU,WAAWqU,aAAa,oBAAxBrU,WAAWqU,aAAa,MAAxBrU,YACL,CAAC,GACD;gBACEsQ,KAAK;gBACLxQ,KAAKJ,KAAKI,GAAG;gBACbwU,QAAQ;gBACRvU,SAASA;gBACTyC,SAAS;YACX,OAEJ,CAAC;YAEH,MAAM+R,uBAAuBpF,OAAOwE,OAAO,CAACU,iBAAiB,CAAC;YAE9D,IAAIE,qBAAqB5N,MAAM,GAAG,GAAG;gBACnCjH,KAAKoD,SAAS,CAAC0R,mBAAmB,GAAGD,qBAAqBnN,GAAG,CAC3D,CAAC,CAAC2L,KAAK0B,MAAM,GACXL,IAAAA,4BAAgB,EACd,wBACA;wBACEM,QAAQ3B;wBACR4B,aAAa,GAAGF,MAAM1O,IAAI,GACxB0O,MAAMG,KAAK,GAAG,MAAM,KACnBC,oBAAE,CAAC1P,SAAS,CAACsP,MAAMG,KAAK,GAAG;oBAChC,GACAlV,KAAKM,UAAU,CAACyE,QAAQ,EACxB/E,KAAKM,UAAU,CAACuE,YAAY,CAACC,mBAAmB;YAGxD;YAEA,IAAI;gBACF,gEAAgE;gBAChE,qEAAqE;gBACrE,kEAAkE;gBAClE,MAAMsQ,eAAeC,IAAAA,sBAAe,EAACvM;gBAErC9I,KAAKoD,SAAS,CAACkS,aAAa,GAAGF,aAAa1N,GAAG,CAC7C,CAACrB;oBACC,MAAMkP,QAAQC,IAAAA,8BAAkB,EAACnP,MAAM;wBACrCoP,iBAAiB;oBACnB;oBACA,OAAO;wBACLF,OAAOA,MAAMG,EAAE,CAACC,QAAQ;wBACxBC,YAAYL,MAAMK,UAAU;wBAC5BC,WAAWN,MAAMM,SAAS;wBAC1BzB,OAAO0B,IAAAA,6BAAe,EAACP;wBACvBlP;oBACF;gBACF;gBAGF,MAAM0P,aAAkD,EAAE;gBAE1D,KAAK,MAAM1P,QAAQ+O,aAAc;oBAC/B,MAAMlH,QAAQ8H,IAAAA,8BAAc,EAAC3P,MAAM;oBACnC,MAAM4P,aAAaT,IAAAA,8BAAkB,EAACtH,MAAM7H,IAAI,EAAE;wBAChDoP,iBAAiB;oBACnB;oBACAM,WAAWnO,IAAI,CAAC;wBACd,GAAGsG,KAAK;wBACRqH,OAAOU,WAAWP,EAAE,CAACC,QAAQ;wBAC7BC,YAAYK,WAAWL,UAAU;wBACjCC,WAAWI,WAAWJ,SAAS;wBAC/BzB,OAAO0B,IAAAA,6BAAe,EAAC;4BACrB,+DAA+D;4BAC/D,uCAAuC;4BACvCJ,IAAI1V,KAAKM,UAAU,CAAC4E,IAAI,GACpB,IAAIgR,OACFhI,MAAMiI,cAAc,CAACrJ,OAAO,CAC1B,CAAC,aAAa,CAAC,EACf,CAAC,mCAAmC,CAAC,KAGzC,IAAIoJ,OAAOhI,MAAMiI,cAAc;4BACnCC,QAAQH,WAAWG,MAAM;wBAC3B;oBACF;gBACF;gBACApW,KAAKoD,SAAS,CAACkS,aAAa,CAACe,OAAO,IAAIN;gBAExC,IAAI,EAACrP,oCAAAA,iBAAkB4P,KAAK,CAAC,CAACC,KAAKpE,MAAQoE,QAAQnB,YAAY,CAACjD,IAAI,IAAG;oBACrE,MAAMqE,cAAcpB,aAAa1U,MAAM,CACrC,CAACwN,QAAU,CAACxH,iBAAiB2D,QAAQ,CAAC6D;oBAExC,MAAMuI,gBAAgB/P,iBAAiBhG,MAAM,CAC3C,CAACwN,QAAU,CAACkH,aAAa/K,QAAQ,CAAC6D;oBAGpC,8CAA8C;oBAC9C5L,YAAYoU,IAAI,CAAC;wBACfxQ,MAAMyQ,6CAA2B,CAACC,yBAAyB;wBAC3DC,MAAM;4BACJ;gCACEC,kBAAkB;4BACpB;yBACD;oBACH;oBAEAN,YAAYtE,OAAO,CAAC,CAAChE;wBACnB5L,YAAYoU,IAAI,CAAC;4BACfxQ,MAAMyQ,6CAA2B,CAACI,UAAU;4BAC5CF,MAAM;gCAAC3I;6BAAM;wBACf;oBACF;oBAEAuI,cAAcvE,OAAO,CAAC,CAAChE;wBACrB5L,YAAYoU,IAAI,CAAC;4BACfxQ,MAAMyQ,6CAA2B,CAACK,YAAY;4BAC9CH,MAAM;gCAAC3I;6BAAM;wBACf;oBACF;gBACF;gBACAxH,mBAAmB0O;gBAEnB,IAAInV,iBAAiB;oBACnB,MAAMgX,qBAAqB,MAAMC,IAAAA,yCAAwB,EAAC;wBACxD9W;wBACAwD;wBACAD;wBACAE;wBACAyF;wBACAtE,WAAWhF,KAAKM,UAAU,CAAC0E,SAAS;wBACpC7B,UAAUnD,KAAKM,UAAU,CAAC6C,QAAQ;wBAClC,6EAA6E;wBAC7E,8CAA8C;wBAC9CwF;wBACAtE;wBACAC;oBACF;oBAEA,MAAMZ,IAAAA,wCAAuB,EAC3BuT,oBACAvO,oBACA1I,KAAKM,UAAU;oBAEjB,MAAM6W,IAAAA,mCAAkB,EAACF,oBAAoBtO;gBAC/C;gBAEA,IAAI,CAAClC,UAAU;oBACbG;oBACAH,WAAW;gBACb;YACF,EAAE,OAAO2Q,GAAG;gBACV,IAAI,CAAC3Q,UAAU;oBACbI,OAAOuQ;oBACP3Q,WAAW;gBACb,OAAO;oBACLuF,KAAIqL,IAAI,CAAC,oCAAoCD;gBAC/C;YACF,SAAU;gBACR,kEAAkE;gBAClE,4DAA4D;gBAC5D,MAAMvX,qBAAqBG,MAAM,kBAAkBmF;YACrD;QACF;QAEA2C,GAAGwP,KAAK,CAAC;YAAElQ,aAAa;gBAAChH;aAAI;YAAEmX,WAAW;QAAE;IAC9C;IAEA,MAAMC,0BAA0B,CAAC,OAAO,EAAE1R,mCAAwB,CAAC,aAAa,EAAE2R,oCAAyB,EAAE;IAC7GzX,KAAKoD,SAAS,CAACsU,iBAAiB,CAACjL,GAAG,CAAC+K;IAErC,MAAMG,4BAA4B,CAAC,OAAO,EAAE7R,mCAAwB,CAAC,aAAa,EAAE8R,yCAA8B,EAAE;IACpH5X,KAAKoD,SAAS,CAACsU,iBAAiB,CAACjL,GAAG,CAACkL;IAErC,MAAME,qCAAqC,CAAC,OAAO,EAAE/R,mCAAwB,CAAC,aAAa,EAAEgS,+CAAoC,EAAE;IACnI9X,KAAKoD,SAAS,CAACsU,iBAAiB,CAACjL,GAAG,CAACoL;IAErC,eAAeE,eAAeC,GAAoB,EAAEC,GAAmB;YAGjEC,qBAcFA,sBACAA;QAjBF,MAAMA,YAAYC,YAAG,CAACC,KAAK,CAACJ,IAAIG,GAAG,IAAI;QAEvC,KAAID,sBAAAA,UAAUhQ,QAAQ,qBAAlBgQ,oBAAoB7N,QAAQ,CAACmN,0BAA0B;YACzDS,IAAII,UAAU,GAAG;YACjBJ,IAAIK,SAAS,CAAC,gBAAgBC,oCAAwB;YACtDN,IAAIO,GAAG,CACLhT,KAAKC,SAAS,CAAC;gBACbyB,OAAOR,iBAAiBhG,MAAM,CAC5B,CAACwN,QAAU,CAAClO,KAAKoD,SAAS,CAACuG,QAAQ,CAAC+E,GAAG,CAACR;YAE5C;YAEF,OAAO;gBAAEuK,UAAU;YAAK;QAC1B;QAEA,IACEP,EAAAA,uBAAAA,UAAUhQ,QAAQ,qBAAlBgQ,qBAAoB7N,QAAQ,CAACsN,iCAC7BO,uBAAAA,UAAUhQ,QAAQ,qBAAlBgQ,qBAAoB7N,QAAQ,CAACwN,sCAC7B;gBAGuB3V;YAFvB+V,IAAII,UAAU,GAAG;YACjBJ,IAAIK,SAAS,CAAC,gBAAgBC,oCAAwB;YACtDN,IAAIO,GAAG,CAAChT,KAAKC,SAAS,CAACvD,EAAAA,2BAAAA,aAAaiK,UAAU,qBAAvBjK,yBAAyBkK,QAAQ,KAAI,EAAE;YAC9D,OAAO;gBAAEqM,UAAU;YAAK;QAC1B;QACA,OAAO;YAAEA,UAAU;QAAM;IAC3B;IAEA,SAASC,0BACPC,GAAY,EACZzS,IAAyE;QAEzE,IAAIyS,eAAeC,wBAAgB,EAAE;YACnC,wDAAwD;YACxD5M,KAAIC,KAAK,CAAC0M,IAAI7E,OAAO;QACvB,OAAO,IAAI6E,eAAeE,qCAAsB,EAAE;QAChD,yEAAyE;QACzE,mEAAmE;QACrE,OAAO,IAAI3S,SAAS,WAAW;YAC7B8F,KAAIqL,IAAI,CAACsB;QACX,OAAO,IAAIzS,SAAS,WAAW;YAC7B8F,KAAIC,KAAK,CAAC0M;QACZ,OAAO,IAAIzS,MAAM;YACf8F,KAAIC,KAAK,CAAC,GAAG/F,KAAK,CAAC,CAAC,EAAEyS;QACxB,OAAO;YACL3M,KAAIC,KAAK,CAAC0M;QACZ;IACF;IAEA,OAAO;QACLzW;QACAI;QACAyV;QACAW;QAEA,MAAMI,kBAAiBC,UAAmB;YACxC,IAAI,CAAC7W,aAAagK,oBAAoB,EAAE;YACxC,OAAO5J,YAAY6D,UAAU,CAAC;gBAC5BE,MAAMnE,aAAagK,oBAAoB;gBACvC9F,YAAY;gBACZI,YAAYrB;gBACZgT,KAAKY;YACP;QACF;IACF;AACF;AAEO,eAAejZ,gBAAgBE,IAAe;IACnD,MAAM4C,WAAWjB,aAAI,CAClBsN,QAAQ,CAACjP,KAAKI,GAAG,EAAEJ,KAAKQ,QAAQ,IAAIR,KAAKS,MAAM,IAAI,IACnD2H,UAAU,CAAC;IAEd,MAAM4Q,SAAS,MAAMxX,aAAa;QAChC,GAAGxB,IAAI;QACP4C;IACF;IAEA5C,KAAKkD,SAAS,CAAC+V,MAAM,CACnBC,IAAAA,uBAAe,EAAClZ,KAAKM,UAAU,EAAE;QAC/B6Y,gBAAgB;QAChBvW;QACAwW,WAAW,CAAC,CAACpZ,KAAKuC,KAAK;QACvB8W,YAAY;QACZ5Y,QAAQ,CAAC,CAACT,KAAKS,MAAM;QACrBD,UAAU,CAAC,CAACR,KAAKQ,QAAQ;QACzB8Y,gBAAgB,CAAC,CAACtZ,KAAKsZ,cAAc;QACrCC,YAAY,CAAC,CAAE,MAAMC,IAAAA,eAAM,EAAC,YAAY;YAAEC,KAAKzZ,KAAKI,GAAG;QAAC;IAC1D;IAGF,4CAA4C;IAC5CJ,KAAKkD,SAAS,CAAC+V,MAAM,CAAC;QACpBS,WAAWC,iCAAyB;QACpCC,SAAS;YACPC,aAAa;YACbC,iBAAiBC,IAAAA,kCAA0B,EAAC/Z,KAAKM,UAAU,IAAI,IAAI;QACrE;IACF;IAEA,OAAO0Y;AACT;CAIA,2DAA2D","ignoreList":[0]}
|
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 type { MiddlewareMatcher } from '../../../build/analysis/get-page-static-info'\nimport type { RoutesManifest } from '../../../build'\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 fs from 'fs'\nimport url from 'url'\nimport path from 'path'\nimport qs from 'querystring'\nimport Watchpack from 'next/dist/compiled/watchpack'\nimport findUp from 'next/dist/compiled/find-up'\nimport { buildCustomRoute } from './filesystem'\nimport * as Log from '../../../build/output/log'\nimport { setGlobal } from '../../../trace/shared'\nimport type { Telemetry } from '../../../telemetry/storage'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport { createValidFileMatcher } from '../find-page-file'\nimport {\n EVENT_BUILD_FEATURE_USAGE,\n eventCliSession,\n} from '../../../telemetry/events'\nimport { getSortedRoutes } from '../../../shared/lib/router/utils'\nimport { sortByPageExts } from '../../../build/sort-by-page-exts'\nimport { verifyTypeScriptSetup } from '../../../lib/verify-typescript-setup'\nimport { verifyPartytownSetup } from '../../../lib/verify-partytown-setup'\nimport { getNamedRouteRegex } 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 DEV_CLIENT_PAGES_MANIFEST,\n DEV_CLIENT_MIDDLEWARE_MANIFEST,\n PHASE_DEVELOPMENT_SERVER,\n TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST,\n ROUTES_MANIFEST,\n PRERENDER_MANIFEST,\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 { devPageFiles } from '../../../build/webpack/plugins/next-types-plugin/shared'\nimport type { LazyRenderServerInstance } from '../router-server'\nimport { HMR_MESSAGE_SENT_TO_BROWSER } from '../../dev/hot-reloader-types'\nimport { PAGE_TYPES } from '../../../lib/page-types'\nimport { generateEncryptionKeyBase64 } from '../../app-render/encryption-utils-server'\nimport {\n isMetadataRouteFile,\n isStaticMetadataFile,\n} 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'\nimport {\n isPersistentCachingEnabled,\n ModuleBuildError,\n} from '../../../shared/lib/turbopack/utils'\nimport { getDefineEnv } from '../../../build/define-env'\nimport { TurbopackInternalError } from '../../../shared/lib/turbopack/internal-error'\nimport { normalizePath } from '../../../lib/normalize-path'\nimport { JSON_CONTENT_TYPE_HEADER } from '../../../lib/constants'\nimport {\n createRouteTypesManifest,\n writeRouteTypesManifest,\n writeValidatorFile,\n} from './route-types-utils'\nimport { isParallelRouteSegment } from '../../../shared/lib/segment'\nimport { ensureLeadingSlash } from '../../../shared/lib/page-path/ensure-leading-slash'\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 onDevServerCleanup: ((listener: () => Promise<void>) => void) | undefined\n resetFetch: () => void\n}\n\nexport interface DevRoutesManifest {\n version: number\n caseSensitive: RoutesManifest['caseSensitive']\n basePath: RoutesManifest['basePath']\n rewrites: RoutesManifest['rewrites']\n redirects: RoutesManifest['redirects']\n headers: RoutesManifest['headers']\n i18n: RoutesManifest['i18n']\n skipMiddlewareUrlNormalize: RoutesManifest['skipMiddlewareUrlNormalize']\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 setIsrStatus?: (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(\n opts: SetupOpts & {\n isSrcDir: boolean\n }\n) {\n const { nextConfig, appDir, pagesDir, dir, resetFetch } = opts\n const { useFileSystemPublicRoutes } = nextConfig\n\n const distDir = path.join(opts.dir, opts.nextConfig.distDir)\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 (async () => {\n const createHotReloaderTurbopack = (\n require('../../dev/hot-reloader-turbopack') as typeof import('../../dev/hot-reloader-turbopack')\n ).createHotReloaderTurbopack\n return await createHotReloaderTurbopack(\n opts,\n serverFields,\n distDir,\n resetFetch\n )\n })()\n : await (async () => {\n const HotReloaderWebpack = (\n require('../../dev/hot-reloader-webpack') as typeof import('../../dev/hot-reloader-webpack')\n ).default\n return new HotReloaderWebpack(opts.dir, {\n isSrcDir: opts.isSrcDir,\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\n await hotReloader.start()\n\n // have to write this after starting hot-reloader since that\n // cleans the dist dir\n const distTypesDir = path.join(distDir, 'types')\n await writeRouteTypesManifest(\n {\n appRoutes: {},\n pageRoutes: {},\n layoutRoutes: {},\n appRouteHandlerRoutes: {},\n redirectRoutes: {},\n rewriteRoutes: {},\n appPagePaths: new Set(),\n pagesRouterPagePaths: new Set(),\n layoutPaths: new Set(),\n appRouteHandlers: new Set(),\n pageApiRoutes: new Set(),\n filePathToRoute: new Map(),\n },\n path.join(distTypesDir, 'routes.d.ts'),\n opts.nextConfig\n )\n\n const usingTypeScript = await verifyTypeScript(opts)\n\n const routesManifestPath = path.join(distDir, ROUTES_MANIFEST)\n const routesManifest: DevRoutesManifest = {\n version: 3,\n caseSensitive: !!nextConfig.experimental.caseSensitiveRoutes,\n basePath: nextConfig.basePath,\n rewrites: opts.fsChecker.rewrites,\n redirects: opts.fsChecker.redirects,\n headers: opts.fsChecker.headers,\n i18n: nextConfig.i18n || undefined,\n skipMiddlewareUrlNormalize: nextConfig.skipMiddlewareUrlNormalize,\n }\n await fs.promises.writeFile(\n routesManifestPath,\n JSON.stringify(routesManifest)\n )\n\n const prerenderManifestPath = path.join(distDir, PRERENDER_MANIFEST)\n await fs.promises.writeFile(\n prerenderManifestPath,\n JSON.stringify(opts.fsChecker.prerenderManifest, null, 2)\n )\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 // Watchpack default is 200ms which adds 200ms of dead time on bootup.\n aggregateTimeout: 5, // Matches webpack-config.ts.\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 const routeTypesFilePath = path.join(distDir, 'types', 'routes.d.ts')\n const validatorFilePath = path.join(distDir, 'types', 'validator.ts')\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 appRouteHandlers: Array<{ route: string; filePath: string }> = []\n const pageApiRoutes: Array<{ route: string; filePath: string }> = []\n\n const pageRoutes: Array<{ route: string; filePath: string }> = []\n const appRoutes: Array<{ route: string; filePath: string }> = []\n const layoutRoutes: Array<{ route: string; filePath: string }> = []\n const slots: Array<{ name: string; parent: string }> = []\n\n let envChange = false\n let tsconfigChange = false\n let conflictingPageChange = 0\n let hasRootAppNotFound = false\n\n const { appFiles, pageFiles, staticMetadataFiles } = opts.fsChecker\n\n appFiles.clear()\n pageFiles.clear()\n staticMetadataFiles.clear()\n devPageFiles.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 getStaticInfoIncludingLayouts = (\n require('../../../build/get-static-info-including-layouts') as typeof import('../../../build/get-static-info-including-layouts')\n ).getStaticInfoIncludingLayouts\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 getPageStaticInfo = (\n require('../../../build/analysis/get-page-static-info') as typeof import('../../../build/analysis/get-page-static-info')\n ).getPageStaticInfo\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\n // Ignore files/directories starting with `_` in the app directory\n if (normalizePathSep(pageName).includes('/_')) {\n continue\n }\n\n // Record parallel route slots for layout typing\n // May run multiple times (e.g. if a parallel route\n // has both a layout and a page, and children) but that's fine\n const segments = normalizePathSep(pageName).split('/')\n for (let i = segments.length - 1; i >= 0; i--) {\n const segment = segments[i]\n if (isParallelRouteSegment(segment)) {\n const parentPath = normalizeAppPath(\n segments.slice(0, i).join('/')\n )\n\n const slotName = segment.slice(1)\n // check if the slot already exists\n if (\n slots.some(\n (s) => s.name === slotName && s.parent === parentPath\n )\n )\n continue\n\n slots.push({\n name: slotName,\n parent: parentPath,\n })\n break\n }\n }\n\n // Record layouts\n if (validFileMatcher.isAppLayoutPage(fileName)) {\n layoutRoutes.push({\n route: ensureLeadingSlash(\n normalizeAppPath(normalizePathSep(pageName)).replace(\n /\\/layout$/,\n ''\n )\n ),\n filePath: fileName,\n })\n }\n\n if (!validFileMatcher.isAppRouterPage(fileName)) {\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(\n opts.turbo\n ? // Turbopack outputs the correct path which is normalized with the `_`.\n originalPageName.replace(/%5F/g, '_')\n : originalPageName\n )\n\n if (useFileSystemPublicRoutes) {\n // Static metadata files will be served from filesystem.\n if (appDir && isStaticMetadataFile(fileName.replace(appDir, ''))) {\n staticMetadataFiles.set(pageName, fileName)\n } else {\n appFiles.add(pageName)\n }\n }\n\n if (validFileMatcher.isAppRouterRoute(fileName)) {\n appRouteHandlers.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n } else {\n appRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\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 if (pageName.startsWith('/api/')) {\n pageApiRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n } else {\n pageRoutes.push({\n route: normalizePathSep(pageName),\n filePath: fileName,\n })\n }\n }\n\n // Record pages\n if (isAppPath) {\n appPageFilePaths.set(pageName, fileName)\n } else {\n pagesPageFilePaths.set(pageName, 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 loadEnvConfig = (\n require('@next/env') as typeof import('@next/env')\n ).loadEnvConfig\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<\n ReturnType<typeof import('../../../build/load-jsconfig').default>\n >\n | undefined\n\n // This is not relevant for Turbopack because tsconfig/jsconfig is handled internally.\n if (!hotReloader.turbopackProject) {\n if (tsconfigChange) {\n try {\n const loadJsConfig = (\n require('../../../build/load-jsconfig') as typeof import('../../../build/load-jsconfig')\n ).default\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\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 const rootPath =\n opts.nextConfig.turbopack?.root ||\n opts.nextConfig.outputFileTracingRoot ||\n opts.dir\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 projectPath: opts.dir,\n rewrites: opts.fsChecker.rewrites,\n }),\n rootPath,\n projectPath: normalizePath(path.relative(rootPath, dir)),\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 isNodeServer,\n middlewareMatchers: undefined,\n projectPath: opts.dir,\n rewrites: opts.fsChecker.rewrites,\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 = getNamedRouteRegex(page, {\n prefixRouteKeys: true,\n })\n return {\n regex: regex.re.toString(),\n namedRegex: regex.namedRegex,\n routeKeys: regex.routeKeys,\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 = getNamedRouteRegex(route.page, {\n prefixRouteKeys: true,\n })\n dataRoutes.push({\n ...route,\n regex: routeRegex.re.toString(),\n namedRegex: routeRegex.namedRegex,\n routeKeys: routeRegex.routeKeys,\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 type: HMR_MESSAGE_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 type: HMR_MESSAGE_SENT_TO_BROWSER.ADDED_PAGE,\n data: [route],\n })\n })\n\n removedRoutes.forEach((route) => {\n hotReloader.send({\n type: HMR_MESSAGE_SENT_TO_BROWSER.REMOVED_PAGE,\n data: [route],\n })\n })\n }\n prevSortedRoutes = sortedRoutes\n\n if (usingTypeScript) {\n const routeTypesManifest = await createRouteTypesManifest({\n dir,\n pageRoutes,\n appRoutes,\n layoutRoutes,\n slots,\n redirects: opts.nextConfig.redirects,\n rewrites: opts.nextConfig.rewrites,\n // Ensure relative paths in validator.ts are computed from validatorFilePath,\n // matching behavior of build and CLI typegen.\n validatorFilePath,\n appRouteHandlers,\n pageApiRoutes,\n })\n\n await writeRouteTypesManifest(\n routeTypesManifest,\n routeTypesFilePath,\n opts.nextConfig\n )\n await writeValidatorFile(routeTypesManifest, validatorFilePath)\n }\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 const devTurbopackMiddlewareManifestPath = `/_next/${CLIENT_STATIC_FILES_PATH}/development/${TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST}`\n opts.fsChecker.devVirtualFsItems.add(devTurbopackMiddlewareManifestPath)\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', JSON_CONTENT_TYPE_HEADER)\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 (\n parsedUrl.pathname?.includes(devMiddlewareManifestPath) ||\n parsedUrl.pathname?.includes(devTurbopackMiddlewareManifestPath)\n ) {\n res.statusCode = 200\n res.setHeader('Content-Type', JSON_CONTENT_TYPE_HEADER)\n res.end(JSON.stringify(serverFields.middleware?.matchers || []))\n return { finished: true }\n }\n return { finished: false }\n }\n\n function logErrorWithOriginalStack(\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 Log.error(err)\n } else if (type) {\n Log.error(`${type}:`, err)\n } else {\n Log.error(err)\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\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({\n ...opts,\n isSrcDir,\n })\n\n opts.telemetry.record(\n eventCliSession(opts.nextConfig, {\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 // Track build features for dev server here:\n opts.telemetry.record({\n eventName: EVENT_BUILD_FEATURE_USAGE,\n payload: {\n featureName: 'turbopackPersistentCaching',\n invocationCount: isPersistentCachingEnabled(opts.nextConfig) ? 1 : 0,\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\n"],"names":["propagateServerField","setupDevBundler","verifyTypeScript","opts","usingTypeScript","verifyResult","verifyTypeScriptSetup","dir","distDir","nextConfig","intentDirs","pagesDir","appDir","filter","Boolean","typeCheckPreflight","tsconfigPath","typescript","disableStaticImages","images","hasAppDir","hasPagesDir","version","field","args","renderServer","instance","startWatcher","resetFetch","useFileSystemPublicRoutes","path","join","setGlobal","PHASE_DEVELOPMENT_SERVER","validFileMatcher","createValidFileMatcher","pageExtensions","serverFields","consoleStore","setState","logging","hotReloader","turbo","createHotReloaderTurbopack","require","HotReloaderWebpack","default","isSrcDir","config","buildId","encryptionKey","generateEncryptionKeyBase64","isBuild","telemetry","rewrites","fsChecker","previewProps","prerenderManifest","preview","start","distTypesDir","writeRouteTypesManifest","appRoutes","pageRoutes","layoutRoutes","appRouteHandlerRoutes","redirectRoutes","rewriteRoutes","appPagePaths","Set","pagesRouterPagePaths","layoutPaths","appRouteHandlers","pageApiRoutes","filePathToRoute","Map","routesManifestPath","ROUTES_MANIFEST","routesManifest","caseSensitive","experimental","caseSensitiveRoutes","basePath","redirects","headers","i18n","undefined","skipMiddlewareUrlNormalize","fs","promises","writeFile","JSON","stringify","prerenderManifestPath","PRERENDER_MANIFEST","nextScriptWorkers","verifyPartytownSetup","CLIENT_STATIC_FILES_PATH","ensureCallback","ensure","item","type","ensurePage","clientOnly","page","itemPath","isApp","definition","resolved","prevSortedRoutes","Promise","resolve","reject","readdir","_","files","length","pages","app","directories","rootDir","getPossibleMiddlewareFilenames","getPossibleInstrumentationHookFilenames","nestedMiddleware","envFiles","map","file","push","tsconfigPaths","wp","Watchpack","aggregateTimeout","ignored","pathname","some","startsWith","d","fileWatchTimes","enabledTypeScript","previousClientRouterFilters","previousConflictingPagePaths","routeTypesFilePath","validatorFilePath","on","middlewareMatchers","routedPages","knownFiles","getTimeInfoEntries","appPaths","pageNameSet","conflictingAppPagePaths","appPageFilePaths","pagesPageFilePaths","slots","envChange","tsconfigChange","conflictingPageChange","hasRootAppNotFound","appFiles","pageFiles","staticMetadataFiles","clear","devPageFiles","sortedKnownFiles","keys","sort","sortByPageExts","fileName","includes","meta","get","watchTime","watchTimeChange","timestamp","set","endsWith","accuracy","isPageFile","isAppPath","normalizePathSep","isPagePath","rootFile","absolutePathToPage","extensions","keepIndex","pagesType","PAGE_TYPES","ROOT","isMiddlewareFile","staticInfo","getStaticInfoIncludingLayouts","pageFilePath","isDev","isInsideAppDir","output","Log","error","actualMiddlewareFile","middleware","matchers","regexp","originalSource","isInstrumentationHookFile","actualInstrumentationHookFile","add","pageName","APP","PAGES","isMetadataRouteFile","replace","getPageStaticInfo","pageType","normalizeMetadataPageToRoute","generateSitemaps","generateImageMetadata","isRootNotFound","segments","split","i","segment","isParallelRouteSegment","parentPath","normalizeAppPath","slice","slotName","s","name","parent","isAppLayoutPage","route","ensureLeadingSlash","filePath","isAppRouterPage","originalPageName","isStaticMetadataFile","isAppRouterRoute","nextDataRoutes","has","test","numConflicting","size","errorMessage","p","appPath","relative","pagesPath","setHmrServerError","Error","clearHmrServerError","clientRouterFilters","clientRouterFilter","createClientRouterFilter","Object","clientRouterFilterRedirects","_originalRedirects","r","internal","clientRouterFilterAllowedRate","then","catch","loadEnvConfig","loadedEnvFiles","process","env","NODE_ENV","envFilePath","info","typedEnv","createEnvDefinitions","configFileName","contents","dev","forceReload","silent","tsconfigResult","turbopackProject","loadJsConfig","hasRewrites","afterFiles","beforeFiles","fallback","rootPath","turbopack","root","outputFileTracingRoot","update","defineEnv","createDefineEnv","isTurbopack","fetchCacheKeyPrefix","projectPath","normalizePath","activeWebpackConfigs","forEach","idx","isClient","isNodeServer","isEdgeServer","plugins","plugin","JsConfigPathsPlugin","jsConfig","resolvedBaseUrl","currentResolvedBaseUrl","resolvedUrlIndex","modules","findIndex","baseUrl","splice","isImplicit","compilerOptions","paths","key","assign","definitions","__NEXT_DEFINE_ENV","newDefine","getDefineEnv","invalidate","reloadAfterInvalidation","NestedMiddlewareError","message","appPathRoutes","fromEntries","entries","k","v","match","hasAppNotFound","middlewareMatcher","getMiddlewareRouteMatcher","interceptionRoutes","generateInterceptionRoutesRewrites","buildCustomRoute","exportPathMap","outDir","exportPathMapEntries","exportPathMapRoutes","value","source","destination","query","qs","sortedRoutes","getSortedRoutes","dynamicRoutes","regex","getNamedRouteRegex","prefixRouteKeys","re","toString","namedRegex","routeKeys","getRouteMatcher","dataRoutes","buildDataRoute","routeRegex","RegExp","dataRouteRegex","groups","unshift","every","val","addedRoutes","removedRoutes","send","HMR_MESSAGE_SENT_TO_BROWSER","DEV_PAGES_MANIFEST_UPDATE","data","devPagesManifest","ADDED_PAGE","REMOVED_PAGE","routeTypesManifest","createRouteTypesManifest","writeValidatorFile","e","warn","watch","startTime","clientPagesManifestPath","DEV_CLIENT_PAGES_MANIFEST","devVirtualFsItems","devMiddlewareManifestPath","DEV_CLIENT_MIDDLEWARE_MANIFEST","devTurbopackMiddlewareManifestPath","TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST","requestHandler","req","res","parsedUrl","url","parse","statusCode","setHeader","JSON_CONTENT_TYPE_HEADER","end","finished","logErrorWithOriginalStack","err","ModuleBuildError","TurbopackInternalError","ensureMiddleware","requestUrl","result","record","eventCliSession","webpackVersion","turboFlag","cliCommand","isCustomServer","hasNowJson","findUp","cwd","eventName","EVENT_BUILD_FEATURE_USAGE","payload","featureName","invocationCount","isPersistentCachingEnabled"],"mappings":"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","ignoreList":[0]}
|
@@ -179,7 +179,7 @@ async function getRequestHandlers({ dir, port, isDev, onDevServerCleanup, server
|
|
179
179
|
async function startServer(serverOptions) {
|
180
180
|
const { dir, isDev, hostname, minimalMode, allowRetry, keepAliveTimeout, selfSignedCertificate } = serverOptions;
|
181
181
|
let { port } = serverOptions;
|
182
|
-
process.title = `next-server (v${"15.6.0-canary.
|
182
|
+
process.title = `next-server (v${"15.6.0-canary.4"})`;
|
183
183
|
let handlersReady = ()=>{};
|
184
184
|
let handlersError = ()=>{};
|
185
185
|
let handlersPromise = new Promise((resolve, reject)=>{
|