• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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, 2008 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 "DocumentType.h"
25 
26 #include "DOMImplementation.h"
27 #include "Document.h"
28 #include "NamedNodeMap.h"
29 
30 namespace WebCore {
31 
DocumentType(Document * document,const String & n,const String & p,const String & s)32 DocumentType::DocumentType(Document* document, const String& n, const String& p, const String& s)
33     : Node(document)
34     , m_name(n)
35     , m_publicId(p)
36     , m_systemId(s)
37 {
38 }
39 
baseURI() const40 KURL DocumentType::baseURI() const
41 {
42     return KURL();
43 }
44 
nodeName() const45 String DocumentType::nodeName() const
46 {
47     return name();
48 }
49 
nodeType() const50 Node::NodeType DocumentType::nodeType() const
51 {
52     return DOCUMENT_TYPE_NODE;
53 }
54 
cloneNode(bool)55 PassRefPtr<Node> DocumentType::cloneNode(bool /*deep*/)
56 {
57     return new DocumentType(document(), m_name, m_publicId, m_systemId);
58 }
59 
insertedIntoDocument()60 void DocumentType::insertedIntoDocument()
61 {
62     // Our document node can be null if we were created by a DOMImplementation.  We use the parent() instead.
63     ASSERT(parent() && parent()->isDocumentNode());
64     if (parent() && parent()->isDocumentNode()) {
65         Document* doc = static_cast<Document*>(parent());
66         if (!doc->doctype())
67             doc->setDocType(this);
68     }
69     Node::insertedIntoDocument();
70 }
71 
removedFromDocument()72 void DocumentType::removedFromDocument()
73 {
74     if (document() && document()->doctype() == this)
75         document()->setDocType(0);
76     Node::removedFromDocument();
77 }
78 
79 }
80