You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			336 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
		
		
			
		
	
	
			336 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			JavaScript
		
	
| 
											9 months ago
										 | "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 _picocolors = require("../../lib/picocolors"); | ||
|  | const _formatwebpackmessages = /*#__PURE__*/ _interop_require_default(require("../../client/dev/error-overlay/format-webpack-messages")); | ||
|  | const _nonnullable = require("../../lib/non-nullable"); | ||
|  | const _constants = require("../../shared/lib/constants"); | ||
|  | const _compiler = require("../compiler"); | ||
|  | const _log = /*#__PURE__*/ _interop_require_wildcard(require("../output/log")); | ||
|  | const _webpackconfig = /*#__PURE__*/ _interop_require_wildcard(require("../webpack-config")); | ||
|  | const _telemetryplugin = require("../webpack/plugins/telemetry-plugin"); | ||
|  | const _buildcontext = require("../build-context"); | ||
|  | const _entries = require("../entries"); | ||
|  | const _config = /*#__PURE__*/ _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 = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/debug")); | ||
|  | const _storage = require("../../telemetry/storage"); | ||
|  | 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 = {}; | ||
|  |     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 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; | ||
|  |     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, | ||
|  |         buildId: _buildcontext.NextBuildContext.buildId, | ||
|  |         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, | ||
|  |         previewModeId: _buildcontext.NextBuildContext.previewModeId, | ||
|  |         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); | ||
|  |     // We run client and server compilation separately to optimize for memory usage
 | ||
|  |     await runWebpackSpan.traceAsyncFn(async ()=>{ | ||
|  |         // Run the server compilers first and then the client
 | ||
|  |         // compiler to track the boundary of server/client components.
 | ||
|  |         let clientResult = null; | ||
|  |         // During the server compilations, entries of client components will be
 | ||
|  |         // injected to this set and then will be consumed by the client compiler.
 | ||
|  |         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`); | ||
|  |         } | ||
|  |         // Only continue if there were no errors
 | ||
|  |         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: [ | ||
|  |                             // TODO-APP: cast clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] to type EntryDescription once it's available from webpack
 | ||
|  |                             // @ts-expect-error clientEntry['main-app'] is type EntryDescription { 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`); | ||
|  |             } | ||
|  |         } | ||
|  |         inputFileSystem.purge(); | ||
|  |         result = { | ||
|  |             warnings: [].concat(clientResult == null ? void 0 : clientResult.warnings, serverResult == null ? void 0 : serverResult.warnings, edgeServerResult == null ? void 0 : edgeServerResult.warnings).filter(_nonnullable.nonNullable), | ||
|  |             errors: [].concat(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) { | ||
|  |         // Only keep the first few errors. Others are often indicative
 | ||
|  |         // of the same problem, but confuse the reader with noise.
 | ||
|  |         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 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.`); | ||
|  |         } | ||
|  |         console.error(error); | ||
|  |         console.error(); | ||
|  |         if (error.indexOf("private-next-pages") > -1 || error.indexOf("__next_polyfill__") > -1) { | ||
|  |             const err = new Error("webpack config.resolve.alias was incorrectly overridden. https://nextjs.org/docs/messages/invalid-resolve-alias"); | ||
|  |             err.code = "INVALID_RESOLVE_ALIAS"; | ||
|  |             throw err; | ||
|  |         } | ||
|  |         const err = new Error("Build failed because of webpack errors"); | ||
|  |         err.code = "WEBPACK_ERRORS"; | ||
|  |         throw err; | ||
|  |     } else { | ||
|  |         if (result.warnings.length > 0) { | ||
|  |             _log.warn("Compiled with warnings\n"); | ||
|  |             console.warn(result.warnings.filter(Boolean).join("\n\n")); | ||
|  |             console.warn(); | ||
|  |         } else if (!compilerName) { | ||
|  |             _log.event("Compiled successfully"); | ||
|  |         } | ||
|  |         return { | ||
|  |             duration: webpackBuildEnd[0], | ||
|  |             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()) || [] | ||
|  |             } | ||
|  |         }; | ||
|  |     } | ||
|  | } | ||
|  | async function workerMain(workerData) { | ||
|  |     // Clone the telemetry for worker
 | ||
|  |     const telemetry = new _storage.Telemetry({ | ||
|  |         distDir: workerData.buildContext.config.distDir | ||
|  |     }); | ||
|  |     (0, _trace.setGlobal)("telemetry", telemetry); | ||
|  |     // setup new build context from the serialized data passed from the parent
 | ||
|  |     Object.assign(_buildcontext.NextBuildContext, workerData.buildContext); | ||
|  |     // Initialize tracer state from the parent
 | ||
|  |     (0, _trace.initializeTraceState)(workerData.traceState); | ||
|  |     // Resume plugin state
 | ||
|  |     (0, _buildcontext.resumePluginState)(_buildcontext.NextBuildContext.pluginState); | ||
|  |     /// load the config because it's not serializable
 | ||
|  |     _buildcontext.NextBuildContext.config = await (0, _config.default)(_constants.PHASE_PRODUCTION_BUILD, _buildcontext.NextBuildContext.dir); | ||
|  |     _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)() | ||
|  |     }; | ||
|  | } | ||
|  | 
 | ||
|  | //# sourceMappingURL=impl.js.map
 |