Index: third_party/WebKit/Source/core/html/HTMLMediaElement.h |
diff --git a/third_party/WebKit/Source/core/html/HTMLMediaElement.h b/third_party/WebKit/Source/core/html/HTMLMediaElement.h |
index 610750d1bc2b8dc29b87058bb2cdf346f9ae84a7..f2a10fc43c5f45dad599ea9394c6a7e6b8699cc8 100644 |
--- a/third_party/WebKit/Source/core/html/HTMLMediaElement.h |
+++ b/third_party/WebKit/Source/core/html/HTMLMediaElement.h |
@@ -26,8 +26,10 @@ |
#ifndef HTMLMediaElement_h |
#define HTMLMediaElement_h |
+#include "bindings/core/v8/ScriptPromise.h" |
#include "core/CoreExport.h" |
#include "core/dom/ActiveDOMObject.h" |
+#include "core/dom/ExceptionCode.h" |
#include "core/events/GenericEventQueue.h" |
#include "core/html/AutoplayExperimentHelper.h" |
#include "core/html/HTMLElement.h" |
@@ -52,6 +54,7 @@ class KURL; |
class MediaControls; |
class MediaError; |
class HTMLMediaSource; |
+class ScriptState; |
class TextTrackContainer; |
class TextTrackList; |
class TimeRanges; |
@@ -140,7 +143,8 @@ public: |
bool shouldAutoplay(const RecordMetricsBehavior = RecordMetricsBehavior::DoNotRecord); |
bool loop() const; |
void setLoop(bool); |
- void play(); |
+ ScriptPromise playForBindings(ScriptState*); |
+ Nullable<ExceptionCode> play(); |
void pause(); |
void requestRemotePlayback(); |
void requestRemotePlaybackControl(); |
@@ -449,6 +453,16 @@ private: |
// TODO(liberato): remove once autoplay gesture override experiment concludes. |
void triggerAutoplayViewportCheckForTesting(); |
+ void scheduleResolvePlayPromises(); |
+ void scheduleRejectPlayPromises(ExceptionCode); |
+ void scheduleNotifyPlaying(); |
+ |
+ void resolvePlayPromises(); |
+ // TODO(mlamouri): this is used for cancellable tasks because we can't pass |
+ // parameters. |
+ void rejectPlayPromises(); |
+ void rejectPlayPromises(ExceptionCode, const String&); |
+ |
UnthrottledTimer<HTMLMediaElement> m_loadTimer; |
UnthrottledTimer<HTMLMediaElement> m_progressEventTimer; |
UnthrottledTimer<HTMLMediaElement> m_playbackProgressTimer; |
@@ -557,6 +571,11 @@ private: |
OwnPtrWillBeMember<CueTimeline> m_cueTimeline; |
+ PersistentHeapVectorWillBeHeapVector<Member<ScriptPromiseResolver>> m_playResolvers; |
+ OwnPtr<CancellableTaskFactory> m_playPromiseResolveTask; |
+ OwnPtr<CancellableTaskFactory> m_playPromiseRejectTask; |
+ ExceptionCode m_playPromiseErrorCode; |
+ |
// This is a weak reference, since m_audioSourceNode holds a reference to us. |
// FIXME: Oilpan: Consider making this a strongly traced pointer with oilpan where strong cycles are not a problem. |
GC_PLUGIN_IGNORE("http://crbug.com/404577") |