| 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 | 5 * Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 Apple Inc. All |
| 6 * rights reserved. | 6 * rights reserved. |
| 7 * Copyright (C) 2007 Alexey Proskuryakov <ap@webkit.org> | 7 * Copyright (C) 2007 Alexey Proskuryakov <ap@webkit.org> |
| 8 * Copyright (C) 2007, 2008 Eric Seidel <eric@webkit.org> | 8 * Copyright (C) 2007, 2008 Eric Seidel <eric@webkit.org> |
| 9 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. | 9 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. |
| 10 * (http://www.torchmobile.com/) | 10 * (http://www.torchmobile.com/) |
| (...skipping 332 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 343 for (size_t selectorIndex = 0; selectorIndex != kNotFound; | 343 for (size_t selectorIndex = 0; selectorIndex != kNotFound; |
| 344 selectorIndex = | 344 selectorIndex = |
| 345 rule->selectorList().indexOfNextSelectorAfter(selectorIndex)) | 345 rule->selectorList().indexOfNextSelectorAfter(selectorIndex)) |
| 346 addRule(rule, selectorIndex, addRuleFlags); | 346 addRule(rule, selectorIndex, addRuleFlags); |
| 347 } | 347 } |
| 348 | 348 |
| 349 void RuleSet::compactPendingRules(PendingRuleMap& pendingMap, | 349 void RuleSet::compactPendingRules(PendingRuleMap& pendingMap, |
| 350 CompactRuleMap& compactMap) { | 350 CompactRuleMap& compactMap) { |
| 351 for (auto& item : pendingMap) { | 351 for (auto& item : pendingMap) { |
| 352 HeapLinkedStack<RuleData>* pendingRules = item.value.release(); | 352 HeapLinkedStack<RuleData>* pendingRules = item.value.release(); |
| 353 // TODO(meade): crbug.com/694520 |
| 354 CHECK(!item.key.isNull()); |
| 355 CHECK(pendingRules); |
| 353 CompactRuleMap::ValueType* compactRules = | 356 CompactRuleMap::ValueType* compactRules = |
| 354 compactMap.insert(item.key, nullptr).storedValue; | 357 compactMap.insert(item.key, nullptr).storedValue; |
| 358 // TODO(meade): crbug.com/694520 |
| 359 CHECK(compactRules); |
| 355 | 360 |
| 356 HeapTerminatedArrayBuilder<RuleData> builder(compactRules->value.release()); | 361 HeapTerminatedArrayBuilder<RuleData> builder(compactRules->value.release()); |
| 357 builder.grow(pendingRules->size()); | 362 builder.grow(pendingRules->size()); |
| 358 while (!pendingRules->isEmpty()) { | 363 while (!pendingRules->isEmpty()) { |
| 359 builder.append(pendingRules->peek()); | 364 builder.append(pendingRules->peek()); |
| 360 pendingRules->pop(); | 365 pendingRules->pop(); |
| 361 } | 366 } |
| 362 | 367 |
| 363 compactRules->value = builder.release(); | 368 compactRules->value = builder.release(); |
| 364 } | 369 } |
| 365 } | 370 } |
| 366 | 371 |
| 367 void RuleSet::compactRules() { | 372 void RuleSet::compactRules() { |
| 368 ASSERT(m_pendingRules); | 373 // TODO(meade): crbug.com/694520 |
| 374 CHECK(m_pendingRules); |
| 369 PendingRuleMaps* pendingRules = m_pendingRules.release(); | 375 PendingRuleMaps* pendingRules = m_pendingRules.release(); |
| 370 compactPendingRules(pendingRules->idRules, m_idRules); | 376 compactPendingRules(pendingRules->idRules, m_idRules); |
| 371 compactPendingRules(pendingRules->classRules, m_classRules); | 377 compactPendingRules(pendingRules->classRules, m_classRules); |
| 372 compactPendingRules(pendingRules->tagRules, m_tagRules); | 378 compactPendingRules(pendingRules->tagRules, m_tagRules); |
| 373 compactPendingRules(pendingRules->shadowPseudoElementRules, | 379 compactPendingRules(pendingRules->shadowPseudoElementRules, |
| 374 m_shadowPseudoElementRules); | 380 m_shadowPseudoElementRules); |
| 375 m_linkPseudoClassRules.shrinkToFit(); | 381 m_linkPseudoClassRules.shrinkToFit(); |
| 376 m_cuePseudoRules.shrinkToFit(); | 382 m_cuePseudoRules.shrinkToFit(); |
| 377 m_focusPseudoClassRules.shrinkToFit(); | 383 m_focusPseudoClassRules.shrinkToFit(); |
| 378 m_placeholderPseudoRules.shrinkToFit(); | 384 m_placeholderPseudoRules.shrinkToFit(); |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 426 } | 432 } |
| 427 | 433 |
| 428 #ifndef NDEBUG | 434 #ifndef NDEBUG |
| 429 void RuleSet::show() const { | 435 void RuleSet::show() const { |
| 430 for (const auto& rule : m_allRules) | 436 for (const auto& rule : m_allRules) |
| 431 rule.selector().show(); | 437 rule.selector().show(); |
| 432 } | 438 } |
| 433 #endif | 439 #endif |
| 434 | 440 |
| 435 } // namespace blink | 441 } // namespace blink |
| OLD | NEW |