2013-02-02 02:13:23 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim:set ts=2 sw=2 sts=2 et cindent: */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
|
|
|
|
#ifndef MediaBufferDecoder_h_
|
|
|
|
#define MediaBufferDecoder_h_
|
|
|
|
|
|
|
|
#include "nsWrapperCache.h"
|
|
|
|
#include "nsCOMPtr.h"
|
|
|
|
#include "nsAutoPtr.h"
|
|
|
|
#include "nsIThreadPool.h"
|
|
|
|
#include "nsString.h"
|
2013-03-17 11:55:16 +04:00
|
|
|
#include "nsTArray.h"
|
2013-02-02 02:13:23 +04:00
|
|
|
#include "mozilla/dom/TypedArray.h"
|
|
|
|
#include <utility>
|
|
|
|
|
2013-03-17 11:55:16 +04:00
|
|
|
namespace mozilla {
|
2013-02-02 02:13:23 +04:00
|
|
|
|
|
|
|
class MediaDecoderReader;
|
2013-03-17 11:55:16 +04:00
|
|
|
namespace dom {
|
2013-02-02 02:13:23 +04:00
|
|
|
class AudioBuffer;
|
|
|
|
class AudioContext;
|
|
|
|
class DecodeErrorCallback;
|
|
|
|
class DecodeSuccessCallback;
|
|
|
|
}
|
|
|
|
|
2013-07-16 13:00:36 +04:00
|
|
|
struct WebAudioDecodeJob MOZ_FINAL
|
2013-03-17 11:55:16 +04:00
|
|
|
{
|
2013-05-04 00:42:28 +04:00
|
|
|
// You may omit both the success and failure callback, or you must pass both.
|
|
|
|
// The callbacks are only necessary for asynchronous operation.
|
2013-02-02 02:13:23 +04:00
|
|
|
WebAudioDecodeJob(const nsACString& aContentType,
|
|
|
|
dom::AudioContext* aContext,
|
2013-07-16 13:00:36 +04:00
|
|
|
const dom::ArrayBuffer& aBuffer,
|
2013-05-04 00:42:28 +04:00
|
|
|
dom::DecodeSuccessCallback* aSuccessCallback = nullptr,
|
|
|
|
dom::DecodeErrorCallback* aFailureCallback = nullptr);
|
2013-02-02 02:13:23 +04:00
|
|
|
~WebAudioDecodeJob();
|
|
|
|
|
2013-07-16 13:00:36 +04:00
|
|
|
NS_INLINE_DECL_CYCLE_COLLECTING_NATIVE_REFCOUNTING(WebAudioDecodeJob)
|
|
|
|
NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_NATIVE_CLASS(WebAudioDecodeJob)
|
|
|
|
|
2013-02-02 02:13:23 +04:00
|
|
|
enum ErrorCode {
|
|
|
|
NoError,
|
|
|
|
UnknownContent,
|
|
|
|
UnknownError,
|
|
|
|
InvalidContent,
|
|
|
|
NoAudio
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef void (WebAudioDecodeJob::*ResultFn)(ErrorCode);
|
2013-05-13 08:17:00 +04:00
|
|
|
typedef nsAutoArrayPtr<float> ChannelBuffer;
|
2013-02-02 02:13:23 +04:00
|
|
|
|
|
|
|
void OnSuccess(ErrorCode /* ignored */);
|
|
|
|
void OnFailure(ErrorCode aErrorCode);
|
|
|
|
|
|
|
|
bool AllocateBuffer();
|
|
|
|
|
2013-07-16 13:00:36 +04:00
|
|
|
|
|
|
|
JS::Heap<JSObject*> mArrayBuffer;
|
2013-02-02 02:13:23 +04:00
|
|
|
nsCString mContentType;
|
2013-05-13 08:17:00 +04:00
|
|
|
uint32_t mWriteIndex;
|
2013-02-02 02:13:23 +04:00
|
|
|
nsRefPtr<dom::AudioContext> mContext;
|
|
|
|
nsRefPtr<dom::DecodeSuccessCallback> mSuccessCallback;
|
|
|
|
nsRefPtr<dom::DecodeErrorCallback> mFailureCallback; // can be null
|
|
|
|
nsRefPtr<dom::AudioBuffer> mOutput;
|
|
|
|
FallibleTArray<ChannelBuffer> mChannelBuffers;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is used to decode media buffers on a dedicated threadpool.
|
|
|
|
*
|
|
|
|
* This class manages the resources that it uses internally (such as the
|
|
|
|
* thread-pool) and provides a clean external interface.
|
|
|
|
*/
|
|
|
|
class MediaBufferDecoder
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
void AsyncDecodeMedia(const char* aContentType, uint8_t* aBuffer,
|
|
|
|
uint32_t aLength, WebAudioDecodeJob& aDecodeJob);
|
|
|
|
|
2013-05-04 00:42:28 +04:00
|
|
|
bool SyncDecodeMedia(const char* aContentType, uint8_t* aBuffer,
|
|
|
|
uint32_t aLength, WebAudioDecodeJob& aDecodeJob);
|
|
|
|
|
2013-02-02 02:13:23 +04:00
|
|
|
void Shutdown();
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool EnsureThreadPoolInitialized();
|
|
|
|
|
|
|
|
private:
|
|
|
|
nsCOMPtr<nsIThreadPool> mThreadPool;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|