diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/html/HTMLSourceElement.cpp | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/WebCore/html/HTMLSourceElement.cpp')
-rw-r--r-- | Source/WebCore/html/HTMLSourceElement.cpp | 104 |
1 files changed, 85 insertions, 19 deletions
diff --git a/Source/WebCore/html/HTMLSourceElement.cpp b/Source/WebCore/html/HTMLSourceElement.cpp index 4e0b4dae6..45018b71c 100644 --- a/Source/WebCore/html/HTMLSourceElement.cpp +++ b/Source/WebCore/html/HTMLSourceElement.cpp @@ -10,10 +10,10 @@ * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR @@ -24,14 +24,16 @@ */ #include "config.h" -#if ENABLE(VIDEO) #include "HTMLSourceElement.h" #include "Event.h" #include "EventNames.h" #include "HTMLDocument.h" +#if ENABLE(VIDEO) #include "HTMLMediaElement.h" +#endif #include "HTMLNames.h" +#include "HTMLPictureElement.h" #include "Logging.h" namespace WebCore { @@ -40,59 +42,81 @@ using namespace HTMLNames; inline HTMLSourceElement::HTMLSourceElement(const QualifiedName& tagName, Document& document) : HTMLElement(tagName, document) - , m_errorEventTimer(this, &HTMLSourceElement::errorEventTimerFired) + , ActiveDOMObject(&document) + , m_errorEventTimer(*this, &HTMLSourceElement::errorEventTimerFired) { LOG(Media, "HTMLSourceElement::HTMLSourceElement - %p", this); ASSERT(hasTagName(sourceTag)); } -PassRefPtr<HTMLSourceElement> HTMLSourceElement::create(const QualifiedName& tagName, Document& document) +Ref<HTMLSourceElement> HTMLSourceElement::create(const QualifiedName& tagName, Document& document) +{ + auto sourceElement = adoptRef(*new HTMLSourceElement(tagName, document)); + sourceElement->suspendIfNeeded(); + return sourceElement; +} + +Ref<HTMLSourceElement> HTMLSourceElement::create(Document& document) { - return adoptRef(new HTMLSourceElement(tagName, document)); + return create(sourceTag, document); } Node::InsertionNotificationRequest HTMLSourceElement::insertedInto(ContainerNode& insertionPoint) { HTMLElement::insertedInto(insertionPoint); Element* parent = parentElement(); - if (parent && parent->isMediaElement()) - toHTMLMediaElement(parentNode())->sourceWasAdded(this); + if (parent) { +#if ENABLE(VIDEO) + if (is<HTMLMediaElement>(*parent)) + downcast<HTMLMediaElement>(*parent).sourceWasAdded(this); + else +#endif + if (is<HTMLPictureElement>(*parent)) + downcast<HTMLPictureElement>(*parent).sourcesChanged(); + } return InsertionDone; } void HTMLSourceElement::removedFrom(ContainerNode& removalRoot) { Element* parent = parentElement(); - if (!parent && removalRoot.isElementNode()) - parent = &toElement(removalRoot); - if (parent && parent->isMediaElement()) - toHTMLMediaElement(parent)->sourceWasRemoved(this); + if (!parent && is<Element>(removalRoot)) + parent = &downcast<Element>(removalRoot); + if (parent) { +#if ENABLE(VIDEO) + if (is<HTMLMediaElement>(*parent)) + downcast<HTMLMediaElement>(*parent).sourceWasRemoved(this); + else +#endif + if (is<HTMLPictureElement>(*parent)) + downcast<HTMLPictureElement>(*parent).sourcesChanged(); + } HTMLElement::removedFrom(removalRoot); } void HTMLSourceElement::setSrc(const String& url) { - setAttribute(srcAttr, url); + setAttributeWithoutSynchronization(srcAttr, url); } String HTMLSourceElement::media() const { - return getAttribute(mediaAttr); + return attributeWithoutSynchronization(mediaAttr); } void HTMLSourceElement::setMedia(const String& media) { - setAttribute(mediaAttr, media); + setAttributeWithoutSynchronization(mediaAttr, media); } String HTMLSourceElement::type() const { - return getAttribute(typeAttr); + return attributeWithoutSynchronization(typeAttr); } void HTMLSourceElement::setType(const String& type) { - setAttribute(typeAttr, type); + setAttributeWithoutSynchronization(typeAttr, type); } void HTMLSourceElement::scheduleErrorEvent() @@ -110,7 +134,7 @@ void HTMLSourceElement::cancelPendingErrorEvent() m_errorEventTimer.stop(); } -void HTMLSourceElement::errorEventTimerFired(Timer<HTMLSourceElement>&) +void HTMLSourceElement::errorEventTimerFired() { LOG(Media, "HTMLSourceElement::errorEventTimerFired - %p", this); dispatchEvent(Event::create(eventNames().errorEvent, false, true)); @@ -121,6 +145,48 @@ bool HTMLSourceElement::isURLAttribute(const Attribute& attribute) const return attribute.name() == srcAttr || HTMLElement::isURLAttribute(attribute); } +const char* HTMLSourceElement::activeDOMObjectName() const +{ + return "HTMLSourceElement"; +} + +bool HTMLSourceElement::canSuspendForDocumentSuspension() const +{ + return true; +} + +void HTMLSourceElement::suspend(ReasonForSuspension why) +{ + if (why == PageCache) { + m_shouldRescheduleErrorEventOnResume = m_errorEventTimer.isActive(); + m_errorEventTimer.stop(); + } +} + +void HTMLSourceElement::resume() +{ + if (m_shouldRescheduleErrorEventOnResume) { + m_errorEventTimer.startOneShot(0); + m_shouldRescheduleErrorEventOnResume = false; + } +} + +void HTMLSourceElement::stop() +{ + cancelPendingErrorEvent(); +} + +void HTMLSourceElement::parseAttribute(const QualifiedName& name, const AtomicString& value) +{ + HTMLElement::parseAttribute(name, value); + if (name == srcsetAttr || name == sizesAttr || name == mediaAttr || name == typeAttr) { + if (name == mediaAttr) + m_mediaQuerySet = MediaQuerySet::create(value); + auto* parent = parentNode(); + if (is<HTMLPictureElement>(parent)) + downcast<HTMLPictureElement>(*parent).sourcesChanged(); + } +} + } -#endif |