4fab58e34d4655ecf4e37da5dd9c3c5622f40768
[WebKit-https.git] / Source / WebCore / dom / DocumentFragment.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) 2004, 2005, 2006, 2009 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 "DocumentFragment.h"
25
26 #include "Document.h"
27 #include "ElementDescendantIterator.h"
28 #include "HTMLDocumentParser.h"
29 #include "Page.h"
30 #include "Settings.h"
31 #include "XMLDocumentParser.h"
32
33 namespace WebCore {
34
35 DocumentFragment::DocumentFragment(Document& document, ConstructionType constructionType)
36     : ContainerNode(document, constructionType)
37 {
38 }
39
40 Ref<DocumentFragment> DocumentFragment::create(Document& document)
41 {
42     return adoptRef(*new DocumentFragment(document, Node::CreateDocumentFragment));
43 }
44
45 String DocumentFragment::nodeName() const
46 {
47     return ASCIILiteral("#document-fragment");
48 }
49
50 Node::NodeType DocumentFragment::nodeType() const
51 {
52     return DOCUMENT_FRAGMENT_NODE;
53 }
54
55 bool DocumentFragment::childTypeAllowed(NodeType type) const
56 {
57     switch (type) {
58         case ELEMENT_NODE:
59         case PROCESSING_INSTRUCTION_NODE:
60         case COMMENT_NODE:
61         case TEXT_NODE:
62         case CDATA_SECTION_NODE:
63         case ENTITY_REFERENCE_NODE:
64             return true;
65         default:
66             return false;
67     }
68 }
69
70 RefPtr<Node> DocumentFragment::cloneNodeInternal(Document& targetDocument, CloningOperation type)
71 {
72     RefPtr<DocumentFragment> clone = create(targetDocument);
73     switch (type) {
74     case CloningOperation::OnlySelf:
75     case CloningOperation::SelfWithTemplateContent:
76         break;
77     case CloningOperation::Everything:
78         cloneChildNodes(clone.get());
79         break;
80     }
81     return clone;
82 }
83
84 void DocumentFragment::parseHTML(const String& source, Element* contextElement, ParserContentPolicy parserContentPolicy)
85 {
86     ASSERT(contextElement);
87     HTMLDocumentParser::parseDocumentFragment(source, *this, *contextElement, parserContentPolicy);
88 }
89
90 bool DocumentFragment::parseXML(const String& source, Element* contextElement, ParserContentPolicy parserContentPolicy)
91 {
92     return XMLDocumentParser::parseDocumentFragment(source, *this, contextElement, parserContentPolicy);
93 }
94
95 Element* DocumentFragment::getElementById(const AtomicString& id) const
96 {
97     // Fast path for ShadowRoot, where we are both a DocumentFragment and a TreeScope.
98     if (isTreeScope())
99         return treeScope().getElementById(id);
100
101     // Otherwise, fall back to iterating all of the element descendants.
102     for (auto& element : elementDescendants(*this)) {
103         if (element.getIdAttribute() == id)
104             return const_cast<Element*>(&element);
105     }
106
107     return nullptr;
108 }
109
110 }