UNPKG

next

Version:

The React Framework

51 lines (48 loc) 2.43 kB
import { getDigestForWellKnownError } from './create-error-handler'; import { isReactLargeShellError } from './react-large-shell-error'; export var Phase = /*#__PURE__*/ function(Phase) { Phase["ProspectiveRender"] = "the prospective render"; Phase["SegmentCollection"] = "segment collection"; return Phase; }({}); export function printDebugThrownValueForProspectiveRender(thrownValue, route, phase) { // We don't need to print well-known Next.js errors. if (getDigestForWellKnownError(thrownValue)) { return; } if (isReactLargeShellError(thrownValue)) { // TODO: Aggregate console.error(thrownValue); return undefined; } let message; if (typeof thrownValue === 'object' && thrownValue !== null && typeof thrownValue.message === 'string') { message = thrownValue.message; if (typeof thrownValue.stack === 'string') { const originalErrorStack = thrownValue.stack; const stackStart = originalErrorStack.indexOf('\n'); if (stackStart > -1) { const error = Object.defineProperty(new Error(`Route ${route} errored during ${phase}. These errors are normally ignored and may not prevent the route from prerendering but are logged here because build debugging is enabled. Original Error: ${message}`), "__NEXT_ERROR_CODE", { value: "E949", enumerable: false, configurable: true }); error.stack = 'Error: ' + error.message + originalErrorStack.slice(stackStart); console.error(error); return; } } } else if (typeof thrownValue === 'string') { message = thrownValue; } if (message) { console.error(`Route ${route} errored during ${phase}. These errors are normally ignored and may not prevent the route from prerendering but are logged here because build debugging is enabled. No stack was provided. Original Message: ${message}`); return; } console.error(`Route ${route} errored during ${phase}. These errors are normally ignored and may not prevent the route from prerendering but are logged here because build debugging is enabled. The thrown value is logged just following this message`); console.error(thrownValue); return; } //# sourceMappingURL=prospective-render-utils.js.map