| "use strict"; |
| Object.defineProperty(exports, "__esModule", { |
| value: true |
| }); |
| 0 && (module.exports = { |
| webpackBuildImpl: null, |
| workerMain: null |
| }); |
| function _export(target, all) { |
| for(var name in all)Object.defineProperty(target, name, { |
| enumerable: true, |
| get: all[name] |
| }); |
| } |
| _export(exports, { |
| webpackBuildImpl: function() { |
| return webpackBuildImpl; |
| }, |
| workerMain: function() { |
| return workerMain; |
| } |
| }); |
| const _webpacksources3 = require("next/dist/compiled/webpack-sources3"); |
| const _picocolors = require("../../lib/picocolors"); |
| const _formatwebpackmessages = _interop_require_default(require("../../shared/lib/format-webpack-messages")); |
| const _nonnullable = require("../../lib/non-nullable"); |
| const _constants = require("../../shared/lib/constants"); |
| const _compiler = require("../compiler"); |
| const _log = _interop_require_wildcard(require("../output/log")); |
| const _webpackconfig = _interop_require_wildcard(require("../webpack-config")); |
| const _telemetryplugin = require("../webpack/plugins/telemetry-plugin/telemetry-plugin"); |
| const _buildcontext = require("../build-context"); |
| const _entries = require("../entries"); |
| const _config = _interop_require_default(require("../../server/config")); |
| const _trace = require("../../trace"); |
| const _constants1 = require("../../lib/constants"); |
| const _nexttraceentrypointsplugin = require("../webpack/plugins/next-trace-entrypoints-plugin"); |
| const _debug = _interop_require_default(require("next/dist/compiled/debug")); |
| const _storage = require("../../telemetry/storage"); |
| const _durationtostring = require("../duration-to-string"); |
| function _interop_require_default(obj) { |
| return obj && obj.__esModule ? obj : { |
| default: obj |
| }; |
| } |
| function _getRequireWildcardCache(nodeInterop) { |
| if (typeof WeakMap !== "function") return null; |
| var cacheBabelInterop = new WeakMap(); |
| var cacheNodeInterop = new WeakMap(); |
| return (_getRequireWildcardCache = function(nodeInterop) { |
| return nodeInterop ? cacheNodeInterop : cacheBabelInterop; |
| })(nodeInterop); |
| } |
| function _interop_require_wildcard(obj, nodeInterop) { |
| if (!nodeInterop && obj && obj.__esModule) { |
| return obj; |
| } |
| if (obj === null || typeof obj !== "object" && typeof obj !== "function") { |
| return { |
| default: obj |
| }; |
| } |
| var cache = _getRequireWildcardCache(nodeInterop); |
| if (cache && cache.has(obj)) { |
| return cache.get(obj); |
| } |
| var newObj = { |
| __proto__: null |
| }; |
| var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; |
| for(var key in obj){ |
| if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { |
| var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; |
| if (desc && (desc.get || desc.set)) { |
| Object.defineProperty(newObj, key, desc); |
| } else { |
| newObj[key] = obj[key]; |
| } |
| } |
| } |
| newObj.default = obj; |
| if (cache) { |
| cache.set(obj, newObj); |
| } |
| return newObj; |
| } |
| const debug = (0, _debug.default)('next:build:webpack-build'); |
| function hrtimeToSeconds(hrtime) { |
| |
| return hrtime[0] + hrtime[1] / 1e9; |
| } |
| function isTelemetryPlugin(plugin) { |
| return plugin instanceof _telemetryplugin.TelemetryPlugin; |
| } |
| function isTraceEntryPointsPlugin(plugin) { |
| return plugin instanceof _nexttraceentrypointsplugin.TraceEntryPointsPlugin; |
| } |
| async function webpackBuildImpl(compilerName) { |
| var _clientConfig_plugins, _serverConfig_plugins; |
| let result = { |
| warnings: [], |
| errors: [], |
| stats: [] |
| }; |
| let webpackBuildStart; |
| const nextBuildSpan = _buildcontext.NextBuildContext.nextBuildSpan; |
| const dir = _buildcontext.NextBuildContext.dir; |
| const config = _buildcontext.NextBuildContext.config; |
| process.env.NEXT_COMPILER_NAME = compilerName || 'server'; |
| const runWebpackSpan = nextBuildSpan.traceChild('run-webpack-compiler'); |
| const entrypoints = await nextBuildSpan.traceChild('create-entrypoints').traceAsyncFn(()=>(0, _entries.createEntrypoints)({ |
| buildId: _buildcontext.NextBuildContext.buildId, |
| config: config, |
| envFiles: _buildcontext.NextBuildContext.loadedEnvFiles, |
| isDev: false, |
| rootDir: dir, |
| pageExtensions: config.pageExtensions, |
| pagesDir: _buildcontext.NextBuildContext.pagesDir, |
| appDir: _buildcontext.NextBuildContext.appDir, |
| pages: _buildcontext.NextBuildContext.mappedPages, |
| appPaths: _buildcontext.NextBuildContext.mappedAppPages, |
| previewMode: _buildcontext.NextBuildContext.previewProps, |
| rootPaths: _buildcontext.NextBuildContext.mappedRootPaths, |
| hasInstrumentationHook: _buildcontext.NextBuildContext.hasInstrumentationHook |
| })); |
| const commonWebpackOptions = { |
| isServer: false, |
| isCompileMode: _buildcontext.NextBuildContext.isCompileMode, |
| buildId: _buildcontext.NextBuildContext.buildId, |
| encryptionKey: _buildcontext.NextBuildContext.encryptionKey, |
| config: config, |
| appDir: _buildcontext.NextBuildContext.appDir, |
| pagesDir: _buildcontext.NextBuildContext.pagesDir, |
| rewrites: _buildcontext.NextBuildContext.rewrites, |
| originalRewrites: _buildcontext.NextBuildContext.originalRewrites, |
| originalRedirects: _buildcontext.NextBuildContext.originalRedirects, |
| reactProductionProfiling: _buildcontext.NextBuildContext.reactProductionProfiling, |
| noMangling: _buildcontext.NextBuildContext.noMangling, |
| clientRouterFilters: _buildcontext.NextBuildContext.clientRouterFilters, |
| previewProps: _buildcontext.NextBuildContext.previewProps, |
| allowedRevalidateHeaderKeys: _buildcontext.NextBuildContext.allowedRevalidateHeaderKeys, |
| fetchCacheKeyPrefix: _buildcontext.NextBuildContext.fetchCacheKeyPrefix |
| }; |
| const configs = await runWebpackSpan.traceChild('generate-webpack-config').traceAsyncFn(async ()=>{ |
| const info = await (0, _webpackconfig.loadProjectInfo)({ |
| dir, |
| config: commonWebpackOptions.config, |
| dev: false |
| }); |
| return Promise.all([ |
| (0, _webpackconfig.default)(dir, { |
| ...commonWebpackOptions, |
| middlewareMatchers: entrypoints.middlewareMatchers, |
| runWebpackSpan, |
| compilerType: _constants.COMPILER_NAMES.client, |
| entrypoints: entrypoints.client, |
| ...info |
| }), |
| (0, _webpackconfig.default)(dir, { |
| ...commonWebpackOptions, |
| runWebpackSpan, |
| middlewareMatchers: entrypoints.middlewareMatchers, |
| compilerType: _constants.COMPILER_NAMES.server, |
| entrypoints: entrypoints.server, |
| ...info |
| }), |
| (0, _webpackconfig.default)(dir, { |
| ...commonWebpackOptions, |
| runWebpackSpan, |
| middlewareMatchers: entrypoints.middlewareMatchers, |
| compilerType: _constants.COMPILER_NAMES.edgeServer, |
| entrypoints: entrypoints.edgeServer, |
| ...info |
| }) |
| ]); |
| }); |
| const clientConfig = configs[0]; |
| const serverConfig = configs[1]; |
| const edgeConfig = configs[2]; |
| if (clientConfig.optimization && (clientConfig.optimization.minimize !== true || clientConfig.optimization.minimizer && clientConfig.optimization.minimizer.length === 0)) { |
| _log.warn(`Production code optimization has been disabled in your project. Read more: https://nextjs.org/docs/messages/minification-disabled`); |
| } |
| webpackBuildStart = process.hrtime(); |
| debug(`starting compiler`, compilerName); |
| |
| await runWebpackSpan.traceAsyncFn(async ()=>{ |
| var _inputFileSystem_purge; |
| if (config.experimental.webpackMemoryOptimizations) { |
| _webpacksources3.stringBufferUtils.disableDualStringBufferCaching(); |
| _webpacksources3.stringBufferUtils.enterStringInterningRange(); |
| } |
| |
| |
| let clientResult = null; |
| |
| |
| let serverResult = null; |
| let edgeServerResult = null; |
| let inputFileSystem; |
| if (!compilerName || compilerName === 'server') { |
| debug('starting server compiler'); |
| const start = Date.now(); |
| [serverResult, inputFileSystem] = await (0, _compiler.runCompiler)(serverConfig, { |
| runWebpackSpan, |
| inputFileSystem |
| }); |
| debug(`server compiler finished ${Date.now() - start}ms`); |
| } |
| if (!compilerName || compilerName === 'edge-server') { |
| debug('starting edge-server compiler'); |
| const start = Date.now(); |
| [edgeServerResult, inputFileSystem] = edgeConfig ? await (0, _compiler.runCompiler)(edgeConfig, { |
| runWebpackSpan, |
| inputFileSystem |
| }) : [ |
| null |
| ]; |
| debug(`edge-server compiler finished ${Date.now() - start}ms`); |
| } |
| |
| if (!(serverResult == null ? void 0 : serverResult.errors.length) && !(edgeServerResult == null ? void 0 : edgeServerResult.errors.length)) { |
| const pluginState = (0, _buildcontext.getPluginState)(); |
| for(const key in pluginState.injectedClientEntries){ |
| const value = pluginState.injectedClientEntries[key]; |
| const clientEntry = clientConfig.entry; |
| if (key === _constants.APP_CLIENT_INTERNALS) { |
| clientEntry[_constants.CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] = { |
| import: [ |
| |
| |
| ...clientEntry[_constants.CLIENT_STATIC_FILES_RUNTIME_MAIN_APP].import, |
| value |
| ], |
| layer: _constants1.WEBPACK_LAYERS.appPagesBrowser |
| }; |
| } else { |
| clientEntry[key] = { |
| dependOn: [ |
| _constants.CLIENT_STATIC_FILES_RUNTIME_MAIN_APP |
| ], |
| import: value, |
| layer: _constants1.WEBPACK_LAYERS.appPagesBrowser |
| }; |
| } |
| } |
| if (!compilerName || compilerName === 'client') { |
| debug('starting client compiler'); |
| const start = Date.now(); |
| [clientResult, inputFileSystem] = await (0, _compiler.runCompiler)(clientConfig, { |
| runWebpackSpan, |
| inputFileSystem |
| }); |
| debug(`client compiler finished ${Date.now() - start}ms`); |
| } |
| } |
| if (config.experimental.webpackMemoryOptimizations) { |
| _webpacksources3.stringBufferUtils.exitStringInterningRange(); |
| } |
| inputFileSystem == null ? void 0 : (_inputFileSystem_purge = inputFileSystem.purge) == null ? void 0 : _inputFileSystem_purge.call(inputFileSystem); |
| result = { |
| warnings: [ |
| ...(clientResult == null ? void 0 : clientResult.warnings) ?? [], |
| ...(serverResult == null ? void 0 : serverResult.warnings) ?? [], |
| ...(edgeServerResult == null ? void 0 : edgeServerResult.warnings) ?? [] |
| ].filter(_nonnullable.nonNullable), |
| errors: [ |
| ...(clientResult == null ? void 0 : clientResult.errors) ?? [], |
| ...(serverResult == null ? void 0 : serverResult.errors) ?? [], |
| ...(edgeServerResult == null ? void 0 : edgeServerResult.errors) ?? [] |
| ].filter(_nonnullable.nonNullable), |
| stats: [ |
| clientResult == null ? void 0 : clientResult.stats, |
| serverResult == null ? void 0 : serverResult.stats, |
| edgeServerResult == null ? void 0 : edgeServerResult.stats |
| ] |
| }; |
| }); |
| result = nextBuildSpan.traceChild('format-webpack-messages').traceFn(()=>(0, _formatwebpackmessages.default)(result, true)); |
| const telemetryPlugin = (_clientConfig_plugins = clientConfig.plugins) == null ? void 0 : _clientConfig_plugins.find(isTelemetryPlugin); |
| const traceEntryPointsPlugin = (_serverConfig_plugins = serverConfig.plugins) == null ? void 0 : _serverConfig_plugins.find(isTraceEntryPointsPlugin); |
| const webpackBuildEnd = process.hrtime(webpackBuildStart); |
| if (result.errors.length > 0) { |
| |
| |
| if (result.errors.length > 5) { |
| result.errors.length = 5; |
| } |
| let error = result.errors.filter(Boolean).join('\n\n'); |
| console.error((0, _picocolors.red)('Failed to compile.\n')); |
| if (error.indexOf('private-next-pages') > -1 && error.indexOf('does not contain a default export') > -1) { |
| const page_name_regex = /'private-next-pages\/(?<page_name>[^']*)'/; |
| const parsed = page_name_regex.exec(error); |
| const page_name = parsed && parsed.groups && parsed.groups.page_name; |
| throw Object.defineProperty(new Error(`webpack build failed: found page without a React Component as default export in pages/${page_name}\n\nSee https://nextjs.org/docs/messages/page-without-valid-component for more info.`), "__NEXT_ERROR_CODE", { |
| value: "E164", |
| enumerable: false, |
| configurable: true |
| }); |
| } |
| console.error(error); |
| console.error(); |
| if (error.indexOf('private-next-pages') > -1 || error.indexOf('__next_polyfill__') > -1) { |
| const err = Object.defineProperty(new Error('webpack config.resolve.alias was incorrectly overridden. https://nextjs.org/docs/messages/invalid-resolve-alias'), "__NEXT_ERROR_CODE", { |
| value: "E70", |
| enumerable: false, |
| configurable: true |
| }); |
| err.code = 'INVALID_RESOLVE_ALIAS'; |
| throw err; |
| } |
| const err = Object.defineProperty(new Error(`Build failed because of ${process.env.NEXT_RSPACK ? 'rspack' : 'webpack'} errors`), "__NEXT_ERROR_CODE", { |
| value: "E661", |
| enumerable: false, |
| configurable: true |
| }); |
| err.code = 'WEBPACK_ERRORS'; |
| throw err; |
| } else { |
| const duration = hrtimeToSeconds(webpackBuildEnd); |
| const durationString = (0, _durationtostring.durationToString)(duration); |
| if (result.warnings.length > 0) { |
| _log.warn(`Compiled with warnings in ${durationString}\n`); |
| console.warn(result.warnings.filter(Boolean).join('\n\n')); |
| console.warn(); |
| } else if (!compilerName) { |
| _log.event(`Compiled successfully in ${durationString}`); |
| } |
| return { |
| duration, |
| buildTraceContext: traceEntryPointsPlugin == null ? void 0 : traceEntryPointsPlugin.buildTraceContext, |
| pluginState: (0, _buildcontext.getPluginState)(), |
| telemetryState: { |
| usages: (telemetryPlugin == null ? void 0 : telemetryPlugin.usages()) || [], |
| packagesUsedInServerSideProps: (telemetryPlugin == null ? void 0 : telemetryPlugin.packagesUsedInServerSideProps()) || [], |
| useCacheTracker: (telemetryPlugin == null ? void 0 : telemetryPlugin.getUseCacheTracker()) || {} |
| } |
| }; |
| } |
| } |
| async function workerMain(workerData) { |
| |
| const telemetry = new _storage.Telemetry({ |
| distDir: workerData.buildContext.config.distDir |
| }); |
| (0, _trace.setGlobal)('telemetry', telemetry); |
| |
| Object.assign(_buildcontext.NextBuildContext, workerData.buildContext); |
| |
| (0, _trace.initializeTraceState)(workerData.traceState); |
| |
| (0, _buildcontext.resumePluginState)(_buildcontext.NextBuildContext.pluginState); |
| |
| _buildcontext.NextBuildContext.config = await (0, _config.default)(_constants.PHASE_PRODUCTION_BUILD, _buildcontext.NextBuildContext.dir, { |
| debugPrerender: _buildcontext.NextBuildContext.debugPrerender |
| }); |
| _buildcontext.NextBuildContext.nextBuildSpan = (0, _trace.trace)(`worker-main-${workerData.compilerName}`); |
| const result = await webpackBuildImpl(workerData.compilerName); |
| const { entriesTrace, chunksTrace } = result.buildTraceContext ?? {}; |
| if (entriesTrace) { |
| const { entryNameMap, depModArray } = entriesTrace; |
| if (depModArray) { |
| result.buildTraceContext.entriesTrace.depModArray = depModArray; |
| } |
| if (entryNameMap) { |
| const entryEntries = entryNameMap; |
| result.buildTraceContext.entriesTrace.entryNameMap = entryEntries; |
| } |
| } |
| if (chunksTrace == null ? void 0 : chunksTrace.entryNameFilesMap) { |
| const entryNameFilesMap = chunksTrace.entryNameFilesMap; |
| result.buildTraceContext.chunksTrace.entryNameFilesMap = entryNameFilesMap; |
| } |
| _buildcontext.NextBuildContext.nextBuildSpan.stop(); |
| return { |
| ...result, |
| debugTraceEvents: (0, _trace.getTraceEvents)() |
| }; |
| } |
|
|
| |