Remove _debugWillReattachChildren assertions from _TableElement#34202
Merged
LongCatIsLooong merged 5 commits intoflutter:masterfrom Jul 11, 2019
Merged
Remove _debugWillReattachChildren assertions from _TableElement#34202LongCatIsLooong merged 5 commits intoflutter:masterfrom
_debugWillReattachChildren assertions from _TableElement#34202LongCatIsLooong merged 5 commits intoflutter:masterfrom
Conversation
goderbauer
reviewed
Jul 3, 2019
Member
goderbauer
left a comment
There was a problem hiding this comment.
Did you checkin with @Hixie, who wrote the original code, to figure out if he remembers why the assert was added in the first place? There may have been a good reason for them to be there in the first place.
| @override | ||
| Widget build(BuildContext context) { | ||
| return toggle | ||
| ? const SizedBox() |
Member
There was a problem hiding this comment.
nit: indentation is off here (this could probably just all be in one line)
Hixie
reviewed
Jul 11, 2019
Contributor
There was a problem hiding this comment.
trivial nit: no space between > and [
Contributor
0d7e69e to
916d094
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Description
Calling
insertChildRenderObjectandremoveChildRenderObjectoutside ofupdateormountin_TableElementshould be allowed.Consider the following minimal reproducible example:
Sequence of events after tapping 'Tap me'
onTapcallback is called,_State.contextis marked dirty.GestureDetectorwas replaced by a widget of a different type,_State.context.updateChildmethod calls_State.context.deactivateChild._TableElementto detach it from_TableElement.renderObject, calling_TableElement.removeChildRenderObject._TableElement.removeChildRenderObjectfails.In the above call path only
removeChildRenderObjectwas called on a_TableElementinstance, pretty much everything else is happening in the descendant elements which we have no knowledge of in the implementation ofTable. So it's probably easier to just remove the asserts than figuring out a way to keep them.Related PR
_debugWillReattachChildrenwasn't brought up in #2961's discussion.Related Issues
Fixes #31473
Tests
I added the following tests:
Checklist
Before you create this PR confirm that it meets all requirements listed below by checking the relevant checkboxes (
[x]). This will ensure a smooth and quick review process.///).flutter analyze --flutter-repo) does not report any problems on my PR.Breaking Change
Does your PR require Flutter developers to manually update their apps to accommodate your change?