Add an argument indicating the type of insertion to Node::insertedInto
[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
31 namespace WebCore {
32
33 using namespace HTMLNames;
34
35 inline HTMLBaseElement::HTMLBaseElement(const QualifiedName& tagName, Document& document)
36     : HTMLElement(tagName, document)
37 {
38     ASSERT(hasTagName(baseTag));
39 }
40
41 Ref<HTMLBaseElement> HTMLBaseElement::create(const QualifiedName& tagName, Document& document)
42 {
43     return adoptRef(*new HTMLBaseElement(tagName, document));
44 }
45
46 void HTMLBaseElement::parseAttribute(const QualifiedName& name, const AtomicString& value)
47 {
48     if (name == hrefAttr || name == targetAttr)
49         document().processBaseElement();
50     else
51         HTMLElement::parseAttribute(name, value);
52 }
53
54 Node::InsertedIntoResult HTMLBaseElement::insertedInto(InsertionType insertionType, ContainerNode& parentOfInsertedTree)
55 {
56     HTMLElement::insertedInto(insertionType, parentOfInsertedTree);
57     if (insertionType.connectedToDocument)
58         document().processBaseElement();
59     return InsertedIntoResult::Done;
60 }
61
62 void HTMLBaseElement::removedFrom(ContainerNode& insertionPoint)
63 {
64     HTMLElement::removedFrom(insertionPoint);
65     if (insertionPoint.isConnected())
66         document().processBaseElement();
67 }
68
69 bool HTMLBaseElement::isURLAttribute(const Attribute& attribute) const
70 {
71     return attribute.name().localName() == hrefAttr || HTMLElement::isURLAttribute(attribute);
72 }
73
74 String HTMLBaseElement::target() const
75 {
76     return attributeWithoutSynchronization(targetAttr);
77 }
78
79 URL HTMLBaseElement::href() const
80 {
81     // This does not use the getURLAttribute function because that will resolve relative to the document's base URL;
82     // base elements like this one can be used to set that base URL. Thus we need to resolve relative to the document's
83     // URL and ignore the base URL.
84
85     const AtomicString& attributeValue = attributeWithoutSynchronization(hrefAttr);
86     if (attributeValue.isNull())
87         return document().url();
88
89     URL url = !document().decoder() ?
90         URL(document().url(), stripLeadingAndTrailingHTMLSpaces(attributeValue)) :
91         URL(document().url(), stripLeadingAndTrailingHTMLSpaces(attributeValue), document().decoder()->encoding());
92
93     if (!url.isValid())
94         return URL();
95
96     return url;
97 }
98
99 void HTMLBaseElement::setHref(const AtomicString& value)
100 {
101     setAttributeWithoutSynchronization(hrefAttr, value);
102 }
103
104 }