• Hixie's avatar
    Short-circuit the relayoutSubtreeRoot when the child couldn't change... · e352ec9f
    Hixie authored
    Short-circuit the relayoutSubtreeRoot when the child couldn't change dimensions anyway because the parent constrained it.
    
    The relayout subtree root concept is intended to handle the case where
    a node, when it lays itself out for a second time, changes its opinion
    about what dimensions it should be. In such a situation, the parent,
    if it based its own opinion about what size _it_ should be on the
    child's dimensions, would also need to lay itself out again. Thus,
    when this scenario is possible, the child remembers the parent, and
    when it would be told to relayout, we actually start the layout with
    the parent.
    
    In practice, this chains, and we end up with nodes that point to
    ancestors ten or more steps up the tree such that when the inner most
    child re-lays-out, the whole app ends up relaying out.
    
    This patch tries to short-circuit this for the case where the
    constraints being applied to the child are such that actually, the
    child has no choice about its dimensions. In that case, the parent
    can't change dimensions when the child re-lays-out.
    
    This makes a huge difference on the stocks demo app. Without this, on
    the third rendered frame, there are 72 relayoutSubtreeRoot links, the
    deepest chain is 8 deep, and 9 of the chains are only 1 level deep.
    With it, there are 63 relayoutSubtreeRoot links, the deepest chain is
    only 4 deep, and 38 of the chains are only 1 level deep.
    
    R=eseidel@chromium.org
    
    Review URL: https://codereview.chromium.org/1196553004.
    e352ec9f
Name
Last commit
Last update
..
borders.dart Loading commit data...
interactive_flex.dart Loading commit data...
justify_content.dart Loading commit data...
render_paragraph.dart Loading commit data...
sector_layout.dart Loading commit data...
shadowed_box.dart Loading commit data...
spinning_flex.dart Loading commit data...
touch_demo.dart Loading commit data...
transform.dart Loading commit data...