From 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c Mon Sep 17 00:00:00 2001 From: Lorry Tar Creator Date: Tue, 27 Jun 2017 06:07:23 +0000 Subject: webkitgtk-2.16.5 --- Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h | 20 ++++++-------------- 1 file changed, 6 insertions(+), 14 deletions(-) (limited to 'Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h') diff --git a/Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h b/Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h index ff096ecaf..bb5c5e337 100644 --- a/Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h +++ b/Source/WebCore/Modules/webaudio/AsyncAudioDecoder.h @@ -22,13 +22,11 @@ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef AsyncAudioDecoder_h -#define AsyncAudioDecoder_h +#pragma once #include #include #include -#include #include #include @@ -51,29 +49,25 @@ public: ~AsyncAudioDecoder(); // Must be called on the main thread. - void decodeAsync(JSC::ArrayBuffer* audioData, float sampleRate, PassRefPtr successCallback, PassRefPtr errorCallback); + void decodeAsync(Ref&& audioData, float sampleRate, RefPtr&& successCallback, RefPtr&& errorCallback); private: class DecodingTask { WTF_MAKE_NONCOPYABLE(DecodingTask); public: - static std::unique_ptr create(JSC::ArrayBuffer* audioData, float sampleRate, PassRefPtr successCallback, PassRefPtr errorCallback); - + DecodingTask(Ref&& audioData, float sampleRate, RefPtr&& successCallback, RefPtr&& errorCallback); void decode(); private: - DecodingTask(JSC::ArrayBuffer* audioData, float sampleRate, PassRefPtr successCallback, PassRefPtr errorCallback); - - JSC::ArrayBuffer* audioData() { return m_audioData.get(); } + JSC::ArrayBuffer& audioData() { return m_audioData; } float sampleRate() const { return m_sampleRate; } AudioBufferCallback* successCallback() { return m_successCallback.get(); } AudioBufferCallback* errorCallback() { return m_errorCallback.get(); } AudioBuffer* audioBuffer() { return m_audioBuffer.get(); } - static void notifyCompleteDispatch(void* userData); void notifyComplete(); - RefPtr m_audioData; + Ref m_audioData; float m_sampleRate; RefPtr m_successCallback; RefPtr m_errorCallback; @@ -84,10 +78,8 @@ private: void runLoop(); WTF::ThreadIdentifier m_threadID; - Mutex m_threadCreationMutex; + Lock m_threadCreationMutex; MessageQueue m_queue; }; } // namespace WebCore - -#endif // AsyncAudioDecoder_h -- cgit v1.2.1