DescriptionUse invalidation sets when selector contains adjacent combinators.
When we found a direct or indirect adjacent combinator, we fell back on
using a subtree recalc for all features in the selector in question. That
is not necessary as we can resume the process of adding separate features
to the invalidation sets once we encounter a non-adjacent combinator going
leftwards.
Example:
.a .b + .c { }
We have an empty invalidation set for 'c', 'b' currently needs to do a sub-
tree recalc to recalculate the 'c' class element when 'b' is added or
removed. However, once we see the descendant combinator left of '.b' we can
get away with adding 'c' to the invalidation set for 'a' since 'c' will
have to be in 'a's sub-tree.
Eventually, I think we could merge collectFeaturesFromSelector with
updateInvalidationSet to get rid of a pass through the selector.
R=esprehn@chromium.org
BUG=351613, 335247
Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=170881
Patch Set 1 #
Total comments: 4
Patch Set 2 : Moved SGML comment out of <style> element. #Patch Set 3 : Rebased with modified expected test results. #
Created: 6 years, 8 months ago
Messages
Total messages: 15 (0 generated)
|