74c6a5f984a7d9404f9f33da975830304faae390
[WebKit-https.git] / WebCore / html / HTMLEmbedElement.cpp
1 /**
2  * This file is part of the DOM implementation for KDE.
3  *
4  * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
5  *           (C) 1999 Antti Koivisto (koivisto@kde.org)
6  *           (C) 2000 Stefan Schimanski (1Stein@gmx.de)
7  * Copyright (C) 2004, 2005, 2006 Apple Computer, Inc.
8  * Copyright (C) 2007 Trolltech ASA
9  *
10  * This library is free software; you can redistribute it and/or
11  * modify it under the terms of the GNU Library General Public
12  * License as published by the Free Software Foundation; either
13  * version 2 of the License, or (at your option) any later version.
14  *
15  * This library is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18  * Library General Public License for more details.
19  *
20  * You should have received a copy of the GNU Library General Public License
21  * along with this library; see the file COPYING.LIB.  If not, write to
22  * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
23  * Boston, MA 02111-1307, USA.
24  */
25 #include "config.h"
26 #include "HTMLEmbedElement.h"
27
28 #include "CSSPropertyNames.h"
29 #include "Frame.h"
30 #include "FrameView.h"
31 #include "HTMLDocument.h"
32 #include "HTMLNames.h"
33 #include "csshelper.h"
34 #include "RenderPartObject.h"
35
36 #if ENABLE(SVG)
37 #include "ExceptionCode.h"
38 #include "SVGDocument.h"
39 #endif
40
41 namespace WebCore {
42
43 using namespace HTMLNames;
44
45 HTMLEmbedElement::HTMLEmbedElement(Document* doc)
46     : HTMLPlugInElement(embedTag, doc)
47 {
48 }
49
50 HTMLEmbedElement::~HTMLEmbedElement()
51 {
52 #if USE(JAVASCRIPTCORE_BINDINGS)
53     // m_instance should have been cleaned up in detach().
54     ASSERT(!m_instance);
55 #endif
56 }
57
58 #if USE(JAVASCRIPTCORE_BINDINGS)
59 KJS::Bindings::Instance *HTMLEmbedElement::getInstance() const
60 {
61     Frame* frame = document()->frame();
62     if (!frame)
63         return 0;
64
65     if (m_instance)
66         return m_instance.get();
67     
68     RenderObject *r = renderer();
69     if (!r) {
70         Node *p = parentNode();
71         if (p && p->hasTagName(objectTag))
72             r = p->renderer();
73     }
74
75     if (r && r->isWidget()) {
76         if (Widget* widget = static_cast<RenderWidget*>(r)->widget()) 
77             m_instance = frame->createScriptInstanceForWidget(widget);
78     }
79     return m_instance.get();
80 }
81 #endif
82
83 bool HTMLEmbedElement::mapToEntry(const QualifiedName& attrName, MappedAttributeEntry& result) const
84 {
85     if (attrName == hiddenAttr) {
86         result = eUniversal;
87         return false;
88     }
89         
90     return HTMLPlugInElement::mapToEntry(attrName, result);
91 }
92
93 void HTMLEmbedElement::parseMappedAttribute(MappedAttribute* attr)
94 {
95     String val = attr->value();
96   
97     if (attr->name() == typeAttr) {
98         m_serviceType = val.lower();
99         int pos = m_serviceType.find(";");
100         if (pos != -1)
101             m_serviceType = m_serviceType.left(pos);
102     } else if (attr->name() == codeAttr || attr->name() == srcAttr)
103          url = parseURL(val).deprecatedString();
104     else if (attr->name() == pluginpageAttr || attr->name() == pluginspageAttr)
105         m_pluginPage = val;
106     else if (attr->name() == hiddenAttr) {
107         if (val.lower() == "yes" || val.lower() == "true") {
108             // FIXME: Not dynamic, but it's not really important that such a rarely-used
109             // feature work dynamically.
110             addCSSLength(attr, CSS_PROP_WIDTH, "0");
111             addCSSLength(attr, CSS_PROP_HEIGHT, "0");
112         }
113     } else if (attr->name() == nameAttr) {
114         if (inDocument() && document()->isHTMLDocument()) {
115             HTMLDocument* doc = static_cast<HTMLDocument*>(document());
116             doc->removeNamedItem(oldNameAttr);
117             doc->addNamedItem(val);
118         }
119         oldNameAttr = val;
120     } else
121         HTMLPlugInElement::parseMappedAttribute(attr);
122 }
123
124 bool HTMLEmbedElement::rendererIsNeeded(RenderStyle *style)
125 {
126     Frame *frame = document()->frame();
127     if (!frame)
128         return false;
129
130     Node *p = parentNode();
131     if (p && p->hasTagName(objectTag)) {
132         ASSERT(p->renderer());
133         return false;
134     }
135
136     return true;
137 }
138
139 RenderObject *HTMLEmbedElement::createRenderer(RenderArena *arena, RenderStyle *style)
140 {
141     return new (arena) RenderPartObject(this);
142 }
143
144 void HTMLEmbedElement::attach()
145 {
146     HTMLPlugInElement::attach();
147
148     if (renderer())
149         static_cast<RenderPartObject*>(renderer())->updateWidget();
150 }
151
152 void HTMLEmbedElement::detach()
153 {
154 #if USE(JAVASCRIPTCORE_BINDINGS)
155     m_instance = 0;
156 #endif
157     HTMLPlugInElement::detach();
158 }
159
160 void HTMLEmbedElement::insertedIntoDocument()
161 {
162     if (document()->isHTMLDocument()) {
163         HTMLDocument *doc = static_cast<HTMLDocument *>(document());
164         doc->addNamedItem(oldNameAttr);
165     }
166
167     HTMLPlugInElement::insertedIntoDocument();
168 }
169
170 void HTMLEmbedElement::removedFromDocument()
171 {
172     if (document()->isHTMLDocument()) {
173         HTMLDocument *doc = static_cast<HTMLDocument *>(document());
174         doc->removeNamedItem(oldNameAttr);
175     }
176
177     HTMLPlugInElement::removedFromDocument();
178 }
179
180 bool HTMLEmbedElement::isURLAttribute(Attribute *attr) const
181 {
182     return attr->name() == srcAttr;
183 }
184
185 String HTMLEmbedElement::src() const
186 {
187     return getAttribute(srcAttr);
188 }
189
190 void HTMLEmbedElement::setSrc(const String& value)
191 {
192     setAttribute(srcAttr, value);
193 }
194
195 String HTMLEmbedElement::type() const
196 {
197     return getAttribute(typeAttr);
198 }
199
200 void HTMLEmbedElement::setType(const String& value)
201 {
202     setAttribute(typeAttr, value);
203 }
204
205 #if ENABLE(SVG)
206 SVGDocument* HTMLEmbedElement::getSVGDocument(ExceptionCode& ec) const
207 {
208     Document* doc = contentDocument();
209     if (doc && doc->isSVGDocument())
210         return static_cast<SVGDocument*>(doc);
211     // Spec: http://www.w3.org/TR/SVG/struct.html#InterfaceGetSVGDocument
212     ec = NOT_SUPPORTED_ERR;
213     return 0;
214 }
215 #endif
216
217 }