Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
| 3 * (C) 2004-2005 Allan Sandfeld Jensen (kde@carewolf.com) | 3 * (C) 2004-2005 Allan Sandfeld Jensen (kde@carewolf.com) |
| 4 * Copyright (C) 2006, 2007 Nicholas Shanks (webkit@nickshanks.com) | 4 * Copyright (C) 2006, 2007 Nicholas Shanks (webkit@nickshanks.com) |
| 5 * Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Apple Inc. All r ights reserved. | 5 * Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Apple Inc. All r ights reserved. |
| 6 * Copyright (C) 2007 Alexey Proskuryakov <ap@webkit.org> | 6 * Copyright (C) 2007 Alexey Proskuryakov <ap@webkit.org> |
| 7 * Copyright (C) 2007, 2008 Eric Seidel <eric@webkit.org> | 7 * Copyright (C) 2007, 2008 Eric Seidel <eric@webkit.org> |
| 8 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/) | 8 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/) |
| 9 * Copyright (c) 2011, Code Aurora Forum. All rights reserved. | 9 * Copyright (c) 2011, Code Aurora Forum. All rights reserved. |
| 10 * Copyright (C) Research In Motion Limited 2011. All rights reserved. | 10 * Copyright (C) Research In Motion Limited 2011. All rights reserved. |
| (...skipping 245 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 256 extractInvalidationSetFeature(*current, features); | 256 extractInvalidationSetFeature(*current, features); |
| 257 // Initialize the entry in the invalidation set map, if supported. | 257 // Initialize the entry in the invalidation set map, if supported. |
| 258 invalidationSetForSelector(*current); | 258 invalidationSetForSelector(*current); |
| 259 if (current->pseudoType() == CSSSelector::PseudoHost || current->pseudoT ype() == CSSSelector::PseudoAny || current->pseudoType() == CSSSelector::PseudoN ot) { | 259 if (current->pseudoType() == CSSSelector::PseudoHost || current->pseudoT ype() == CSSSelector::PseudoAny || current->pseudoType() == CSSSelector::PseudoN ot) { |
| 260 if (const CSSSelectorList* selectorList = current->selectorList()) { | 260 if (const CSSSelectorList* selectorList = current->selectorList()) { |
| 261 for (const CSSSelector* selector = selectorList->first(); select or; selector = CSSSelectorList::next(*selector)) | 261 for (const CSSSelector* selector = selectorList->first(); select or; selector = CSSSelectorList::next(*selector)) |
| 262 extractInvalidationSetFeatures(*selector, features, current- >pseudoType() == CSSSelector::PseudoNot); | 262 extractInvalidationSetFeatures(*selector, features, current- >pseudoType() == CSSSelector::PseudoNot); |
| 263 } | 263 } |
| 264 } | 264 } |
| 265 | 265 |
| 266 switch (current->relation()) { | 266 if (current->relation() == CSSSelector::SubSelector) |
| 267 case CSSSelector::SubSelector: | 267 continue; |
| 268 break; | 268 |
| 269 case CSSSelector::ShadowPseudo: | 269 if (current->isShadowSelector()) |
| 270 case CSSSelector::ShadowDeep: | |
| 271 features.treeBoundaryCrossing = true; | 270 features.treeBoundaryCrossing = true; |
|
chrishtr
2014/10/10 16:26:02
Can be written as:
features.treeBundaryCrossing =
rune
2014/10/10 20:00:35
Done.
| |
| 272 return current->tagHistory(); | 271 |
| 273 case CSSSelector::DirectAdjacent: | 272 features.adjacent = current->isAdjacentSelector(); |
| 274 case CSSSelector::IndirectAdjacent: | 273 return current->tagHistory(); |
|
Mike West
2014/10/08 12:24:00
This is a huge improvement in readability. Kudos.
| |
| 275 features.wholeSubtree = true; | |
| 276 return current->tagHistory(); | |
| 277 case CSSSelector::Descendant: | |
| 278 case CSSSelector::Child: | |
| 279 return current->tagHistory(); | |
| 280 } | |
| 281 } | 274 } |
| 282 return 0; | 275 return 0; |
| 283 } | 276 } |
| 284 | 277 |
| 285 // Add features extracted from the rightmost compound selector to descendant inv alidation | 278 // Add features extracted from the rightmost compound selector to descendant inv alidation |
| 286 // sets for features found in other compound selectors. | 279 // sets for features found in other compound selectors. |
| 287 // | 280 // |
| 288 // Style invalidation is currently supported for descendants only, not for sibli ng subtrees. | 281 // Style invalidation is currently supported for descendants only, not for sibli ng subtrees. |
| 289 // We use wholeSubtree invalidation for features found left of adjacent combinat ors as | 282 // We use wholeSubtree invalidation for features found left of adjacent combinat ors as |
| 290 // SubtreeStyleChange will force sibling subtree recalc in | 283 // SubtreeStyleChange will force sibling subtree recalc in |
| 291 // ContainerNode::checkForChildrenAdjacentRuleChanges. | 284 // ContainerNode::checkForChildrenAdjacentRuleChanges. |
| 292 // | 285 // |
| 293 // As we encounter a descendant type of combinator, the features only need to be checked | 286 // As we encounter a descendant type of combinator, the features only need to be checked |
| 294 // against descendants in the same subtree only. Hence wholeSubtree is reset to false. | 287 // against descendants in the same subtree only. features.adjacent is set to fal se, and |
| 288 // we start adding features instead of calling setWholeSubtreeInvalid. | |
| 295 | 289 |
| 296 void RuleFeatureSet::addFeaturesToInvalidationSets(const CSSSelector& selector, InvalidationSetFeatures& features) | 290 void RuleFeatureSet::addFeaturesToInvalidationSets(const CSSSelector& selector, InvalidationSetFeatures& features) |
| 297 { | 291 { |
| 298 for (const CSSSelector* current = &selector; current; current = current->tag History()) { | 292 for (const CSSSelector* current = &selector; current; current = current->tag History()) { |
| 299 if (DescendantInvalidationSet* invalidationSet = invalidationSetForSelec tor(*current)) { | 293 if (DescendantInvalidationSet* invalidationSet = invalidationSetForSelec tor(*current)) { |
| 300 if (features.treeBoundaryCrossing) | 294 if (features.treeBoundaryCrossing) |
| 301 invalidationSet->setTreeBoundaryCrossing(); | 295 invalidationSet->setTreeBoundaryCrossing(); |
| 302 if (features.wholeSubtree) { | 296 if (features.adjacent) { |
| 303 invalidationSet->setWholeSubtreeInvalid(); | 297 invalidationSet->setWholeSubtreeInvalid(); |
| 304 } else { | 298 } else { |
| 305 if (!features.id.isEmpty()) | 299 if (!features.id.isEmpty()) |
| 306 invalidationSet->addId(features.id); | 300 invalidationSet->addId(features.id); |
| 307 if (!features.tagName.isEmpty()) | 301 if (!features.tagName.isEmpty()) |
| 308 invalidationSet->addTagName(features.tagName); | 302 invalidationSet->addTagName(features.tagName); |
| 309 for (Vector<AtomicString>::const_iterator it = features.classes. begin(); it != features.classes.end(); ++it) | 303 for (Vector<AtomicString>::const_iterator it = features.classes. begin(); it != features.classes.end(); ++it) |
| 310 invalidationSet->addClass(*it); | 304 invalidationSet->addClass(*it); |
| 311 for (Vector<AtomicString>::const_iterator it = features.attribut es.begin(); it != features.attributes.end(); ++it) | 305 for (Vector<AtomicString>::const_iterator it = features.attribut es.begin(); it != features.attributes.end(); ++it) |
| 312 invalidationSet->addAttribute(*it); | 306 invalidationSet->addAttribute(*it); |
| 313 if (features.customPseudoElement) | 307 if (features.customPseudoElement) |
| 314 invalidationSet->setCustomPseudoInvalid(); | 308 invalidationSet->setCustomPseudoInvalid(); |
| 315 } | 309 } |
| 316 } else { | 310 } else { |
| 317 if (current->pseudoType() == CSSSelector::PseudoHost) | 311 if (current->pseudoType() == CSSSelector::PseudoHost) |
| 318 features.treeBoundaryCrossing = true; | 312 features.treeBoundaryCrossing = true; |
| 319 if (const CSSSelectorList* selectorList = current->selectorList()) { | 313 if (const CSSSelectorList* selectorList = current->selectorList()) { |
| 320 ASSERT(current->pseudoType() == CSSSelector::PseudoHost || curre nt->pseudoType() == CSSSelector::PseudoAny || current->pseudoType() == CSSSelect or::PseudoNot); | 314 ASSERT(current->pseudoType() == CSSSelector::PseudoHost || curre nt->pseudoType() == CSSSelector::PseudoAny || current->pseudoType() == CSSSelect or::PseudoNot); |
| 321 for (const CSSSelector* selector = selectorList->first(); select or; selector = CSSSelectorList::next(*selector)) | 315 for (const CSSSelector* selector = selectorList->first(); select or; selector = CSSSelectorList::next(*selector)) |
| 322 addFeaturesToInvalidationSets(*selector, features); | 316 addFeaturesToInvalidationSets(*selector, features); |
| 323 } | 317 } |
| 324 } | 318 } |
| 325 switch (current->relation()) { | 319 |
| 326 case CSSSelector::SubSelector: | 320 if (current->isShadowSelector()) |
| 327 break; | |
| 328 case CSSSelector::ShadowPseudo: | |
| 329 case CSSSelector::ShadowDeep: | |
| 330 features.treeBoundaryCrossing = true; | 321 features.treeBoundaryCrossing = true; |
| 331 features.wholeSubtree = false; | 322 |
| 332 break; | 323 if (current->relation() != CSSSelector::SubSelector) |
| 333 case CSSSelector::Descendant: | 324 features.adjacent = current->isAdjacentSelector(); |
|
Mike West
2014/10/08 12:24:00
This is even better. :)
| |
| 334 case CSSSelector::Child: | |
| 335 features.wholeSubtree = false; | |
| 336 break; | |
| 337 case CSSSelector::DirectAdjacent: | |
| 338 case CSSSelector::IndirectAdjacent: | |
| 339 features.wholeSubtree = true; | |
| 340 break; | |
| 341 } | |
| 342 } | 325 } |
| 343 } | 326 } |
| 344 | 327 |
| 345 void RuleFeatureSet::addContentAttr(const AtomicString& attributeName) | 328 void RuleFeatureSet::addContentAttr(const AtomicString& attributeName) |
| 346 { | 329 { |
| 347 ensureAttributeInvalidationSet(attributeName); | 330 ensureAttributeInvalidationSet(attributeName); |
| 348 } | 331 } |
| 349 | 332 |
| 350 void RuleFeatureSet::collectFeaturesFromRuleData(const RuleData& ruleData) | 333 void RuleFeatureSet::collectFeaturesFromRuleData(const RuleData& ruleData) |
| 351 { | 334 { |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 564 visitor->trace(uncommonAttributeRules); | 547 visitor->trace(uncommonAttributeRules); |
| 565 visitor->trace(m_classInvalidationSets); | 548 visitor->trace(m_classInvalidationSets); |
| 566 visitor->trace(m_attributeInvalidationSets); | 549 visitor->trace(m_attributeInvalidationSets); |
| 567 visitor->trace(m_idInvalidationSets); | 550 visitor->trace(m_idInvalidationSets); |
| 568 visitor->trace(m_pseudoInvalidationSets); | 551 visitor->trace(m_pseudoInvalidationSets); |
| 569 visitor->trace(m_styleInvalidator); | 552 visitor->trace(m_styleInvalidator); |
| 570 #endif | 553 #endif |
| 571 } | 554 } |
| 572 | 555 |
| 573 } // namespace blink | 556 } // namespace blink |
| OLD | NEW |