From fd907c1f153958950ba48db758cbd826d1e1af53 Mon Sep 17 00:00:00 2001 From: Andrew Clark Date: Mon, 3 May 2021 13:34:19 -0500 Subject: [PATCH] Re-land "Use highest priority lane to detect interruptions (#21088)"" This re-lands commit b4044f8a07323bcad7d55cbaedc35c35b4acf7e0. --- packages/react-reconciler/src/ReactFiberLane.new.js | 11 ++++++----- packages/react-reconciler/src/ReactFiberLane.old.js | 11 ++++++----- 2 files changed, 12 insertions(+), 10 deletions(-) diff --git a/packages/react-reconciler/src/ReactFiberLane.new.js b/packages/react-reconciler/src/ReactFiberLane.new.js index cdf5543c36e6f..5a71b4ce489e3 100644 --- a/packages/react-reconciler/src/ReactFiberLane.new.js +++ b/packages/react-reconciler/src/ReactFiberLane.new.js @@ -301,15 +301,16 @@ export function getNextLanes(root: FiberRoot, wipLanes: Lanes): Lanes { // bother waiting until the root is complete. (wipLanes & suspendedLanes) === NoLanes ) { - getHighestPriorityLanes(wipLanes); - const wipLanePriority = return_highestLanePriority; + const nextLane = getHighestPriorityLane(nextLanes); + const wipLane = getHighestPriorityLane(wipLanes); if ( - nextLanePriority <= wipLanePriority || + // Tests whether the next lane is equal or lower priority than the wip + // one. This works because the bits decrease in priority as you go left. + nextLane >= wipLane || // Default priority updates should not interrupt transition updates. The // only difference between default updates and transition updates is that // default updates do not support refresh transitions. - (nextLanePriority === DefaultLanePriority && - wipLanePriority === TransitionPriority) + (nextLane === DefaultLane && (wipLane & TransitionLanes) !== NoLanes) ) { // Keep working on the existing in-progress tree. Do not interrupt. return wipLanes; diff --git a/packages/react-reconciler/src/ReactFiberLane.old.js b/packages/react-reconciler/src/ReactFiberLane.old.js index 6ab7163cbb927..d3443dbe24d00 100644 --- a/packages/react-reconciler/src/ReactFiberLane.old.js +++ b/packages/react-reconciler/src/ReactFiberLane.old.js @@ -301,15 +301,16 @@ export function getNextLanes(root: FiberRoot, wipLanes: Lanes): Lanes { // bother waiting until the root is complete. (wipLanes & suspendedLanes) === NoLanes ) { - getHighestPriorityLanes(wipLanes); - const wipLanePriority = return_highestLanePriority; + const nextLane = getHighestPriorityLane(nextLanes); + const wipLane = getHighestPriorityLane(wipLanes); if ( - nextLanePriority <= wipLanePriority || + // Tests whether the next lane is equal or lower priority than the wip + // one. This works because the bits decrease in priority as you go left. + nextLane >= wipLane || // Default priority updates should not interrupt transition updates. The // only difference between default updates and transition updates is that // default updates do not support refresh transitions. - (nextLanePriority === DefaultLanePriority && - wipLanePriority === TransitionPriority) + (nextLane === DefaultLane && (wipLane & TransitionLanes) !== NoLanes) ) { // Keep working on the existing in-progress tree. Do not interrupt. return wipLanes;