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, 2013 Apple Inc.
All rights reserved. | 5 * Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013 Apple Inc.
All rights 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 235 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
246 appendCSSOMWrapperForRule(const_cast<CSSStyleSheet*>(matchedRules[i]
.parentStyleSheet()), matchedRules[i].ruleData()->rule()); | 246 appendCSSOMWrapperForRule(const_cast<CSSStyleSheet*>(matchedRules[i]
.parentStyleSheet()), matchedRules[i].ruleData()->rule()); |
247 return; | 247 return; |
248 } | 248 } |
249 | 249 |
250 // Now transfer the set of matched rules over to our list of declarations. | 250 // Now transfer the set of matched rules over to our list of declarations. |
251 for (unsigned i = 0; i < matchedRules.size(); i++) { | 251 for (unsigned i = 0; i < matchedRules.size(); i++) { |
252 // FIXME: Matching should not modify the style directly. | 252 // FIXME: Matching should not modify the style directly. |
253 const RuleData* ruleData = matchedRules[i].ruleData(); | 253 const RuleData* ruleData = matchedRules[i].ruleData(); |
254 if (m_style && ruleData->containsUncommonAttributeSelector()) | 254 if (m_style && ruleData->containsUncommonAttributeSelector()) |
255 m_style->setUnique(); | 255 m_style->setUnique(); |
256 m_result.addMatchedProperties(ruleData->rule()->properties(), ruleData->
rule(), ruleData->linkMatchType(), ruleData->propertyWhitelistType(m_matchingUAR
ules)); | 256 m_result.addMatchedProperties(&ruleData->rule()->properties(), ruleData-
>rule(), ruleData->linkMatchType(), ruleData->propertyWhitelistType(m_matchingUA
Rules)); |
257 } | 257 } |
258 } | 258 } |
259 | 259 |
260 inline bool ElementRuleCollector::ruleMatches(const RuleData& ruleData, const Co
ntainerNode* scope, SelectorChecker::BehaviorAtBoundary behaviorAtBoundary, Sele
ctorChecker::MatchResult* result) | 260 inline bool ElementRuleCollector::ruleMatches(const RuleData& ruleData, const Co
ntainerNode* scope, SelectorChecker::BehaviorAtBoundary behaviorAtBoundary, Sele
ctorChecker::MatchResult* result) |
261 { | 261 { |
262 // Scoped rules can't match because the fast path uses a pool of tag/class/i
ds, collected from | 262 // Scoped rules can't match because the fast path uses a pool of tag/class/i
ds, collected from |
263 // elements in that tree and those will never match the host, since it's in
a different pool. | 263 // elements in that tree and those will never match the host, since it's in
a different pool. |
264 if (ruleData.hasFastCheckableSelector() && !scope) { | 264 if (ruleData.hasFastCheckableSelector() && !scope) { |
265 // We know this selector does not include any pseudo elements. | 265 // We know this selector does not include any pseudo elements. |
266 if (m_pseudoStyleRequest.pseudoId != NOPSEUDO) | 266 if (m_pseudoStyleRequest.pseudoId != NOPSEUDO) |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
300 | 300 |
301 void ElementRuleCollector::collectRuleIfMatches(const RuleData& ruleData, Select
orChecker::BehaviorAtBoundary behaviorAtBoundary, CascadeScope cascadeScope, Cas
cadeOrder cascadeOrder, const MatchRequest& matchRequest, RuleRange& ruleRange) | 301 void ElementRuleCollector::collectRuleIfMatches(const RuleData& ruleData, Select
orChecker::BehaviorAtBoundary behaviorAtBoundary, CascadeScope cascadeScope, Cas
cadeOrder cascadeOrder, const MatchRequest& matchRequest, RuleRange& ruleRange) |
302 { | 302 { |
303 if (m_canUseFastReject && m_selectorFilter.fastRejectSelector<RuleData::maxi
mumIdentifierCount>(ruleData.descendantSelectorIdentifierHashes())) | 303 if (m_canUseFastReject && m_selectorFilter.fastRejectSelector<RuleData::maxi
mumIdentifierCount>(ruleData.descendantSelectorIdentifierHashes())) |
304 return; | 304 return; |
305 | 305 |
306 StyleRule* rule = ruleData.rule(); | 306 StyleRule* rule = ruleData.rule(); |
307 SelectorChecker::MatchResult result; | 307 SelectorChecker::MatchResult result; |
308 if (ruleMatches(ruleData, matchRequest.scope, behaviorAtBoundary, &result))
{ | 308 if (ruleMatches(ruleData, matchRequest.scope, behaviorAtBoundary, &result))
{ |
309 // If the rule has no properties to apply, then ignore it in the non-deb
ug mode. | 309 // If the rule has no properties to apply, then ignore it in the non-deb
ug mode. |
310 const StylePropertySet* properties = rule->properties(); | 310 const StylePropertySet& properties = rule->properties(); |
311 if (!properties || (properties->isEmpty() && !matchRequest.includeEmptyR
ules)) | 311 if (properties.isEmpty() && !matchRequest.includeEmptyRules) |
312 return; | 312 return; |
313 // FIXME: Exposing the non-standard getMatchedCSSRules API to web is the
only reason this is needed. | 313 // FIXME: Exposing the non-standard getMatchedCSSRules API to web is the
only reason this is needed. |
314 if (m_sameOriginOnly && !ruleData.hasDocumentSecurityOrigin()) | 314 if (m_sameOriginOnly && !ruleData.hasDocumentSecurityOrigin()) |
315 return; | 315 return; |
316 | 316 |
317 PseudoId dynamicPseudo = result.dynamicPseudo; | 317 PseudoId dynamicPseudo = result.dynamicPseudo; |
318 // If we're matching normal rules, set a pseudo bit if | 318 // If we're matching normal rules, set a pseudo bit if |
319 // we really just matched a pseudo-element. | 319 // we really just matched a pseudo-element. |
320 if (dynamicPseudo != NOPSEUDO && m_pseudoStyleRequest.pseudoId == NOPSEU
DO) { | 320 if (dynamicPseudo != NOPSEUDO && m_pseudoStyleRequest.pseudoId == NOPSEU
DO) { |
321 if (m_mode == SelectorChecker::CollectingCSSRules || m_mode == Selec
torChecker::CollectingStyleRules) | 321 if (m_mode == SelectorChecker::CollectingCSSRules || m_mode == Selec
torChecker::CollectingStyleRules) |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
383 // information about "scope". | 383 // information about "scope". |
384 int firstRuleIndex = -1, lastRuleIndex = -1; | 384 int firstRuleIndex = -1, lastRuleIndex = -1; |
385 RuleRange ruleRange(firstRuleIndex, lastRuleIndex); | 385 RuleRange ruleRange(firstRuleIndex, lastRuleIndex); |
386 // FIXME: Verify whether it's ok to ignore CascadeScope here. | 386 // FIXME: Verify whether it's ok to ignore CascadeScope here. |
387 collectMatchingRules(MatchRequest(ruleSet), ruleRange, SelectorChecker::Stay
sWithinTreeScope); | 387 collectMatchingRules(MatchRequest(ruleSet), ruleRange, SelectorChecker::Stay
sWithinTreeScope); |
388 | 388 |
389 return m_matchedRules && !m_matchedRules->isEmpty(); | 389 return m_matchedRules && !m_matchedRules->isEmpty(); |
390 } | 390 } |
391 | 391 |
392 } // namespace WebCore | 392 } // namespace WebCore |
OLD | NEW |