From a9e58204eee362e457630738b7d7f2128ff8c9c4 Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Fri, 12 Nov 2021 09:41:05 -0500 Subject: [PATCH] Add runtime type checks around module boundary code --- .../react-reconciler/src/SchedulingProfiler.js | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/packages/react-reconciler/src/SchedulingProfiler.js b/packages/react-reconciler/src/SchedulingProfiler.js index 0304f39a12e56..6ef0b6293bc76 100644 --- a/packages/react-reconciler/src/SchedulingProfiler.js +++ b/packages/react-reconciler/src/SchedulingProfiler.js @@ -18,6 +18,7 @@ import { import ReactVersion from 'shared/ReactVersion'; import getComponentNameFromFiber from 'react-reconciler/src/getComponentNameFromFiber'; import {SCHEDULING_PROFILER_VERSION} from 'react-devtools-timeline/src/constants'; +import isArray from 'shared/isArray'; import { getLabelForLane as getLabelForLane_old, @@ -105,11 +106,18 @@ function markInternalModuleRanges() { typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.getInternalModuleRanges === 'function' ) { const ranges = __REACT_DEVTOOLS_GLOBAL_HOOK__.getInternalModuleRanges(); - for (let i = 0; i < ranges.length; i++) { - const [startStackFrame, stopStackFrame] = ranges[i]; - - markAndClear(`--react-internal-module-start-${startStackFrame}`); - markAndClear(`--react-internal-module-stop-${stopStackFrame}`); + // This check would not be required, + // except that it's possible for things to override __REACT_DEVTOOLS_GLOBAL_HOOK__. + if (isArray(ranges)) { + for (let i = 0; i < ranges.length; i++) { + const range = ranges[i]; + if (isArray(range) && range.length === 2) { + const [startStackFrame, stopStackFrame] = ranges[i]; + + markAndClear(`--react-internal-module-start-${startStackFrame}`); + markAndClear(`--react-internal-module-stop-${stopStackFrame}`); + } + } } } }