next 16.0.2-canary.10 → 16.0.2-canary.12
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/babel/loader/get-config.js +5 -0
- package/dist/build/babel/loader/get-config.js.map +1 -1
- package/dist/build/index.js +7 -4
- package/dist/build/index.js.map +1 -1
- package/dist/build/jest/jest.js +2 -1
- package/dist/build/jest/jest.js.map +1 -1
- package/dist/build/load-entrypoint.js +1 -2
- package/dist/build/load-entrypoint.js.map +1 -1
- package/dist/build/lockfile.d.ts +1 -1
- package/dist/build/lockfile.js +5 -9
- package/dist/build/lockfile.js.map +1 -1
- package/dist/build/next-config-ts/transpile-config.js +13 -3
- package/dist/build/next-config-ts/transpile-config.js.map +1 -1
- package/dist/build/swc/index.d.ts +4 -2
- package/dist/build/swc/index.js +54 -51
- package/dist/build/swc/index.js.map +1 -1
- package/dist/build/swc/install-bindings.d.ts +15 -0
- package/dist/build/swc/install-bindings.js +30 -0
- package/dist/build/swc/install-bindings.js.map +1 -0
- package/dist/build/templates/app-page.js +7 -1
- package/dist/build/templates/app-page.js.map +1 -1
- package/dist/build/turbopack-build/impl.js +9 -4
- package/dist/build/turbopack-build/impl.js.map +1 -1
- package/dist/build/webpack/loaders/lightningcss-loader/src/loader.js +7 -2
- package/dist/build/webpack/loaders/lightningcss-loader/src/loader.js.map +1 -1
- package/dist/build/webpack/loaders/lightningcss-loader/src/minify.js +2 -2
- package/dist/build/webpack/loaders/lightningcss-loader/src/minify.js.map +1 -1
- package/dist/build/webpack/loaders/next-app-loader/index.js +6 -0
- package/dist/build/webpack/loaders/next-app-loader/index.js.map +1 -1
- package/dist/build/webpack/loaders/next-barrel-loader.js +5 -0
- package/dist/build/webpack/loaders/next-barrel-loader.js.map +1 -1
- package/dist/build/webpack/loaders/next-metadata-image-loader.js +5 -0
- package/dist/build/webpack/loaders/next-metadata-image-loader.js.map +1 -1
- package/dist/build/webpack/loaders/next-metadata-route-loader.js +5 -0
- package/dist/build/webpack/loaders/next-metadata-route-loader.js.map +1 -1
- package/dist/build/webpack/loaders/next-swc-loader.js +10 -6
- package/dist/build/webpack/loaders/next-swc-loader.js.map +1 -1
- package/dist/build/webpack-build/impl.js +4 -1
- package/dist/build/webpack-build/impl.js.map +1 -1
- package/dist/build/webpack-config.js +2 -7
- package/dist/build/webpack-config.js.map +1 -1
- package/dist/cli/next-typegen.js +3 -0
- package/dist/cli/next-typegen.js.map +1 -1
- package/dist/client/app-bootstrap.js +1 -1
- package/dist/client/index.js +1 -1
- package/dist/compiled/@next/font/dist/google/font-data.json +63 -0
- package/dist/compiled/@next/font/dist/google/index.d.ts +40 -0
- package/dist/esm/build/babel/loader/get-config.js +5 -0
- package/dist/esm/build/babel/loader/get-config.js.map +1 -1
- package/dist/esm/build/index.js +7 -4
- package/dist/esm/build/index.js.map +1 -1
- package/dist/esm/build/load-entrypoint.js +2 -3
- package/dist/esm/build/load-entrypoint.js.map +1 -1
- package/dist/esm/build/lockfile.js +5 -9
- package/dist/esm/build/lockfile.js.map +1 -1
- package/dist/esm/build/next-config-ts/transpile-config.js +13 -3
- package/dist/esm/build/next-config-ts/transpile-config.js.map +1 -1
- package/dist/esm/build/swc/index.js +52 -49
- package/dist/esm/build/swc/index.js.map +1 -1
- package/dist/esm/build/swc/install-bindings.js +20 -0
- package/dist/esm/build/swc/install-bindings.js.map +1 -0
- package/dist/esm/build/templates/app-page.js +7 -1
- package/dist/esm/build/templates/app-page.js.map +1 -1
- package/dist/esm/build/turbopack-build/impl.js +10 -5
- package/dist/esm/build/turbopack-build/impl.js.map +1 -1
- package/dist/esm/build/webpack/loaders/lightningcss-loader/src/loader.js +7 -2
- package/dist/esm/build/webpack/loaders/lightningcss-loader/src/loader.js.map +1 -1
- package/dist/esm/build/webpack/loaders/lightningcss-loader/src/minify.js +2 -2
- package/dist/esm/build/webpack/loaders/lightningcss-loader/src/minify.js.map +1 -1
- package/dist/esm/build/webpack/loaders/next-app-loader/index.js +6 -0
- package/dist/esm/build/webpack/loaders/next-app-loader/index.js.map +1 -1
- package/dist/esm/build/webpack/loaders/next-barrel-loader.js +5 -0
- package/dist/esm/build/webpack/loaders/next-barrel-loader.js.map +1 -1
- package/dist/esm/build/webpack/loaders/next-metadata-image-loader.js +5 -0
- package/dist/esm/build/webpack/loaders/next-metadata-image-loader.js.map +1 -1
- package/dist/esm/build/webpack/loaders/next-metadata-route-loader.js +5 -0
- package/dist/esm/build/webpack/loaders/next-metadata-route-loader.js.map +1 -1
- package/dist/esm/build/webpack/loaders/next-swc-loader.js +11 -7
- package/dist/esm/build/webpack/loaders/next-swc-loader.js.map +1 -1
- package/dist/esm/build/webpack-build/impl.js +4 -1
- package/dist/esm/build/webpack-build/impl.js.map +1 -1
- package/dist/esm/build/webpack-config.js +2 -7
- package/dist/esm/build/webpack-config.js.map +1 -1
- package/dist/esm/client/app-bootstrap.js +1 -1
- package/dist/esm/client/index.js +1 -1
- package/dist/esm/server/config.js +2 -2
- package/dist/esm/server/config.js.map +1 -1
- package/dist/esm/server/dev/hot-reloader-turbopack.js +3 -4
- package/dist/esm/server/dev/hot-reloader-turbopack.js.map +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 +3 -0
- 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/lib/trace/tracer.js +6 -5
- package/dist/esm/server/lib/trace/tracer.js.map +1 -1
- package/dist/esm/shared/lib/errors/canary-only-config-error.js +1 -1
- package/dist/server/config.js +2 -2
- package/dist/server/config.js.map +1 -1
- package/dist/server/dev/hot-reloader-turbopack.js +2 -3
- package/dist/server/dev/hot-reloader-turbopack.js.map +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 +3 -0
- 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/lib/trace/tracer.js +6 -5
- package/dist/server/lib/trace/tracer.js.map +1 -1
- package/dist/shared/lib/errors/canary-only-config-error.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/build/webpack/loaders/next-barrel-loader.ts"],"sourcesContent":["/**\n * ## Barrel Optimizations\n *\n * This loader is used to optimize the imports of \"barrel\" files that have many\n * re-exports. Currently, both Node.js and Webpack have to enter all of these\n * submodules even if we only need a few of them.\n *\n * For example, say a file `foo.js` with the following contents:\n *\n * export { a } from './a'\n * export { b } from './b'\n * export { c } from './c'\n * ...\n *\n * If the user imports `a` only, this loader will accept the `names` option to\n * be `['a']`. Then, it request the \"__barrel_transform__\" SWC transform to load\n * `foo.js` and receive the following output:\n *\n * export const __next_private_export_map__ = '[[\"a\",\"./a\",\"a\"],[\"b\",\"./b\",\"b\"],[\"c\",\"./c\",\"c\"],...]'\n *\n * format: '[\"<imported identifier>\", \"<import path>\", \"<exported name>\"]'\n * e.g.: import { a as b } from './module-a' => '[\"b\", \"./module-a\", \"a\"]'\n *\n * The export map, generated by SWC, is a JSON that represents the exports of\n * that module, their original file, and their original name (since you can do\n * `export { a as b }`).\n *\n * Then, this loader can safely remove all the exports that are not needed and\n * re-export the ones from `names`:\n *\n * export { a } from './a'\n *\n * That's the basic situation and also the happy path.\n *\n *\n *\n * ## Wildcard Exports\n *\n * For wildcard exports (e.g. `export * from './a'`), it becomes a bit more complicated.\n * Say `foo.js` with the following contents:\n *\n * export * from './a'\n * export * from './b'\n * export * from './c'\n * ...\n *\n * If the user imports `bar` from it, SWC can never know which files are going to be\n * exporting `bar`. So, we have to keep all the wildcard exports and do the same\n * process recursively. This loader will return the following output:\n *\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./a'\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./b'\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./c'\n * ...\n *\n * The \"!=!\" tells Webpack to use the same loader to process './a', './b', and './c'.\n * After the recursive process, the \"inner loaders\" will either return an empty string\n * or:\n *\n * export * from './target'\n *\n * Where `target` is the file that exports `bar`.\n *\n *\n *\n * ## Non-Barrel Files\n *\n * If the file is not a barrel, we can't apply any optimizations. That's because\n * we can't easily remove things from the file. For example, say `foo.js` with:\n *\n * const v = 1\n * export function b () {\n * return v\n * }\n *\n * If the user imports `b` only, we can't remove the `const v = 1` even though\n * the file is side-effect free. In these caes, this loader will simply re-export\n * `foo.js`:\n *\n * export * from './foo'\n *\n * Besides these cases, this loader also carefully handles the module cache so\n * SWC won't analyze the same file twice, and no instance of the same file will\n * be accidentally created as different instances.\n */\n\nimport type webpack from 'webpack'\n\nimport path from 'path'\nimport { transform } from '../../swc'\n\n// This is a in-memory cache for the mapping of barrel exports. This only applies\n// to the packages that we optimize. It will never change (e.g. upgrading packages)\n// during the lifetime of the server so we can safely cache it.\n// There is also no need to collect the cache for the same reason.\nconst barrelTransformMappingCache = new Map<\n string,\n {\n exportList: [string, string, string][]\n wildcardExports: string[]\n isClientEntry: boolean\n } | null\n>()\n\nasync function getBarrelMapping(\n resourcePath: string,\n swcCacheDir: string,\n resolve: (context: string, request: string) => Promise<string>,\n fs: {\n readFile: (\n path: string,\n callback: (err: any, data: string | Buffer | undefined) => void\n ) => void\n }\n) {\n if (barrelTransformMappingCache.has(resourcePath)) {\n return barrelTransformMappingCache.get(resourcePath)!\n }\n\n // This is a SWC transform specifically for `optimizeBarrelExports`. We don't\n // care about other things but the export map only.\n async function transpileSource(\n filename: string,\n source: string,\n isWildcard: boolean\n ) {\n const isTypeScript = filename.endsWith('.ts') || filename.endsWith('.tsx')\n return new Promise<string>((res) =>\n transform(source, {\n filename,\n inputSourceMap: undefined,\n sourceFileName: filename,\n optimizeBarrelExports: {\n wildcard: isWildcard,\n },\n jsc: {\n parser: {\n syntax: isTypeScript ? 'typescript' : 'ecmascript',\n [isTypeScript ? 'tsx' : 'jsx']: true,\n },\n experimental: {\n cacheRoot: swcCacheDir,\n },\n },\n }).then((output) => {\n res(output.code)\n })\n )\n }\n\n // Avoid circular `export *` dependencies\n const visited = new Set<string>()\n async function getMatches(\n file: string,\n isWildcard: boolean,\n isClientEntry: boolean\n ) {\n if (visited.has(file)) {\n return null\n }\n visited.add(file)\n\n const source = await new Promise<string>((res, rej) => {\n fs.readFile(file, (err, data) => {\n if (err || data === undefined) {\n rej(err)\n } else {\n res(data.toString())\n }\n })\n })\n\n const output = await transpileSource(file, source, isWildcard)\n\n const matches = output.match(\n /^([^]*)export (const|var) __next_private_export_map__ = ('[^']+'|\"[^\"]+\")/\n )\n if (!matches) {\n return null\n }\n\n const matchedDirectives = output.match(\n /^([^]*)export (const|var) __next_private_directive_list__ = '([^']+)'/\n )\n const directiveList = matchedDirectives\n ? JSON.parse(matchedDirectives[3])\n : []\n // \"use client\" in barrel files has to be transferred to the target file.\n isClientEntry = directiveList.includes('use client')\n\n let exportList = JSON.parse(matches[3].slice(1, -1)) as [\n string,\n string,\n string,\n ][]\n const wildcardExports = [\n ...output.matchAll(/export \\* from \"([^\"]+)\"/g),\n ].map((match) => match[1])\n\n // In the wildcard case, if the value is exported from another file, we\n // redirect to that file (decl[0]). Otherwise, export from the current\n // file itself.\n if (isWildcard) {\n for (const decl of exportList) {\n decl[1] = file\n decl[2] = decl[0]\n }\n }\n\n // This recursively handles the wildcard exports (e.g. `export * from './a'`)\n if (wildcardExports.length) {\n await Promise.all(\n wildcardExports.map(async (req) => {\n const targetPath = await resolve(\n path.dirname(file),\n req.replace('__barrel_optimize__?names=__PLACEHOLDER__!=!', '')\n )\n\n const targetMatches = await getMatches(\n targetPath,\n true,\n isClientEntry\n )\n\n if (targetMatches) {\n // Merge the export list\n exportList = exportList.concat(targetMatches.exportList)\n }\n })\n )\n }\n\n return {\n exportList,\n wildcardExports,\n isClientEntry,\n }\n }\n\n const res = await getMatches(resourcePath, false, false)\n barrelTransformMappingCache.set(resourcePath, res)\n\n return res\n}\n\nconst NextBarrelLoader = async function (\n this: webpack.LoaderContext<{\n names: string[]\n swcCacheDir: string\n }>\n) {\n this.async()\n this.cacheable(true)\n\n const { names, swcCacheDir } = this.getOptions()\n\n // For barrel optimizations, we always prefer the \"module\" field over the\n // \"main\" field because ESM handling is more robust with better tree-shaking.\n const resolve = this.getResolve({\n mainFields: ['module', 'main'],\n })\n\n const mapping = await getBarrelMapping(\n this.resourcePath,\n swcCacheDir,\n resolve,\n this.fs\n )\n\n // `resolve` adds all sub-paths to the dependency graph. However, we already\n // cached the mapping and we assume them to not change. So, we can safely\n // clear the dependencies here to avoid unnecessary watchers which turned out\n // to be very expensive.\n this.clearDependencies()\n\n if (!mapping) {\n // This file isn't a barrel and we can't apply any optimizations. Let's re-export everything.\n // Since this loader accepts `names` and the request is keyed with `names`, we can't simply\n // return the original source here. That will create these imports with different names as\n // different modules instances.\n this.callback(null, `export * from ${JSON.stringify(this.resourcePath)}`)\n return\n }\n\n const exportList = mapping.exportList\n const isClientEntry = mapping.isClientEntry\n const exportMap = new Map<string, [string, string]>()\n for (const [name, filePath, orig] of exportList) {\n exportMap.set(name, [filePath, orig])\n }\n\n let output = ''\n let missedNames: string[] = []\n for (const name of names) {\n // If the name matches\n if (exportMap.has(name)) {\n const decl = exportMap.get(name)!\n\n if (decl[1] === '*') {\n output += `\\nexport * as ${name} from ${JSON.stringify(decl[0])}`\n } else if (decl[1] === 'default') {\n output += `\\nexport { default as ${name} } from ${JSON.stringify(\n decl[0]\n )}`\n } else if (decl[1] === name) {\n output += `\\nexport { ${name} } from ${JSON.stringify(decl[0])}`\n } else {\n output += `\\nexport { ${decl[1]} as ${name} } from ${JSON.stringify(\n decl[0]\n )}`\n }\n } else {\n missedNames.push(name)\n }\n }\n\n // These are from wildcard exports.\n if (missedNames.length > 0) {\n for (const req of mapping.wildcardExports) {\n output += `\\nexport * from ${JSON.stringify(\n req.replace('__PLACEHOLDER__', missedNames.join(',') + '&wildcard')\n )}`\n }\n }\n\n // When it has `\"use client\"` inherited from its barrel files, we need to\n // prefix it to this target file as well.\n if (isClientEntry) {\n output = `\"use client\";\\n${output}`\n }\n\n this.callback(null, output)\n}\n\nexport default NextBarrelLoader\n"],"names":["barrelTransformMappingCache","Map","getBarrelMapping","resourcePath","swcCacheDir","resolve","fs","has","get","transpileSource","filename","source","isWildcard","isTypeScript","endsWith","Promise","res","transform","inputSourceMap","undefined","sourceFileName","optimizeBarrelExports","wildcard","jsc","parser","syntax","experimental","cacheRoot","then","output","code","visited","Set","getMatches","file","isClientEntry","add","rej","readFile","err","data","toString","matches","match","matchedDirectives","directiveList","JSON","parse","includes","exportList","slice","wildcardExports","matchAll","map","decl","length","all","req","targetPath","path","dirname","replace","targetMatches","concat","set","NextBarrelLoader","async","cacheable","names","getOptions","getResolve","mainFields","mapping","clearDependencies","callback","stringify","exportMap","name","filePath","orig","missedNames","push","join"],"mappings":"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","ignoreList":[0]}
|
|
1
|
+
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-barrel-loader.ts"],"sourcesContent":["/**\n * ## Barrel Optimizations\n *\n * This loader is used to optimize the imports of \"barrel\" files that have many\n * re-exports. Currently, both Node.js and Webpack have to enter all of these\n * submodules even if we only need a few of them.\n *\n * For example, say a file `foo.js` with the following contents:\n *\n * export { a } from './a'\n * export { b } from './b'\n * export { c } from './c'\n * ...\n *\n * If the user imports `a` only, this loader will accept the `names` option to\n * be `['a']`. Then, it request the \"__barrel_transform__\" SWC transform to load\n * `foo.js` and receive the following output:\n *\n * export const __next_private_export_map__ = '[[\"a\",\"./a\",\"a\"],[\"b\",\"./b\",\"b\"],[\"c\",\"./c\",\"c\"],...]'\n *\n * format: '[\"<imported identifier>\", \"<import path>\", \"<exported name>\"]'\n * e.g.: import { a as b } from './module-a' => '[\"b\", \"./module-a\", \"a\"]'\n *\n * The export map, generated by SWC, is a JSON that represents the exports of\n * that module, their original file, and their original name (since you can do\n * `export { a as b }`).\n *\n * Then, this loader can safely remove all the exports that are not needed and\n * re-export the ones from `names`:\n *\n * export { a } from './a'\n *\n * That's the basic situation and also the happy path.\n *\n *\n *\n * ## Wildcard Exports\n *\n * For wildcard exports (e.g. `export * from './a'`), it becomes a bit more complicated.\n * Say `foo.js` with the following contents:\n *\n * export * from './a'\n * export * from './b'\n * export * from './c'\n * ...\n *\n * If the user imports `bar` from it, SWC can never know which files are going to be\n * exporting `bar`. So, we have to keep all the wildcard exports and do the same\n * process recursively. This loader will return the following output:\n *\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./a'\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./b'\n * export * from '__barrel_optimize__?names=bar&wildcard!=!./c'\n * ...\n *\n * The \"!=!\" tells Webpack to use the same loader to process './a', './b', and './c'.\n * After the recursive process, the \"inner loaders\" will either return an empty string\n * or:\n *\n * export * from './target'\n *\n * Where `target` is the file that exports `bar`.\n *\n *\n *\n * ## Non-Barrel Files\n *\n * If the file is not a barrel, we can't apply any optimizations. That's because\n * we can't easily remove things from the file. For example, say `foo.js` with:\n *\n * const v = 1\n * export function b () {\n * return v\n * }\n *\n * If the user imports `b` only, we can't remove the `const v = 1` even though\n * the file is side-effect free. In these caes, this loader will simply re-export\n * `foo.js`:\n *\n * export * from './foo'\n *\n * Besides these cases, this loader also carefully handles the module cache so\n * SWC won't analyze the same file twice, and no instance of the same file will\n * be accidentally created as different instances.\n */\n\nimport type webpack from 'webpack'\n\nimport path from 'path'\nimport { transform } from '../../swc'\nimport { installBindings } from '../../swc/install-bindings'\n\n// This is a in-memory cache for the mapping of barrel exports. This only applies\n// to the packages that we optimize. It will never change (e.g. upgrading packages)\n// during the lifetime of the server so we can safely cache it.\n// There is also no need to collect the cache for the same reason.\nconst barrelTransformMappingCache = new Map<\n string,\n {\n exportList: [string, string, string][]\n wildcardExports: string[]\n isClientEntry: boolean\n } | null\n>()\n\nasync function getBarrelMapping(\n resourcePath: string,\n swcCacheDir: string,\n resolve: (context: string, request: string) => Promise<string>,\n fs: {\n readFile: (\n path: string,\n callback: (err: any, data: string | Buffer | undefined) => void\n ) => void\n }\n) {\n if (barrelTransformMappingCache.has(resourcePath)) {\n return barrelTransformMappingCache.get(resourcePath)!\n }\n\n // This is a SWC transform specifically for `optimizeBarrelExports`. We don't\n // care about other things but the export map only.\n async function transpileSource(\n filename: string,\n source: string,\n isWildcard: boolean\n ) {\n const isTypeScript = filename.endsWith('.ts') || filename.endsWith('.tsx')\n return new Promise<string>((res) =>\n transform(source, {\n filename,\n inputSourceMap: undefined,\n sourceFileName: filename,\n optimizeBarrelExports: {\n wildcard: isWildcard,\n },\n jsc: {\n parser: {\n syntax: isTypeScript ? 'typescript' : 'ecmascript',\n [isTypeScript ? 'tsx' : 'jsx']: true,\n },\n experimental: {\n cacheRoot: swcCacheDir,\n },\n },\n }).then((output) => {\n res(output.code)\n })\n )\n }\n\n // Avoid circular `export *` dependencies\n const visited = new Set<string>()\n async function getMatches(\n file: string,\n isWildcard: boolean,\n isClientEntry: boolean\n ) {\n if (visited.has(file)) {\n return null\n }\n visited.add(file)\n\n const source = await new Promise<string>((res, rej) => {\n fs.readFile(file, (err, data) => {\n if (err || data === undefined) {\n rej(err)\n } else {\n res(data.toString())\n }\n })\n })\n\n const output = await transpileSource(file, source, isWildcard)\n\n const matches = output.match(\n /^([^]*)export (const|var) __next_private_export_map__ = ('[^']+'|\"[^\"]+\")/\n )\n if (!matches) {\n return null\n }\n\n const matchedDirectives = output.match(\n /^([^]*)export (const|var) __next_private_directive_list__ = '([^']+)'/\n )\n const directiveList = matchedDirectives\n ? JSON.parse(matchedDirectives[3])\n : []\n // \"use client\" in barrel files has to be transferred to the target file.\n isClientEntry = directiveList.includes('use client')\n\n let exportList = JSON.parse(matches[3].slice(1, -1)) as [\n string,\n string,\n string,\n ][]\n const wildcardExports = [\n ...output.matchAll(/export \\* from \"([^\"]+)\"/g),\n ].map((match) => match[1])\n\n // In the wildcard case, if the value is exported from another file, we\n // redirect to that file (decl[0]). Otherwise, export from the current\n // file itself.\n if (isWildcard) {\n for (const decl of exportList) {\n decl[1] = file\n decl[2] = decl[0]\n }\n }\n\n // This recursively handles the wildcard exports (e.g. `export * from './a'`)\n if (wildcardExports.length) {\n await Promise.all(\n wildcardExports.map(async (req) => {\n const targetPath = await resolve(\n path.dirname(file),\n req.replace('__barrel_optimize__?names=__PLACEHOLDER__!=!', '')\n )\n\n const targetMatches = await getMatches(\n targetPath,\n true,\n isClientEntry\n )\n\n if (targetMatches) {\n // Merge the export list\n exportList = exportList.concat(targetMatches.exportList)\n }\n })\n )\n }\n\n return {\n exportList,\n wildcardExports,\n isClientEntry,\n }\n }\n\n const res = await getMatches(resourcePath, false, false)\n barrelTransformMappingCache.set(resourcePath, res)\n\n return res\n}\n\nconst NextBarrelLoader = async function (\n this: webpack.LoaderContext<{\n names: string[]\n swcCacheDir: string\n }>\n) {\n this.async()\n this.cacheable(true)\n // Install bindings early so they are definitely available.\n // When run by webpack in next this is already done with correct configuration so this is a no-op.\n // In turbopack loaders are run in a subprocess so it may or may not be done.\n await installBindings()\n\n const { names, swcCacheDir } = this.getOptions()\n\n // For barrel optimizations, we always prefer the \"module\" field over the\n // \"main\" field because ESM handling is more robust with better tree-shaking.\n const resolve = this.getResolve({\n mainFields: ['module', 'main'],\n })\n\n const mapping = await getBarrelMapping(\n this.resourcePath,\n swcCacheDir,\n resolve,\n this.fs\n )\n\n // `resolve` adds all sub-paths to the dependency graph. However, we already\n // cached the mapping and we assume them to not change. So, we can safely\n // clear the dependencies here to avoid unnecessary watchers which turned out\n // to be very expensive.\n this.clearDependencies()\n\n if (!mapping) {\n // This file isn't a barrel and we can't apply any optimizations. Let's re-export everything.\n // Since this loader accepts `names` and the request is keyed with `names`, we can't simply\n // return the original source here. That will create these imports with different names as\n // different modules instances.\n this.callback(null, `export * from ${JSON.stringify(this.resourcePath)}`)\n return\n }\n\n const exportList = mapping.exportList\n const isClientEntry = mapping.isClientEntry\n const exportMap = new Map<string, [string, string]>()\n for (const [name, filePath, orig] of exportList) {\n exportMap.set(name, [filePath, orig])\n }\n\n let output = ''\n let missedNames: string[] = []\n for (const name of names) {\n // If the name matches\n if (exportMap.has(name)) {\n const decl = exportMap.get(name)!\n\n if (decl[1] === '*') {\n output += `\\nexport * as ${name} from ${JSON.stringify(decl[0])}`\n } else if (decl[1] === 'default') {\n output += `\\nexport { default as ${name} } from ${JSON.stringify(\n decl[0]\n )}`\n } else if (decl[1] === name) {\n output += `\\nexport { ${name} } from ${JSON.stringify(decl[0])}`\n } else {\n output += `\\nexport { ${decl[1]} as ${name} } from ${JSON.stringify(\n decl[0]\n )}`\n }\n } else {\n missedNames.push(name)\n }\n }\n\n // These are from wildcard exports.\n if (missedNames.length > 0) {\n for (const req of mapping.wildcardExports) {\n output += `\\nexport * from ${JSON.stringify(\n req.replace('__PLACEHOLDER__', missedNames.join(',') + '&wildcard')\n )}`\n }\n }\n\n // When it has `\"use client\"` inherited from its barrel files, we need to\n // prefix it to this target file as well.\n if (isClientEntry) {\n output = `\"use client\";\\n${output}`\n }\n\n this.callback(null, output)\n}\n\nexport default NextBarrelLoader\n"],"names":["barrelTransformMappingCache","Map","getBarrelMapping","resourcePath","swcCacheDir","resolve","fs","has","get","transpileSource","filename","source","isWildcard","isTypeScript","endsWith","Promise","res","transform","inputSourceMap","undefined","sourceFileName","optimizeBarrelExports","wildcard","jsc","parser","syntax","experimental","cacheRoot","then","output","code","visited","Set","getMatches","file","isClientEntry","add","rej","readFile","err","data","toString","matches","match","matchedDirectives","directiveList","JSON","parse","includes","exportList","slice","wildcardExports","matchAll","map","decl","length","all","req","targetPath","path","dirname","replace","targetMatches","concat","set","NextBarrelLoader","async","cacheable","installBindings","names","getOptions","getResolve","mainFields","mapping","clearDependencies","callback","stringify","exportMap","name","filePath","orig","missedNames","push","join"],"mappings":"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","ignoreList":[0]}
|
|
@@ -30,6 +30,7 @@ const _mimetype = require("../../../lib/mime-type");
|
|
|
30
30
|
const _constants = require("../../../lib/constants");
|
|
31
31
|
const _normalizepathsep = require("../../../shared/lib/page-path/normalize-path-sep");
|
|
32
32
|
const _utils = require("./utils");
|
|
33
|
+
const _installbindings = require("../../swc/install-bindings");
|
|
33
34
|
function _interop_require_default(obj) {
|
|
34
35
|
return obj && obj.__esModule ? obj : {
|
|
35
36
|
default: obj
|
|
@@ -38,6 +39,10 @@ function _interop_require_default(obj) {
|
|
|
38
39
|
// [NOTE] For turbopack, refer to app_page_loader_tree's write_metadata_item for
|
|
39
40
|
// corresponding features.
|
|
40
41
|
async function nextMetadataImageLoader(content) {
|
|
42
|
+
// Install bindings early so they are definitely available to the loader.
|
|
43
|
+
// When run by webpack in next this is already done with correct configuration so this is a no-op.
|
|
44
|
+
// In turbopack loaders are run in a subprocess so it may or may not be done.
|
|
45
|
+
await (0, _installbindings.installBindings)();
|
|
41
46
|
const options = this.getOptions();
|
|
42
47
|
const { type, segment, pageExtensions, basePath } = options;
|
|
43
48
|
const { resourcePath, rootContext: context } = this;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-metadata-image-loader.ts"],"sourcesContent":["/*\n * This loader is responsible for extracting the metadata image info for rendering in html\n */\n\nimport type webpack from 'webpack'\nimport type {\n MetadataImageModule,\n PossibleImageFileNameConvention,\n} from './metadata/types'\nimport { existsSync, promises as fs } from 'fs'\nimport path from 'path'\nimport loaderUtils from 'next/dist/compiled/loader-utils3'\nimport { getImageSize } from '../../../server/image-optimizer'\nimport { imageExtMimeTypeMap } from '../../../lib/mime-type'\nimport { WEBPACK_RESOURCE_QUERIES } from '../../../lib/constants'\nimport { normalizePathSep } from '../../../shared/lib/page-path/normalize-path-sep'\nimport type { PageExtensions } from '../../page-extensions-type'\nimport { getLoaderModuleNamedExports } from './utils'\n\ninterface Options {\n segment: string\n type: PossibleImageFileNameConvention\n pageExtensions: PageExtensions\n basePath: string\n}\n\n// [NOTE] For turbopack, refer to app_page_loader_tree's write_metadata_item for\n// corresponding features.\nasync function nextMetadataImageLoader(\n this: webpack.LoaderContext<Options>,\n content: Buffer\n) {\n const options: Options = this.getOptions()\n const { type, segment, pageExtensions, basePath } = options\n const { resourcePath, rootContext: context } = this\n const { name: fileNameBase, ext } = path.parse(resourcePath)\n const useNumericSizes = type === 'twitter' || type === 'openGraph'\n\n let extension = ext.slice(1)\n if (extension === 'jpg') {\n extension = 'jpeg'\n }\n\n const opts = { context, content }\n\n const contentHash = loaderUtils.interpolateName(this, '[contenthash]', opts)\n\n const interpolatedName = loaderUtils.interpolateName(\n this,\n '[name].[ext]',\n opts\n )\n\n const isDynamicResource = pageExtensions.includes(extension)\n const pageSegment = isDynamicResource ? fileNameBase : interpolatedName\n const hashQuery = contentHash ? '?' + contentHash : ''\n const pathnamePrefix = normalizePathSep(path.join(basePath, segment))\n\n if (isDynamicResource) {\n const exportedFieldsExcludingDefault = (\n await getLoaderModuleNamedExports(resourcePath, this)\n ).filter((name) => name !== 'default')\n\n // re-export and spread as `exportedImageData` to avoid non-exported error\n return `\\\n import {\n ${exportedFieldsExcludingDefault\n .map((field) => `${field} as _${field}`)\n .join(',')}\n } from ${JSON.stringify(\n // This is an arbitrary resource query to ensure it's a new request, instead\n // of sharing the same module with next-metadata-route-loader.\n // Since here we only need export fields such as `size`, `alt` and\n // `generateImageMetadata`, avoid sharing the same module can make this entry\n // smaller.\n resourcePath + '?' + WEBPACK_RESOURCE_QUERIES.metadataImageMeta\n )}\n import { fillMetadataSegment } from 'next/dist/lib/metadata/get-metadata-route'\n\n const imageModule = {\n ${exportedFieldsExcludingDefault\n .map((field) => `${field}: _${field}`)\n .join(',')}\n }\n\n function getImageMetadata(imageMetadata, idParam, resolvedParams) {\n const imageUrl = fillMetadataSegment(${JSON.stringify(\n pathnamePrefix\n )}, resolvedParams, ${JSON.stringify(pageSegment)})\n const data = {\n alt: imageMetadata.alt,\n type: imageMetadata.contentType || 'image/png',\n url: imageUrl + (idParam ? ('/' + idParam) : '') + ${JSON.stringify(\n hashQuery\n )},\n }\n const { size } = imageMetadata\n if (size) {\n ${\n type === 'twitter' || type === 'openGraph'\n ? 'data.width = size.width; data.height = size.height;'\n : 'data.sizes = size.width + \"x\" + size.height;'\n }\n }\n return data\n }\n\n export default async function (props) {\n const { generateImageMetadata } = imageModule\n const resolvedParams = await props.params\n\n if (generateImageMetadata) {\n const imageMetadataArray = await generateImageMetadata({ params: resolvedParams })\n return imageMetadataArray.map((imageMetadata, index) => {\n const idParam = imageMetadata.id + ''\n return getImageMetadata(imageMetadata, idParam, resolvedParams)\n })\n } else {\n return [getImageMetadata(imageModule, '', resolvedParams)]\n }\n }`\n }\n\n let imageError\n const imageSize: { width?: number; height?: number } = await getImageSize(\n content\n ).catch((error) => {\n const message = `Process image \"${path.posix.join(segment || '/', interpolatedName)}\" failed: ${error}`\n imageError = new Error(message)\n return {}\n })\n\n if (imageError) {\n throw imageError\n }\n\n const imageData: Omit<MetadataImageModule, 'url'> = {\n ...(extension in imageExtMimeTypeMap && {\n type: imageExtMimeTypeMap[extension as keyof typeof imageExtMimeTypeMap],\n }),\n ...(useNumericSizes && imageSize.width != null && imageSize.height != null\n ? imageSize\n : {\n sizes:\n // For SVGs, skip sizes and use \"any\" to let it scale automatically based on viewport,\n // For the images doesn't provide the size properly, use \"any\" as well.\n // If the size is presented, use the actual size for the image.\n extension !== 'svg' &&\n imageSize.width != null &&\n imageSize.height != null\n ? `${imageSize.width}x${imageSize.height}`\n : 'any',\n }),\n }\n if (type === 'openGraph' || type === 'twitter') {\n const altPath = path.join(\n path.dirname(resourcePath),\n fileNameBase + '.alt.txt'\n )\n\n if (existsSync(altPath)) {\n imageData.alt = await fs.readFile(altPath, 'utf8')\n }\n }\n\n return `\\\n import { fillMetadataSegment } from 'next/dist/lib/metadata/get-metadata-route'\n\n export default async (props) => {\n const imageData = ${JSON.stringify(imageData)}\n const imageUrl = fillMetadataSegment(${JSON.stringify(\n pathnamePrefix\n )}, await props.params, ${JSON.stringify(pageSegment)})\n\n return [{\n ...imageData,\n url: imageUrl + ${JSON.stringify(hashQuery)},\n }]\n }`\n}\n\nexport const raw = true\nexport default nextMetadataImageLoader\n"],"names":["raw","nextMetadataImageLoader","content","options","getOptions","type","segment","pageExtensions","basePath","resourcePath","rootContext","context","name","fileNameBase","ext","path","parse","useNumericSizes","extension","slice","opts","contentHash","loaderUtils","interpolateName","interpolatedName","isDynamicResource","includes","pageSegment","hashQuery","pathnamePrefix","normalizePathSep","join","exportedFieldsExcludingDefault","getLoaderModuleNamedExports","filter","map","field","JSON","stringify","WEBPACK_RESOURCE_QUERIES","metadataImageMeta","imageError","imageSize","getImageSize","catch","error","message","posix","Error","imageData","imageExtMimeTypeMap","width","height","sizes","altPath","dirname","existsSync","alt","fs","readFile"],"mappings":"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","ignoreList":[0]}
|
|
1
|
+
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-metadata-image-loader.ts"],"sourcesContent":["/*\n * This loader is responsible for extracting the metadata image info for rendering in html\n */\n\nimport type webpack from 'webpack'\nimport type {\n MetadataImageModule,\n PossibleImageFileNameConvention,\n} from './metadata/types'\nimport { existsSync, promises as fs } from 'fs'\nimport path from 'path'\nimport loaderUtils from 'next/dist/compiled/loader-utils3'\nimport { getImageSize } from '../../../server/image-optimizer'\nimport { imageExtMimeTypeMap } from '../../../lib/mime-type'\nimport { WEBPACK_RESOURCE_QUERIES } from '../../../lib/constants'\nimport { normalizePathSep } from '../../../shared/lib/page-path/normalize-path-sep'\nimport type { PageExtensions } from '../../page-extensions-type'\nimport { getLoaderModuleNamedExports } from './utils'\nimport { installBindings } from '../../swc/install-bindings'\n\ninterface Options {\n segment: string\n type: PossibleImageFileNameConvention\n pageExtensions: PageExtensions\n basePath: string\n}\n\n// [NOTE] For turbopack, refer to app_page_loader_tree's write_metadata_item for\n// corresponding features.\nasync function nextMetadataImageLoader(\n this: webpack.LoaderContext<Options>,\n content: Buffer\n) {\n // Install bindings early so they are definitely available to the loader.\n // When run by webpack in next this is already done with correct configuration so this is a no-op.\n // In turbopack loaders are run in a subprocess so it may or may not be done.\n await installBindings()\n const options: Options = this.getOptions()\n const { type, segment, pageExtensions, basePath } = options\n const { resourcePath, rootContext: context } = this\n const { name: fileNameBase, ext } = path.parse(resourcePath)\n const useNumericSizes = type === 'twitter' || type === 'openGraph'\n\n let extension = ext.slice(1)\n if (extension === 'jpg') {\n extension = 'jpeg'\n }\n\n const opts = { context, content }\n\n const contentHash = loaderUtils.interpolateName(this, '[contenthash]', opts)\n\n const interpolatedName = loaderUtils.interpolateName(\n this,\n '[name].[ext]',\n opts\n )\n\n const isDynamicResource = pageExtensions.includes(extension)\n const pageSegment = isDynamicResource ? fileNameBase : interpolatedName\n const hashQuery = contentHash ? '?' + contentHash : ''\n const pathnamePrefix = normalizePathSep(path.join(basePath, segment))\n\n if (isDynamicResource) {\n const exportedFieldsExcludingDefault = (\n await getLoaderModuleNamedExports(resourcePath, this)\n ).filter((name) => name !== 'default')\n\n // re-export and spread as `exportedImageData` to avoid non-exported error\n return `\\\n import {\n ${exportedFieldsExcludingDefault\n .map((field) => `${field} as _${field}`)\n .join(',')}\n } from ${JSON.stringify(\n // This is an arbitrary resource query to ensure it's a new request, instead\n // of sharing the same module with next-metadata-route-loader.\n // Since here we only need export fields such as `size`, `alt` and\n // `generateImageMetadata`, avoid sharing the same module can make this entry\n // smaller.\n resourcePath + '?' + WEBPACK_RESOURCE_QUERIES.metadataImageMeta\n )}\n import { fillMetadataSegment } from 'next/dist/lib/metadata/get-metadata-route'\n\n const imageModule = {\n ${exportedFieldsExcludingDefault\n .map((field) => `${field}: _${field}`)\n .join(',')}\n }\n\n function getImageMetadata(imageMetadata, idParam, resolvedParams) {\n const imageUrl = fillMetadataSegment(${JSON.stringify(\n pathnamePrefix\n )}, resolvedParams, ${JSON.stringify(pageSegment)})\n const data = {\n alt: imageMetadata.alt,\n type: imageMetadata.contentType || 'image/png',\n url: imageUrl + (idParam ? ('/' + idParam) : '') + ${JSON.stringify(\n hashQuery\n )},\n }\n const { size } = imageMetadata\n if (size) {\n ${\n type === 'twitter' || type === 'openGraph'\n ? 'data.width = size.width; data.height = size.height;'\n : 'data.sizes = size.width + \"x\" + size.height;'\n }\n }\n return data\n }\n\n export default async function (props) {\n const { generateImageMetadata } = imageModule\n const resolvedParams = await props.params\n\n if (generateImageMetadata) {\n const imageMetadataArray = await generateImageMetadata({ params: resolvedParams })\n return imageMetadataArray.map((imageMetadata, index) => {\n const idParam = imageMetadata.id + ''\n return getImageMetadata(imageMetadata, idParam, resolvedParams)\n })\n } else {\n return [getImageMetadata(imageModule, '', resolvedParams)]\n }\n }`\n }\n\n let imageError\n const imageSize: { width?: number; height?: number } = await getImageSize(\n content\n ).catch((error) => {\n const message = `Process image \"${path.posix.join(segment || '/', interpolatedName)}\" failed: ${error}`\n imageError = new Error(message)\n return {}\n })\n\n if (imageError) {\n throw imageError\n }\n\n const imageData: Omit<MetadataImageModule, 'url'> = {\n ...(extension in imageExtMimeTypeMap && {\n type: imageExtMimeTypeMap[extension as keyof typeof imageExtMimeTypeMap],\n }),\n ...(useNumericSizes && imageSize.width != null && imageSize.height != null\n ? imageSize\n : {\n sizes:\n // For SVGs, skip sizes and use \"any\" to let it scale automatically based on viewport,\n // For the images doesn't provide the size properly, use \"any\" as well.\n // If the size is presented, use the actual size for the image.\n extension !== 'svg' &&\n imageSize.width != null &&\n imageSize.height != null\n ? `${imageSize.width}x${imageSize.height}`\n : 'any',\n }),\n }\n if (type === 'openGraph' || type === 'twitter') {\n const altPath = path.join(\n path.dirname(resourcePath),\n fileNameBase + '.alt.txt'\n )\n\n if (existsSync(altPath)) {\n imageData.alt = await fs.readFile(altPath, 'utf8')\n }\n }\n\n return `\\\n import { fillMetadataSegment } from 'next/dist/lib/metadata/get-metadata-route'\n\n export default async (props) => {\n const imageData = ${JSON.stringify(imageData)}\n const imageUrl = fillMetadataSegment(${JSON.stringify(\n pathnamePrefix\n )}, await props.params, ${JSON.stringify(pageSegment)})\n\n return [{\n ...imageData,\n url: imageUrl + ${JSON.stringify(hashQuery)},\n }]\n }`\n}\n\nexport const raw = true\nexport default nextMetadataImageLoader\n"],"names":["raw","nextMetadataImageLoader","content","installBindings","options","getOptions","type","segment","pageExtensions","basePath","resourcePath","rootContext","context","name","fileNameBase","ext","path","parse","useNumericSizes","extension","slice","opts","contentHash","loaderUtils","interpolateName","interpolatedName","isDynamicResource","includes","pageSegment","hashQuery","pathnamePrefix","normalizePathSep","join","exportedFieldsExcludingDefault","getLoaderModuleNamedExports","filter","map","field","JSON","stringify","WEBPACK_RESOURCE_QUERIES","metadataImageMeta","imageError","imageSize","getImageSize","catch","error","message","posix","Error","imageData","imageExtMimeTypeMap","width","height","sizes","altPath","dirname","existsSync","alt","fs","readFile"],"mappings":"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","ignoreList":[0]}
|
|
@@ -24,6 +24,7 @@ const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
|
|
|
24
24
|
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
|
|
25
25
|
const _mimetype = require("../../../lib/mime-type");
|
|
26
26
|
const _utils = require("./utils");
|
|
27
|
+
const _installbindings = require("../../swc/install-bindings");
|
|
27
28
|
function _interop_require_default(obj) {
|
|
28
29
|
return obj && obj.__esModule ? obj : {
|
|
29
30
|
default: obj
|
|
@@ -315,6 +316,10 @@ async function getSitemapRouteCode(resourcePath, loaderContext) {
|
|
|
315
316
|
// When it's static route, it could be favicon.ico, sitemap.xml, robots.txt etc.
|
|
316
317
|
// TODO-METADATA: improve the cache control strategy
|
|
317
318
|
const nextMetadataRouterLoader = async function() {
|
|
319
|
+
// Install bindings early so they are definitely available to the loader.
|
|
320
|
+
// When run by webpack in next this is already done with correct configuration so this is a no-op.
|
|
321
|
+
// In turbopack loaders are run in a subprocess so it may or may not be done.
|
|
322
|
+
await (0, _installbindings.installBindings)();
|
|
318
323
|
const { isDynamicRouteExtension, filePath } = this.getOptions();
|
|
319
324
|
const { name: fileBaseName } = getFilenameAndExtension(filePath);
|
|
320
325
|
this.addDependency(filePath);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-metadata-route-loader.ts"],"sourcesContent":["import type webpack from 'webpack'\nimport fs from 'fs'\nimport path from 'path'\nimport { imageExtMimeTypeMap } from '../../../lib/mime-type'\nimport { getLoaderModuleNamedExports } from './utils'\n\nfunction errorOnBadHandler(resourcePath: string) {\n return `\n if (typeof handler !== 'function') {\n throw new Error('Default export is missing in ${JSON.stringify(\n resourcePath\n )}')\n }\n `\n}\n\n/* re-export the userland route configs */\nasync function createReExportsCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n // Re-export configs but avoid conflicted exports\n const reExportNames = exportNames.filter(\n (name) =>\n name !== 'default' &&\n name !== 'generateSitemaps' &&\n name !== 'dynamicParams'\n )\n\n return reExportNames.length > 0\n ? `export { ${reExportNames.join(', ')} } from ${JSON.stringify(\n resourcePath\n )}\\n`\n : ''\n}\n\nconst CACHE_HEADERS = {\n NO_CACHE: 'no-cache, no-store',\n REVALIDATE: 'public, max-age=0, must-revalidate',\n}\n\nexport type MetadataRouteLoaderOptions = {\n // Using separate argument to avoid json being parsed and hit error\n // x-ref: https://github.com/vercel/next.js/pull/62615\n filePath: string\n isDynamicRouteExtension: '1' | '0'\n}\n\nexport function getFilenameAndExtension(resourcePath: string) {\n const filename = path.basename(resourcePath)\n const [name, ext] = filename.split('.', 2)\n return {\n name,\n ext,\n }\n}\n\nfunction getContentType(resourcePath: string) {\n let { name, ext } = getFilenameAndExtension(resourcePath)\n if (ext === 'jpg') ext = 'jpeg'\n\n if (name === 'favicon' && ext === 'ico') return 'image/x-icon'\n if (name === 'sitemap') return 'application/xml'\n if (name === 'robots') return 'text/plain'\n if (name === 'manifest') return 'application/manifest+json'\n\n if (ext === 'png' || ext === 'jpeg' || ext === 'ico' || ext === 'svg') {\n return imageExtMimeTypeMap[ext]\n }\n return 'text/plain'\n}\n\nasync function getStaticAssetRouteCode(\n resourcePath: string,\n fileBaseName: string\n) {\n const cache =\n process.env.NODE_ENV !== 'production'\n ? CACHE_HEADERS.NO_CACHE\n : CACHE_HEADERS.REVALIDATE\n\n const isTwitter = fileBaseName === 'twitter-image'\n const isOpenGraph = fileBaseName === 'opengraph-image'\n // Twitter image file size limit is 5MB.\n // General Open Graph image file size limit is 8MB.\n // x-ref: https://developer.x.com/en/docs/x-for-websites/cards/overview/summary\n // x-ref(facebook): https://developers.facebook.com/docs/sharing/webmasters/images\n const fileSizeLimit = isTwitter ? 5 : 8\n const imgName = isTwitter ? 'Twitter' : 'Open Graph'\n\n const code = `\\\n/* static asset route */\nimport { NextResponse } from 'next/server'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst buffer = Buffer.from(${JSON.stringify(\n (await fs.promises.readFile(resourcePath)).toString('base64')\n )}, 'base64'\n )\n\nif (${isTwitter || isOpenGraph}) {\n const fileSizeInMB = buffer.byteLength / 1024 / 1024\n if (fileSizeInMB > ${fileSizeLimit}) {\n throw new Error('File size for ${imgName} image ${JSON.stringify(resourcePath)} exceeds ${fileSizeLimit}MB. ' +\n \\`(Current: \\${fileSizeInMB.toFixed(2)}MB)\\n\\` +\n 'Read more: https://nextjs.org/docs/app/api-reference/file-conventions/metadata/opengraph-image#image-files-jpg-png-gif'\n )\n }\n}\n\nexport function GET() {\n return new NextResponse(buffer, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(cache)},\n },\n })\n}\n\nexport const dynamic = 'force-static'\n`\n return code\n}\n\nasync function getDynamicTextRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic asset route */\nimport { NextResponse } from 'next/server'\nimport handler from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET() {\n const data = await handler()\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n`\n}\n\nasync function getDynamicImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic image route with generateImageMetadata */\nimport { NextResponse } from 'next/server'\nimport { default as handler, generateImageMetadata } from ${JSON.stringify(resourcePath)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n const paramsPromise = ctx.params\n const idPromise = paramsPromise.then(params => params?.__metadata_id__)\n const restParamsPromise = paramsPromise.then(params => {\n if (!params) return undefined\n const { __metadata_id__, ...rest } = params\n return rest\n })\n\n const restParams = await restParamsPromise\n const __metadata_id__ = await idPromise\n const imageMetadata = await generateImageMetadata({ params: restParams })\n const id = imageMetadata.find((item) => {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateImageMetadata')\n }\n\n return item.id.toString() === __metadata_id__\n })?.id\n\n if (id == null) {\n return new NextResponse('Not Found', {\n status: 404,\n })\n }\n\n return handler({ params: restParamsPromise, id: idPromise })\n}\n\nexport async function generateStaticParams({ params }) {\n const imageMetadata = await generateImageMetadata({ params })\n const staticParams = []\n\n for (const item of imageMetadata) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateImageMetadata')\n }\n staticParams.push({ __metadata_id__: item.id.toString() })\n }\n return staticParams\n}\n`\n}\n\nasync function getSingleImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic image route without generateImageMetadata */\nimport { NextResponse } from 'next/server'\nimport { default as handler } from ${JSON.stringify(resourcePath)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n return handler({ params: ctx.params })\n}\n`\n}\n\n// <metadata-image>/[id]/route.js\nasync function getImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n\n const hasGenerateParamsExport = exportNames.includes('generateImageMetadata')\n\n if (hasGenerateParamsExport) {\n return getDynamicImageRouteCode(resourcePath, loaderContext)\n } else {\n return getSingleImageRouteCode(resourcePath, loaderContext)\n }\n}\n\nasync function getSingleSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* single sitemap route */\nimport { NextResponse } from 'next/server'\nimport { default as handler } from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET() {\n const data = await handler()\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n`\n}\n\nasync function getDynamicSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const code = `\\\n/* dynamic sitemap route with generateSitemaps */\nimport { NextResponse } from 'next/server'\nimport { default as handler, generateSitemaps } from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n const paramsPromise = ctx.params\n const idPromise = paramsPromise.then(params => params?.__metadata_id__)\n\n const id = await idPromise\n const hasXmlExtension = id ? id.endsWith('.xml') : false\n const sitemaps = await generateSitemaps()\n let foundId\n for (const item of sitemaps) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateSitemaps')\n }\n\n const baseId = id && hasXmlExtension ? id.slice(0, -4) : undefined\n if (item.id.toString() === baseId) {\n foundId = item.id\n }\n }\n if (foundId == null) {\n return new NextResponse('Not Found', {\n status: 404,\n })\n }\n\n const targetIdPromise = idPromise.then(id => {\n const hasXmlExtension = id ? id.endsWith('.xml') : false\n return id && hasXmlExtension ? id.slice(0, -4) : undefined\n })\n const data = await handler({ id: targetIdPromise })\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n\nexport async function generateStaticParams() {\n const sitemaps = await generateSitemaps()\n const params = []\n\n for (const item of sitemaps) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateSitemaps')\n }\n params.push({ __metadata_id__: item.id.toString() + '.xml' })\n }\n return params\n}\n`\n return code\n}\n\n// <metadata-sitemap>/[id]/route.js\nasync function getSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n\n const hasGenerateSitemaps = exportNames.includes('generateSitemaps')\n\n if (hasGenerateSitemaps) {\n return getDynamicSitemapRouteCode(resourcePath, loaderContext)\n } else {\n return getSingleSitemapRouteCode(resourcePath, loaderContext)\n }\n}\n\n// When it's static route, it could be favicon.ico, sitemap.xml, robots.txt etc.\n// TODO-METADATA: improve the cache control strategy\nconst nextMetadataRouterLoader: webpack.LoaderDefinitionFunction<MetadataRouteLoaderOptions> =\n async function () {\n const { isDynamicRouteExtension, filePath } = this.getOptions()\n const { name: fileBaseName } = getFilenameAndExtension(filePath)\n this.addDependency(filePath)\n\n let code = ''\n if (isDynamicRouteExtension === '1') {\n if (fileBaseName === 'robots' || fileBaseName === 'manifest') {\n code = await getDynamicTextRouteCode(filePath, this)\n } else if (fileBaseName === 'sitemap') {\n code = await getSitemapRouteCode(filePath, this)\n } else {\n code = await getImageRouteCode(filePath, this)\n }\n } else {\n code = await getStaticAssetRouteCode(filePath, fileBaseName)\n }\n\n return code\n }\n\nexport default nextMetadataRouterLoader\n"],"names":["getFilenameAndExtension","errorOnBadHandler","resourcePath","JSON","stringify","createReExportsCode","loaderContext","exportNames","getLoaderModuleNamedExports","reExportNames","filter","name","length","join","CACHE_HEADERS","NO_CACHE","REVALIDATE","filename","path","basename","ext","split","getContentType","imageExtMimeTypeMap","getStaticAssetRouteCode","fileBaseName","cache","process","env","NODE_ENV","isTwitter","isOpenGraph","fileSizeLimit","imgName","code","fs","promises","readFile","toString","getDynamicTextRouteCode","getDynamicImageRouteCode","getSingleImageRouteCode","getImageRouteCode","hasGenerateParamsExport","includes","getSingleSitemapRouteCode","getDynamicSitemapRouteCode","getSitemapRouteCode","hasGenerateSitemaps","nextMetadataRouterLoader","isDynamicRouteExtension","filePath","getOptions","addDependency"],"mappings":"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","ignoreList":[0]}
|
|
1
|
+
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-metadata-route-loader.ts"],"sourcesContent":["import type webpack from 'webpack'\nimport fs from 'fs'\nimport path from 'path'\nimport { imageExtMimeTypeMap } from '../../../lib/mime-type'\nimport { getLoaderModuleNamedExports } from './utils'\nimport { installBindings } from '../../swc/install-bindings'\n\nfunction errorOnBadHandler(resourcePath: string) {\n return `\n if (typeof handler !== 'function') {\n throw new Error('Default export is missing in ${JSON.stringify(\n resourcePath\n )}')\n }\n `\n}\n\n/* re-export the userland route configs */\nasync function createReExportsCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n // Re-export configs but avoid conflicted exports\n const reExportNames = exportNames.filter(\n (name) =>\n name !== 'default' &&\n name !== 'generateSitemaps' &&\n name !== 'dynamicParams'\n )\n\n return reExportNames.length > 0\n ? `export { ${reExportNames.join(', ')} } from ${JSON.stringify(\n resourcePath\n )}\\n`\n : ''\n}\n\nconst CACHE_HEADERS = {\n NO_CACHE: 'no-cache, no-store',\n REVALIDATE: 'public, max-age=0, must-revalidate',\n}\n\nexport type MetadataRouteLoaderOptions = {\n // Using separate argument to avoid json being parsed and hit error\n // x-ref: https://github.com/vercel/next.js/pull/62615\n filePath: string\n isDynamicRouteExtension: '1' | '0'\n}\n\nexport function getFilenameAndExtension(resourcePath: string) {\n const filename = path.basename(resourcePath)\n const [name, ext] = filename.split('.', 2)\n return {\n name,\n ext,\n }\n}\n\nfunction getContentType(resourcePath: string) {\n let { name, ext } = getFilenameAndExtension(resourcePath)\n if (ext === 'jpg') ext = 'jpeg'\n\n if (name === 'favicon' && ext === 'ico') return 'image/x-icon'\n if (name === 'sitemap') return 'application/xml'\n if (name === 'robots') return 'text/plain'\n if (name === 'manifest') return 'application/manifest+json'\n\n if (ext === 'png' || ext === 'jpeg' || ext === 'ico' || ext === 'svg') {\n return imageExtMimeTypeMap[ext]\n }\n return 'text/plain'\n}\n\nasync function getStaticAssetRouteCode(\n resourcePath: string,\n fileBaseName: string\n) {\n const cache =\n process.env.NODE_ENV !== 'production'\n ? CACHE_HEADERS.NO_CACHE\n : CACHE_HEADERS.REVALIDATE\n\n const isTwitter = fileBaseName === 'twitter-image'\n const isOpenGraph = fileBaseName === 'opengraph-image'\n // Twitter image file size limit is 5MB.\n // General Open Graph image file size limit is 8MB.\n // x-ref: https://developer.x.com/en/docs/x-for-websites/cards/overview/summary\n // x-ref(facebook): https://developers.facebook.com/docs/sharing/webmasters/images\n const fileSizeLimit = isTwitter ? 5 : 8\n const imgName = isTwitter ? 'Twitter' : 'Open Graph'\n\n const code = `\\\n/* static asset route */\nimport { NextResponse } from 'next/server'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst buffer = Buffer.from(${JSON.stringify(\n (await fs.promises.readFile(resourcePath)).toString('base64')\n )}, 'base64'\n )\n\nif (${isTwitter || isOpenGraph}) {\n const fileSizeInMB = buffer.byteLength / 1024 / 1024\n if (fileSizeInMB > ${fileSizeLimit}) {\n throw new Error('File size for ${imgName} image ${JSON.stringify(resourcePath)} exceeds ${fileSizeLimit}MB. ' +\n \\`(Current: \\${fileSizeInMB.toFixed(2)}MB)\\n\\` +\n 'Read more: https://nextjs.org/docs/app/api-reference/file-conventions/metadata/opengraph-image#image-files-jpg-png-gif'\n )\n }\n}\n\nexport function GET() {\n return new NextResponse(buffer, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(cache)},\n },\n })\n}\n\nexport const dynamic = 'force-static'\n`\n return code\n}\n\nasync function getDynamicTextRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic asset route */\nimport { NextResponse } from 'next/server'\nimport handler from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET() {\n const data = await handler()\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n`\n}\n\nasync function getDynamicImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic image route with generateImageMetadata */\nimport { NextResponse } from 'next/server'\nimport { default as handler, generateImageMetadata } from ${JSON.stringify(resourcePath)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n const paramsPromise = ctx.params\n const idPromise = paramsPromise.then(params => params?.__metadata_id__)\n const restParamsPromise = paramsPromise.then(params => {\n if (!params) return undefined\n const { __metadata_id__, ...rest } = params\n return rest\n })\n\n const restParams = await restParamsPromise\n const __metadata_id__ = await idPromise\n const imageMetadata = await generateImageMetadata({ params: restParams })\n const id = imageMetadata.find((item) => {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateImageMetadata')\n }\n\n return item.id.toString() === __metadata_id__\n })?.id\n\n if (id == null) {\n return new NextResponse('Not Found', {\n status: 404,\n })\n }\n\n return handler({ params: restParamsPromise, id: idPromise })\n}\n\nexport async function generateStaticParams({ params }) {\n const imageMetadata = await generateImageMetadata({ params })\n const staticParams = []\n\n for (const item of imageMetadata) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateImageMetadata')\n }\n staticParams.push({ __metadata_id__: item.id.toString() })\n }\n return staticParams\n}\n`\n}\n\nasync function getSingleImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* dynamic image route without generateImageMetadata */\nimport { NextResponse } from 'next/server'\nimport { default as handler } from ${JSON.stringify(resourcePath)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n return handler({ params: ctx.params })\n}\n`\n}\n\n// <metadata-image>/[id]/route.js\nasync function getImageRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n\n const hasGenerateParamsExport = exportNames.includes('generateImageMetadata')\n\n if (hasGenerateParamsExport) {\n return getDynamicImageRouteCode(resourcePath, loaderContext)\n } else {\n return getSingleImageRouteCode(resourcePath, loaderContext)\n }\n}\n\nasync function getSingleSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n return `\\\n/* single sitemap route */\nimport { NextResponse } from 'next/server'\nimport { default as handler } from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET() {\n const data = await handler()\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n`\n}\n\nasync function getDynamicSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const code = `\\\n/* dynamic sitemap route with generateSitemaps */\nimport { NextResponse } from 'next/server'\nimport { default as handler, generateSitemaps } from ${JSON.stringify(resourcePath)}\nimport { resolveRouteData } from 'next/dist/build/webpack/loaders/metadata/resolve-route-data'\n\nconst contentType = ${JSON.stringify(getContentType(resourcePath))}\nconst fileType = ${JSON.stringify(getFilenameAndExtension(resourcePath).name)}\n\n${errorOnBadHandler(resourcePath)}\n${await createReExportsCode(resourcePath, loaderContext)}\n\nexport async function GET(_, ctx) {\n const paramsPromise = ctx.params\n const idPromise = paramsPromise.then(params => params?.__metadata_id__)\n\n const id = await idPromise\n const hasXmlExtension = id ? id.endsWith('.xml') : false\n const sitemaps = await generateSitemaps()\n let foundId\n for (const item of sitemaps) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateSitemaps')\n }\n\n const baseId = id && hasXmlExtension ? id.slice(0, -4) : undefined\n if (item.id.toString() === baseId) {\n foundId = item.id\n }\n }\n if (foundId == null) {\n return new NextResponse('Not Found', {\n status: 404,\n })\n }\n\n const targetIdPromise = idPromise.then(id => {\n const hasXmlExtension = id ? id.endsWith('.xml') : false\n return id && hasXmlExtension ? id.slice(0, -4) : undefined\n })\n const data = await handler({ id: targetIdPromise })\n const content = resolveRouteData(data, fileType)\n\n return new NextResponse(content, {\n headers: {\n 'Content-Type': contentType,\n 'Cache-Control': ${JSON.stringify(CACHE_HEADERS.REVALIDATE)},\n },\n })\n}\n\nexport async function generateStaticParams() {\n const sitemaps = await generateSitemaps()\n const params = []\n\n for (const item of sitemaps) {\n if (item?.id == null) {\n throw new Error('id property is required for every item returned from generateSitemaps')\n }\n params.push({ __metadata_id__: item.id.toString() + '.xml' })\n }\n return params\n}\n`\n return code\n}\n\n// <metadata-sitemap>/[id]/route.js\nasync function getSitemapRouteCode(\n resourcePath: string,\n loaderContext: webpack.LoaderContext<any>\n) {\n const exportNames = await getLoaderModuleNamedExports(\n resourcePath,\n loaderContext\n )\n\n const hasGenerateSitemaps = exportNames.includes('generateSitemaps')\n\n if (hasGenerateSitemaps) {\n return getDynamicSitemapRouteCode(resourcePath, loaderContext)\n } else {\n return getSingleSitemapRouteCode(resourcePath, loaderContext)\n }\n}\n\n// When it's static route, it could be favicon.ico, sitemap.xml, robots.txt etc.\n// TODO-METADATA: improve the cache control strategy\nconst nextMetadataRouterLoader: webpack.LoaderDefinitionFunction<MetadataRouteLoaderOptions> =\n async function () {\n // Install bindings early so they are definitely available to the loader.\n // When run by webpack in next this is already done with correct configuration so this is a no-op.\n // In turbopack loaders are run in a subprocess so it may or may not be done.\n await installBindings()\n const { isDynamicRouteExtension, filePath } = this.getOptions()\n const { name: fileBaseName } = getFilenameAndExtension(filePath)\n this.addDependency(filePath)\n\n let code = ''\n if (isDynamicRouteExtension === '1') {\n if (fileBaseName === 'robots' || fileBaseName === 'manifest') {\n code = await getDynamicTextRouteCode(filePath, this)\n } else if (fileBaseName === 'sitemap') {\n code = await getSitemapRouteCode(filePath, this)\n } else {\n code = await getImageRouteCode(filePath, this)\n }\n } else {\n code = await getStaticAssetRouteCode(filePath, fileBaseName)\n }\n\n return code\n }\n\nexport default nextMetadataRouterLoader\n"],"names":["getFilenameAndExtension","errorOnBadHandler","resourcePath","JSON","stringify","createReExportsCode","loaderContext","exportNames","getLoaderModuleNamedExports","reExportNames","filter","name","length","join","CACHE_HEADERS","NO_CACHE","REVALIDATE","filename","path","basename","ext","split","getContentType","imageExtMimeTypeMap","getStaticAssetRouteCode","fileBaseName","cache","process","env","NODE_ENV","isTwitter","isOpenGraph","fileSizeLimit","imgName","code","fs","promises","readFile","toString","getDynamicTextRouteCode","getDynamicImageRouteCode","getSingleImageRouteCode","getImageRouteCode","hasGenerateParamsExport","includes","getSingleSitemapRouteCode","getDynamicSitemapRouteCode","getSitemapRouteCode","hasGenerateSitemaps","nextMetadataRouterLoader","installBindings","isDynamicRouteExtension","filePath","getOptions","addDependency"],"mappings":"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","ignoreList":[0]}
|
|
@@ -52,6 +52,7 @@ _export(exports, {
|
|
|
52
52
|
});
|
|
53
53
|
const _constants = require("../../../lib/constants");
|
|
54
54
|
const _swc = require("../../swc");
|
|
55
|
+
const _installbindings = require("../../swc/install-bindings");
|
|
55
56
|
const _options = require("../../swc/options");
|
|
56
57
|
const _path = /*#__PURE__*/ _interop_require_wildcard(require("path"));
|
|
57
58
|
const _webpackconfig = require("../../webpack-config");
|
|
@@ -215,7 +216,7 @@ function pitch() {
|
|
|
215
216
|
(async ()=>{
|
|
216
217
|
if (// if it might be excluded/no-op we can't use pitch loader
|
|
217
218
|
!shouldMaybeExclude && // TODO: investigate swc file reading in PnP mode?
|
|
218
|
-
!process.versions.pnp && !EXCLUDED_PATHS.test(this.resourcePath) && this.loaders.length - 1 === this.loaderIndex && (0, _path.isAbsolute)(this.resourcePath) && !
|
|
219
|
+
!process.versions.pnp && !EXCLUDED_PATHS.test(this.resourcePath) && this.loaders.length - 1 === this.loaderIndex && (0, _path.isAbsolute)(this.resourcePath) && !(0, _swc.getBindingsSync)().isWasm) {
|
|
219
220
|
this.addDependency(this.resourcePath);
|
|
220
221
|
return loaderTransform.call(this);
|
|
221
222
|
}
|
|
@@ -226,11 +227,14 @@ function pitch() {
|
|
|
226
227
|
}
|
|
227
228
|
function swcLoader(inputSource, inputSourceMap) {
|
|
228
229
|
const callback = this.async();
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
230
|
+
// Install bindings early so they are definitely available to the loader.
|
|
231
|
+
// When run by webpack in next this is already done with correct configuration so this is a no-op.
|
|
232
|
+
// In turbopack loaders are run in a subprocess so it may or may not be done.
|
|
233
|
+
(0, _installbindings.installBindings)().then(()=>loaderTransform.call(this, inputSource, inputSourceMap).then(([transformedSource, outputSourceMap])=>{
|
|
234
|
+
callback(null, transformedSource, outputSourceMap || inputSourceMap);
|
|
235
|
+
}, (err)=>{
|
|
236
|
+
callback(err);
|
|
237
|
+
}));
|
|
234
238
|
}
|
|
235
239
|
const raw = true;
|
|
236
240
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-swc-loader.ts"],"sourcesContent":["/*\nCopyright (c) 2017 The swc Project Developers\n\nPermission is hereby granted, free of charge, to any\nperson obtaining a copy of this software and associated\ndocumentation files (the \"Software\"), to deal in the\nSoftware without restriction, including without\nlimitation the rights to use, copy, modify, merge,\npublish, distribute, sublicense, and/or sell copies of\nthe Software, and to permit persons to whom the Software\nis furnished to do so, subject to the following\nconditions:\n\nThe above copyright notice and this permission notice\nshall be included in all copies or substantial portions\nof the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF\nANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED\nTO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\nPARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT\nSHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION\nOF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR\nIN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\nDEALINGS IN THE SOFTWARE.\n*/\n\nimport type { NextConfig } from '../../../types'\nimport { type WebpackLayerName, WEBPACK_LAYERS } from '../../../lib/constants'\nimport { isWasm, transform } from '../../swc'\nimport { getLoaderSWCOptions } from '../../swc/options'\nimport path, { isAbsolute } from 'path'\nimport { babelIncludeRegexes } from '../../webpack-config'\nimport { isResourceInPackages } from '../../handle-externals'\nimport type { TelemetryLoaderContext } from '../plugins/telemetry-plugin/telemetry-plugin'\nimport {\n updateTelemetryLoaderCtxFromTransformOutput,\n type SwcTransformTelemetryOutput,\n} from '../plugins/telemetry-plugin/update-telemetry-loader-context-from-swc'\nimport type { LoaderContext } from 'webpack'\nimport {\n COMPILER_NAMES,\n type CompilerNameValues,\n} from '../../../shared/lib/constants'\n\nconst maybeExclude = (\n excludePath: string,\n transpilePackages: string[]\n): boolean => {\n if (babelIncludeRegexes.some((r) => r.test(excludePath))) {\n return false\n }\n\n const shouldBeBundled = isResourceInPackages(excludePath, transpilePackages)\n if (shouldBeBundled) return false\n\n return excludePath.includes('node_modules')\n}\n\nexport interface SWCLoaderOptions {\n rootDir: string\n isServer: boolean\n compilerType: CompilerNameValues\n pagesDir?: string\n appDir?: string\n hasReactRefresh: boolean\n optimizeServerReact?: boolean\n nextConfig: NextConfig\n jsConfig: any\n supportedBrowsers: string[] | undefined\n swcCacheDir: string\n serverComponents?: boolean\n serverReferenceHashSalt: string\n bundleLayer?: WebpackLayerName\n esm?: boolean\n transpilePackages?: string[]\n}\n\n// these are exact code conditions checked\n// for to force transpiling a `node_module`\nconst FORCE_TRANSPILE_CONDITIONS =\n /next\\/font|next\\/dynamic|use server|use client|use cache/\n// same as above, but including `import(...)`.\n// (note the optional whitespace: `import (...)` is also syntactically valid)\nconst FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT = new RegExp(\n String.raw`(?:${FORCE_TRANSPILE_CONDITIONS.source})|import\\s*\\(`\n)\n\nasync function loaderTransform(\n this: LoaderContext<SWCLoaderOptions> & TelemetryLoaderContext,\n source?: string,\n inputSourceMap?: any\n) {\n // Make the loader async\n const filename = this.resourcePath\n\n // Ensure `.d.ts` are not processed.\n if (filename.endsWith('.d.ts')) {\n return [source, inputSourceMap]\n }\n\n let loaderOptions: SWCLoaderOptions = this.getOptions() || {}\n const shouldMaybeExclude = maybeExclude(\n filename,\n loaderOptions.transpilePackages || []\n )\n\n const trackDynamicImports = shouldTrackDynamicImports(loaderOptions)\n\n if (shouldMaybeExclude) {\n if (!source) {\n throw new Error(`Invariant might be excluded but missing source`)\n }\n\n const forceTranspileConditions = trackDynamicImports\n ? FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT\n : FORCE_TRANSPILE_CONDITIONS\n\n if (!forceTranspileConditions.test(source)) {\n return [source, inputSourceMap]\n }\n }\n\n const {\n isServer,\n rootDir,\n pagesDir,\n appDir,\n hasReactRefresh,\n nextConfig,\n jsConfig,\n supportedBrowsers,\n swcCacheDir,\n serverComponents,\n serverReferenceHashSalt,\n bundleLayer,\n esm,\n } = loaderOptions\n const isPageFile = pagesDir ? filename.startsWith(pagesDir) : false\n const relativeFilePathFromRoot = path.relative(rootDir, filename)\n\n const swcOptions = getLoaderSWCOptions({\n pagesDir,\n appDir,\n filename,\n isServer,\n isPageFile,\n development:\n this.mode === 'development' ||\n !!nextConfig.experimental?.allowDevelopmentBuild,\n isCacheComponents: nextConfig.cacheComponents,\n hasReactRefresh,\n modularizeImports: nextConfig?.modularizeImports,\n optimizePackageImports: nextConfig?.experimental?.optimizePackageImports,\n swcPlugins: nextConfig?.experimental?.swcPlugins,\n compilerOptions: nextConfig?.compiler,\n optimizeServerReact: nextConfig?.experimental?.optimizeServerReact,\n jsConfig,\n supportedBrowsers,\n swcCacheDir,\n relativeFilePathFromRoot,\n serverComponents,\n serverReferenceHashSalt,\n bundleLayer,\n esm,\n cacheHandlers: nextConfig.cacheHandlers,\n useCacheEnabled: nextConfig.experimental?.useCache,\n trackDynamicImports,\n })\n\n const programmaticOptions = {\n ...swcOptions,\n filename,\n inputSourceMap: inputSourceMap ? JSON.stringify(inputSourceMap) : undefined,\n\n // Set the default sourcemap behavior based on Webpack's mapping flag,\n sourceMaps: this.sourceMap,\n inlineSourcesContent: this.sourceMap,\n\n // Ensure that Webpack will get a full absolute path in the sourcemap\n // so that it can properly map the module back to its internal cached\n // modules.\n sourceFileName: filename,\n }\n\n if (!programmaticOptions.inputSourceMap) {\n delete programmaticOptions.inputSourceMap\n }\n\n // auto detect development mode\n if (\n this.mode &&\n programmaticOptions.jsc &&\n programmaticOptions.jsc.transform &&\n programmaticOptions.jsc.transform.react &&\n !Object.prototype.hasOwnProperty.call(\n programmaticOptions.jsc.transform.react,\n 'development'\n )\n ) {\n programmaticOptions.jsc.transform.react.development =\n this.mode === 'development'\n }\n\n return transform(source as any, programmaticOptions).then(\n (\n output: {\n code: string\n map?: string\n } & SwcTransformTelemetryOutput\n ) => {\n updateTelemetryLoaderCtxFromTransformOutput(this, output)\n return [output.code, output.map ? JSON.parse(output.map) : undefined]\n }\n )\n}\n\nfunction shouldTrackDynamicImports(loaderOptions: SWCLoaderOptions): boolean {\n // we only need to track `import()` 1. in cacheComponents, 2. on the server (RSC and SSR)\n // (Note: logic duplicated in crates/next-core/src/next_server/transforms.rs)\n const { nextConfig, bundleLayer, compilerType } = loaderOptions\n return (\n !!nextConfig.cacheComponents &&\n // NOTE: `server` means nodejs. `cacheComponents` is not supported in the edge runtime, so we want to exclude it.\n // (also, the code generated by the dynamic imports transform relies on `CacheSignal`, which uses nodejs-specific APIs)\n compilerType === COMPILER_NAMES.server &&\n (bundleLayer === WEBPACK_LAYERS.reactServerComponents ||\n bundleLayer === WEBPACK_LAYERS.serverSideRendering)\n )\n}\n\nconst EXCLUDED_PATHS =\n /[\\\\/](cache[\\\\/][^\\\\/]+\\.zip[\\\\/]node_modules|__virtual__)[\\\\/]/g\n\nexport function pitch(this: any) {\n const callback = this.async()\n let loaderOptions: SWCLoaderOptions = this.getOptions() || {}\n\n const shouldMaybeExclude = maybeExclude(\n this.resourcePath,\n loaderOptions.transpilePackages || []\n )\n\n ;(async () => {\n if (\n // if it might be excluded/no-op we can't use pitch loader\n !shouldMaybeExclude &&\n // TODO: investigate swc file reading in PnP mode?\n !process.versions.pnp &&\n !EXCLUDED_PATHS.test(this.resourcePath) &&\n this.loaders.length - 1 === this.loaderIndex &&\n isAbsolute(this.resourcePath) &&\n !(await isWasm())\n ) {\n this.addDependency(this.resourcePath)\n return loaderTransform.call(this)\n }\n })().then((r) => {\n if (r) return callback(null, ...r)\n callback()\n }, callback)\n}\n\nexport default function swcLoader(\n this: any,\n inputSource: string,\n inputSourceMap: any\n) {\n const callback = this.async()\n loaderTransform.call(this, inputSource, inputSourceMap).then(\n ([transformedSource, outputSourceMap]: any) => {\n callback(null, transformedSource, outputSourceMap || inputSourceMap)\n },\n (err: Error) => {\n callback(err)\n }\n )\n}\n\n// accept Buffers instead of strings\nexport const raw = true\n"],"names":["swcLoader","pitch","raw","maybeExclude","excludePath","transpilePackages","babelIncludeRegexes","some","r","test","shouldBeBundled","isResourceInPackages","includes","FORCE_TRANSPILE_CONDITIONS","FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT","RegExp","String","source","loaderTransform","inputSourceMap","nextConfig","filename","resourcePath","endsWith","loaderOptions","getOptions","shouldMaybeExclude","trackDynamicImports","shouldTrackDynamicImports","Error","forceTranspileConditions","isServer","rootDir","pagesDir","appDir","hasReactRefresh","jsConfig","supportedBrowsers","swcCacheDir","serverComponents","serverReferenceHashSalt","bundleLayer","esm","isPageFile","startsWith","relativeFilePathFromRoot","path","relative","swcOptions","getLoaderSWCOptions","development","mode","experimental","allowDevelopmentBuild","isCacheComponents","cacheComponents","modularizeImports","optimizePackageImports","swcPlugins","compilerOptions","compiler","optimizeServerReact","cacheHandlers","useCacheEnabled","useCache","programmaticOptions","JSON","stringify","undefined","sourceMaps","sourceMap","inlineSourcesContent","sourceFileName","jsc","transform","react","Object","prototype","hasOwnProperty","call","then","output","updateTelemetryLoaderCtxFromTransformOutput","code","map","parse","compilerType","COMPILER_NAMES","server","WEBPACK_LAYERS","reactServerComponents","serverSideRendering","EXCLUDED_PATHS","callback","async","process","versions","pnp","loaders","length","loaderIndex","isAbsolute","isWasm","addDependency","inputSource","transformedSource","outputSourceMap","err"],"mappings":"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","ignoreList":[0]}
|
|
1
|
+
{"version":3,"sources":["../../../../src/build/webpack/loaders/next-swc-loader.ts"],"sourcesContent":["/*\nCopyright (c) 2017 The swc Project Developers\n\nPermission is hereby granted, free of charge, to any\nperson obtaining a copy of this software and associated\ndocumentation files (the \"Software\"), to deal in the\nSoftware without restriction, including without\nlimitation the rights to use, copy, modify, merge,\npublish, distribute, sublicense, and/or sell copies of\nthe Software, and to permit persons to whom the Software\nis furnished to do so, subject to the following\nconditions:\n\nThe above copyright notice and this permission notice\nshall be included in all copies or substantial portions\nof the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF\nANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED\nTO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\nPARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT\nSHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION\nOF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR\nIN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\nDEALINGS IN THE SOFTWARE.\n*/\n\nimport type { NextConfig } from '../../../types'\nimport { type WebpackLayerName, WEBPACK_LAYERS } from '../../../lib/constants'\nimport { getBindingsSync, transform } from '../../swc'\nimport { installBindings } from '../../swc/install-bindings'\nimport { getLoaderSWCOptions } from '../../swc/options'\nimport path, { isAbsolute } from 'path'\nimport { babelIncludeRegexes } from '../../webpack-config'\nimport { isResourceInPackages } from '../../handle-externals'\nimport type { TelemetryLoaderContext } from '../plugins/telemetry-plugin/telemetry-plugin'\nimport {\n updateTelemetryLoaderCtxFromTransformOutput,\n type SwcTransformTelemetryOutput,\n} from '../plugins/telemetry-plugin/update-telemetry-loader-context-from-swc'\nimport type { LoaderContext } from 'webpack'\nimport {\n COMPILER_NAMES,\n type CompilerNameValues,\n} from '../../../shared/lib/constants'\n\nconst maybeExclude = (\n excludePath: string,\n transpilePackages: string[]\n): boolean => {\n if (babelIncludeRegexes.some((r) => r.test(excludePath))) {\n return false\n }\n\n const shouldBeBundled = isResourceInPackages(excludePath, transpilePackages)\n if (shouldBeBundled) return false\n\n return excludePath.includes('node_modules')\n}\n\nexport interface SWCLoaderOptions {\n rootDir: string\n isServer: boolean\n compilerType: CompilerNameValues\n pagesDir?: string\n appDir?: string\n hasReactRefresh: boolean\n optimizeServerReact?: boolean\n nextConfig: NextConfig\n jsConfig: any\n supportedBrowsers: string[] | undefined\n swcCacheDir: string\n serverComponents?: boolean\n serverReferenceHashSalt: string\n bundleLayer?: WebpackLayerName\n esm?: boolean\n transpilePackages?: string[]\n}\n\n// these are exact code conditions checked\n// for to force transpiling a `node_module`\nconst FORCE_TRANSPILE_CONDITIONS =\n /next\\/font|next\\/dynamic|use server|use client|use cache/\n// same as above, but including `import(...)`.\n// (note the optional whitespace: `import (...)` is also syntactically valid)\nconst FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT = new RegExp(\n String.raw`(?:${FORCE_TRANSPILE_CONDITIONS.source})|import\\s*\\(`\n)\n\nasync function loaderTransform(\n this: LoaderContext<SWCLoaderOptions> & TelemetryLoaderContext,\n source?: string,\n inputSourceMap?: any\n) {\n // Make the loader async\n const filename = this.resourcePath\n\n // Ensure `.d.ts` are not processed.\n if (filename.endsWith('.d.ts')) {\n return [source, inputSourceMap]\n }\n\n let loaderOptions: SWCLoaderOptions = this.getOptions() || {}\n const shouldMaybeExclude = maybeExclude(\n filename,\n loaderOptions.transpilePackages || []\n )\n\n const trackDynamicImports = shouldTrackDynamicImports(loaderOptions)\n\n if (shouldMaybeExclude) {\n if (!source) {\n throw new Error(`Invariant might be excluded but missing source`)\n }\n\n const forceTranspileConditions = trackDynamicImports\n ? FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT\n : FORCE_TRANSPILE_CONDITIONS\n\n if (!forceTranspileConditions.test(source)) {\n return [source, inputSourceMap]\n }\n }\n\n const {\n isServer,\n rootDir,\n pagesDir,\n appDir,\n hasReactRefresh,\n nextConfig,\n jsConfig,\n supportedBrowsers,\n swcCacheDir,\n serverComponents,\n serverReferenceHashSalt,\n bundleLayer,\n esm,\n } = loaderOptions\n const isPageFile = pagesDir ? filename.startsWith(pagesDir) : false\n const relativeFilePathFromRoot = path.relative(rootDir, filename)\n\n const swcOptions = getLoaderSWCOptions({\n pagesDir,\n appDir,\n filename,\n isServer,\n isPageFile,\n development:\n this.mode === 'development' ||\n !!nextConfig.experimental?.allowDevelopmentBuild,\n isCacheComponents: nextConfig.cacheComponents,\n hasReactRefresh,\n modularizeImports: nextConfig?.modularizeImports,\n optimizePackageImports: nextConfig?.experimental?.optimizePackageImports,\n swcPlugins: nextConfig?.experimental?.swcPlugins,\n compilerOptions: nextConfig?.compiler,\n optimizeServerReact: nextConfig?.experimental?.optimizeServerReact,\n jsConfig,\n supportedBrowsers,\n swcCacheDir,\n relativeFilePathFromRoot,\n serverComponents,\n serverReferenceHashSalt,\n bundleLayer,\n esm,\n cacheHandlers: nextConfig.cacheHandlers,\n useCacheEnabled: nextConfig.experimental?.useCache,\n trackDynamicImports,\n })\n\n const programmaticOptions = {\n ...swcOptions,\n filename,\n inputSourceMap: inputSourceMap ? JSON.stringify(inputSourceMap) : undefined,\n\n // Set the default sourcemap behavior based on Webpack's mapping flag,\n sourceMaps: this.sourceMap,\n inlineSourcesContent: this.sourceMap,\n\n // Ensure that Webpack will get a full absolute path in the sourcemap\n // so that it can properly map the module back to its internal cached\n // modules.\n sourceFileName: filename,\n }\n\n if (!programmaticOptions.inputSourceMap) {\n delete programmaticOptions.inputSourceMap\n }\n\n // auto detect development mode\n if (\n this.mode &&\n programmaticOptions.jsc &&\n programmaticOptions.jsc.transform &&\n programmaticOptions.jsc.transform.react &&\n !Object.prototype.hasOwnProperty.call(\n programmaticOptions.jsc.transform.react,\n 'development'\n )\n ) {\n programmaticOptions.jsc.transform.react.development =\n this.mode === 'development'\n }\n\n return transform(source as any, programmaticOptions).then(\n (\n output: {\n code: string\n map?: string\n } & SwcTransformTelemetryOutput\n ) => {\n updateTelemetryLoaderCtxFromTransformOutput(this, output)\n return [output.code, output.map ? JSON.parse(output.map) : undefined]\n }\n )\n}\n\nfunction shouldTrackDynamicImports(loaderOptions: SWCLoaderOptions): boolean {\n // we only need to track `import()` 1. in cacheComponents, 2. on the server (RSC and SSR)\n // (Note: logic duplicated in crates/next-core/src/next_server/transforms.rs)\n const { nextConfig, bundleLayer, compilerType } = loaderOptions\n return (\n !!nextConfig.cacheComponents &&\n // NOTE: `server` means nodejs. `cacheComponents` is not supported in the edge runtime, so we want to exclude it.\n // (also, the code generated by the dynamic imports transform relies on `CacheSignal`, which uses nodejs-specific APIs)\n compilerType === COMPILER_NAMES.server &&\n (bundleLayer === WEBPACK_LAYERS.reactServerComponents ||\n bundleLayer === WEBPACK_LAYERS.serverSideRendering)\n )\n}\n\nconst EXCLUDED_PATHS =\n /[\\\\/](cache[\\\\/][^\\\\/]+\\.zip[\\\\/]node_modules|__virtual__)[\\\\/]/g\n\nexport function pitch(this: any) {\n const callback = this.async()\n let loaderOptions: SWCLoaderOptions = this.getOptions() || {}\n\n const shouldMaybeExclude = maybeExclude(\n this.resourcePath,\n loaderOptions.transpilePackages || []\n )\n\n ;(async () => {\n if (\n // if it might be excluded/no-op we can't use pitch loader\n !shouldMaybeExclude &&\n // TODO: investigate swc file reading in PnP mode?\n !process.versions.pnp &&\n !EXCLUDED_PATHS.test(this.resourcePath) &&\n this.loaders.length - 1 === this.loaderIndex &&\n isAbsolute(this.resourcePath) &&\n !getBindingsSync().isWasm\n ) {\n this.addDependency(this.resourcePath)\n return loaderTransform.call(this)\n }\n })().then((r) => {\n if (r) return callback(null, ...r)\n callback()\n }, callback)\n}\n\nexport default function swcLoader(\n this: any,\n inputSource: string,\n inputSourceMap: any\n) {\n const callback = this.async()\n // Install bindings early so they are definitely available to the loader.\n // When run by webpack in next this is already done with correct configuration so this is a no-op.\n // In turbopack loaders are run in a subprocess so it may or may not be done.\n installBindings().then(() =>\n loaderTransform.call(this, inputSource, inputSourceMap).then(\n ([transformedSource, outputSourceMap]: any) => {\n callback(null, transformedSource, outputSourceMap || inputSourceMap)\n },\n (err: Error) => {\n callback(err)\n }\n )\n )\n}\n\n// accept Buffers instead of strings\nexport const raw = true\n"],"names":["swcLoader","pitch","raw","maybeExclude","excludePath","transpilePackages","babelIncludeRegexes","some","r","test","shouldBeBundled","isResourceInPackages","includes","FORCE_TRANSPILE_CONDITIONS","FORCE_TRANSPILE_CONDITIONS_WITH_IMPORT","RegExp","String","source","loaderTransform","inputSourceMap","nextConfig","filename","resourcePath","endsWith","loaderOptions","getOptions","shouldMaybeExclude","trackDynamicImports","shouldTrackDynamicImports","Error","forceTranspileConditions","isServer","rootDir","pagesDir","appDir","hasReactRefresh","jsConfig","supportedBrowsers","swcCacheDir","serverComponents","serverReferenceHashSalt","bundleLayer","esm","isPageFile","startsWith","relativeFilePathFromRoot","path","relative","swcOptions","getLoaderSWCOptions","development","mode","experimental","allowDevelopmentBuild","isCacheComponents","cacheComponents","modularizeImports","optimizePackageImports","swcPlugins","compilerOptions","compiler","optimizeServerReact","cacheHandlers","useCacheEnabled","useCache","programmaticOptions","JSON","stringify","undefined","sourceMaps","sourceMap","inlineSourcesContent","sourceFileName","jsc","transform","react","Object","prototype","hasOwnProperty","call","then","output","updateTelemetryLoaderCtxFromTransformOutput","code","map","parse","compilerType","COMPILER_NAMES","server","WEBPACK_LAYERS","reactServerComponents","serverSideRendering","EXCLUDED_PATHS","callback","async","process","versions","pnp","loaders","length","loaderIndex","isAbsolute","getBindingsSync","isWasm","addDependency","inputSource","installBindings","transformedSource","outputSourceMap","err"],"mappings":"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","ignoreList":[0]}
|
|
@@ -38,6 +38,7 @@ const _nexttraceentrypointsplugin = require("../webpack/plugins/next-trace-entry
|
|
|
38
38
|
const _debug = /*#__PURE__*/ _interop_require_default(require("next/dist/compiled/debug"));
|
|
39
39
|
const _storage = require("../../telemetry/storage");
|
|
40
40
|
const _durationtostring = require("../duration-to-string");
|
|
41
|
+
const _installbindings = require("../swc/install-bindings");
|
|
41
42
|
function _interop_require_default(obj) {
|
|
42
43
|
return obj && obj.__esModule ? obj : {
|
|
43
44
|
default: obj
|
|
@@ -334,6 +335,7 @@ async function webpackBuildImpl(compilerName) {
|
|
|
334
335
|
}
|
|
335
336
|
}
|
|
336
337
|
async function workerMain(workerData) {
|
|
338
|
+
var _config_experimental;
|
|
337
339
|
// Clone the telemetry for worker
|
|
338
340
|
const telemetry = new _storage.Telemetry({
|
|
339
341
|
distDir: workerData.buildContext.config.distDir
|
|
@@ -346,10 +348,11 @@ async function workerMain(workerData) {
|
|
|
346
348
|
// Resume plugin state
|
|
347
349
|
(0, _buildcontext.resumePluginState)(_buildcontext.NextBuildContext.pluginState);
|
|
348
350
|
/// load the config because it's not serializable
|
|
349
|
-
_buildcontext.NextBuildContext.config = await (0, _config.default)(_constants.PHASE_PRODUCTION_BUILD, _buildcontext.NextBuildContext.dir, {
|
|
351
|
+
const config = _buildcontext.NextBuildContext.config = await (0, _config.default)(_constants.PHASE_PRODUCTION_BUILD, _buildcontext.NextBuildContext.dir, {
|
|
350
352
|
debugPrerender: _buildcontext.NextBuildContext.debugPrerender,
|
|
351
353
|
reactProductionProfiling: _buildcontext.NextBuildContext.reactProductionProfiling
|
|
352
354
|
});
|
|
355
|
+
await (0, _installbindings.installBindings)((_config_experimental = config.experimental) == null ? void 0 : _config_experimental.useWasmBinary);
|
|
353
356
|
_buildcontext.NextBuildContext.nextBuildSpan = (0, _trace.trace)(`worker-main-${workerData.compilerName}`);
|
|
354
357
|
const result = await webpackBuildImpl(workerData.compilerName);
|
|
355
358
|
const { entriesTrace, chunksTrace } = result.buildTraceContext ?? {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/build/webpack-build/impl.ts"],"sourcesContent":["import type { webpack } from 'next/dist/compiled/webpack/webpack'\nimport { stringBufferUtils } from 'next/dist/compiled/webpack-sources3'\nimport { red } from '../../lib/picocolors'\nimport formatWebpackMessages from '../../shared/lib/format-webpack-messages'\nimport { nonNullable } from '../../lib/non-nullable'\nimport type { COMPILER_INDEXES } from '../../shared/lib/constants'\nimport {\n COMPILER_NAMES,\n CLIENT_STATIC_FILES_RUNTIME_MAIN_APP,\n APP_CLIENT_INTERNALS,\n PHASE_PRODUCTION_BUILD,\n} from '../../shared/lib/constants'\nimport { runCompiler } from '../compiler'\nimport * as Log from '../output/log'\nimport getBaseWebpackConfig, { loadProjectInfo } from '../webpack-config'\nimport type { NextError } from '../../lib/is-error'\nimport {\n TelemetryPlugin,\n type TelemetryPluginState,\n} from '../webpack/plugins/telemetry-plugin/telemetry-plugin'\nimport {\n NextBuildContext,\n resumePluginState,\n getPluginState,\n} from '../build-context'\nimport { createEntrypoints } from '../entries'\nimport loadConfig from '../../server/config'\nimport {\n getTraceEvents,\n initializeTraceState,\n setGlobal,\n trace,\n type TraceEvent,\n type TraceState,\n} from '../../trace'\nimport { WEBPACK_LAYERS } from '../../lib/constants'\nimport { TraceEntryPointsPlugin } from '../webpack/plugins/next-trace-entrypoints-plugin'\nimport type { BuildTraceContext } from '../webpack/plugins/next-trace-entrypoints-plugin'\nimport type { UnwrapPromise } from '../../lib/coalesced-function'\n\nimport origDebug from 'next/dist/compiled/debug'\nimport { Telemetry } from '../../telemetry/storage'\nimport { durationToString, hrtimeToSeconds } from '../duration-to-string'\n\nconst debug = origDebug('next:build:webpack-build')\n\ntype CompilerResult = {\n errors: webpack.StatsError[]\n warnings: webpack.StatsError[]\n stats: (webpack.Stats | undefined)[]\n}\n\ntype SingleCompilerResult = {\n errors: webpack.StatsError[]\n warnings: webpack.StatsError[]\n stats: webpack.Stats | undefined\n}\n\nfunction isTelemetryPlugin(plugin: unknown): plugin is TelemetryPlugin {\n return plugin instanceof TelemetryPlugin\n}\n\nfunction isTraceEntryPointsPlugin(\n plugin: unknown\n): plugin is TraceEntryPointsPlugin {\n return plugin instanceof TraceEntryPointsPlugin\n}\n\nexport async function webpackBuildImpl(\n compilerName: keyof typeof COMPILER_INDEXES | null\n): Promise<{\n duration: number\n pluginState: any\n buildTraceContext?: BuildTraceContext\n telemetryState?: TelemetryPluginState\n}> {\n let result: CompilerResult | null = {\n warnings: [],\n errors: [],\n stats: [],\n }\n let webpackBuildStart\n const nextBuildSpan = NextBuildContext.nextBuildSpan!\n const dir = NextBuildContext.dir!\n const config = NextBuildContext.config!\n process.env.NEXT_COMPILER_NAME = compilerName || 'server'\n\n const runWebpackSpan = nextBuildSpan.traceChild('run-webpack-compiler')\n const entrypoints = await nextBuildSpan\n .traceChild('create-entrypoints')\n .traceAsyncFn(() =>\n createEntrypoints({\n buildId: NextBuildContext.buildId!,\n config: config,\n envFiles: NextBuildContext.loadedEnvFiles!,\n isDev: false,\n rootDir: dir,\n pageExtensions: config.pageExtensions!,\n pagesDir: NextBuildContext.pagesDir!,\n appDir: NextBuildContext.appDir!,\n pages: NextBuildContext.mappedPages!,\n appPaths: NextBuildContext.mappedAppPages!,\n previewMode: NextBuildContext.previewProps!,\n rootPaths: NextBuildContext.mappedRootPaths!,\n hasInstrumentationHook: NextBuildContext.hasInstrumentationHook!,\n })\n )\n\n const commonWebpackOptions = {\n isServer: false,\n isCompileMode: NextBuildContext.isCompileMode,\n buildId: NextBuildContext.buildId!,\n encryptionKey: NextBuildContext.encryptionKey!,\n config: config,\n appDir: NextBuildContext.appDir!,\n pagesDir: NextBuildContext.pagesDir!,\n rewrites: NextBuildContext.rewrites!,\n originalRewrites: NextBuildContext.originalRewrites,\n originalRedirects: NextBuildContext.originalRedirects,\n reactProductionProfiling: NextBuildContext.reactProductionProfiling!,\n noMangling: NextBuildContext.noMangling!,\n clientRouterFilters: NextBuildContext.clientRouterFilters!,\n previewProps: NextBuildContext.previewProps!,\n allowedRevalidateHeaderKeys: NextBuildContext.allowedRevalidateHeaderKeys!,\n fetchCacheKeyPrefix: NextBuildContext.fetchCacheKeyPrefix!,\n }\n\n const configs = await runWebpackSpan\n .traceChild('generate-webpack-config')\n .traceAsyncFn(async () => {\n const info = await loadProjectInfo({\n dir,\n config: commonWebpackOptions.config,\n dev: false,\n })\n return Promise.all([\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n middlewareMatchers: entrypoints.middlewareMatchers,\n runWebpackSpan,\n compilerType: COMPILER_NAMES.client,\n entrypoints: entrypoints.client,\n ...info,\n }),\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n runWebpackSpan,\n middlewareMatchers: entrypoints.middlewareMatchers,\n compilerType: COMPILER_NAMES.server,\n entrypoints: entrypoints.server,\n ...info,\n }),\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n runWebpackSpan,\n middlewareMatchers: entrypoints.middlewareMatchers,\n compilerType: COMPILER_NAMES.edgeServer,\n entrypoints: entrypoints.edgeServer,\n ...info,\n }),\n ])\n })\n\n const clientConfig = configs[0]\n const serverConfig = configs[1]\n const edgeConfig = configs[2]\n\n if (\n clientConfig.optimization &&\n (clientConfig.optimization.minimize !== true ||\n (clientConfig.optimization.minimizer &&\n clientConfig.optimization.minimizer.length === 0))\n ) {\n Log.warn(\n `Production code optimization has been disabled in your project. Read more: https://nextjs.org/docs/messages/minification-disabled`\n )\n }\n\n webpackBuildStart = process.hrtime()\n\n debug(`starting compiler`, compilerName)\n // We run client and server compilation separately to optimize for memory usage\n await runWebpackSpan.traceAsyncFn(async () => {\n if (config.experimental.webpackMemoryOptimizations) {\n stringBufferUtils.disableDualStringBufferCaching()\n stringBufferUtils.enterStringInterningRange()\n }\n\n // Run the server compilers first and then the client\n // compiler to track the boundary of server/client components.\n let clientResult: SingleCompilerResult | null = null\n\n // During the server compilations, entries of client components will be\n // injected to this set and then will be consumed by the client compiler.\n let serverResult: UnwrapPromise<ReturnType<typeof runCompiler>>[0] | null =\n null\n let edgeServerResult:\n | UnwrapPromise<ReturnType<typeof runCompiler>>[0]\n | null = null\n\n let inputFileSystem: webpack.Compiler['inputFileSystem'] | undefined\n\n if (!compilerName || compilerName === 'server') {\n debug('starting server compiler')\n const start = Date.now()\n ;[serverResult, inputFileSystem] = await runCompiler(serverConfig, {\n runWebpackSpan,\n inputFileSystem,\n })\n debug(`server compiler finished ${Date.now() - start}ms`)\n }\n\n if (!compilerName || compilerName === 'edge-server') {\n debug('starting edge-server compiler')\n const start = Date.now()\n ;[edgeServerResult, inputFileSystem] = edgeConfig\n ? await runCompiler(edgeConfig, { runWebpackSpan, inputFileSystem })\n : [null]\n debug(`edge-server compiler finished ${Date.now() - start}ms`)\n }\n\n // Only continue if there were no errors\n if (!serverResult?.errors.length && !edgeServerResult?.errors.length) {\n const pluginState = getPluginState()\n for (const key in pluginState.injectedClientEntries) {\n const value = pluginState.injectedClientEntries[key]\n const clientEntry = clientConfig.entry as webpack.EntryObject\n if (key === APP_CLIENT_INTERNALS) {\n clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] = {\n import: [\n // TODO-APP: cast clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] to type EntryDescription once it's available from webpack\n // @ts-expect-error clientEntry['main-app'] is type EntryDescription { import: ... }\n ...clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP].import,\n value,\n ],\n layer: WEBPACK_LAYERS.appPagesBrowser,\n }\n } else {\n clientEntry[key] = {\n dependOn: [CLIENT_STATIC_FILES_RUNTIME_MAIN_APP],\n import: value,\n layer: WEBPACK_LAYERS.appPagesBrowser,\n }\n }\n }\n\n if (!compilerName || compilerName === 'client') {\n debug('starting client compiler')\n const start = Date.now()\n ;[clientResult, inputFileSystem] = await runCompiler(clientConfig, {\n runWebpackSpan,\n inputFileSystem,\n })\n debug(`client compiler finished ${Date.now() - start}ms`)\n }\n }\n\n if (config.experimental.webpackMemoryOptimizations) {\n stringBufferUtils.exitStringInterningRange()\n }\n inputFileSystem?.purge?.()\n\n result = {\n warnings: [\n ...(clientResult?.warnings ?? []),\n ...(serverResult?.warnings ?? []),\n ...(edgeServerResult?.warnings ?? []),\n ].filter(nonNullable),\n errors: [\n ...(clientResult?.errors ?? []),\n ...(serverResult?.errors ?? []),\n ...(edgeServerResult?.errors ?? []),\n ].filter(nonNullable),\n stats: [\n clientResult?.stats,\n serverResult?.stats,\n edgeServerResult?.stats,\n ],\n }\n })\n result = nextBuildSpan\n .traceChild('format-webpack-messages')\n .traceFn(() => formatWebpackMessages(result, true)) as CompilerResult\n\n const telemetryPlugin = (clientConfig as webpack.Configuration).plugins?.find(\n isTelemetryPlugin\n )\n\n const traceEntryPointsPlugin = (\n serverConfig as webpack.Configuration\n ).plugins?.find(isTraceEntryPointsPlugin)\n\n const webpackBuildEnd = process.hrtime(webpackBuildStart)\n\n if (result.errors.length > 0) {\n // Only keep the first few errors. Others are often indicative\n // of the same problem, but confuse the reader with noise.\n if (result.errors.length > 5) {\n result.errors.length = 5\n }\n let error = result.errors.filter(Boolean).join('\\n\\n')\n\n console.error(red('Failed to compile.\\n'))\n\n if (\n error.indexOf('private-next-pages') > -1 &&\n error.indexOf('does not contain a default export') > -1\n ) {\n const page_name_regex = /'private-next-pages\\/(?<page_name>[^']*)'/\n const parsed = page_name_regex.exec(error)\n const page_name = parsed && parsed.groups && parsed.groups.page_name\n throw new Error(\n `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.`\n )\n }\n\n console.error(error)\n console.error()\n\n if (\n error.indexOf('private-next-pages') > -1 ||\n error.indexOf('__next_polyfill__') > -1\n ) {\n const err = new Error(\n 'webpack config.resolve.alias was incorrectly overridden. https://nextjs.org/docs/messages/invalid-resolve-alias'\n ) as NextError\n err.code = 'INVALID_RESOLVE_ALIAS'\n throw err\n }\n const err = new Error(\n `Build failed because of ${process.env.NEXT_RSPACK ? 'Rspack' : 'webpack'} errors`\n ) as NextError\n err.code = 'WEBPACK_ERRORS'\n throw err\n } else {\n const duration = hrtimeToSeconds(webpackBuildEnd)\n const durationString = durationToString(duration)\n\n if (result.warnings.length > 0) {\n Log.warn(`Compiled with warnings in ${durationString}\\n`)\n console.warn(result.warnings.filter(Boolean).join('\\n\\n'))\n console.warn()\n } else if (!compilerName) {\n Log.event(`Compiled successfully in ${durationString}`)\n }\n\n return {\n duration,\n buildTraceContext: traceEntryPointsPlugin?.buildTraceContext,\n pluginState: getPluginState(),\n telemetryState: {\n usages: telemetryPlugin?.usages() || [],\n packagesUsedInServerSideProps:\n telemetryPlugin?.packagesUsedInServerSideProps() || [],\n useCacheTracker: telemetryPlugin?.getUseCacheTracker() || {},\n },\n }\n }\n}\n\n// the main function when this file is run as a worker\nexport async function workerMain(workerData: {\n compilerName: keyof typeof COMPILER_INDEXES\n buildContext: typeof NextBuildContext\n traceState: TraceState\n}): Promise<\n Awaited<ReturnType<typeof webpackBuildImpl>> & {\n debugTraceEvents: TraceEvent[]\n }\n> {\n // Clone the telemetry for worker\n const telemetry = new Telemetry({\n distDir: workerData.buildContext.config!.distDir,\n })\n setGlobal('telemetry', telemetry)\n // setup new build context from the serialized data passed from the parent\n Object.assign(NextBuildContext, workerData.buildContext)\n\n // Initialize tracer state from the parent\n initializeTraceState(workerData.traceState)\n\n // Resume plugin state\n resumePluginState(NextBuildContext.pluginState)\n\n /// load the config because it's not serializable\n NextBuildContext.config = await loadConfig(\n PHASE_PRODUCTION_BUILD,\n NextBuildContext.dir!,\n {\n debugPrerender: NextBuildContext.debugPrerender,\n reactProductionProfiling: NextBuildContext.reactProductionProfiling,\n }\n )\n NextBuildContext.nextBuildSpan = trace(\n `worker-main-${workerData.compilerName}`\n )\n\n const result = await webpackBuildImpl(workerData.compilerName)\n const { entriesTrace, chunksTrace } = result.buildTraceContext ?? {}\n if (entriesTrace) {\n const { entryNameMap, depModArray } = entriesTrace\n if (depModArray) {\n result.buildTraceContext!.entriesTrace!.depModArray = depModArray\n }\n if (entryNameMap) {\n const entryEntries = entryNameMap\n result.buildTraceContext!.entriesTrace!.entryNameMap = entryEntries\n }\n }\n if (chunksTrace?.entryNameFilesMap) {\n const entryNameFilesMap = chunksTrace.entryNameFilesMap\n result.buildTraceContext!.chunksTrace!.entryNameFilesMap = entryNameFilesMap\n }\n NextBuildContext.nextBuildSpan.stop()\n return { ...result, debugTraceEvents: getTraceEvents() }\n}\n"],"names":["webpackBuildImpl","workerMain","debug","origDebug","isTelemetryPlugin","plugin","TelemetryPlugin","isTraceEntryPointsPlugin","TraceEntryPointsPlugin","compilerName","result","warnings","errors","stats","webpackBuildStart","nextBuildSpan","NextBuildContext","dir","config","process","env","NEXT_COMPILER_NAME","runWebpackSpan","traceChild","entrypoints","traceAsyncFn","createEntrypoints","buildId","envFiles","loadedEnvFiles","isDev","rootDir","pageExtensions","pagesDir","appDir","pages","mappedPages","appPaths","mappedAppPages","previewMode","previewProps","rootPaths","mappedRootPaths","hasInstrumentationHook","commonWebpackOptions","isServer","isCompileMode","encryptionKey","rewrites","originalRewrites","originalRedirects","reactProductionProfiling","noMangling","clientRouterFilters","allowedRevalidateHeaderKeys","fetchCacheKeyPrefix","configs","info","loadProjectInfo","dev","Promise","all","getBaseWebpackConfig","middlewareMatchers","compilerType","COMPILER_NAMES","client","server","edgeServer","clientConfig","serverConfig","edgeConfig","optimization","minimize","minimizer","length","Log","warn","hrtime","inputFileSystem","experimental","webpackMemoryOptimizations","stringBufferUtils","disableDualStringBufferCaching","enterStringInterningRange","clientResult","serverResult","edgeServerResult","start","Date","now","runCompiler","pluginState","getPluginState","key","injectedClientEntries","value","clientEntry","entry","APP_CLIENT_INTERNALS","CLIENT_STATIC_FILES_RUNTIME_MAIN_APP","import","layer","WEBPACK_LAYERS","appPagesBrowser","dependOn","exitStringInterningRange","purge","filter","nonNullable","traceFn","formatWebpackMessages","telemetryPlugin","plugins","find","traceEntryPointsPlugin","webpackBuildEnd","error","Boolean","join","console","red","indexOf","page_name_regex","parsed","exec","page_name","groups","Error","err","code","NEXT_RSPACK","duration","hrtimeToSeconds","durationString","durationToString","event","buildTraceContext","telemetryState","usages","packagesUsedInServerSideProps","useCacheTracker","getUseCacheTracker","workerData","telemetry","Telemetry","distDir","buildContext","setGlobal","Object","assign","initializeTraceState","traceState","resumePluginState","loadConfig","PHASE_PRODUCTION_BUILD","debugPrerender","trace","entriesTrace","chunksTrace","entryNameMap","depModArray","entryEntries","entryNameFilesMap","stop","debugTraceEvents","getTraceEvents"],"mappings":"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","ignoreList":[0]}
|
|
1
|
+
{"version":3,"sources":["../../../src/build/webpack-build/impl.ts"],"sourcesContent":["import type { webpack } from 'next/dist/compiled/webpack/webpack'\nimport { stringBufferUtils } from 'next/dist/compiled/webpack-sources3'\nimport { red } from '../../lib/picocolors'\nimport formatWebpackMessages from '../../shared/lib/format-webpack-messages'\nimport { nonNullable } from '../../lib/non-nullable'\nimport type { COMPILER_INDEXES } from '../../shared/lib/constants'\nimport {\n COMPILER_NAMES,\n CLIENT_STATIC_FILES_RUNTIME_MAIN_APP,\n APP_CLIENT_INTERNALS,\n PHASE_PRODUCTION_BUILD,\n} from '../../shared/lib/constants'\nimport { runCompiler } from '../compiler'\nimport * as Log from '../output/log'\nimport getBaseWebpackConfig, { loadProjectInfo } from '../webpack-config'\nimport type { NextError } from '../../lib/is-error'\nimport {\n TelemetryPlugin,\n type TelemetryPluginState,\n} from '../webpack/plugins/telemetry-plugin/telemetry-plugin'\nimport {\n NextBuildContext,\n resumePluginState,\n getPluginState,\n} from '../build-context'\nimport { createEntrypoints } from '../entries'\nimport loadConfig from '../../server/config'\nimport {\n getTraceEvents,\n initializeTraceState,\n setGlobal,\n trace,\n type TraceEvent,\n type TraceState,\n} from '../../trace'\nimport { WEBPACK_LAYERS } from '../../lib/constants'\nimport { TraceEntryPointsPlugin } from '../webpack/plugins/next-trace-entrypoints-plugin'\nimport type { BuildTraceContext } from '../webpack/plugins/next-trace-entrypoints-plugin'\nimport type { UnwrapPromise } from '../../lib/coalesced-function'\n\nimport origDebug from 'next/dist/compiled/debug'\nimport { Telemetry } from '../../telemetry/storage'\nimport { durationToString, hrtimeToSeconds } from '../duration-to-string'\nimport { installBindings } from '../swc/install-bindings'\n\nconst debug = origDebug('next:build:webpack-build')\n\ntype CompilerResult = {\n errors: webpack.StatsError[]\n warnings: webpack.StatsError[]\n stats: (webpack.Stats | undefined)[]\n}\n\ntype SingleCompilerResult = {\n errors: webpack.StatsError[]\n warnings: webpack.StatsError[]\n stats: webpack.Stats | undefined\n}\n\nfunction isTelemetryPlugin(plugin: unknown): plugin is TelemetryPlugin {\n return plugin instanceof TelemetryPlugin\n}\n\nfunction isTraceEntryPointsPlugin(\n plugin: unknown\n): plugin is TraceEntryPointsPlugin {\n return plugin instanceof TraceEntryPointsPlugin\n}\n\nexport async function webpackBuildImpl(\n compilerName: keyof typeof COMPILER_INDEXES | null\n): Promise<{\n duration: number\n pluginState: any\n buildTraceContext?: BuildTraceContext\n telemetryState?: TelemetryPluginState\n}> {\n let result: CompilerResult | null = {\n warnings: [],\n errors: [],\n stats: [],\n }\n let webpackBuildStart\n const nextBuildSpan = NextBuildContext.nextBuildSpan!\n const dir = NextBuildContext.dir!\n const config = NextBuildContext.config!\n process.env.NEXT_COMPILER_NAME = compilerName || 'server'\n\n const runWebpackSpan = nextBuildSpan.traceChild('run-webpack-compiler')\n const entrypoints = await nextBuildSpan\n .traceChild('create-entrypoints')\n .traceAsyncFn(() =>\n createEntrypoints({\n buildId: NextBuildContext.buildId!,\n config: config,\n envFiles: NextBuildContext.loadedEnvFiles!,\n isDev: false,\n rootDir: dir,\n pageExtensions: config.pageExtensions!,\n pagesDir: NextBuildContext.pagesDir!,\n appDir: NextBuildContext.appDir!,\n pages: NextBuildContext.mappedPages!,\n appPaths: NextBuildContext.mappedAppPages!,\n previewMode: NextBuildContext.previewProps!,\n rootPaths: NextBuildContext.mappedRootPaths!,\n hasInstrumentationHook: NextBuildContext.hasInstrumentationHook!,\n })\n )\n\n const commonWebpackOptions = {\n isServer: false,\n isCompileMode: NextBuildContext.isCompileMode,\n buildId: NextBuildContext.buildId!,\n encryptionKey: NextBuildContext.encryptionKey!,\n config: config,\n appDir: NextBuildContext.appDir!,\n pagesDir: NextBuildContext.pagesDir!,\n rewrites: NextBuildContext.rewrites!,\n originalRewrites: NextBuildContext.originalRewrites,\n originalRedirects: NextBuildContext.originalRedirects,\n reactProductionProfiling: NextBuildContext.reactProductionProfiling!,\n noMangling: NextBuildContext.noMangling!,\n clientRouterFilters: NextBuildContext.clientRouterFilters!,\n previewProps: NextBuildContext.previewProps!,\n allowedRevalidateHeaderKeys: NextBuildContext.allowedRevalidateHeaderKeys!,\n fetchCacheKeyPrefix: NextBuildContext.fetchCacheKeyPrefix!,\n }\n\n const configs = await runWebpackSpan\n .traceChild('generate-webpack-config')\n .traceAsyncFn(async () => {\n const info = await loadProjectInfo({\n dir,\n config: commonWebpackOptions.config,\n dev: false,\n })\n return Promise.all([\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n middlewareMatchers: entrypoints.middlewareMatchers,\n runWebpackSpan,\n compilerType: COMPILER_NAMES.client,\n entrypoints: entrypoints.client,\n ...info,\n }),\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n runWebpackSpan,\n middlewareMatchers: entrypoints.middlewareMatchers,\n compilerType: COMPILER_NAMES.server,\n entrypoints: entrypoints.server,\n ...info,\n }),\n getBaseWebpackConfig(dir, {\n ...commonWebpackOptions,\n runWebpackSpan,\n middlewareMatchers: entrypoints.middlewareMatchers,\n compilerType: COMPILER_NAMES.edgeServer,\n entrypoints: entrypoints.edgeServer,\n ...info,\n }),\n ])\n })\n\n const clientConfig = configs[0]\n const serverConfig = configs[1]\n const edgeConfig = configs[2]\n\n if (\n clientConfig.optimization &&\n (clientConfig.optimization.minimize !== true ||\n (clientConfig.optimization.minimizer &&\n clientConfig.optimization.minimizer.length === 0))\n ) {\n Log.warn(\n `Production code optimization has been disabled in your project. Read more: https://nextjs.org/docs/messages/minification-disabled`\n )\n }\n\n webpackBuildStart = process.hrtime()\n\n debug(`starting compiler`, compilerName)\n // We run client and server compilation separately to optimize for memory usage\n await runWebpackSpan.traceAsyncFn(async () => {\n if (config.experimental.webpackMemoryOptimizations) {\n stringBufferUtils.disableDualStringBufferCaching()\n stringBufferUtils.enterStringInterningRange()\n }\n\n // Run the server compilers first and then the client\n // compiler to track the boundary of server/client components.\n let clientResult: SingleCompilerResult | null = null\n\n // During the server compilations, entries of client components will be\n // injected to this set and then will be consumed by the client compiler.\n let serverResult: UnwrapPromise<ReturnType<typeof runCompiler>>[0] | null =\n null\n let edgeServerResult:\n | UnwrapPromise<ReturnType<typeof runCompiler>>[0]\n | null = null\n\n let inputFileSystem: webpack.Compiler['inputFileSystem'] | undefined\n\n if (!compilerName || compilerName === 'server') {\n debug('starting server compiler')\n const start = Date.now()\n ;[serverResult, inputFileSystem] = await runCompiler(serverConfig, {\n runWebpackSpan,\n inputFileSystem,\n })\n debug(`server compiler finished ${Date.now() - start}ms`)\n }\n\n if (!compilerName || compilerName === 'edge-server') {\n debug('starting edge-server compiler')\n const start = Date.now()\n ;[edgeServerResult, inputFileSystem] = edgeConfig\n ? await runCompiler(edgeConfig, { runWebpackSpan, inputFileSystem })\n : [null]\n debug(`edge-server compiler finished ${Date.now() - start}ms`)\n }\n\n // Only continue if there were no errors\n if (!serverResult?.errors.length && !edgeServerResult?.errors.length) {\n const pluginState = getPluginState()\n for (const key in pluginState.injectedClientEntries) {\n const value = pluginState.injectedClientEntries[key]\n const clientEntry = clientConfig.entry as webpack.EntryObject\n if (key === APP_CLIENT_INTERNALS) {\n clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] = {\n import: [\n // TODO-APP: cast clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP] to type EntryDescription once it's available from webpack\n // @ts-expect-error clientEntry['main-app'] is type EntryDescription { import: ... }\n ...clientEntry[CLIENT_STATIC_FILES_RUNTIME_MAIN_APP].import,\n value,\n ],\n layer: WEBPACK_LAYERS.appPagesBrowser,\n }\n } else {\n clientEntry[key] = {\n dependOn: [CLIENT_STATIC_FILES_RUNTIME_MAIN_APP],\n import: value,\n layer: WEBPACK_LAYERS.appPagesBrowser,\n }\n }\n }\n\n if (!compilerName || compilerName === 'client') {\n debug('starting client compiler')\n const start = Date.now()\n ;[clientResult, inputFileSystem] = await runCompiler(clientConfig, {\n runWebpackSpan,\n inputFileSystem,\n })\n debug(`client compiler finished ${Date.now() - start}ms`)\n }\n }\n\n if (config.experimental.webpackMemoryOptimizations) {\n stringBufferUtils.exitStringInterningRange()\n }\n inputFileSystem?.purge?.()\n\n result = {\n warnings: [\n ...(clientResult?.warnings ?? []),\n ...(serverResult?.warnings ?? []),\n ...(edgeServerResult?.warnings ?? []),\n ].filter(nonNullable),\n errors: [\n ...(clientResult?.errors ?? []),\n ...(serverResult?.errors ?? []),\n ...(edgeServerResult?.errors ?? []),\n ].filter(nonNullable),\n stats: [\n clientResult?.stats,\n serverResult?.stats,\n edgeServerResult?.stats,\n ],\n }\n })\n result = nextBuildSpan\n .traceChild('format-webpack-messages')\n .traceFn(() => formatWebpackMessages(result, true)) as CompilerResult\n\n const telemetryPlugin = (clientConfig as webpack.Configuration).plugins?.find(\n isTelemetryPlugin\n )\n\n const traceEntryPointsPlugin = (\n serverConfig as webpack.Configuration\n ).plugins?.find(isTraceEntryPointsPlugin)\n\n const webpackBuildEnd = process.hrtime(webpackBuildStart)\n\n if (result.errors.length > 0) {\n // Only keep the first few errors. Others are often indicative\n // of the same problem, but confuse the reader with noise.\n if (result.errors.length > 5) {\n result.errors.length = 5\n }\n let error = result.errors.filter(Boolean).join('\\n\\n')\n\n console.error(red('Failed to compile.\\n'))\n\n if (\n error.indexOf('private-next-pages') > -1 &&\n error.indexOf('does not contain a default export') > -1\n ) {\n const page_name_regex = /'private-next-pages\\/(?<page_name>[^']*)'/\n const parsed = page_name_regex.exec(error)\n const page_name = parsed && parsed.groups && parsed.groups.page_name\n throw new Error(\n `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.`\n )\n }\n\n console.error(error)\n console.error()\n\n if (\n error.indexOf('private-next-pages') > -1 ||\n error.indexOf('__next_polyfill__') > -1\n ) {\n const err = new Error(\n 'webpack config.resolve.alias was incorrectly overridden. https://nextjs.org/docs/messages/invalid-resolve-alias'\n ) as NextError\n err.code = 'INVALID_RESOLVE_ALIAS'\n throw err\n }\n const err = new Error(\n `Build failed because of ${process.env.NEXT_RSPACK ? 'Rspack' : 'webpack'} errors`\n ) as NextError\n err.code = 'WEBPACK_ERRORS'\n throw err\n } else {\n const duration = hrtimeToSeconds(webpackBuildEnd)\n const durationString = durationToString(duration)\n\n if (result.warnings.length > 0) {\n Log.warn(`Compiled with warnings in ${durationString}\\n`)\n console.warn(result.warnings.filter(Boolean).join('\\n\\n'))\n console.warn()\n } else if (!compilerName) {\n Log.event(`Compiled successfully in ${durationString}`)\n }\n\n return {\n duration,\n buildTraceContext: traceEntryPointsPlugin?.buildTraceContext,\n pluginState: getPluginState(),\n telemetryState: {\n usages: telemetryPlugin?.usages() || [],\n packagesUsedInServerSideProps:\n telemetryPlugin?.packagesUsedInServerSideProps() || [],\n useCacheTracker: telemetryPlugin?.getUseCacheTracker() || {},\n },\n }\n }\n}\n\n// the main function when this file is run as a worker\nexport async function workerMain(workerData: {\n compilerName: keyof typeof COMPILER_INDEXES\n buildContext: typeof NextBuildContext\n traceState: TraceState\n}): Promise<\n Awaited<ReturnType<typeof webpackBuildImpl>> & {\n debugTraceEvents: TraceEvent[]\n }\n> {\n // Clone the telemetry for worker\n const telemetry = new Telemetry({\n distDir: workerData.buildContext.config!.distDir,\n })\n setGlobal('telemetry', telemetry)\n // setup new build context from the serialized data passed from the parent\n Object.assign(NextBuildContext, workerData.buildContext)\n\n // Initialize tracer state from the parent\n initializeTraceState(workerData.traceState)\n\n // Resume plugin state\n resumePluginState(NextBuildContext.pluginState)\n\n /// load the config because it's not serializable\n const config = (NextBuildContext.config = await loadConfig(\n PHASE_PRODUCTION_BUILD,\n NextBuildContext.dir!,\n {\n debugPrerender: NextBuildContext.debugPrerender,\n reactProductionProfiling: NextBuildContext.reactProductionProfiling,\n }\n ))\n await installBindings(config.experimental?.useWasmBinary)\n NextBuildContext.nextBuildSpan = trace(\n `worker-main-${workerData.compilerName}`\n )\n\n const result = await webpackBuildImpl(workerData.compilerName)\n const { entriesTrace, chunksTrace } = result.buildTraceContext ?? {}\n if (entriesTrace) {\n const { entryNameMap, depModArray } = entriesTrace\n if (depModArray) {\n result.buildTraceContext!.entriesTrace!.depModArray = depModArray\n }\n if (entryNameMap) {\n const entryEntries = entryNameMap\n result.buildTraceContext!.entriesTrace!.entryNameMap = entryEntries\n }\n }\n if (chunksTrace?.entryNameFilesMap) {\n const entryNameFilesMap = chunksTrace.entryNameFilesMap\n result.buildTraceContext!.chunksTrace!.entryNameFilesMap = entryNameFilesMap\n }\n NextBuildContext.nextBuildSpan.stop()\n return { ...result, debugTraceEvents: getTraceEvents() }\n}\n"],"names":["webpackBuildImpl","workerMain","debug","origDebug","isTelemetryPlugin","plugin","TelemetryPlugin","isTraceEntryPointsPlugin","TraceEntryPointsPlugin","compilerName","result","warnings","errors","stats","webpackBuildStart","nextBuildSpan","NextBuildContext","dir","config","process","env","NEXT_COMPILER_NAME","runWebpackSpan","traceChild","entrypoints","traceAsyncFn","createEntrypoints","buildId","envFiles","loadedEnvFiles","isDev","rootDir","pageExtensions","pagesDir","appDir","pages","mappedPages","appPaths","mappedAppPages","previewMode","previewProps","rootPaths","mappedRootPaths","hasInstrumentationHook","commonWebpackOptions","isServer","isCompileMode","encryptionKey","rewrites","originalRewrites","originalRedirects","reactProductionProfiling","noMangling","clientRouterFilters","allowedRevalidateHeaderKeys","fetchCacheKeyPrefix","configs","info","loadProjectInfo","dev","Promise","all","getBaseWebpackConfig","middlewareMatchers","compilerType","COMPILER_NAMES","client","server","edgeServer","clientConfig","serverConfig","edgeConfig","optimization","minimize","minimizer","length","Log","warn","hrtime","inputFileSystem","experimental","webpackMemoryOptimizations","stringBufferUtils","disableDualStringBufferCaching","enterStringInterningRange","clientResult","serverResult","edgeServerResult","start","Date","now","runCompiler","pluginState","getPluginState","key","injectedClientEntries","value","clientEntry","entry","APP_CLIENT_INTERNALS","CLIENT_STATIC_FILES_RUNTIME_MAIN_APP","import","layer","WEBPACK_LAYERS","appPagesBrowser","dependOn","exitStringInterningRange","purge","filter","nonNullable","traceFn","formatWebpackMessages","telemetryPlugin","plugins","find","traceEntryPointsPlugin","webpackBuildEnd","error","Boolean","join","console","red","indexOf","page_name_regex","parsed","exec","page_name","groups","Error","err","code","NEXT_RSPACK","duration","hrtimeToSeconds","durationString","durationToString","event","buildTraceContext","telemetryState","usages","packagesUsedInServerSideProps","useCacheTracker","getUseCacheTracker","workerData","telemetry","Telemetry","distDir","buildContext","setGlobal","Object","assign","initializeTraceState","traceState","resumePluginState","loadConfig","PHASE_PRODUCTION_BUILD","debugPrerender","installBindings","useWasmBinary","trace","entriesTrace","chunksTrace","entryNameMap","depModArray","entryEntries","entryNameFilesMap","stop","debugTraceEvents","getTraceEvents"],"mappings":"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","ignoreList":[0]}
|
|
@@ -86,7 +86,6 @@ const _flightcliententryplugin = require("./webpack/plugins/flight-client-entry-
|
|
|
86
86
|
const _rspackflightcliententryplugin = require("./webpack/plugins/rspack-flight-client-entry-plugin");
|
|
87
87
|
const _nexttypesplugin = require("./webpack/plugins/next-types-plugin");
|
|
88
88
|
const _loadjsconfig = /*#__PURE__*/ _interop_require_default(require("./load-jsconfig"));
|
|
89
|
-
const _swc = require("./swc");
|
|
90
89
|
const _subresourceintegrityplugin = require("./webpack/plugins/subresource-integrity-plugin");
|
|
91
90
|
const _nextfontmanifestplugin = require("./webpack/plugins/next-font-manifest-plugin");
|
|
92
91
|
const _memorywithgccacheplugin = require("./webpack/plugins/memory-with-gc-cache-plugin");
|
|
@@ -344,10 +343,6 @@ async function getBaseWebpackConfig(dir, { buildId, encryptionKey, config, compi
|
|
|
344
343
|
_log.info(`Disabled SWC as replacement for Babel because of custom Babel configuration "${_path.default.relative(dir, babelConfigFile)}" https://nextjs.org/docs/messages/swc-disabled`);
|
|
345
344
|
loggedSwcDisabled = true;
|
|
346
345
|
}
|
|
347
|
-
// eagerly load swc bindings instead of waiting for transform calls
|
|
348
|
-
if (!babelConfigFile && isClient) {
|
|
349
|
-
await (0, _swc.loadBindings)(config.experimental.useWasmBinary);
|
|
350
|
-
}
|
|
351
346
|
// since `pages` doesn't always bundle by default we need to
|
|
352
347
|
// auto-include optimizePackageImports in transpilePackages
|
|
353
348
|
const finalTranspilePackages = (config.transpilePackages || []).concat(DEFAULT_TRANSPILED_PACKAGES);
|
|
@@ -1728,7 +1723,7 @@ async function getBaseWebpackConfig(dir, { buildId, encryptionKey, config, compi
|
|
|
1728
1723
|
isClient && new _copyfileplugin.CopyFilePlugin({
|
|
1729
1724
|
// file path to build output of `@next/polyfill-nomodule`
|
|
1730
1725
|
filePath: require.resolve('./polyfills/polyfill-nomodule'),
|
|
1731
|
-
cacheKey: "16.0.2-canary.
|
|
1726
|
+
cacheKey: "16.0.2-canary.12",
|
|
1732
1727
|
name: `static/chunks/polyfills${dev ? '' : '-[hash]'}.js`,
|
|
1733
1728
|
minimize: false,
|
|
1734
1729
|
info: {
|
|
@@ -1914,7 +1909,7 @@ async function getBaseWebpackConfig(dir, { buildId, encryptionKey, config, compi
|
|
|
1914
1909
|
// - Next.js location on disk (some loaders use absolute paths and some resolve options depend on absolute paths)
|
|
1915
1910
|
// - Next.js version
|
|
1916
1911
|
// - next.config.js keys that affect compilation
|
|
1917
|
-
version: `${__dirname}|${"16.0.2-canary.
|
|
1912
|
+
version: `${__dirname}|${"16.0.2-canary.12"}|${configVars}`,
|
|
1918
1913
|
cacheDirectory: _path.default.join(distDir, 'cache', 'webpack'),
|
|
1919
1914
|
// For production builds, it's more efficient to compress all cache files together instead of compression each one individually.
|
|
1920
1915
|
// So we disable compression here and allow the build runner to take care of compressing the cache as a whole.
|