Skip to content

Commit

Permalink
old
Browse files Browse the repository at this point in the history
  • Loading branch information
lunaruan committed Mar 22, 2022
1 parent d962ee8 commit 87dba57
Show file tree
Hide file tree
Showing 11 changed files with 420 additions and 123 deletions.
85 changes: 68 additions & 17 deletions packages/react-reconciler/src/ReactFiberBeginWork.old.js
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ import {
markSkippedUpdateLanes,
getWorkInProgressRoot,
pushRenderLanes,
getWorkInProgressTransitions,
setRootPendingSuspenseBoundaries,
} from './ReactFiberWorkLoop.old';
import {setWorkInProgressVersion} from './ReactMutableSource.old';
import {pushCacheProvider, CacheContext} from './ReactFiberCacheComponent.old';
Expand All @@ -256,6 +256,7 @@ import {
getSuspendedCache,
pushTransition,
getOffscreenDeferredCache,
getSuspendedTransitions,
} from './ReactFiberTransition.old';

const ReactCurrentOwner = ReactSharedInternals.ReactCurrentOwner;
Expand Down Expand Up @@ -655,13 +656,14 @@ function updateOffscreenComponent(
const nextState: OffscreenState = {
baseLanes: NoLanes,
cachePool: null,
transitions: null,
};
workInProgress.memoizedState = nextState;
if (enableCache) {
// push the cache pool even though we're going to bail out
// because otherwise there'd be a context mismatch
if (current !== null) {
pushTransition(workInProgress, null);
pushTransition(workInProgress, null, null);
}
}
pushRenderLanes(workInProgress, renderLanes);
Expand All @@ -688,14 +690,15 @@ function updateOffscreenComponent(
const nextState: OffscreenState = {
baseLanes: nextBaseLanes,
cachePool: spawnedCachePool,
transitions: null,
};
workInProgress.memoizedState = nextState;
workInProgress.updateQueue = null;
if (enableCache) {
// push the cache pool even though we're going to bail out
// because otherwise there'd be a context mismatch
if (current !== null) {
pushTransition(workInProgress, null);
pushTransition(workInProgress, null, null);
}
}

Expand Down Expand Up @@ -723,6 +726,7 @@ function updateOffscreenComponent(
const nextState: OffscreenState = {
baseLanes: NoLanes,
cachePool: null,
transitions: null,
};
workInProgress.memoizedState = nextState;
// Push the lanes that were skipped when we bailed out.
Expand All @@ -733,7 +737,7 @@ function updateOffscreenComponent(
// using the same cache. Unless the parent changed, since that means
// there was a refresh.
const prevCachePool = prevState !== null ? prevState.cachePool : null;
pushTransition(workInProgress, prevCachePool);
pushTransition(workInProgress, prevCachePool, null);
}

pushRenderLanes(workInProgress, subtreeRenderLanes);
Expand All @@ -746,14 +750,14 @@ function updateOffscreenComponent(

subtreeRenderLanes = mergeLanes(prevState.baseLanes, renderLanes);

if (enableCache) {
if (enableCache || enableTransitionTracing) {
// If the render that spawned this one accessed the cache pool, resume
// using the same cache. Unless the parent changed, since that means
// there was a refresh.
const prevCachePool = prevState.cachePool;
pushTransition(workInProgress, prevCachePool);
const transitions = prevState.transitions;
pushTransition(workInProgress, prevCachePool, transitions);
}

// Since we're not hidden anymore, reset the state
workInProgress.memoizedState = null;
} else {
Expand All @@ -767,7 +771,7 @@ function updateOffscreenComponent(
// using the same cache. Unless the parent changed, since that means
// there was a refresh.
if (current !== null) {
pushTransition(workInProgress, null);
pushTransition(workInProgress, null, null);
}
}
}
Expand Down Expand Up @@ -1325,27 +1329,34 @@ function updateHostRoot(current, workInProgress, renderLanes) {
const nextProps = workInProgress.pendingProps;
const prevState = workInProgress.memoizedState;
const prevChildren = prevState.element;

cloneUpdateQueue(current, workInProgress);
processUpdateQueue(workInProgress, nextProps, null, renderLanes);

const nextState: RootState = workInProgress.memoizedState;
const root: FiberRoot = workInProgress.stateNode;

if (enableCache || enableTransitionTracing) {
pushRootTransition(workInProgress, root, renderLanes);
}

if (enableCache) {
const nextCache: Cache = nextState.cache;
pushRootTransition(root);
const nextCache: Cache = workInProgress.memoizedState.cache;
pushCacheProvider(workInProgress, nextCache);
if (nextCache !== prevState.cache) {
// The root cache refreshed.
propagateContextChange(workInProgress, CacheContext, renderLanes);
}
}

let pendingSuspenseBoundaries = nextState.pendingSuspenseBoundaries;
if (enableTransitionTracing) {
// FIXME: Slipped past code review. This is not a safe mutation:
// workInProgress.memoizedState is a shared object. Need to fix before
// rolling out the Transition Tracing experiment.
workInProgress.memoizedState.transitions = getWorkInProgressTransitions();
if (prevState.pendingSuspenseBoundaries === null) {
pendingSuspenseBoundaries = new Map();
}
// TODO(luna) change to pushPendingSuspenseBoundaries
// once we add tracing markers
setRootPendingSuspenseBoundaries(pendingSuspenseBoundaries);
}

// Caution: React DevTools currently depends on this property
Expand All @@ -1361,6 +1372,7 @@ function updateHostRoot(current, workInProgress, renderLanes) {
element: nextChildren,
isDehydrated: false,
cache: nextState.cache,
pendingSuspenseBoundaries: pendingSuspenseBoundaries,
transitions: nextState.transitions,
};
const updateQueue: UpdateQueue<RootState> = (workInProgress.updateQueue: any);
Expand Down Expand Up @@ -1434,6 +1446,20 @@ function updateHostRoot(current, workInProgress, renderLanes) {
}
}
} else {
if (enableTransitionTracing) {
if (pendingSuspenseBoundaries !== nextState.pendingSuspenseBoundaries) {
const overrideState: RootState = {
element: nextChildren,
isDehydrated: nextState.isDehydrated,
cache: nextState.cache,
pendingSuspenseBoundaries: pendingSuspenseBoundaries,
transitions: nextState.transitions,
};

workInProgress.memoizedState = overrideState;
}
}

// Root is not dehydrated. Either this is a client-only root, or it
// already hydrated.
resetHydrationState();
Expand Down Expand Up @@ -1978,6 +2004,7 @@ function mountSuspenseOffscreenState(renderLanes: Lanes): OffscreenState {
return {
baseLanes: renderLanes,
cachePool: getSuspendedCache(),
transitions: getSuspendedTransitions(),
};
}

Expand Down Expand Up @@ -2009,9 +2036,22 @@ function updateSuspenseOffscreenState(
cachePool = getSuspendedCache();
}
}

let transitions = null;
if (enableTransitionTracing) {
const currentTransitions = getSuspendedTransitions();
const prevTransitions = prevOffscreenState.transitions;
if (prevTransitions !== null) {
transitions = prevTransitions.concat(currentTransitions);
} else {
transitions = currentTransitions;
}
}

return {
baseLanes: mergeLanes(prevOffscreenState.baseLanes, renderLanes),
cachePool,
transitions,
};
}

Expand Down Expand Up @@ -2345,6 +2385,7 @@ function mountSuspensePrimaryChildren(
renderLanes,
) {
const mode = workInProgress.mode;

const primaryChildProps: OffscreenProps = {
mode: 'visible',
children: primaryChildren,
Expand All @@ -2367,7 +2408,6 @@ function mountSuspenseFallbackChildren(
) {
const mode = workInProgress.mode;
const progressedPrimaryFragment: Fiber | null = workInProgress.child;

const primaryChildProps: OffscreenProps = {
mode: 'hidden',
children: primaryChildren,
Expand Down Expand Up @@ -3571,14 +3611,25 @@ function attemptEarlyBailoutIfNoScheduledUpdate(
case HostRoot:
pushHostRootContext(workInProgress);
const root: FiberRoot = workInProgress.stateNode;
if (enableCache || enableTransitionTracing) {
pushRootTransition(workInProgress, root, renderLanes);
}

if (enableCache) {
const cache: Cache = current.memoizedState.cache;
pushCacheProvider(workInProgress, cache);
pushRootTransition(root);
}

if (enableTransitionTracing) {
workInProgress.memoizedState.transitions = getWorkInProgressTransitions();
const pendingSuspenseBoundaries =
workInProgress.memoizedState.pendingSuspenseBoundaries;
// TODO(luna) change to pushPendingSuspenseBoundaries
// once we add tracing markers
if (pendingSuspenseBoundaries) {
setRootPendingSuspenseBoundaries(pendingSuspenseBoundaries);
}
}

resetHydrationState();
break;
case HostComponent:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ import {enableCache} from 'shared/ReactFeatureFlags';
import {REACT_CONTEXT_TYPE} from 'shared/ReactSymbols';

import {pushProvider, popProvider} from './ReactFiberNewContext.old';
import * as Scheduler from 'scheduler';

import * as Scheduler from 'scheduler';
export type Cache = {|
controller: AbortController,
data: Map<() => mixed, mixed>,
Expand Down
Loading

0 comments on commit 87dba57

Please sign in to comment.