1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
/*
* Copyright (C) 1999 Lars Knoll (knoll@kde.org)
* (C) 1999 Antti Koivisto (koivisto@kde.org)
* Copyright (C) 2004, 2005, 2006, 2007, 2009 Apple Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef HTMLElement_h
#define HTMLElement_h
#include "StyledElement.h"
namespace WebCore {
class DocumentFragment;
class HTMLCollection;
class HTMLFormElement;
class HTMLElement : public StyledElement {
public:
static PassRefPtr<HTMLElement> create(const QualifiedName& tagName, Document*);
PassRefPtr<HTMLCollection> children();
virtual String title() const;
virtual short tabIndex() const;
void setTabIndex(int);
String innerHTML() const;
String outerHTML() const;
// deprecatedCreateContextualFragment logic should be moved into Range::createContextualFragment
PassRefPtr<DocumentFragment> deprecatedCreateContextualFragment(const String&, FragmentScriptingPermission = FragmentScriptingAllowed);
void setInnerHTML(const String&, ExceptionCode&);
void setOuterHTML(const String&, ExceptionCode&);
void setInnerText(const String&, ExceptionCode&);
void setOuterText(const String&, ExceptionCode&);
Element* insertAdjacentElement(const String& where, Element* newChild, ExceptionCode&);
void insertAdjacentHTML(const String& where, const String& html, ExceptionCode&);
void insertAdjacentText(const String& where, const String& text, ExceptionCode&);
virtual bool supportsFocus() const;
String contentEditable() const;
void setContentEditable(const String&, ExceptionCode&);
virtual bool draggable() const;
void setDraggable(bool);
bool spellcheck() const;
void setSpellcheck(bool);
void click();
virtual void accessKeyAction(bool sendToAnyElement);
virtual bool rendererIsNeeded(RenderStyle*);
virtual RenderObject* createRenderer(RenderArena*, RenderStyle*);
HTMLFormElement* form() const { return virtualForm(); }
static void addHTMLAlignmentToStyledElement(StyledElement*, Attribute*);
HTMLFormElement* findFormAncestor() const;
TextDirection directionalityIfhasDirAutoAttribute(bool& isAuto) const;
protected:
HTMLElement(const QualifiedName& tagName, Document*);
void addHTMLAlignment(Attribute*);
virtual bool mapToEntry(const QualifiedName& attrName, MappedAttributeEntry& result) const;
virtual void parseMappedAttribute(Attribute*);
virtual void childrenChanged(bool changedByParser = false, Node* beforeChange = 0, Node* afterChange = 0, int childCountDelta = 0);
private:
virtual String nodeName() const;
void setContentEditable(Attribute*);
virtual HTMLFormElement* virtualForm() const;
Node* insertAdjacent(const String& where, Node* newChild, ExceptionCode&);
PassRefPtr<DocumentFragment> textToFragment(const String&, ExceptionCode&);
void dirAttributeChanged(Attribute*);
void adjustDirectionalityIfNeededAfterChildAttributeChanged(Element* child);
void calculateAndAdjustDirectionality();
void adjustDirectionalityIfNeededAfterChildrenChanged(Node* beforeChange, int childCountDelta);
TextDirection directionality(Node** strongDirectionalityTextNode= 0) const;
};
inline HTMLElement* toHTMLElement(Node* node)
{
ASSERT(!node || node->isHTMLElement());
return static_cast<HTMLElement*>(node);
}
inline const HTMLElement* toHTMLElement(const Node* node)
{
ASSERT(!node || node->isHTMLElement());
return static_cast<const HTMLElement*>(node);
}
inline HTMLElement::HTMLElement(const QualifiedName& tagName, Document* document)
: StyledElement(tagName, document, CreateHTMLElement)
{
ASSERT(tagName.localName().impl());
}
} // namespace WebCore
#endif // HTMLElement_h
|