-
Notifications
You must be signed in to change notification settings - Fork 47k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixed an issue with nested contexts unwinding when server rendering. Issue #12984 #12985
Changes from 4 commits
8ff3f62
27bb329
8d38f45
037c4d5
e69904c
731c686
6d31d3a
5114a3e
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -641,7 +641,7 @@ class ReactDOMServerRenderer { | |
previousWasTextNode: boolean; | ||
makeStaticMarkup: boolean; | ||
|
||
providerStack: Array<?ReactProvider<any>>; | ||
providerStack: Array<ReactProvider<any>>; | ||
providerIndex: number; | ||
|
||
constructor(children: mixed, makeStaticMarkup: boolean) { | ||
|
@@ -686,17 +686,22 @@ class ReactDOMServerRenderer { | |
'Unexpected pop.', | ||
); | ||
} | ||
this.providerStack[this.providerIndex] = null; | ||
this.providerStack.length = this.providerIndex; | ||
this.providerIndex -= 1; | ||
const context: ReactContext<any> = provider.type._context; | ||
if (this.providerIndex < 0) { | ||
context._currentValue = context._defaultValue; | ||
} else { | ||
// We assume this type is correct because of the index check above. | ||
const previousProvider: ReactProvider<any> = (this.providerStack[ | ||
this.providerIndex | ||
]: any); | ||
// find the correct previous provider based on type | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This comment is redundant, IMO the code speaks for itself There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. OK |
||
let previousProvider = null; | ||
for (let i = this.providerIndex; i >= 0; i--) { | ||
// We assume this Flow type is correct because of the index check above. | ||
if ((this.providerStack[i]: ReactProvider<any>).type === provider.type) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please read There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yep. |
||
previousProvider = this.providerStack[i]; | ||
break; | ||
} | ||
} | ||
if (previousProvider !== null) { | ||
context._currentValue = previousProvider.props.value; | ||
} else { | ||
context._currentValue = context._defaultValue; | ||
} | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What does
.length
assignment do in V8? I'd like to make sure it doesn't think the array length change is likely to "stay" because it changes all the time. I think just usingnull
is more straightforward and less surprising to the engine (even though the typing isn't as nice for us).There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OK. But, going back to using
null
seems to require testing fornull
when accessing array items by index, since Flow has been told thatnull
andundefined
are expected array item values. Or, is there an alternate Flow syntax that allows us to remove the explicit checks?