UNPKG

next

Version:

The React Framework

124 lines (123 loc) 4.68 kB
import { isWebpackInternalResource, formatFrameSourceFile } from './webpack-module-path'; function getOriginalStackFrame(source, response) { var _source_file; async function _getOriginalStackFrame() { var _body_originalStackFrame; if (response.status === 'rejected') { throw Object.defineProperty(new Error(response.reason), "__NEXT_ERROR_CODE", { value: "E394", enumerable: false, configurable: true }); } const body = response.value; return { error: false, reason: null, external: false, sourceStackFrame: source, originalStackFrame: body.originalStackFrame, originalCodeFrame: body.originalCodeFrame || null, ignored: ((_body_originalStackFrame = body.originalStackFrame) == null ? void 0 : _body_originalStackFrame.ignored) || false }; } // TODO: merge this section into ignoredList handling if (source.file === 'file://' || ((_source_file = source.file) == null ? void 0 : _source_file.match(/https?:\/\//))) { return Promise.resolve({ error: false, reason: null, external: true, sourceStackFrame: source, originalStackFrame: null, originalCodeFrame: null, ignored: true }); } return _getOriginalStackFrame().catch((err)=>{ var _err_message, _ref; return { error: true, reason: (_ref = (_err_message = err == null ? void 0 : err.message) != null ? _err_message : err == null ? void 0 : err.toString()) != null ? _ref : 'Unknown Error', external: false, sourceStackFrame: source, originalStackFrame: null, originalCodeFrame: null, ignored: false }; }); } export async function getOriginalStackFrames(frames, type, isAppDir) { const req = { frames, isServer: type === 'server', isEdgeServer: type === 'edge-server', isAppDirectory: isAppDir }; let res = undefined; let reason = undefined; try { res = await fetch('/__nextjs_original-stack-frames', { method: 'POST', body: JSON.stringify(req) }); } catch (e) { reason = e + ''; } // When fails to fetch the original stack frames, we reject here to be // caught at `_getOriginalStackFrame()` and return the stack frames so // that the error overlay can render. if (res && res.ok && res.status !== 204) { const data = await res.json(); return Promise.all(frames.map((frame, index)=>getOriginalStackFrame(frame, data[index]))); } else { if (res) { reason = await res.text(); } } return Promise.all(frames.map((frame)=>getOriginalStackFrame(frame, { status: 'rejected', reason: "Failed to fetch the original stack frames " + (reason ? ": " + reason : '') }))); } export function getFrameSource(frame) { if (!frame.file) return ''; const isWebpackFrame = isWebpackInternalResource(frame.file); let str = ''; // Skip URL parsing for webpack internal file paths. if (isWebpackFrame) { str = formatFrameSourceFile(frame.file); } else { try { var _globalThis_location; const u = new URL(frame.file); let parsedPath = ''; // Strip the origin for same-origin scripts. if (((_globalThis_location = globalThis.location) == null ? void 0 : _globalThis_location.origin) !== u.origin) { // URLs can be valid without an `origin`, so long as they have a // `protocol`. However, `origin` is preferred. if (u.origin === 'null') { parsedPath += u.protocol; } else { parsedPath += u.origin; } } // Strip query string information as it's typically too verbose to be // meaningful. parsedPath += u.pathname; str = formatFrameSourceFile(parsedPath); } catch (e) { str = formatFrameSourceFile(frame.file); } } if (!isWebpackInternalResource(frame.file) && frame.lineNumber != null) { if (str) { if (frame.column != null) { str += " (" + frame.lineNumber + ":" + frame.column + ")"; } else { str += " (" + frame.lineNumber + ")"; } } } return str; } //# sourceMappingURL=stack-frame.js.map