From 02f9e3c2c97716f78ece74dbe0c40c05f762b33a Mon Sep 17 00:00:00 2001 From: Sebastian Markbage Date: Wed, 23 Jul 2025 21:39:01 -0400 Subject: [PATCH] Use about: protocol instead of rsc: protocol for fake evals --- packages/react-client/src/ReactFlightClient.js | 4 ++-- packages/react-client/src/ReactFlightReplyClient.js | 4 ++-- packages/react-client/src/__tests__/ReactFlight-test.js | 6 +++--- packages/react-server/src/ReactFlightServer.js | 4 ++-- 4 files changed, 9 insertions(+), 9 deletions(-) diff --git a/packages/react-client/src/ReactFlightClient.js b/packages/react-client/src/ReactFlightClient.js index 5281c20966a81..4403687383ae7 100644 --- a/packages/react-client/src/ReactFlightClient.js +++ b/packages/react-client/src/ReactFlightClient.js @@ -3154,7 +3154,7 @@ function createFakeFunction( } if (sourceMap) { - // We use the prefix rsc://React/ to separate these from other files listed in + // We use the prefix about://React/ to separate these from other files listed in // the Chrome DevTools. We need a "host name" and not just a protocol because // otherwise the group name becomes the root folder. Ideally we don't want to // show these at all but there's two reasons to assign a fake URL. @@ -3162,7 +3162,7 @@ function createFakeFunction( // 2) If source maps are disabled or fails, you should at least be able to tell // which file it was. code += - '\n//# sourceURL=rsc://React/' + + '\n//# sourceURL=about://React/' + encodeURIComponent(environmentName) + '/' + encodeURI(filename) + diff --git a/packages/react-client/src/ReactFlightReplyClient.js b/packages/react-client/src/ReactFlightReplyClient.js index d22a894b5157c..22479aac04471 100644 --- a/packages/react-client/src/ReactFlightReplyClient.js +++ b/packages/react-client/src/ReactFlightReplyClient.js @@ -1095,7 +1095,7 @@ function createFakeServerFunction, T>( } if (sourceMap) { - // We use the prefix rsc://React/ to separate these from other files listed in + // We use the prefix about://React/ to separate these from other files listed in // the Chrome DevTools. We need a "host name" and not just a protocol because // otherwise the group name becomes the root folder. Ideally we don't want to // show these at all but there's two reasons to assign a fake URL. @@ -1103,7 +1103,7 @@ function createFakeServerFunction, T>( // 2) If source maps are disabled or fails, you should at least be able to tell // which file it was. code += - '\n//# sourceURL=rsc://React/' + + '\n//# sourceURL=about://React/' + encodeURIComponent(environmentName) + '/' + encodeURI(filename) + diff --git a/packages/react-client/src/__tests__/ReactFlight-test.js b/packages/react-client/src/__tests__/ReactFlight-test.js index 6c1b22f1414ed..2ccf874cee91b 100644 --- a/packages/react-client/src/__tests__/ReactFlight-test.js +++ b/packages/react-client/src/__tests__/ReactFlight-test.js @@ -1314,7 +1314,7 @@ describe('ReactFlight', () => { ' at async file:///testing.js:42:3', // third-party RSC frame // Ideally this would be a real frame produced by React not a mocked one. - ' at ThirdParty (rsc://React/ThirdParty/file:///code/%5Broot%2520of%2520the%2520server%5D.js?42:1:1)', + ' at ThirdParty (about://React/ThirdParty/file:///code/%5Broot%2520of%2520the%2520server%5D.js?42:1:1)', // We'll later filter this out based on line/column in `filterStackFrame`. ' at ThirdPartyModule (file:///file-with-index-source-map.js:52656:16374)', // host component in parent stack @@ -3073,7 +3073,7 @@ describe('ReactFlight', () => { ReactNoopFlightClient.read(transport, { findSourceMapURL(url) { // By giving a source map url we're saying that we can't use the original - // file as the sourceURL, which gives stack traces a rsc://React/ prefix. + // file as the sourceURL, which gives stack traces a about://React/ prefix. return 'source-map://' + url; }, }), @@ -3147,7 +3147,7 @@ describe('ReactFlight', () => { expectedErrorStack={expectedErrorStack}> {ReactNoopFlightClient.read(transport, { findSourceMapURL(url, environmentName) { - if (url.startsWith('rsc://React/')) { + if (url.startsWith('about://React/')) { // We don't expect to see any React prefixed URLs here. sawReactPrefix = true; } diff --git a/packages/react-server/src/ReactFlightServer.js b/packages/react-server/src/ReactFlightServer.js index 2ba4c0dee8277..688a9ef0c574a 100644 --- a/packages/react-server/src/ReactFlightServer.js +++ b/packages/react-server/src/ReactFlightServer.js @@ -179,12 +179,12 @@ function defaultFilterStackFrame( } function devirtualizeURL(url: string): string { - if (url.startsWith('rsc://React/')) { + if (url.startsWith('about://React/')) { // This callsite is a virtual fake callsite that came from another Flight client. // We need to reverse it back into the original location by stripping its prefix // and suffix. We don't need the environment name because it's available on the // parent object that will contain the stack. - const envIdx = url.indexOf('/', 'rsc://React/'.length); + const envIdx = url.indexOf('/', 'about://React/'.length); const suffixIdx = url.lastIndexOf('?'); if (envIdx > -1 && suffixIdx > -1) { return decodeURI(url.slice(envIdx + 1, suffixIdx));