From 98383c33e9991112e62c194c1f7cf6c4ca5ff429 Mon Sep 17 00:00:00 2001 From: Sebastian Markbage Date: Fri, 12 Jul 2024 17:28:01 -0400 Subject: [PATCH] Encode the name of a function as an object property --- .../react-client/src/ReactFlightClient.js | 26 +++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/packages/react-client/src/ReactFlightClient.js b/packages/react-client/src/ReactFlightClient.js index 03a4ab96c0abc..c0d599297858e 100644 --- a/packages/react-client/src/ReactFlightClient.js +++ b/packages/react-client/src/ReactFlightClient.js @@ -1891,19 +1891,33 @@ function createFakeFunction( const comment = '/* This module was rendered by a Server Component. Turn on Source Maps to see the server source. */'; + if (!name) { + // An eval:ed function with no name gets the name "eval". We give it something more descriptive. + name = '(anonymous)'; + } + const encodedName = JSON.stringify(name); // We generate code where the call is at the line and column of the server executed code. // This allows us to use the original source map as the source map of this fake file to // point to the original source. let code; if (line <= 1) { - code = '_=>' + ' '.repeat(col < 4 ? 0 : col - 4) + '_()\n' + comment; + const minSize = encodedName.length + 7; + code = + '({' + + encodedName + + ':_=>' + + ' '.repeat(col < minSize ? 0 : col - minSize) + + '_()})\n' + + comment; } else { code = comment + '\n'.repeat(line - 2) + - '_=>\n' + + '({' + + encodedName + + ':_=>\n' + ' '.repeat(col < 1 ? 0 : col - 1) + - '_()'; + '_()})'; } if (filename.startsWith('/')) { @@ -1931,7 +1945,7 @@ function createFakeFunction( let fn: FakeFunction; try { // eslint-disable-next-line no-eval - fn = (0, eval)(code); + fn = (0, eval)(code)[name]; } catch (x) { // If eval fails, such as if in an environment that doesn't support it, // we fallback to creating a function here. It'll still have the right @@ -1940,10 +1954,6 @@ function createFakeFunction( return _(); }; } - // $FlowFixMe[cannot-write] - Object.defineProperty(fn, 'name', {value: name || '(anonymous)'}); - // $FlowFixMe[prop-missing] - fn.displayName = name; return fn; }