-
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 1 commit
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 |
---|---|---|
|
@@ -692,8 +692,8 @@ class ReactDOMServerRenderer { | |
// find the correct previous provider based on type | ||
let previousProvider; | ||
if (this.providerIndex > -1) { | ||
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. Seems like we can remove this condition? For loop already covers it. 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. |
||
for (let i = 0; i <= this.providerIndex; i += 1) { | ||
if (this.providerStack[i] && | ||
for (let i = this.providerIndex; i >= 0; i -= 1) { | ||
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. If you don't mind, 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. Done. I'm used to not allowing infix from our projects lint rules, old habits. |
||
if (this.providerStack[i] !== null && this.providerStack[i] !== undefined && | ||
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. So, do we actually need those checks? I wouldn't expect a provider "below" to ever be 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. Agreed. But, Flow doesn't seem to be aware of that. Perhaps we need some special Flow syntax I'm not aware of, which is highly likely? 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. I addressed this by changing the array definition to be stricter and pop via setting the length. It didn't seem right to allow |
||
(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. This comment was about why we felt comfortable using Flow // We assume this type is correct because of the index check above. Please keep it above the // We assume this Flow type is correct because of the index check above. 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. |
||
previousProvider = this.providerStack[i]; | ||
break; | ||
|
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.
This comment is redundant, IMO the code speaks for itself
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