// 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/c/pp_errors.h" #include "ppapi/shared_impl/ppb_device_ref_shared.h" #include "ppapi/shared_impl/tracked_callback.h" #include "ppapi/thunk/enter.h" #include "ppapi/thunk/ppb_device_ref_api.h" #include "ppapi/thunk/ppb_video_capture_api.h" #include "ppapi/thunk/resource_creation_api.h" #include "ppapi/thunk/thunk.h" namespace ppapi { namespace thunk { namespace { typedef EnterResource<PPB_VideoCapture_API> EnterVideoCapture; PP_Resource Create(PP_Instance instance) { EnterResourceCreation enter(instance); if (enter.failed()) return 0; return enter.functions()->CreateVideoCapture(instance); } PP_Bool IsVideoCapture(PP_Resource resource) { EnterVideoCapture enter(resource, false); return PP_FromBool(enter.succeeded()); } int32_t EnumerateDevices(PP_Resource video_capture, PP_ArrayOutput output, PP_CompletionCallback callback) { EnterVideoCapture enter(video_capture, callback, true); if (enter.failed()) return enter.retval(); return enter.SetResult(enter.object()->EnumerateDevices(output, enter.callback())); } int32_t MonitorDeviceChange(PP_Resource video_capture, PP_MonitorDeviceChangeCallback callback, void* user_data) { EnterVideoCapture enter(video_capture, true); if (enter.failed()) return enter.retval(); return enter.object()->MonitorDeviceChange(callback, user_data); } int32_t Open(PP_Resource video_capture, PP_Resource device_ref, const PP_VideoCaptureDeviceInfo_Dev* requested_info, uint32_t buffer_count, PP_CompletionCallback callback) { EnterVideoCapture enter(video_capture, callback, true); if (enter.failed()) return enter.retval(); std::string device_id; // |device_id| remains empty if |device_ref| is 0, which means the default // device. if (device_ref != 0) { EnterResourceNoLock<PPB_DeviceRef_API> enter_device_ref(device_ref, true); if (enter_device_ref.failed()) return enter.SetResult(PP_ERROR_BADRESOURCE); device_id = enter_device_ref.object()->GetDeviceRefData().id; } return enter.SetResult(enter.object()->Open( device_id, *requested_info, buffer_count, enter.callback())); } int32_t StartCapture(PP_Resource video_capture) { EnterVideoCapture enter(video_capture, true); if (enter.failed()) return enter.retval(); return enter.object()->StartCapture(); } int32_t ReuseBuffer(PP_Resource video_capture, uint32_t buffer) { EnterVideoCapture enter(video_capture, true); if (enter.failed()) return enter.retval(); return enter.object()->ReuseBuffer(buffer); } int32_t StopCapture(PP_Resource video_capture) { EnterVideoCapture enter(video_capture, true); if (enter.failed()) return enter.retval(); return enter.object()->StopCapture(); } void Close(PP_Resource video_capture) { EnterVideoCapture enter(video_capture, true); if (enter.succeeded()) enter.object()->Close(); } const PPB_VideoCapture_Dev_0_3 g_ppb_video_capture_0_3_thunk = { &Create, &IsVideoCapture, &EnumerateDevices, &MonitorDeviceChange, &Open, &StartCapture, &ReuseBuffer, &StopCapture, &Close }; } // namespace const PPB_VideoCapture_Dev_0_3* GetPPB_VideoCapture_Dev_0_3_Thunk() { return &g_ppb_video_capture_0_3_thunk; } } // namespace thunk } // namespace ppapi