OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
3 * (C) 1999 Antti Koivisto (koivisto@kde.org) | 3 * (C) 1999 Antti Koivisto (koivisto@kde.org) |
4 * (C) 2001 Dirk Mueller (mueller@kde.org) | 4 * (C) 2001 Dirk Mueller (mueller@kde.org) |
5 * (C) 2006 Alexey Proskuryakov (ap@webkit.org) | 5 * (C) 2006 Alexey Proskuryakov (ap@webkit.org) |
6 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2011, 2012 Apple Inc. All r ights reserved. | 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2011, 2012 Apple Inc. All r ights reserved. |
7 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/) | 7 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t orchmobile.com/) |
8 * Copyright (C) 2008, 2009, 2011, 2012 Google Inc. All rights reserved. | 8 * Copyright (C) 2008, 2009, 2011, 2012 Google Inc. All rights reserved. |
9 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies) | 9 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies) |
10 * Copyright (C) Research In Motion Limited 2010-2011. All rights reserved. | 10 * Copyright (C) Research In Motion Limited 2010-2011. All rights reserved. |
(...skipping 1091 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1102 | 1102 |
1103 void Document::setCharset(const String& charset) | 1103 void Document::setCharset(const String& charset) |
1104 { | 1104 { |
1105 if (DocumentLoader* documentLoader = loader()) | 1105 if (DocumentLoader* documentLoader = loader()) |
1106 documentLoader->setUserChosenEncoding(charset); | 1106 documentLoader->setUserChosenEncoding(charset); |
1107 WTF::TextEncoding encoding(charset); | 1107 WTF::TextEncoding encoding(charset); |
1108 // In case the encoding didn't exist, we keep the old one (helps some sites specifying invalid encodings). | 1108 // In case the encoding didn't exist, we keep the old one (helps some sites specifying invalid encodings). |
1109 if (!encoding.isValid()) | 1109 if (!encoding.isValid()) |
1110 return; | 1110 return; |
1111 DocumentEncodingData newEncodingData = m_encodingData; | 1111 DocumentEncodingData newEncodingData = m_encodingData; |
1112 newEncodingData.encoding = encoding; | 1112 newEncodingData.setEncoding(encoding); |
1113 setEncodingData(newEncodingData); | 1113 setEncodingData(newEncodingData); |
1114 } | 1114 } |
1115 | 1115 |
1116 void Document::setContentLanguage(const String& language) | 1116 void Document::setContentLanguage(const String& language) |
1117 { | 1117 { |
1118 if (m_contentLanguage == language) | 1118 if (m_contentLanguage == language) |
1119 return; | 1119 return; |
1120 m_contentLanguage = language; | 1120 m_contentLanguage = language; |
1121 | 1121 |
1122 // Document's style depends on the content language. | 1122 // Document's style depends on the content language. |
(...skipping 979 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2102 // If the document has already been detached, do not make a new axObjectCach e. | 2102 // If the document has already been detached, do not make a new axObjectCach e. |
2103 if (!topDocument->renderView()) | 2103 if (!topDocument->renderView()) |
2104 return 0; | 2104 return 0; |
2105 | 2105 |
2106 ASSERT(topDocument == this || !m_axObjectCache); | 2106 ASSERT(topDocument == this || !m_axObjectCache); |
2107 if (!topDocument->m_axObjectCache) | 2107 if (!topDocument->m_axObjectCache) |
2108 topDocument->m_axObjectCache = adoptPtr(new AXObjectCache(topDocument)); | 2108 topDocument->m_axObjectCache = adoptPtr(new AXObjectCache(topDocument)); |
2109 return topDocument->m_axObjectCache.get(); | 2109 return topDocument->m_axObjectCache.get(); |
2110 } | 2110 } |
2111 | 2111 |
2112 void Document::setVisuallyOrdered() | |
2113 { | |
2114 m_visuallyOrdered = true; | |
2115 // FIXME: How is possible to not have a renderer here? | |
2116 if (renderView()) | |
2117 renderView()->style()->setRTLOrdering(VisualOrder); | |
2118 setNeedsStyleRecalc(); | |
2119 } | |
2120 | |
2121 PassRefPtr<DocumentParser> Document::createParser() | 2112 PassRefPtr<DocumentParser> Document::createParser() |
2122 { | 2113 { |
2123 if (isHTMLDocument()) { | 2114 if (isHTMLDocument()) { |
2124 bool reportErrors = InspectorInstrumentation::collectingHTMLParseErrors( this->page()); | 2115 bool reportErrors = InspectorInstrumentation::collectingHTMLParseErrors( this->page()); |
2125 return HTMLDocumentParser::create(toHTMLDocument(this), reportErrors); | 2116 return HTMLDocumentParser::create(toHTMLDocument(this), reportErrors); |
2126 } | 2117 } |
2127 // FIXME: this should probably pass the frame instead | 2118 // FIXME: this should probably pass the frame instead |
2128 return XMLDocumentParser::create(this, view()); | 2119 return XMLDocumentParser::create(this, view()); |
2129 } | 2120 } |
2130 | 2121 |
(...skipping 1825 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3956 | 3947 |
3957 void Document::setEncodingData(const DocumentEncodingData& newData) | 3948 void Document::setEncodingData(const DocumentEncodingData& newData) |
3958 { | 3949 { |
3959 // It's possible for the encoding of the document to change while we're deco ding | 3950 // It's possible for the encoding of the document to change while we're deco ding |
3960 // data. That can only occur while we're processing the <head> portion of th e | 3951 // data. That can only occur while we're processing the <head> portion of th e |
3961 // document. There isn't much user-visible content in the <head>, but there is | 3952 // document. There isn't much user-visible content in the <head>, but there is |
3962 // the <title> element. This function detects that situation and re-decodes the | 3953 // the <title> element. This function detects that situation and re-decodes the |
3963 // document's title so that the user doesn't see an incorrectly decoded titl e | 3954 // document's title so that the user doesn't see an incorrectly decoded titl e |
3964 // in the title bar. | 3955 // in the title bar. |
3965 if (m_titleElement | 3956 if (m_titleElement |
3966 && encoding() != newData.encoding | 3957 && encoding() != newData.encoding() |
3967 && !m_titleElement->firstElementChild() | 3958 && !m_titleElement->firstElementChild() |
3968 && encoding() == Latin1Encoding() | 3959 && encoding() == Latin1Encoding() |
3969 && m_titleElement->textContent().containsOnlyLatin1()) { | 3960 && m_titleElement->textContent().containsOnlyLatin1()) { |
3970 | 3961 |
3971 CString originalBytes = m_titleElement->textContent().latin1(); | 3962 CString originalBytes = m_titleElement->textContent().latin1(); |
3972 OwnPtr<TextCodec> codec = newTextCodec(newData.encoding); | 3963 OwnPtr<TextCodec> codec = newTextCodec(newData.encoding()); |
3973 String correctlyDecodedTitle = codec->decode(originalBytes.data(), origi nalBytes.length(), true); | 3964 String correctlyDecodedTitle = codec->decode(originalBytes.data(), origi nalBytes.length(), true); |
3974 m_titleElement->setTextContent(correctlyDecodedTitle, IGNORE_EXCEPTION); | 3965 m_titleElement->setTextContent(correctlyDecodedTitle, IGNORE_EXCEPTION); |
3975 } | 3966 } |
3976 | 3967 |
3977 m_encodingData = newData; | 3968 m_encodingData = newData; |
3969 | |
3970 // FIXME: Should be removed as part of https://code.google.com/p/chromium/is sues/detail?id=319643 | |
3971 if (m_encodingData.encoding().usesVisualOrdering() != m_visuallyOrdered) { | |
3972 m_visuallyOrdered = !m_visuallyOrdered; | |
eseidel
2013/11/25 19:57:13
This reads weird to me, but OK.
oystein (OOO til 10th of July)
2013/11/27 00:47:30
Habitual thing, I suppose; I added a new local var
| |
3973 // FIXME: How is possible to not have a renderer here? | |
3974 if (renderView()) | |
3975 renderView()->style()->setRTLOrdering(m_visuallyOrdered ? VisualOrde r : LogicalOrder); | |
3976 setNeedsStyleRecalc(); | |
3977 } | |
3978 } | 3978 } |
3979 | 3979 |
3980 KURL Document::completeURL(const String& url, const KURL& baseURLOverride) const | 3980 KURL Document::completeURL(const String& url, const KURL& baseURLOverride) const |
3981 { | 3981 { |
3982 // Always return a null URL when passed a null string. | 3982 // Always return a null URL when passed a null string. |
3983 // FIXME: Should we change the KURL constructor to have this behavior? | 3983 // FIXME: Should we change the KURL constructor to have this behavior? |
3984 // See also [CSS]StyleSheet::completeURL(const String&) | 3984 // See also [CSS]StyleSheet::completeURL(const String&) |
3985 if (url.isNull()) | 3985 if (url.isNull()) |
3986 return KURL(); | 3986 return KURL(); |
3987 const KURL& baseURL = ((baseURLOverride.isEmpty() || baseURLOverride == blan kURL()) && parentDocument()) ? parentDocument()->baseURL() : baseURLOverride; | 3987 const KURL& baseURL = ((baseURLOverride.isEmpty() || baseURLOverride == blan kURL()) && parentDocument()) ? parentDocument()->baseURL() : baseURLOverride; |
(...skipping 1209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
5197 void Document::modifiedStyleSheet(StyleSheet* sheet, RecalcStyleTime when, Style ResolverUpdateMode updateMode) | 5197 void Document::modifiedStyleSheet(StyleSheet* sheet, RecalcStyleTime when, Style ResolverUpdateMode updateMode) |
5198 { | 5198 { |
5199 if (!isActive()) | 5199 if (!isActive()) |
5200 return; | 5200 return; |
5201 | 5201 |
5202 styleEngine()->modifiedStyleSheet(sheet); | 5202 styleEngine()->modifiedStyleSheet(sheet); |
5203 styleResolverChanged(when, updateMode); | 5203 styleResolverChanged(when, updateMode); |
5204 } | 5204 } |
5205 | 5205 |
5206 } // namespace WebCore | 5206 } // namespace WebCore |
OLD | NEW |