From fe67c16ea3f21a17fec847e16feefb7f9ce78ad0 Mon Sep 17 00:00:00 2001 From: Andrew Clark Date: Tue, 29 Jan 2019 16:32:15 -0800 Subject: [PATCH] Phased dispatcher (#14701) * Move DEV-only function right above where it's used I don't like looking at this top-level function #petty * Use different dispatchers for functions & classes Classes support readContext, but not any of the other dispatcher methods. Function support all methods. This is a more robust version of our previous strategy of checking whether `currentlyRenderingFiber` is null. As a next step, we can use a separate dispatcher for each phase of the render cycle (mount versus update). * Use separate dispatchers for mount and update * Remove mount code from update path Deletes mount-specific code from the update path, since it should be unreachable. To continue supporting progressive enhancement (mounting new hooks at the end of the list), we detect when there are no more current hooks and switch back to the mount dispatcher. Progressive enhancement isn't officially supported yet, so it will continue to warn. * Factoring nits * Fix Flow Had to cheat more than I would like * More Flow nits * Switch back to using a special dispatcher for nested hooks in DEV In order for this strategy to work, I had to revert progressive enhancement support (appending hooks to the end). It was previously a warning but now it results in an error. We'll reconsider later. * Always pass args to updateState and updateReducer Even though the extra args are only used on mount, to ensure type consistency. --- src/ReactShallowRenderer.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/ReactShallowRenderer.js b/src/ReactShallowRenderer.js index 815220e..ee8b68b 100644 --- a/src/ReactShallowRenderer.js +++ b/src/ReactShallowRenderer.js @@ -18,7 +18,7 @@ import ReactSharedInternals from 'shared/ReactSharedInternals'; import warning from 'shared/warning'; import is from 'shared/objectIs'; -import typeof {Dispatcher as DispatcherType} from 'react-reconciler/src/ReactFiberDispatcher'; +import type {Dispatcher as DispatcherType} from 'react-reconciler/src/ReactFiberHooks'; import type {ReactContext} from 'shared/ReactTypes'; import type {ReactElement} from 'shared/ReactElementType';