Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(50)

Side by Side Diff: Source/core/html/HTMLSourceElement.cpp

Issue 258503007: Use EventSender class in HTMLSourceElement (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « Source/core/html/HTMLSourceElement.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2007, 2008, 2010 Apple Inc. All rights reserved. 2 * Copyright (C) 2007, 2008, 2010 Apple Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * 12 *
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */ 24 */
25 25
26 #include "config.h" 26 #include "config.h"
27 #include "core/html/HTMLSourceElement.h" 27 #include "core/html/HTMLSourceElement.h"
28 28
29 #include "HTMLNames.h" 29 #include "HTMLNames.h"
30 #include "core/events/Event.h" 30 #include "core/events/EventSender.h"
31 #include "core/html/HTMLMediaElement.h" 31 #include "core/html/HTMLMediaElement.h"
32 #include "platform/Logging.h" 32 #include "platform/Logging.h"
33 33
34 using namespace std; 34 using namespace std;
35 35
36 namespace WebCore { 36 namespace WebCore {
37 37
38 using namespace HTMLNames; 38 using namespace HTMLNames;
39 39
40 static SourceEventSender& sourceErrorEventSender()
41 {
42 DEFINE_STATIC_LOCAL(SourceEventSender, sharedErrorEventSender, (EventTypeNam es::error));
43 return sharedErrorEventSender;
44 }
45
40 inline HTMLSourceElement::HTMLSourceElement(Document& document) 46 inline HTMLSourceElement::HTMLSourceElement(Document& document)
41 : HTMLElement(sourceTag, document) 47 : HTMLElement(sourceTag, document)
42 , m_errorEventTimer(this, &HTMLSourceElement::errorEventTimerFired)
43 { 48 {
44 WTF_LOG(Media, "HTMLSourceElement::HTMLSourceElement - %p", this); 49 WTF_LOG(Media, "HTMLSourceElement::HTMLSourceElement - %p", this);
45 ScriptWrappable::init(this); 50 ScriptWrappable::init(this);
46 } 51 }
47 52
48 PassRefPtr<HTMLSourceElement> HTMLSourceElement::create(Document& document) 53 PassRefPtr<HTMLSourceElement> HTMLSourceElement::create(Document& document)
49 { 54 {
50 return adoptRef(new HTMLSourceElement(document)); 55 return adoptRef(new HTMLSourceElement(document));
51 } 56 }
52 57
58 HTMLSourceElement::~HTMLSourceElement()
59 {
60 sourceErrorEventSender().cancelEvent(this);
61 }
62
53 Node::InsertionNotificationRequest HTMLSourceElement::insertedInto(ContainerNode * insertionPoint) 63 Node::InsertionNotificationRequest HTMLSourceElement::insertedInto(ContainerNode * insertionPoint)
54 { 64 {
55 HTMLElement::insertedInto(insertionPoint); 65 HTMLElement::insertedInto(insertionPoint);
56 Element* parent = parentElement(); 66 Element* parent = parentElement();
57 if (isHTMLMediaElement(parent)) 67 if (isHTMLMediaElement(parent))
58 toHTMLMediaElement(parent)->sourceWasAdded(this); 68 toHTMLMediaElement(parent)->sourceWasAdded(this);
59 return InsertionDone; 69 return InsertionDone;
60 } 70 }
61 71
62 void HTMLSourceElement::removedFrom(ContainerNode* removalRoot) 72 void HTMLSourceElement::removedFrom(ContainerNode* removalRoot)
(...skipping 17 matching lines...) Expand all
80 } 90 }
81 91
82 void HTMLSourceElement::setType(const AtomicString& type) 92 void HTMLSourceElement::setType(const AtomicString& type)
83 { 93 {
84 setAttribute(typeAttr, type); 94 setAttribute(typeAttr, type);
85 } 95 }
86 96
87 void HTMLSourceElement::scheduleErrorEvent() 97 void HTMLSourceElement::scheduleErrorEvent()
88 { 98 {
89 WTF_LOG(Media, "HTMLSourceElement::scheduleErrorEvent - %p", this); 99 WTF_LOG(Media, "HTMLSourceElement::scheduleErrorEvent - %p", this);
90 if (m_errorEventTimer.isActive()) 100 sourceErrorEventSender().dispatchEventSoon(this);
91 return;
92
93 m_errorEventTimer.startOneShot(0, FROM_HERE);
94 } 101 }
95 102
96 void HTMLSourceElement::cancelPendingErrorEvent() 103 void HTMLSourceElement::cancelPendingErrorEvent()
97 { 104 {
98 WTF_LOG(Media, "HTMLSourceElement::cancelPendingErrorEvent - %p", this); 105 WTF_LOG(Media, "HTMLSourceElement::cancelPendingErrorEvent - %p", this);
99 m_errorEventTimer.stop(); 106 sourceErrorEventSender().cancelEvent(this);
100 } 107 }
101 108
102 void HTMLSourceElement::errorEventTimerFired(Timer<HTMLSourceElement>*) 109 void HTMLSourceElement::dispatchPendingEvent(SourceEventSender* eventSender)
103 { 110 {
104 WTF_LOG(Media, "HTMLSourceElement::errorEventTimerFired - %p", this); 111 ASSERT_UNUSED(eventSender, eventSender == &sourceErrorEventSender());
112 WTF_LOG(Media, "HTMLSourceElement::dispatchPendingEvent - %p", this);
esprehn 2014/04/24 20:49:56 All these logs seem kind of silly.
105 dispatchEvent(Event::createCancelable(EventTypeNames::error)); 113 dispatchEvent(Event::createCancelable(EventTypeNames::error));
106 } 114 }
107 115
108 bool HTMLSourceElement::isURLAttribute(const Attribute& attribute) const 116 bool HTMLSourceElement::isURLAttribute(const Attribute& attribute) const
109 { 117 {
110 return attribute.name() == srcAttr || HTMLElement::isURLAttribute(attribute) ; 118 return attribute.name() == srcAttr || HTMLElement::isURLAttribute(attribute) ;
111 } 119 }
112 120
113 } 121 }
OLDNEW
« no previous file with comments | « Source/core/html/HTMLSourceElement.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698