Chromium Code Reviews| Index: Source/modules/webmidi/MIDIAccess.h |
| diff --git a/Source/modules/webmidi/MIDIAccess.h b/Source/modules/webmidi/MIDIAccess.h |
| index a683b042b0839a19bd7010bf426a8e1455fe88f7..658c22a2c462f074314a2873322125ab5d3b22db 100644 |
| --- a/Source/modules/webmidi/MIDIAccess.h |
| +++ b/Source/modules/webmidi/MIDIAccess.h |
| @@ -31,6 +31,8 @@ |
| #ifndef MIDIAccess_h |
| #define MIDIAccess_h |
| +#include "bindings/v8/MIDIAccessResolver.h" |
| +#include "bindings/v8/ScriptPromise.h" |
| #include "bindings/v8/ScriptWrappable.h" |
| #include "core/dom/ActiveDOMObject.h" |
| #include "core/events/EventTarget.h" |
| @@ -38,7 +40,9 @@ |
| #include "modules/webmidi/MIDIAccessor.h" |
| #include "modules/webmidi/MIDIAccessorClient.h" |
| #include "modules/webmidi/MIDIInput.h" |
| +#include "modules/webmidi/MIDIOptions.h" |
| #include "modules/webmidi/MIDIOutput.h" |
| +#include "platform/Timer.h" |
| #include "wtf/RefCounted.h" |
| #include "wtf/RefPtr.h" |
| #include "wtf/Vector.h" |
| @@ -46,13 +50,12 @@ |
| namespace WebCore { |
| class ExecutionContext; |
| -class MIDIAccessPromise; |
| class MIDIAccess FINAL : public RefCountedWillBeRefCountedGarbageCollected<MIDIAccess>, public ScriptWrappable, public ActiveDOMObject, public EventTargetWithInlineData, public MIDIAccessorClient { |
| DEFINE_EVENT_TARGET_REFCOUNTING(RefCountedWillBeRefCountedGarbageCollected<MIDIAccess>); |
| public: |
| virtual ~MIDIAccess(); |
| - static PassRefPtrWillBeRawPtr<MIDIAccess> create(ExecutionContext*, MIDIAccessPromise*); |
| + static PassRefPtrWillBeRawPtr<MIDIAccess> create(const MIDIOptions&, ExecutionContext*); |
| MIDIInputVector inputs() const { return m_inputs; } |
| MIDIOutputVector outputs() const { return m_outputs; } |
| @@ -68,6 +71,8 @@ public: |
| virtual ExecutionContext* executionContext() const OVERRIDE { return ActiveDOMObject::executionContext(); } |
| // ActiveDOMObject |
| + virtual void suspend() OVERRIDE; |
| + virtual void resume() OVERRIDE; |
| virtual void stop() OVERRIDE; |
| // MIDIAccessorClient |
| @@ -80,21 +85,47 @@ public: |
| void sendMIDIData(unsigned portIndex, const unsigned char* data, size_t length, double timeStampInMilliseconds); |
| void trace(Visitor*); |
| + ScriptPromise startRequest(); |
| private: |
| - MIDIAccess(ExecutionContext*, MIDIAccessPromise*); |
| + enum ActiveDOMObjectState { |
| + Active, |
| + Suspended, |
| + Stopped, |
| + }; |
| + enum PromiseState { |
| + Pending, |
| + Resolving, |
| + Rejecting, |
| + ResolvedOrRejected, |
| + }; |
|
haraken
2014/02/26 11:30:39
This kind of state management looks too complicate
|
| + |
| + MIDIAccess(const MIDIOptions&, ExecutionContext*); |
| - void startRequest(); |
| void permissionDenied(); |
| + void setRequesting(bool); |
| + |
| + void resolve(); |
| + void reject(PassRefPtr<DOMError>); |
| + void resolveNow(); |
| + void rejectNow(PassRefPtr<DOMError>); |
| + |
| + void resumeTimerFired(Timer<MIDIAccess>*); |
| + |
| + ActiveDOMObjectState m_activeDOMObjectState; |
| + PromiseState m_promiseState; |
| MIDIInputVector m_inputs; |
| MIDIOutputVector m_outputs; |
| - RawPtrWillBeMember<MIDIAccessPromise> m_promise; |
| OwnPtr<MIDIAccessor> m_accessor; |
| + OwnPtr<MIDIAccessResolver> m_resolver; |
| + MIDIOptions m_options; |
| bool m_hasAccess; |
| bool m_sysExEnabled; |
| bool m_requesting; |
| + Timer<MIDIAccess> m_resumeTimer; |
| + RefPtr<DOMError> m_error; |
| }; |
| } // namespace WebCore |