Chromium Code Reviews| 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/CSSParserContext.h" | 5 #include "core/css/parser/CSSParserContext.h" |
| 6 | 6 |
| 7 #include "core/css/CSSStyleSheet.h" | |
| 8 #include "core/css/StyleSheetContents.h" | |
| 7 #include "core/frame/Settings.h" | 9 #include "core/frame/Settings.h" |
| 8 #include "core/frame/csp/ContentSecurityPolicy.h" | 10 #include "core/frame/csp/ContentSecurityPolicy.h" |
| 9 #include "core/html/imports/HTMLImportsController.h" | 11 #include "core/html/imports/HTMLImportsController.h" |
| 10 | 12 |
| 11 namespace blink { | 13 namespace blink { |
| 12 | 14 |
| 13 CSSParserContext::CSSParserContext(CSSParserMode mode, | 15 // static |
| 14 UseCounter* useCounter, | 16 CSSParserContext* CSSParserContext::create(const CSSParserContext* other, |
| 15 SelectorProfile profile) | 17 const CSSStyleSheet* styleSheet) { |
| 18 return new CSSParserContext(other, UseCounter::getFrom(styleSheet)); | |
| 19 } | |
| 20 | |
| 21 // static | |
| 22 CSSParserContext* CSSParserContext::create( | |
| 23 const CSSParserContext* other, | |
| 24 const StyleSheetContents* styleSheetContents) { | |
| 25 return new CSSParserContext(other, UseCounter::getFrom(styleSheetContents)); | |
| 26 } | |
| 27 | |
| 28 CSSParserContext::CSSParserContext(CSSParserMode mode, SelectorProfile profile) | |
| 16 : m_mode(mode), | 29 : m_mode(mode), |
| 17 m_matchMode(mode), | 30 m_matchMode(mode), |
| 18 m_profile(profile), | 31 m_profile(profile), |
| 19 m_isHTMLDocument(false), | 32 m_isHTMLDocument(false), |
| 20 m_useLegacyBackgroundSizeShorthandBehavior(false), | 33 m_useLegacyBackgroundSizeShorthandBehavior(false), |
| 21 m_shouldCheckContentSecurityPolicy(DoNotCheckContentSecurityPolicy), | 34 m_shouldCheckContentSecurityPolicy(DoNotCheckContentSecurityPolicy), |
| 22 m_useCounter(useCounter) {} | 35 m_useCounter(nullptr) {} |
| 23 | 36 |
| 24 CSSParserContext::CSSParserContext(const Document& document, | 37 CSSParserContext::CSSParserContext(const Document& document, |
| 25 UseCounter* useCounter, | |
| 26 const KURL& baseURL, | 38 const KURL& baseURL, |
| 27 const String& charset, | 39 const String& charset, |
| 28 SelectorProfile profile) | 40 SelectorProfile profile) |
| 29 : m_baseURL(baseURL.isNull() ? document.baseURL() : baseURL), | 41 : m_baseURL(baseURL.isNull() ? document.baseURL() : baseURL), |
| 30 m_charset(charset), | 42 m_charset(charset), |
| 31 m_mode(document.inQuirksMode() ? HTMLQuirksMode : HTMLStandardMode), | 43 m_mode(document.inQuirksMode() ? HTMLQuirksMode : HTMLStandardMode), |
| 32 m_profile(profile), | 44 m_profile(profile), |
| 33 m_referrer(m_baseURL.strippedForUseAsReferrer(), | 45 m_referrer(m_baseURL.strippedForUseAsReferrer(), |
| 34 document.getReferrerPolicy()), | 46 document.getReferrerPolicy()), |
| 35 m_isHTMLDocument(document.isHTMLDocument()), | 47 m_isHTMLDocument(document.isHTMLDocument()), |
| 36 m_useLegacyBackgroundSizeShorthandBehavior( | 48 m_useLegacyBackgroundSizeShorthandBehavior( |
| 37 document.settings() | 49 document.settings() |
| 38 ? document.settings() | 50 ? document.settings() |
| 39 ->getUseLegacyBackgroundSizeShorthandBehavior() | 51 ->getUseLegacyBackgroundSizeShorthandBehavior() |
| 40 : false), | 52 : false), |
| 41 m_shouldCheckContentSecurityPolicy(DoNotCheckContentSecurityPolicy), | 53 m_shouldCheckContentSecurityPolicy(DoNotCheckContentSecurityPolicy), |
| 42 m_useCounter(useCounter) { | 54 m_useCounter(nullptr) { |
| 43 if (ContentSecurityPolicy::shouldBypassMainWorld(&document)) | 55 if (ContentSecurityPolicy::shouldBypassMainWorld(&document)) |
| 44 m_shouldCheckContentSecurityPolicy = DoNotCheckContentSecurityPolicy; | 56 m_shouldCheckContentSecurityPolicy = DoNotCheckContentSecurityPolicy; |
| 45 else | 57 else |
| 46 m_shouldCheckContentSecurityPolicy = CheckContentSecurityPolicy; | 58 m_shouldCheckContentSecurityPolicy = CheckContentSecurityPolicy; |
| 47 | 59 |
| 48 if (HTMLImportsController* importsController = document.importsController()) { | 60 if (HTMLImportsController* importsController = document.importsController()) { |
| 49 m_matchMode = importsController->master()->inQuirksMode() | 61 m_matchMode = importsController->master()->inQuirksMode() |
| 50 ? HTMLQuirksMode | 62 ? HTMLQuirksMode |
| 51 : HTMLStandardMode; | 63 : HTMLStandardMode; |
| 52 } else { | 64 } else { |
| 53 m_matchMode = m_mode; | 65 m_matchMode = m_mode; |
| 54 } | 66 } |
| 55 } | 67 } |
| 56 | 68 |
| 57 CSSParserContext::CSSParserContext(const CSSParserContext& other, | 69 CSSParserContext::CSSParserContext(const CSSParserContext* other, |
| 58 UseCounter* useCounter) | 70 UseCounter* useCounter) |
| 59 : m_baseURL(other.m_baseURL), | 71 : m_baseURL(other->m_baseURL), |
| 60 m_charset(other.m_charset), | 72 m_charset(other->m_charset), |
| 61 m_mode(other.m_mode), | 73 m_mode(other->m_mode), |
| 62 m_matchMode(other.m_matchMode), | 74 m_matchMode(other->m_matchMode), |
| 63 m_profile(other.m_profile), | 75 m_profile(other->m_profile), |
| 64 m_referrer(other.m_referrer), | 76 m_referrer(other->m_referrer), |
| 65 m_isHTMLDocument(other.m_isHTMLDocument), | 77 m_isHTMLDocument(other->m_isHTMLDocument), |
| 66 m_useLegacyBackgroundSizeShorthandBehavior( | 78 m_useLegacyBackgroundSizeShorthandBehavior( |
| 67 other.m_useLegacyBackgroundSizeShorthandBehavior), | 79 other->m_useLegacyBackgroundSizeShorthandBehavior), |
| 68 m_shouldCheckContentSecurityPolicy( | 80 m_shouldCheckContentSecurityPolicy( |
| 69 other.m_shouldCheckContentSecurityPolicy), | 81 other->m_shouldCheckContentSecurityPolicy), |
| 70 m_useCounter(useCounter) {} | 82 m_useCounter(useCounter) {} |
| 71 | 83 |
| 72 bool CSSParserContext::operator==(const CSSParserContext& other) const { | 84 bool CSSParserContext::operator==(const CSSParserContext& other) const { |
| 73 return m_baseURL == other.m_baseURL && m_charset == other.m_charset && | 85 return m_baseURL == other.m_baseURL && m_charset == other.m_charset && |
| 74 m_mode == other.m_mode && m_matchMode == other.m_matchMode && | 86 m_mode == other.m_mode && m_matchMode == other.m_matchMode && |
| 75 m_profile == other.m_profile && | 87 m_profile == other.m_profile && |
| 76 m_isHTMLDocument == other.m_isHTMLDocument && | 88 m_isHTMLDocument == other.m_isHTMLDocument && |
| 77 m_useLegacyBackgroundSizeShorthandBehavior == | 89 m_useLegacyBackgroundSizeShorthandBehavior == |
| 78 other.m_useLegacyBackgroundSizeShorthandBehavior; | 90 other.m_useLegacyBackgroundSizeShorthandBehavior; |
| 79 } | 91 } |
| 80 | 92 |
| 81 const CSSParserContext& strictCSSParserContext() { | 93 const CSSParserContext* strictCSSParserContext() { |
| 82 DEFINE_STATIC_LOCAL(CSSParserContext, strictContext, | 94 DEFINE_STATIC_LOCAL(CSSParserContext, strictContext, |
| 83 (HTMLStandardMode, nullptr)); | 95 (new CSSParserContext(HTMLStandardMode))); |
| 84 return strictContext; | 96 return &strictContext; |
|
haraken
2017/01/12 04:51:13
Or you can change the type of the return value to
Bret
2017/01/13 02:15:28
I think this is okay, as long as it isn't wrong. T
| |
| 85 } | 97 } |
| 86 | 98 |
| 87 KURL CSSParserContext::completeURL(const String& url) const { | 99 KURL CSSParserContext::completeURL(const String& url) const { |
| 88 if (url.isNull()) | 100 if (url.isNull()) |
| 89 return KURL(); | 101 return KURL(); |
| 90 if (charset().isEmpty()) | 102 if (charset().isEmpty()) |
| 91 return KURL(baseURL(), url); | 103 return KURL(baseURL(), url); |
| 92 return KURL(baseURL(), url, charset()); | 104 return KURL(baseURL(), url, charset()); |
| 93 } | 105 } |
| 94 | 106 |
| 95 } // namespace blink | 107 } // namespace blink |
| OLD | NEW |