Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(413)

Unified Diff: Source/core/dom/Element.cpp

Issue 540533004: Use style invalidation for more pseudo classes. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Rebased Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/core/dom/Element.cpp
diff --git a/Source/core/dom/Element.cpp b/Source/core/dom/Element.cpp
index 1f2fed69eefcbaeb8f6dd79a86194da9d66c3598..6ecb77722fdbfa7d0b64531482d8923085384971 100644
--- a/Source/core/dom/Element.cpp
+++ b/Source/core/dom/Element.cpp
@@ -1604,11 +1604,15 @@ ElementShadow& Element::ensureShadow()
return ensureElementRareData().ensureShadow();
}
-void Element::didAffectSelector(AffectedSelectorMask mask)
+void Element::pseudoStateChanged(CSSSelector::PseudoType pseudo)
{
- setNeedsStyleRecalc(SubtreeStyleChange);
+ StyleResolver* styleResolver = document().styleResolver();
+
+ if (inActiveDocument() && styleResolver && styleChangeType() < SubtreeStyleChange)
+ styleResolver->ensureUpdatedRuleFeatureSet().scheduleStyleInvalidationForPseudoChange(pseudo, *this);
+
if (ElementShadow* elementShadow = shadowWhereNodeCanBeDistributed(*this))
- elementShadow->didAffectSelector(mask);
+ elementShadow->distributedNodePseudoStateChanged(pseudo);
}
void Element::setAnimationStyleChange(bool animationStyleChange)

Powered by Google App Engine
This is Rietveld 408576698