[WPE][GTK] Build failure with ENABLE_ACCESSIBILITY=OFF
[WebKit-https.git] / Source / WebCore / html / HTMLBaseElement.cpp
1 /*
2  * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
3  *           (C) 1999 Antti Koivisto (koivisto@kde.org)
4  *           (C) 2001 Dirk Mueller (mueller@kde.org)
5  * Copyright (C) 2003, 2008, 2009, 2010 Apple Inc. All rights reserved.
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Library General Public
9  * License as published by the Free Software Foundation; either
10  * version 2 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Library General Public License for more details.
16  *
17  * You should have received a copy of the GNU Library General Public License
18  * along with this library; see the file COPYING.LIB.  If not, write to
19  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20  * Boston, MA 02110-1301, USA.
21  */
22
23 #include "config.h"
24 #include "HTMLBaseElement.h"
25
26 #include "Document.h"
27 #include "HTMLNames.h"
28 #include "HTMLParserIdioms.h"
29 #include "TextResourceDecoder.h"
30 #include <wtf/IsoMallocInlines.h>
31
32 namespace WebCore {
33
34 WTF_MAKE_ISO_ALLOCATED_IMPL(HTMLBaseElement);
35
36 using namespace HTMLNames;
37
38 inline HTMLBaseElement::HTMLBaseElement(const QualifiedName& tagName, Document& document)
39     : HTMLElement(tagName, document)
40 {
41     ASSERT(hasTagName(baseTag));
42 }
43
44 Ref<HTMLBaseElement> HTMLBaseElement::create(const QualifiedName& tagName, Document& document)
45 {
46     return adoptRef(*new HTMLBaseElement(tagName, document));
47 }
48
49 void HTMLBaseElement::parseAttribute(const QualifiedName& name, const AtomString& value)
50 {
51     if (name == hrefAttr || name == targetAttr)
52         document().processBaseElement();
53     else
54         HTMLElement::parseAttribute(name, value);
55 }
56
57 Node::InsertedIntoAncestorResult HTMLBaseElement::insertedIntoAncestor(InsertionType insertionType, ContainerNode& parentOfInsertedTree)
58 {
59     HTMLElement::insertedIntoAncestor(insertionType, parentOfInsertedTree);
60     if (insertionType.connectedToDocument)
61         document().processBaseElement();
62     return InsertedIntoAncestorResult::Done;
63 }
64
65 void HTMLBaseElement::removedFromAncestor(RemovalType removalType, ContainerNode& oldParentOfRemovedTree)
66 {
67     HTMLElement::removedFromAncestor(removalType, oldParentOfRemovedTree);
68     if (removalType.disconnectedFromDocument)
69         document().processBaseElement();
70 }
71
72 bool HTMLBaseElement::isURLAttribute(const Attribute& attribute) const
73 {
74     return attribute.name().localName() == hrefAttr || HTMLElement::isURLAttribute(attribute);
75 }
76
77 String HTMLBaseElement::target() const
78 {
79     return attributeWithoutSynchronization(targetAttr);
80 }
81
82 URL HTMLBaseElement::href() const
83 {
84     // This does not use the getURLAttribute function because that will resolve relative to the document's base URL;
85     // base elements like this one can be used to set that base URL. Thus we need to resolve relative to the document's
86     // URL and ignore the base URL.
87
88     const AtomString& attributeValue = attributeWithoutSynchronization(hrefAttr);
89     if (attributeValue.isNull())
90         return document().url();
91
92     auto* encoding = document().decoder() ? document().decoder()->encodingForURLParsing() : nullptr;
93     URL url(document().url(), stripLeadingAndTrailingHTMLSpaces(attributeValue), encoding);
94
95     if (!url.isValid())
96         return URL();
97
98     return url;
99 }
100
101 void HTMLBaseElement::setHref(const AtomString& value)
102 {
103     setAttributeWithoutSynchronization(hrefAttr, value);
104 }
105
106 }