blob: 9fc2bd081542ae4034520400a4d8063d5a78bd62 [file] [log] [blame]
/*
* Copyright (C) 1999 Lars Knoll (knoll@kde.org)
* (C) 1999 Antti Koivisto (koivisto@kde.org)
* Copyright (C) 2004, 2006, 2007, 2008, 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 HTMLObjectElement_h
#define HTMLObjectElement_h
#include "FormAssociatedElement.h"
#include "HTMLPlugInImageElement.h"
namespace WebCore {
class HTMLFormElement;
class HTMLObjectElement final : public HTMLPlugInImageElement, public FormAssociatedElement {
public:
static Ref<HTMLObjectElement> create(const QualifiedName&, Document&, HTMLFormElement*, bool createdByParser);
virtual ~HTMLObjectElement();
bool isDocNamedItem() const { return m_docNamedItem; }
bool containsJavaApplet() const;
bool hasFallbackContent() const;
bool useFallbackContent() const final { return m_useFallbackContent; }
void renderFallbackContent();
bool willValidate() const final { return false; }
// Implementation of constraint validation API.
// Note that the object elements are always barred from constraint validation.
static bool checkValidity() { return true; }
void setCustomValidity(const String&) final { }
String validationMessage() const final { return String(); }
using HTMLPlugInImageElement::ref;
using HTMLPlugInImageElement::deref;
using FormAssociatedElement::form;
private:
HTMLObjectElement(const QualifiedName&, Document&, HTMLFormElement*, bool createdByParser);
void parseAttribute(const QualifiedName&, const AtomicString&) final;
bool isPresentationAttribute(const QualifiedName&) const final;
void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStyleProperties&) final;
InsertionNotificationRequest insertedInto(ContainerNode&) final;
void finishedInsertingSubtree() final;
void removedFrom(ContainerNode&) final;
void didMoveToNewDocument(Document* oldDocument) final;
void childrenChanged(const ChildChange&) final;
bool isURLAttribute(const Attribute&) const final;
const AtomicString& imageSourceURL() const final;
RenderWidget* renderWidgetLoadingPlugin() const final;
void addSubresourceAttributeURLs(ListHashSet<URL>&) const final;
void updateWidget(CreatePlugins) final;
void updateDocNamedItem();
// FIXME: This function should not deal with url or serviceType
// so that we can better share code between <object> and <embed>.
void parametersForPlugin(Vector<String>& paramNames, Vector<String>& paramValues, String& url, String& serviceType);
bool shouldAllowQuickTimeClassIdQuirk();
bool hasValidClassId();
void clearUseFallbackContent() { m_useFallbackContent = false; }
void refFormAssociatedElement() final { ref(); }
void derefFormAssociatedElement() final { deref(); }
HTMLFormElement* virtualForm() const final;
FormNamedItem* asFormNamedItem() final { return this; }
HTMLObjectElement& asHTMLElement() final { return *this; }
const HTMLObjectElement& asHTMLElement() const final { return *this; }
bool isFormControlElement() const final { return false; }
bool isEnumeratable() const final { return true; }
bool appendFormData(FormDataList&, bool) final;
bool canContainRangeEndPoint() const final;
bool m_docNamedItem : 1;
bool m_useFallbackContent : 1;
};
}
#endif