Skip to content

Commit

Permalink
Track which fibers scheduled the current render work
Browse files Browse the repository at this point in the history
  • Loading branch information
Brian Vaughn committed Apr 2, 2021
1 parent 9ed0167 commit 373acb6
Show file tree
Hide file tree
Showing 22 changed files with 1,018 additions and 42 deletions.
71 changes: 54 additions & 17 deletions packages/react-reconciler/src/ReactFiberCommitWork.new.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import {
enableScopeAPI,
enableStrictEffects,
deletedTreeCleanUpLevel,
enableUpdaterTracking,
} from 'shared/ReactFeatureFlags';
import {
FunctionComponent,
Expand Down Expand Up @@ -86,7 +87,7 @@ import {
resetCurrentFiber as resetCurrentDebugFiberInDEV,
setCurrentFiber as setCurrentDebugFiberInDEV,
} from './ReactCurrentFiber';

import {isDevToolsPresent} from './ReactFiberDevToolsHook.new';
import {onCommitUnmount} from './ReactFiberDevToolsHook.new';
import {resolveDefaultProps} from './ReactFiberLazyComponent.new';
import {
Expand Down Expand Up @@ -134,6 +135,7 @@ import {
resolveRetryWakeable,
markCommitTimeOfFallback,
enqueuePendingPassiveProfilerEffect,
restorePendingUpdaters,
} from './ReactFiberWorkLoop.new';
import {
NoFlags as NoHookEffect,
Expand Down Expand Up @@ -1663,7 +1665,12 @@ function commitDeletion(
detachFiberMutation(current);
}

function commitWork(current: Fiber | null, finishedWork: Fiber): void {
function commitWork(
finishedRoot: FiberRoot,
current: Fiber | null,
finishedWork: Fiber,
committedLanes: Lanes,
): void {
if (!supportsMutation) {
switch (finishedWork.tag) {
case FunctionComponent:
Expand Down Expand Up @@ -1704,11 +1711,19 @@ function commitWork(current: Fiber | null, finishedWork: Fiber): void {
}
case SuspenseComponent: {
commitSuspenseComponent(finishedWork);
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(
finishedRoot,
finishedWork,
committedLanes,
);
return;
}
case SuspenseListComponent: {
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(
finishedRoot,
finishedWork,
committedLanes,
);
return;
}
case HostRoot: {
Expand Down Expand Up @@ -1827,11 +1842,11 @@ function commitWork(current: Fiber | null, finishedWork: Fiber): void {
}
case SuspenseComponent: {
commitSuspenseComponent(finishedWork);
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(finishedRoot, finishedWork, committedLanes);
return;
}
case SuspenseListComponent: {
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(finishedRoot, finishedWork, committedLanes);
return;
}
case IncompleteClassComponent: {
Expand Down Expand Up @@ -1927,7 +1942,11 @@ function commitSuspenseHydrationCallbacks(
}
}

function attachSuspenseRetryListeners(finishedWork: Fiber) {
function attachSuspenseRetryListeners(
finishedRoot: FiberRoot,
finishedWork: Fiber,
committedLanes: Lanes,
) {
// If this boundary just timed out, then it will have a set of wakeables.
// For each wakeable, attach a listener so that when it resolves, React
// attempts to re-render the boundary in the primary (pre-timeout) state.
Expand All @@ -1947,6 +1966,12 @@ function attachSuspenseRetryListeners(finishedWork: Fiber) {
retry = Schedule_tracing_wrap(retry);
}
}
if (enableUpdaterTracking) {
if (isDevToolsPresent) {
// If we have pending work still, associate the original updaters with it.
restorePendingUpdaters(finishedRoot, committedLanes);
}
}
retryCache.add(wakeable);
wakeable.then(retry, retry);
}
Expand Down Expand Up @@ -1978,12 +2003,16 @@ function commitResetTextContent(current: Fiber) {
resetTextContent(current.stateNode);
}

export function commitMutationEffects(root: FiberRoot, firstChild: Fiber) {
export function commitMutationEffects(
root: FiberRoot,
firstChild: Fiber,
committedLanes: Lanes,
) {
nextEffect = firstChild;
commitMutationEffects_begin(root);
commitMutationEffects_begin(root, committedLanes);
}

function commitMutationEffects_begin(root: FiberRoot) {
function commitMutationEffects_begin(root: FiberRoot, committedLanes: Lanes) {
while (nextEffect !== null) {
const fiber = nextEffect;

Expand Down Expand Up @@ -2020,12 +2049,15 @@ function commitMutationEffects_begin(root: FiberRoot) {
ensureCorrectReturnPointer(child, fiber);
nextEffect = child;
} else {
commitMutationEffects_complete(root);
commitMutationEffects_complete(root, committedLanes);
}
}
}

function commitMutationEffects_complete(root: FiberRoot) {
function commitMutationEffects_complete(
root: FiberRoot,
committedLanes: Lanes,
) {
while (nextEffect !== null) {
const fiber = nextEffect;
if (__DEV__) {
Expand All @@ -2036,6 +2068,7 @@ function commitMutationEffects_complete(root: FiberRoot) {
null,
fiber,
root,
committedLanes,
);
if (hasCaughtError()) {
const error = clearCaughtError();
Expand All @@ -2044,7 +2077,7 @@ function commitMutationEffects_complete(root: FiberRoot) {
resetCurrentDebugFiberInDEV();
} else {
try {
commitMutationEffectsOnFiber(fiber, root);
commitMutationEffectsOnFiber(fiber, root, committedLanes);
} catch (error) {
captureCommitPhaseError(fiber, fiber.return, error);
}
Expand All @@ -2061,7 +2094,11 @@ function commitMutationEffects_complete(root: FiberRoot) {
}
}

function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {
function commitMutationEffectsOnFiber(
finishedWork: Fiber,
root: FiberRoot,
committedLanes: Lanes,
) {
const flags = finishedWork.flags;

if (flags & ContentReset) {
Expand Down Expand Up @@ -2106,7 +2143,7 @@ function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {

// Update
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
case Hydrating: {
Expand All @@ -2118,12 +2155,12 @@ function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {

// Update
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
case Update: {
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
}
Expand Down
71 changes: 54 additions & 17 deletions packages/react-reconciler/src/ReactFiberCommitWork.old.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import {
enableScopeAPI,
enableStrictEffects,
deletedTreeCleanUpLevel,
enableUpdaterTracking,
} from 'shared/ReactFeatureFlags';
import {
FunctionComponent,
Expand Down Expand Up @@ -86,7 +87,7 @@ import {
resetCurrentFiber as resetCurrentDebugFiberInDEV,
setCurrentFiber as setCurrentDebugFiberInDEV,
} from './ReactCurrentFiber';

import {isDevToolsPresent} from './ReactFiberDevToolsHook.old';
import {onCommitUnmount} from './ReactFiberDevToolsHook.old';
import {resolveDefaultProps} from './ReactFiberLazyComponent.old';
import {
Expand Down Expand Up @@ -134,6 +135,7 @@ import {
resolveRetryWakeable,
markCommitTimeOfFallback,
enqueuePendingPassiveProfilerEffect,
restorePendingUpdaters,
} from './ReactFiberWorkLoop.old';
import {
NoFlags as NoHookEffect,
Expand Down Expand Up @@ -1663,7 +1665,12 @@ function commitDeletion(
detachFiberMutation(current);
}

function commitWork(current: Fiber | null, finishedWork: Fiber): void {
function commitWork(
finishedRoot: FiberRoot,
current: Fiber | null,
finishedWork: Fiber,
committedLanes: Lanes,
): void {
if (!supportsMutation) {
switch (finishedWork.tag) {
case FunctionComponent:
Expand Down Expand Up @@ -1704,11 +1711,19 @@ function commitWork(current: Fiber | null, finishedWork: Fiber): void {
}
case SuspenseComponent: {
commitSuspenseComponent(finishedWork);
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(
finishedRoot,
finishedWork,
committedLanes,
);
return;
}
case SuspenseListComponent: {
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(
finishedRoot,
finishedWork,
committedLanes,
);
return;
}
case HostRoot: {
Expand Down Expand Up @@ -1827,11 +1842,11 @@ function commitWork(current: Fiber | null, finishedWork: Fiber): void {
}
case SuspenseComponent: {
commitSuspenseComponent(finishedWork);
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(finishedRoot, finishedWork, committedLanes);
return;
}
case SuspenseListComponent: {
attachSuspenseRetryListeners(finishedWork);
attachSuspenseRetryListeners(finishedRoot, finishedWork, committedLanes);
return;
}
case IncompleteClassComponent: {
Expand Down Expand Up @@ -1927,7 +1942,11 @@ function commitSuspenseHydrationCallbacks(
}
}

function attachSuspenseRetryListeners(finishedWork: Fiber) {
function attachSuspenseRetryListeners(
finishedRoot: FiberRoot,
finishedWork: Fiber,
committedLanes: Lanes,
) {
// If this boundary just timed out, then it will have a set of wakeables.
// For each wakeable, attach a listener so that when it resolves, React
// attempts to re-render the boundary in the primary (pre-timeout) state.
Expand All @@ -1947,6 +1966,12 @@ function attachSuspenseRetryListeners(finishedWork: Fiber) {
retry = Schedule_tracing_wrap(retry);
}
}
if (enableUpdaterTracking) {
if (isDevToolsPresent) {
// If we have pending work still, associate the original updaters with it.
restorePendingUpdaters(finishedRoot, committedLanes);
}
}
retryCache.add(wakeable);
wakeable.then(retry, retry);
}
Expand Down Expand Up @@ -1978,12 +2003,16 @@ function commitResetTextContent(current: Fiber) {
resetTextContent(current.stateNode);
}

export function commitMutationEffects(root: FiberRoot, firstChild: Fiber) {
export function commitMutationEffects(
root: FiberRoot,
firstChild: Fiber,
committedLanes: Lanes,
) {
nextEffect = firstChild;
commitMutationEffects_begin(root);
commitMutationEffects_begin(root, committedLanes);
}

function commitMutationEffects_begin(root: FiberRoot) {
function commitMutationEffects_begin(root: FiberRoot, committedLanes: Lanes) {
while (nextEffect !== null) {
const fiber = nextEffect;

Expand Down Expand Up @@ -2020,12 +2049,15 @@ function commitMutationEffects_begin(root: FiberRoot) {
ensureCorrectReturnPointer(child, fiber);
nextEffect = child;
} else {
commitMutationEffects_complete(root);
commitMutationEffects_complete(root, committedLanes);
}
}
}

function commitMutationEffects_complete(root: FiberRoot) {
function commitMutationEffects_complete(
root: FiberRoot,
committedLanes: Lanes,
) {
while (nextEffect !== null) {
const fiber = nextEffect;
if (__DEV__) {
Expand All @@ -2036,6 +2068,7 @@ function commitMutationEffects_complete(root: FiberRoot) {
null,
fiber,
root,
committedLanes,
);
if (hasCaughtError()) {
const error = clearCaughtError();
Expand All @@ -2044,7 +2077,7 @@ function commitMutationEffects_complete(root: FiberRoot) {
resetCurrentDebugFiberInDEV();
} else {
try {
commitMutationEffectsOnFiber(fiber, root);
commitMutationEffectsOnFiber(fiber, root, committedLanes);
} catch (error) {
captureCommitPhaseError(fiber, fiber.return, error);
}
Expand All @@ -2061,7 +2094,11 @@ function commitMutationEffects_complete(root: FiberRoot) {
}
}

function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {
function commitMutationEffectsOnFiber(
finishedWork: Fiber,
root: FiberRoot,
committedLanes: Lanes,
) {
const flags = finishedWork.flags;

if (flags & ContentReset) {
Expand Down Expand Up @@ -2106,7 +2143,7 @@ function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {

// Update
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
case Hydrating: {
Expand All @@ -2118,12 +2155,12 @@ function commitMutationEffectsOnFiber(finishedWork: Fiber, root: FiberRoot) {

// Update
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
case Update: {
const current = finishedWork.alternate;
commitWork(current, finishedWork);
commitWork(root, current, finishedWork, committedLanes);
break;
}
}
Expand Down
Loading

0 comments on commit 373acb6

Please sign in to comment.