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

Side by Side Diff: Source/modules/mediasource/WebKitMediaSource.cpp

Issue 14619016: Add WebKit prefix to MediaSource,SourceBuffer, and SourceBufferList objects. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Rebase Created 7 years, 7 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
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2012 Google Inc. All rights reserved. 2 * Copyright (C) 2012 Google 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 are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 11 matching lines...) Expand all
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #include "config.h" 31 #include "config.h"
32 #include "modules/mediasource/MediaSource.h" 32 #include "modules/mediasource/WebKitMediaSource.h"
33 33
34 #include "core/dom/Event.h" 34 #include "core/dom/Event.h"
35 #include "core/html/TimeRanges.h" 35 #include "core/html/TimeRanges.h"
36 #include "core/platform/ContentType.h" 36 #include "core/platform/ContentType.h"
37 #include "core/platform/MIMETypeRegistry.h" 37 #include "core/platform/MIMETypeRegistry.h"
38 #include "core/platform/graphics/SourceBufferPrivate.h" 38 #include "core/platform/graphics/SourceBufferPrivate.h"
39 #include "wtf/Uint8Array.h" 39 #include "wtf/Uint8Array.h"
40 40
41 namespace WebCore { 41 namespace WebCore {
42 42
43 PassRefPtr<MediaSource> MediaSource::create(ScriptExecutionContext* context) 43 PassRefPtr<WebKitMediaSource> WebKitMediaSource::create(ScriptExecutionContext* context)
44 { 44 {
45 RefPtr<MediaSource> mediaSource(adoptRef(new MediaSource(context))); 45 RefPtr<WebKitMediaSource> mediaSource(adoptRef(new WebKitMediaSource(context )));
46 mediaSource->suspendIfNeeded(); 46 mediaSource->suspendIfNeeded();
47 return mediaSource.release(); 47 return mediaSource.release();
48 } 48 }
49 49
50 MediaSource::MediaSource(ScriptExecutionContext* context) 50 WebKitMediaSource::WebKitMediaSource(ScriptExecutionContext* context)
51 : ActiveDOMObject(context) 51 : ActiveDOMObject(context)
52 , m_readyState(closedKeyword()) 52 , m_readyState(closedKeyword())
53 , m_asyncEventQueue(GenericEventQueue::create(this)) 53 , m_asyncEventQueue(GenericEventQueue::create(this))
54 { 54 {
55 m_sourceBuffers = SourceBufferList::create(scriptExecutionContext(), m_async EventQueue.get()); 55 m_sourceBuffers = WebKitSourceBufferList::create(scriptExecutionContext(), m _asyncEventQueue.get());
56 m_activeSourceBuffers = SourceBufferList::create(scriptExecutionContext(), m _asyncEventQueue.get()); 56 m_activeSourceBuffers = WebKitSourceBufferList::create(scriptExecutionContex t(), m_asyncEventQueue.get());
57 } 57 }
58 58
59 const String& MediaSource::openKeyword() 59 const String& WebKitMediaSource::openKeyword()
60 { 60 {
61 DEFINE_STATIC_LOCAL(const String, open, (ASCIILiteral("open"))); 61 DEFINE_STATIC_LOCAL(const String, open, (ASCIILiteral("open")));
62 return open; 62 return open;
63 } 63 }
64 64
65 const String& MediaSource::closedKeyword() 65 const String& WebKitMediaSource::closedKeyword()
66 { 66 {
67 DEFINE_STATIC_LOCAL(const String, closed, (ASCIILiteral("closed"))); 67 DEFINE_STATIC_LOCAL(const String, closed, (ASCIILiteral("closed")));
68 return closed; 68 return closed;
69 } 69 }
70 70
71 const String& MediaSource::endedKeyword() 71 const String& WebKitMediaSource::endedKeyword()
72 { 72 {
73 DEFINE_STATIC_LOCAL(const String, ended, (ASCIILiteral("ended"))); 73 DEFINE_STATIC_LOCAL(const String, ended, (ASCIILiteral("ended")));
74 return ended; 74 return ended;
75 } 75 }
76 76
77 SourceBufferList* MediaSource::sourceBuffers() 77 WebKitSourceBufferList* WebKitMediaSource::sourceBuffers()
78 { 78 {
79 return m_sourceBuffers.get(); 79 return m_sourceBuffers.get();
80 } 80 }
81 81
82 SourceBufferList* MediaSource::activeSourceBuffers() 82 WebKitSourceBufferList* WebKitMediaSource::activeSourceBuffers()
83 { 83 {
84 // FIXME(91649): support track selection 84 // FIXME(91649): support track selection
85 return m_activeSourceBuffers.get(); 85 return m_activeSourceBuffers.get();
86 } 86 }
87 87
88 double MediaSource::duration() const 88 double WebKitMediaSource::duration() const
89 { 89 {
90 return m_readyState == closedKeyword() ? std::numeric_limits<float>::quiet_N aN() : m_private->duration(); 90 return m_readyState == closedKeyword() ? std::numeric_limits<float>::quiet_N aN() : m_private->duration();
91 } 91 }
92 92
93 void MediaSource::setDuration(double duration, ExceptionCode& ec) 93 void WebKitMediaSource::setDuration(double duration, ExceptionCode& ec)
94 { 94 {
95 if (duration < 0.0 || std::isnan(duration)) { 95 if (duration < 0.0 || std::isnan(duration)) {
96 ec = INVALID_ACCESS_ERR; 96 ec = INVALID_ACCESS_ERR;
97 return; 97 return;
98 } 98 }
99 if (m_readyState != openKeyword()) { 99 if (m_readyState != openKeyword()) {
100 ec = INVALID_STATE_ERR; 100 ec = INVALID_STATE_ERR;
101 return; 101 return;
102 } 102 }
103 m_private->setDuration(duration); 103 m_private->setDuration(duration);
104 } 104 }
105 105
106 SourceBuffer* MediaSource::addSourceBuffer(const String& type, ExceptionCode& ec ) 106 WebKitSourceBuffer* WebKitMediaSource::addSourceBuffer(const String& type, Excep tionCode& ec)
107 { 107 {
108 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-addsourcebuffer 108 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-addsourcebuffer
109 // 1. If type is null or an empty then throw an INVALID_ACCESS_ERR exception and 109 // 1. If type is null or an empty then throw an INVALID_ACCESS_ERR exception and
110 // abort these steps. 110 // abort these steps.
111 if (type.isNull() || type.isEmpty()) { 111 if (type.isNull() || type.isEmpty()) {
112 ec = INVALID_ACCESS_ERR; 112 ec = INVALID_ACCESS_ERR;
113 return 0; 113 return 0;
114 } 114 }
115 115
116 // 2. If type contains a MIME type that is not supported ..., then throw a 116 // 2. If type contains a MIME type that is not supported ..., then throw a
(...skipping 10 matching lines...) Expand all
127 return 0; 127 return 0;
128 } 128 }
129 129
130 // 5. Create a new SourceBuffer object and associated resources. 130 // 5. Create a new SourceBuffer object and associated resources.
131 ContentType contentType(type); 131 ContentType contentType(type);
132 Vector<String> codecs = contentType.codecs(); 132 Vector<String> codecs = contentType.codecs();
133 OwnPtr<SourceBufferPrivate> sourceBufferPrivate; 133 OwnPtr<SourceBufferPrivate> sourceBufferPrivate;
134 switch (m_private->addSourceBuffer(contentType.type(), codecs, &sourceBuffer Private)) { 134 switch (m_private->addSourceBuffer(contentType.type(), codecs, &sourceBuffer Private)) {
135 case MediaSourcePrivate::Ok: { 135 case MediaSourcePrivate::Ok: {
136 ASSERT(sourceBufferPrivate); 136 ASSERT(sourceBufferPrivate);
137 RefPtr<SourceBuffer> buffer = SourceBuffer::create(sourceBufferPrivate.r elease(), this); 137 RefPtr<WebKitSourceBuffer> buffer = WebKitSourceBuffer::create(sourceBuf ferPrivate.release(), this);
138 138
139 // 6. Add the new object to sourceBuffers and fire a addsourcebuffer on that object. 139 // 6. Add the new object to sourceBuffers and fire a addsourcebuffer on that object.
140 m_sourceBuffers->add(buffer); 140 m_sourceBuffers->add(buffer);
141 m_activeSourceBuffers->add(buffer); 141 m_activeSourceBuffers->add(buffer);
142 // 7. Return the new object to the caller. 142 // 7. Return the new object to the caller.
143 return buffer.get(); 143 return buffer.get();
144 } 144 }
145 case MediaSourcePrivate::NotSupported: 145 case MediaSourcePrivate::NotSupported:
146 // 2 (cont). If type contains a MIME type ... that is not supported with the types 146 // 2 (cont). If type contains a MIME type ... that is not supported with the types
147 // specified for the other SourceBuffer objects in sourceBuffers, then t hrow 147 // specified for the other SourceBuffer objects in sourceBuffers, then t hrow
148 // a NOT_SUPPORTED_ERR exception and abort these steps. 148 // a NOT_SUPPORTED_ERR exception and abort these steps.
149 ec = NOT_SUPPORTED_ERR; 149 ec = NOT_SUPPORTED_ERR;
150 return 0; 150 return 0;
151 case MediaSourcePrivate::ReachedIdLimit: 151 case MediaSourcePrivate::ReachedIdLimit:
152 // 3 (cont). If the user agent can't handle any more SourceBuffer object s then throw 152 // 3 (cont). If the user agent can't handle any more SourceBuffer object s then throw
153 // a QUOTA_EXCEEDED_ERR exception and abort these steps. 153 // a QUOTA_EXCEEDED_ERR exception and abort these steps.
154 ec = QUOTA_EXCEEDED_ERR; 154 ec = QUOTA_EXCEEDED_ERR;
155 return 0; 155 return 0;
156 } 156 }
157 157
158 ASSERT_NOT_REACHED(); 158 ASSERT_NOT_REACHED();
159 return 0; 159 return 0;
160 } 160 }
161 161
162 void MediaSource::removeSourceBuffer(SourceBuffer* buffer, ExceptionCode& ec) 162 void WebKitMediaSource::removeSourceBuffer(WebKitSourceBuffer* buffer, Exception Code& ec)
163 { 163 {
164 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-removesourcebuffer 164 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-removesourcebuffer
165 // 1. If sourceBuffer is null then throw an INVALID_ACCESS_ERR exception and 165 // 1. If sourceBuffer is null then throw an INVALID_ACCESS_ERR exception and
166 // abort these steps. 166 // abort these steps.
167 if (!buffer) { 167 if (!buffer) {
168 ec = INVALID_ACCESS_ERR; 168 ec = INVALID_ACCESS_ERR;
169 return; 169 return;
170 } 170 }
171 171
172 // 2. If sourceBuffers is empty then throw an INVALID_STATE_ERR exception an d 172 // 2. If sourceBuffers is empty then throw an INVALID_STATE_ERR exception an d
173 // abort these steps. 173 // abort these steps.
174 if (!m_private || !m_sourceBuffers->length()) { 174 if (!m_private || !m_sourceBuffers->length()) {
175 ec = INVALID_STATE_ERR; 175 ec = INVALID_STATE_ERR;
176 return; 176 return;
177 } 177 }
178 178
179 // 3. If sourceBuffer specifies an object that is not in sourceBuffers then 179 // 3. If sourceBuffer specifies an object that is not in sourceBuffers then
180 // throw a NOT_FOUND_ERR exception and abort these steps. 180 // throw a NOT_FOUND_ERR exception and abort these steps.
181 // 6. Remove sourceBuffer from sourceBuffers and fire a removesourcebuffer e vent 181 // 6. Remove sourceBuffer from sourceBuffers and fire a removesourcebuffer e vent
182 // on that object. 182 // on that object.
183 if (!m_sourceBuffers->remove(buffer)) { 183 if (!m_sourceBuffers->remove(buffer)) {
184 ec = NOT_FOUND_ERR; 184 ec = NOT_FOUND_ERR;
185 return; 185 return;
186 } 186 }
187 187
188 // 7. Destroy all resources for sourceBuffer. 188 // 7. Destroy all resources for sourceBuffer.
189 m_activeSourceBuffers->remove(buffer); 189 m_activeSourceBuffers->remove(buffer);
190 190
191 // 4. Remove track information from audioTracks, videoTracks, and textTracks for all tracks 191 // 4. Remove track information from audioTracks, videoTracks, and textTracks for all tracks
192 // associated with sourceBuffer and fire a simple event named change on the modified lists. 192 // associated with sourceBuffer and fire a simple event named change on the modified lists.
193 // FIXME(91649): support track selection 193 // FIXME(91649): support track selection
194 194
195 // 5. If sourceBuffer is in activeSourceBuffers, then remove it from that li st and fire a 195 // 5. If sourceBuffer is in activeSourceBuffers, then remove it from that li st and fire a
196 // removesourcebuffer event on that object. 196 // removesourcebuffer event on that object.
197 // FIXME(91649): support track selection 197 // FIXME(91649): support track selection
198 } 198 }
199 199
200 const String& MediaSource::readyState() const 200 const String& WebKitMediaSource::readyState() const
201 { 201 {
202 return m_readyState; 202 return m_readyState;
203 } 203 }
204 204
205 void MediaSource::setReadyState(const String& state) 205 void WebKitMediaSource::setReadyState(const String& state)
206 { 206 {
207 ASSERT(state == openKeyword() || state == closedKeyword() || state == endedK eyword()); 207 ASSERT(state == openKeyword() || state == closedKeyword() || state == endedK eyword());
208 if (m_readyState == state) 208 if (m_readyState == state)
209 return; 209 return;
210 210
211 String oldState = m_readyState; 211 String oldState = m_readyState;
212 m_readyState = state; 212 m_readyState = state;
213 213
214 if (m_readyState == closedKeyword()) { 214 if (m_readyState == closedKeyword()) {
215 m_sourceBuffers->clear(); 215 m_sourceBuffers->clear();
216 m_activeSourceBuffers->clear(); 216 m_activeSourceBuffers->clear();
217 m_private.clear(); 217 m_private.clear();
218 scheduleEvent(eventNames().webkitsourcecloseEvent); 218 scheduleEvent(eventNames().webkitsourcecloseEvent);
219 return; 219 return;
220 } 220 }
221 221
222 if (oldState == openKeyword() && m_readyState == endedKeyword()) { 222 if (oldState == openKeyword() && m_readyState == endedKeyword()) {
223 scheduleEvent(eventNames().webkitsourceendedEvent); 223 scheduleEvent(eventNames().webkitsourceendedEvent);
224 return; 224 return;
225 } 225 }
226 226
227 if (m_readyState == openKeyword()) { 227 if (m_readyState == openKeyword()) {
228 scheduleEvent(eventNames().webkitsourceopenEvent); 228 scheduleEvent(eventNames().webkitsourceopenEvent);
229 return; 229 return;
230 } 230 }
231 } 231 }
232 232
233 void MediaSource::endOfStream(const String& error, ExceptionCode& ec) 233 void WebKitMediaSource::endOfStream(const String& error, ExceptionCode& ec)
234 { 234 {
235 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-endofstream 235 // 3.1 http://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-sour ce.html#dom-endofstream
236 // 1. If the readyState attribute is not in the "open" state then throw an 236 // 1. If the readyState attribute is not in the "open" state then throw an
237 // INVALID_STATE_ERR exception and abort these steps. 237 // INVALID_STATE_ERR exception and abort these steps.
238 if (!m_private || m_readyState != openKeyword()) { 238 if (!m_private || m_readyState != openKeyword()) {
239 ec = INVALID_STATE_ERR; 239 ec = INVALID_STATE_ERR;
240 return; 240 return;
241 } 241 }
242 242
243 MediaSourcePrivate::EndOfStreamStatus eosStatus = MediaSourcePrivate::EosNoE rror; 243 MediaSourcePrivate::EndOfStreamStatus eosStatus = MediaSourcePrivate::EosNoE rror;
244 244
245 if (error.isNull() || error.isEmpty()) 245 if (error.isNull() || error.isEmpty())
246 eosStatus = MediaSourcePrivate::EosNoError; 246 eosStatus = MediaSourcePrivate::EosNoError;
247 else if (error == "network") 247 else if (error == "network")
248 eosStatus = MediaSourcePrivate::EosNetworkError; 248 eosStatus = MediaSourcePrivate::EosNetworkError;
249 else if (error == "decode") 249 else if (error == "decode")
250 eosStatus = MediaSourcePrivate::EosDecodeError; 250 eosStatus = MediaSourcePrivate::EosDecodeError;
251 else { 251 else {
252 ec = INVALID_ACCESS_ERR; 252 ec = INVALID_ACCESS_ERR;
253 return; 253 return;
254 } 254 }
255 255
256 // 2. Change the readyState attribute value to "ended". 256 // 2. Change the readyState attribute value to "ended".
257 setReadyState(endedKeyword()); 257 setReadyState(endedKeyword());
258 m_private->endOfStream(eosStatus); 258 m_private->endOfStream(eosStatus);
259 } 259 }
260 260
261 bool MediaSource::isTypeSupported(const String& type) 261 bool WebKitMediaSource::isTypeSupported(const String& type)
262 { 262 {
263 // Section 2.1 isTypeSupported() method steps. 263 // Section 2.1 isTypeSupported() method steps.
264 // https://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-source. html#widl-MediaSource-isTypeSupported-boolean-DOMString-type 264 // https://dvcs.w3.org/hg/html-media/raw-file/tip/media-source/media-source. html#widl-MediaSource-isTypeSupported-boolean-DOMString-type
265 // 1. If type is an empty string, then return false. 265 // 1. If type is an empty string, then return false.
266 if (type.isNull() || type.isEmpty()) 266 if (type.isNull() || type.isEmpty())
267 return false; 267 return false;
268 268
269 ContentType contentType(type); 269 ContentType contentType(type);
270 String codecs = contentType.parameter("codecs"); 270 String codecs = contentType.parameter("codecs");
271 271
272 // 2. If type does not contain a valid MIME type string, then return false. 272 // 2. If type does not contain a valid MIME type string, then return false.
273 if (contentType.type().isEmpty() || codecs.isEmpty()) 273 if (contentType.type().isEmpty() || codecs.isEmpty())
274 return false; 274 return false;
275 275
276 // 3. If type contains a media type or media subtype that the MediaSource do es not support, then return false. 276 // 3. If type contains a media type or media subtype that the MediaSource do es not support, then return false.
277 // 4. If type contains at a codec that the MediaSource does not support, the n return false. 277 // 4. If type contains at a codec that the MediaSource does not support, the n return false.
278 // 5. If the MediaSource does not support the specified combination of media type, media subtype, and codecs then return false. 278 // 5. If the MediaSource does not support the specified combination of media type, media subtype, and codecs then return false.
279 // 6. Return true. 279 // 6. Return true.
280 return MIMETypeRegistry::isSupportedMediaSourceMIMEType(contentType.type(), codecs); 280 return MIMETypeRegistry::isSupportedMediaSourceMIMEType(contentType.type(), codecs);
281 } 281 }
282 282
283 void MediaSource::setPrivateAndOpen(PassOwnPtr<MediaSourcePrivate> mediaSourcePr ivate) 283 void WebKitMediaSource::setPrivateAndOpen(PassOwnPtr<MediaSourcePrivate> mediaSo urcePrivate)
284 { 284 {
285 ASSERT(mediaSourcePrivate); 285 ASSERT(mediaSourcePrivate);
286 ASSERT(!m_private); 286 ASSERT(!m_private);
287 m_private = mediaSourcePrivate; 287 m_private = mediaSourcePrivate;
288 setReadyState(openKeyword()); 288 setReadyState(openKeyword());
289 } 289 }
290 290
291 const AtomicString& MediaSource::interfaceName() const 291 const AtomicString& WebKitMediaSource::interfaceName() const
292 { 292 {
293 return eventNames().interfaceForMediaSource; 293 return eventNames().interfaceForWebKitMediaSource;
294 } 294 }
295 295
296 ScriptExecutionContext* MediaSource::scriptExecutionContext() const 296 ScriptExecutionContext* WebKitMediaSource::scriptExecutionContext() const
297 { 297 {
298 return ActiveDOMObject::scriptExecutionContext(); 298 return ActiveDOMObject::scriptExecutionContext();
299 } 299 }
300 300
301 bool MediaSource::hasPendingActivity() const 301 bool WebKitMediaSource::hasPendingActivity() const
302 { 302 {
303 return m_private || m_asyncEventQueue->hasPendingEvents() 303 return m_private || m_asyncEventQueue->hasPendingEvents()
304 || ActiveDOMObject::hasPendingActivity(); 304 || ActiveDOMObject::hasPendingActivity();
305 } 305 }
306 306
307 void MediaSource::stop() 307 void WebKitMediaSource::stop()
308 { 308 {
309 m_private.clear(); 309 m_private.clear();
310 m_asyncEventQueue->cancelAllEvents(); 310 m_asyncEventQueue->cancelAllEvents();
311 } 311 }
312 312
313 EventTargetData* MediaSource::eventTargetData() 313 EventTargetData* WebKitMediaSource::eventTargetData()
314 { 314 {
315 return &m_eventTargetData; 315 return &m_eventTargetData;
316 } 316 }
317 317
318 EventTargetData* MediaSource::ensureEventTargetData() 318 EventTargetData* WebKitMediaSource::ensureEventTargetData()
319 { 319 {
320 return &m_eventTargetData; 320 return &m_eventTargetData;
321 } 321 }
322 322
323 void MediaSource::scheduleEvent(const AtomicString& eventName) 323 void WebKitMediaSource::scheduleEvent(const AtomicString& eventName)
324 { 324 {
325 ASSERT(m_asyncEventQueue); 325 ASSERT(m_asyncEventQueue);
326 326
327 RefPtr<Event> event = Event::create(eventName, false, false); 327 RefPtr<Event> event = Event::create(eventName, false, false);
328 event->setTarget(this); 328 event->setTarget(this);
329 329
330 m_asyncEventQueue->enqueueEvent(event.release()); 330 m_asyncEventQueue->enqueueEvent(event.release());
331 } 331 }
332 332
333 } // namespace WebCore 333 } // namespace WebCore
OLDNEW
« no previous file with comments | « Source/modules/mediasource/WebKitMediaSource.h ('k') | Source/modules/mediasource/WebKitMediaSource.idl » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698