| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "core/css/parser/CSSLazyParsingState.h" | 5 #include "core/css/parser/CSSLazyParsingState.h" |
| 6 #include "core/css/parser/CSSLazyPropertyParserImpl.h" | 6 #include "core/css/parser/CSSLazyPropertyParserImpl.h" |
| 7 #include "core/css/parser/CSSParserTokenRange.h" | 7 #include "core/css/parser/CSSParserTokenRange.h" |
| 8 #include "core/dom/Document.h" | 8 #include "core/dom/Document.h" |
| 9 #include "core/frame/UseCounter.h" | 9 #include "core/frame/UseCounter.h" |
| 10 #include "platform/Histogram.h" | 10 #include "platform/Histogram.h" |
| 11 | 11 |
| 12 namespace blink { | 12 namespace blink { |
| 13 | 13 |
| 14 CSSLazyParsingState::CSSLazyParsingState(const CSSParserContext& context, | 14 CSSLazyParsingState::CSSLazyParsingState(const CSSParserContext& context, |
| 15 Vector<String> escapedStrings, | |
| 16 const String& sheetText, | 15 const String& sheetText, |
| 17 StyleSheetContents* contents) | 16 StyleSheetContents* contents) |
| 18 : m_context(context), | 17 : m_context(context), |
| 19 m_escapedStrings(std::move(escapedStrings)), | |
| 20 m_sheetText(sheetText), | 18 m_sheetText(sheetText), |
| 21 m_owningContents(contents), | 19 m_owningContents(contents), |
| 22 m_parsedStyleRules(0), | 20 m_parsedStyleRules(0), |
| 23 m_totalStyleRules(0), | 21 m_totalStyleRules(0), |
| 24 m_styleRulesNeededForNextMilestone(0), | 22 m_styleRulesNeededForNextMilestone(0), |
| 25 m_usage(UsageGe0), | 23 m_usage(UsageGe0), |
| 26 m_shouldUseCount(!!m_context.useCounter()) { | 24 m_shouldUseCount(!!m_context.useCounter()) { |
| 27 recordUsageMetrics(); | 25 recordUsageMetrics(); |
| 28 } | 26 } |
| 29 | 27 |
| 30 CSSLazyPropertyParserImpl* CSSLazyParsingState::createLazyParser( | 28 CSSLazyPropertyParserImpl* CSSLazyParsingState::createLazyParser( |
| 31 const CSSParserTokenRange& block) { | 29 size_t blockOffset) { |
| 32 ++m_totalStyleRules; | 30 ++m_totalStyleRules; |
| 33 return new CSSLazyPropertyParserImpl(std::move(block), this); | 31 return new CSSLazyPropertyParserImpl(blockOffset, this); |
| 34 } | 32 } |
| 35 | 33 |
| 36 const CSSParserContext& CSSLazyParsingState::context() { | 34 const CSSParserContext& CSSLazyParsingState::context() { |
| 37 DCHECK(m_owningContents); | 35 DCHECK(m_owningContents); |
| 38 if (!m_shouldUseCount) { | 36 if (!m_shouldUseCount) { |
| 39 DCHECK(!m_context.useCounter()); | 37 DCHECK(!m_context.useCounter()); |
| 40 return m_context; | 38 return m_context; |
| 41 } | 39 } |
| 42 | 40 |
| 43 // Try as best as possible to grab a valid UseCounter if the underlying | 41 // Try as best as possible to grab a valid UseCounter if the underlying |
| (...skipping 12 matching lines...) Expand all Loading... |
| 56 void CSSLazyParsingState::countRuleParsed() { | 54 void CSSLazyParsingState::countRuleParsed() { |
| 57 ++m_parsedStyleRules; | 55 ++m_parsedStyleRules; |
| 58 while (m_parsedStyleRules > m_styleRulesNeededForNextMilestone) { | 56 while (m_parsedStyleRules > m_styleRulesNeededForNextMilestone) { |
| 59 DCHECK_NE(UsageAll, m_usage); | 57 DCHECK_NE(UsageAll, m_usage); |
| 60 ++m_usage; | 58 ++m_usage; |
| 61 recordUsageMetrics(); | 59 recordUsageMetrics(); |
| 62 } | 60 } |
| 63 } | 61 } |
| 64 | 62 |
| 65 bool CSSLazyParsingState::shouldLazilyParseProperties( | 63 bool CSSLazyParsingState::shouldLazilyParseProperties( |
| 66 const CSSSelectorList& selectors, | 64 const CSSSelectorList& selectors) const { |
| 67 const CSSParserTokenRange& block) const { | |
| 68 // Simple heuristic for an empty block. Note that |block| here does not | |
| 69 // include {} brackets. We avoid lazy parsing empty blocks so we can avoid | |
| 70 // considering them when possible for matching. Lazy blocks must always be | |
| 71 // considered. Three tokens is a reasonable minimum for a block: | |
| 72 // ident ':' <value>. | |
| 73 if (block.end() - block.begin() <= 2) | |
| 74 return false; | |
| 75 | |
| 76 // Disallow lazy parsing for blocks which have before/after in their selector | 65 // Disallow lazy parsing for blocks which have before/after in their selector |
| 77 // list. This ensures we don't cause a collectFeatures() when we trigger | 66 // list. This ensures we don't cause a collectFeatures() when we trigger |
| 78 // parsing for attr() functions which would trigger expensive invalidation | 67 // parsing for attr() functions which would trigger expensive invalidation |
| 79 // propagation. | 68 // propagation. |
| 80 for (const auto* s = selectors.first(); s; s = CSSSelectorList::next(*s)) { | 69 for (const auto* s = selectors.first(); s; s = CSSSelectorList::next(*s)) { |
| 81 for (const CSSSelector* current = s; current; | 70 for (const CSSSelector* current = s; current; |
| 82 current = current->tagHistory()) { | 71 current = current->tagHistory()) { |
| 83 const CSSSelector::PseudoType type(current->getPseudoType()); | 72 const CSSSelector::PseudoType type(current->getPseudoType()); |
| 84 if (type == CSSSelector::PseudoBefore || type == CSSSelector::PseudoAfter) | 73 if (type == CSSSelector::PseudoBefore || type == CSSSelector::PseudoAfter) |
| 85 return false; | 74 return false; |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 119 | 108 |
| 120 usageHistogram.count(m_usage); | 109 usageHistogram.count(m_usage); |
| 121 } | 110 } |
| 122 | 111 |
| 123 DEFINE_TRACE(CSSLazyParsingState) { | 112 DEFINE_TRACE(CSSLazyParsingState) { |
| 124 visitor->trace(m_owningContents); | 113 visitor->trace(m_owningContents); |
| 125 visitor->trace(m_document); | 114 visitor->trace(m_document); |
| 126 } | 115 } |
| 127 | 116 |
| 128 } // namespace blink | 117 } // namespace blink |
| OLD | NEW |