blob: 92ad8382b07547e04dc15dc119a8b7f4466e1033 [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ppapi/cpp/dev/audio_input_dev.h"
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_errors.h"
#include "ppapi/cpp/dev/resource_array_dev.h"
#include "ppapi/cpp/instance_handle.h"
#include "ppapi/cpp/module_impl.h"
namespace pp {
namespace {
template <> const char* interface_name<PPB_AudioInput_Dev_0_2>() {
return PPB_AUDIO_INPUT_DEV_INTERFACE_0_2;
}
template <> const char* interface_name<PPB_AudioInput_Dev_0_1>() {
return PPB_AUDIO_INPUT_DEV_INTERFACE_0_1;
}
} // namespace
AudioInput_Dev::AudioInput_Dev() : audio_input_callback_(NULL),
user_data_(NULL) {
}
AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance,
const AudioConfig& config,
PPB_AudioInput_Callback callback,
void* user_data)
: config_(config),
audio_input_callback_(callback),
user_data_(user_data) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
PassRefFromConstructor(get_interface<PPB_AudioInput_Dev_0_2>()->Create(
instance.pp_instance()));
} else if (has_interface<PPB_AudioInput_Dev_0_1>()) {
PassRefFromConstructor(get_interface<PPB_AudioInput_Dev_0_1>()->Create(
instance.pp_instance(), config.pp_resource(), callback, user_data));
}
}
AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance)
: audio_input_callback_(NULL),
user_data_(NULL) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
PassRefFromConstructor(get_interface<PPB_AudioInput_Dev_0_2>()->Create(
instance.pp_instance()));
}
}
AudioInput_Dev::~AudioInput_Dev() {
}
// static
bool AudioInput_Dev::IsAvailable() {
return has_interface<PPB_AudioInput_Dev_0_2>() ||
has_interface<PPB_AudioInput_Dev_0_1>();
}
int32_t AudioInput_Dev::EnumerateDevices(
const CompletionCallbackWithOutput<std::vector<DeviceRef_Dev> >& callback) {
if (!has_interface<PPB_AudioInput_Dev_0_2>())
return callback.MayForce(PP_ERROR_NOINTERFACE);
if (!callback.pp_completion_callback().func)
return callback.MayForce(PP_ERROR_BLOCKS_MAIN_THREAD);
// ArrayOutputCallbackConverter is responsible to delete it.
ResourceArray_Dev::ArrayOutputCallbackData* data =
new ResourceArray_Dev::ArrayOutputCallbackData(
callback.output(), callback.pp_completion_callback());
return get_interface<PPB_AudioInput_Dev_0_2>()->EnumerateDevices(
pp_resource(), &data->resource_array_output,
PP_MakeCompletionCallback(
&ResourceArray_Dev::ArrayOutputCallbackConverter, data));
}
int32_t AudioInput_Dev::Open(const DeviceRef_Dev& device_ref,
const CompletionCallback& callback) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
return get_interface<PPB_AudioInput_Dev_0_2>()->Open(
pp_resource(), device_ref.pp_resource(), config_.pp_resource(),
audio_input_callback_, user_data_, callback.pp_completion_callback());
}
if (has_interface<PPB_AudioInput_Dev_0_1>()) {
if (is_null())
return callback.MayForce(PP_ERROR_FAILED);
// If the v0.1 interface is being used and there is a valid resource handle,
// then the default device has been successfully opened during resource
// creation.
if (device_ref.is_null())
return callback.MayForce(PP_OK);
// The v0.1 interface doesn't support devices other than the default one.
return callback.MayForce(PP_ERROR_NOTSUPPORTED);
}
return callback.MayForce(PP_ERROR_NOINTERFACE);
}
int32_t AudioInput_Dev::Open(const DeviceRef_Dev& device_ref,
const AudioConfig& config,
PPB_AudioInput_Callback audio_input_callback,
void* user_data,
const CompletionCallback& callback) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
return get_interface<PPB_AudioInput_Dev_0_2>()->Open(
pp_resource(), device_ref.pp_resource(), config.pp_resource(),
audio_input_callback, user_data, callback.pp_completion_callback());
}
return callback.MayForce(PP_ERROR_NOINTERFACE);
}
bool AudioInput_Dev::StartCapture() {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
return PP_ToBool(get_interface<PPB_AudioInput_Dev_0_2>()->StartCapture(
pp_resource()));
}
if (has_interface<PPB_AudioInput_Dev_0_1>()) {
return PP_ToBool(get_interface<PPB_AudioInput_Dev_0_1>()->StartCapture(
pp_resource()));
}
return false;
}
bool AudioInput_Dev::StopCapture() {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
return PP_ToBool(get_interface<PPB_AudioInput_Dev_0_2>()->StopCapture(
pp_resource()));
}
if (has_interface<PPB_AudioInput_Dev_0_1>()) {
return PP_ToBool(get_interface<PPB_AudioInput_Dev_0_1>()->StopCapture(
pp_resource()));
}
return false;
}
void AudioInput_Dev::Close() {
if (has_interface<PPB_AudioInput_Dev_0_2>())
get_interface<PPB_AudioInput_Dev_0_2>()->Close(pp_resource());
}
} // namespace pp