Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(285)

Unified Diff: ppapi/cpp/dev/audio_input_dev.cc

Issue 9965080: Change the cpp wrappers of audio input/video capture to use CompletionCallbackWithOutput. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Avoid extra copies in Dispatcher*::operator(). Created 8 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ppapi/cpp/dev/audio_input_dev.cc
diff --git a/ppapi/cpp/dev/audio_input_dev.cc b/ppapi/cpp/dev/audio_input_dev.cc
index 2429259512949385316a5c48351cba88fdbb0a67..1f031514faae0512186b0b3d2f258244fa029efc 100644
--- a/ppapi/cpp/dev/audio_input_dev.cc
+++ b/ppapi/cpp/dev/audio_input_dev.cc
@@ -4,13 +4,11 @@
#include "ppapi/cpp/dev/audio_input_dev.h"
-#include "ppapi/c/dev/ppb_audio_input_dev.h"
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_errors.h"
-#include "ppapi/cpp/completion_callback.h"
-#include "ppapi/cpp/dev/device_ref_dev.h"
#include "ppapi/cpp/dev/resource_array_dev.h"
#include "ppapi/cpp/instance_handle.h"
+#include "ppapi/cpp/logging.h"
#include "ppapi/cpp/module.h"
#include "ppapi/cpp/module_impl.h"
@@ -28,25 +26,7 @@ template <> const char* interface_name<PPB_AudioInput_Dev_0_1>() {
} // namespace
-struct AudioInput_Dev::EnumerateDevicesState {
- EnumerateDevicesState(std::vector<DeviceRef_Dev>* in_devices,
- const CompletionCallback& in_callback,
- AudioInput_Dev* in_audio_input)
- : devices_resource(0),
- devices(in_devices),
- callback(in_callback),
- audio_input(in_audio_input) {
- }
-
- PP_Resource devices_resource;
- // This is owned by the user of AudioInput_Dev::EnumerateDevices().
- std::vector<DeviceRef_Dev>* devices;
- CompletionCallback callback;
- AudioInput_Dev* audio_input;
-};
-
-AudioInput_Dev::AudioInput_Dev() : enum_state_(NULL),
- audio_input_callback_(NULL),
+AudioInput_Dev::AudioInput_Dev() : audio_input_callback_(NULL),
user_data_(NULL) {
}
@@ -55,7 +35,6 @@ AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance,
PPB_AudioInput_Callback callback,
void* user_data)
: config_(config),
- enum_state_(NULL),
audio_input_callback_(callback),
user_data_(user_data) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
@@ -68,8 +47,7 @@ AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance,
}
AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance)
- : enum_state_(NULL),
- audio_input_callback_(NULL),
+ : audio_input_callback_(NULL),
user_data_(NULL) {
if (has_interface<PPB_AudioInput_Dev_0_2>()) {
PassRefFromConstructor(get_interface<PPB_AudioInput_Dev_0_2>()->Create(
@@ -77,26 +55,7 @@ AudioInput_Dev::AudioInput_Dev(const InstanceHandle& instance)
}
}
-AudioInput_Dev::AudioInput_Dev(const AudioInput_Dev& other)
- : Resource(other),
- config_(other.config_),
- enum_state_(NULL),
- audio_input_callback_(other.audio_input_callback_),
- user_data_(other.user_data_) {
-}
-
AudioInput_Dev::~AudioInput_Dev() {
- AbortEnumerateDevices();
-}
-
-AudioInput_Dev& AudioInput_Dev::operator=(const AudioInput_Dev& other) {
- AbortEnumerateDevices();
-
- Resource::operator=(other);
- config_ = other.config_;
- audio_input_callback_ = other.audio_input_callback_;
- user_data_ = other.user_data_;
- return *this;
}
// static
@@ -105,23 +64,22 @@ bool AudioInput_Dev::IsAvailable() {
has_interface<PPB_AudioInput_Dev_0_1>();
}
-int32_t AudioInput_Dev::EnumerateDevices(std::vector<DeviceRef_Dev>* devices,
- const CompletionCallback& callback) {
+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 (!devices)
- return callback.MayForce(PP_ERROR_BADARGUMENT);
if (!callback.pp_completion_callback().func)
return callback.MayForce(PP_ERROR_BLOCKS_MAIN_THREAD);
- if (enum_state_)
- return callback.MayForce(PP_ERROR_INPROGRESS);
- // It will be deleted in OnEnumerateDevicesComplete().
- enum_state_ = new EnumerateDevicesState(devices, callback, this);
+ // CallbackConverter is responsible to delete it.
+ EnumerateCallbackData0_2* data = new EnumerateCallbackData0_2;
+ data->devices = 0;
+ data->output = callback.output();
+ data->original_callback = callback.pp_completion_callback();
+
return get_interface<PPB_AudioInput_Dev_0_2>()->EnumerateDevices(
- pp_resource(), &enum_state_->devices_resource,
- PP_MakeCompletionCallback(&AudioInput_Dev::OnEnumerateDevicesComplete,
- enum_state_));
+ pp_resource(), &data->devices,
+ PP_MakeCompletionCallback(&CallbackConverter, data));
}
int32_t AudioInput_Dev::Open(const DeviceRef_Dev& device_ref,
@@ -196,44 +154,30 @@ void AudioInput_Dev::Close() {
get_interface<PPB_AudioInput_Dev_0_2>()->Close(pp_resource());
}
-void AudioInput_Dev::AbortEnumerateDevices() {
- if (enum_state_) {
- enum_state_->devices = NULL;
- Module::Get()->core()->CallOnMainThread(0, enum_state_->callback,
- PP_ERROR_ABORTED);
- enum_state_->audio_input = NULL;
- enum_state_ = NULL;
- }
-}
-
// static
-void AudioInput_Dev::OnEnumerateDevicesComplete(void* user_data,
- int32_t result) {
- EnumerateDevicesState* enum_state =
- static_cast<EnumerateDevicesState*>(user_data);
-
- bool need_to_callback = !!enum_state->audio_input;
-
- if (result == PP_OK) {
- // It will take care of releasing the reference.
- ResourceArray_Dev resources(pp::PASS_REF,
- enum_state->devices_resource);
-
- if (need_to_callback) {
- enum_state->devices->clear();
- for (uint32_t index = 0; index < resources.size(); ++index) {
- DeviceRef_Dev device(resources[index]);
- enum_state->devices->push_back(device);
- }
+void AudioInput_Dev::CallbackConverter(void* user_data, int32_t result) {
+ EnumerateCallbackData0_2* data =
+ static_cast<EnumerateCallbackData0_2*>(user_data);
+
+ // data->devices should remain 0 if the call to EnumerateDevices failed.
+ ResourceArray_Dev resources(PASS_REF, data->devices);
+ PP_DCHECK(resources.is_null() || result == PP_OK);
+
+ // Need to issue the "GetDataBuffer" even for error cases and when the number
+ // of items is 0.
+ PP_Resource* output_buf = static_cast<PP_Resource*>(
+ data->output.GetDataBuffer(
+ data->output.user_data, resources.is_null() ? 0 : resources.size(),
+ sizeof(PP_Resource)));
+ if (output_buf) {
+ for (uint32_t index = 0; index < resources.size(); ++index) {
+ output_buf[index] = resources[index];
+ Module::Get()->core()->AddRefResource(output_buf[index]);
}
}
- if (need_to_callback) {
- enum_state->audio_input->enum_state_ = NULL;
- enum_state->callback.Run(result);
- }
-
- delete enum_state;
+ PP_RunCompletionCallback(&data->original_callback, result);
+ delete data;
}
} // namespace pp

Powered by Google App Engine
This is Rietveld 408576698