| Index: webkit/plugins/ppapi/ppb_video_capture_impl.cc | 
| diff --git a/webkit/plugins/ppapi/ppb_video_capture_impl.cc b/webkit/plugins/ppapi/ppb_video_capture_impl.cc | 
| deleted file mode 100644 | 
| index caf9027c910470232155c7c8ca4da14355025feb..0000000000000000000000000000000000000000 | 
| --- a/webkit/plugins/ppapi/ppb_video_capture_impl.cc | 
| +++ /dev/null | 
| @@ -1,332 +0,0 @@ | 
| -// 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 "webkit/plugins/ppapi/ppb_video_capture_impl.h" | 
| - | 
| -#include <algorithm> | 
| -#include <string> | 
| - | 
| -#include "base/bind.h" | 
| -#include "base/logging.h" | 
| -#include "base/memory/scoped_ptr.h" | 
| -#include "ppapi/c/dev/pp_video_capture_dev.h" | 
| -#include "ppapi/c/dev/ppb_video_capture_dev.h" | 
| -#include "ppapi/c/pp_completion_callback.h" | 
| -#include "ppapi/c/pp_errors.h" | 
| -#include "ppapi/shared_impl/ppapi_globals.h" | 
| -#include "ppapi/shared_impl/ppb_device_ref_shared.h" | 
| -#include "ppapi/shared_impl/resource_tracker.h" | 
| -#include "ppapi/shared_impl/tracked_callback.h" | 
| -#include "ppapi/thunk/enter.h" | 
| -#include "webkit/plugins/ppapi/common.h" | 
| -#include "webkit/plugins/ppapi/plugin_module.h" | 
| -#include "webkit/plugins/ppapi/ppapi_plugin_instance.h" | 
| -#include "webkit/plugins/ppapi/ppb_buffer_impl.h" | 
| -#include "webkit/plugins/ppapi/resource_helper.h" | 
| - | 
| -using ppapi::DeviceRefData; | 
| -using ppapi::PpapiGlobals; | 
| -using ppapi::thunk::EnterResourceNoLock; | 
| -using ppapi::thunk::PPB_Buffer_API; | 
| -using ppapi::thunk::PPB_VideoCapture_API; | 
| -using ppapi::TrackedCallback; | 
| - | 
| -namespace { | 
| - | 
| -// Maximum number of buffers to actually allocate. | 
| -const uint32_t kMaxBuffers = 20; | 
| - | 
| -}  // namespace | 
| - | 
| -namespace webkit { | 
| -namespace ppapi { | 
| - | 
| -PPB_VideoCapture_Impl::PPB_VideoCapture_Impl(PP_Instance instance) | 
| -    : PPB_VideoCapture_Shared(instance), | 
| -      buffer_count_hint_(0), | 
| -      ppp_videocapture_(NULL), | 
| -      capability_() { | 
| -} | 
| - | 
| -PPB_VideoCapture_Impl::~PPB_VideoCapture_Impl() { | 
| -  Close(); | 
| -} | 
| - | 
| -bool PPB_VideoCapture_Impl::Init() { | 
| -  PluginInstance* instance = ResourceHelper::GetPluginInstance(this); | 
| -  if (!instance) | 
| -    return false; | 
| -  ppp_videocapture_ = static_cast<const PPP_VideoCapture_Dev*>( | 
| -      instance->module()->GetPluginInterface(PPP_VIDEO_CAPTURE_DEV_INTERFACE)); | 
| -  if (!ppp_videocapture_) | 
| -    return false; | 
| - | 
| -  return true; | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnStarted(media::VideoCapture* capture) { | 
| -  if (SetStatus(PP_VIDEO_CAPTURE_STATUS_STARTED, false)) | 
| -    SendStatus(); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnStopped(media::VideoCapture* capture) { | 
| -  if (SetStatus(PP_VIDEO_CAPTURE_STATUS_STOPPED, false)) | 
| -    SendStatus(); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnPaused(media::VideoCapture* capture) { | 
| -  if (SetStatus(PP_VIDEO_CAPTURE_STATUS_PAUSED, false)) | 
| -    SendStatus(); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnError(media::VideoCapture* capture, | 
| -                                    int error_code) { | 
| -  // Today, the media layer only sends "1" as an error. | 
| -  DCHECK(error_code == 1); | 
| -  // It either comes because some error was detected while starting (e.g. 2 | 
| -  // conflicting "master" resolution), or because the browser failed to start | 
| -  // the capture. | 
| -  SetStatus(PP_VIDEO_CAPTURE_STATUS_STOPPED, true); | 
| -  ppp_videocapture_->OnError(pp_instance(), pp_resource(), PP_ERROR_FAILED); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnRemoved(media::VideoCapture* capture) { | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnBufferReady( | 
| -    media::VideoCapture* capture, | 
| -    scoped_refptr<media::VideoCapture::VideoFrameBuffer> buffer) { | 
| -  DCHECK(buffer.get()); | 
| -  for (uint32_t i = 0; i < buffers_.size(); ++i) { | 
| -    if (!buffers_[i].in_use) { | 
| -      // TODO(ihf): Switch to a size calculation based on stride. | 
| -      // Stride is filled out now but not more meaningful than size | 
| -      // until wjia unifies VideoFrameBuffer and media::VideoFrame. | 
| -      size_t size = std::min(static_cast<size_t>(buffers_[i].buffer->size()), | 
| -          buffer->buffer_size); | 
| -      memcpy(buffers_[i].data, buffer->memory_pointer, size); | 
| -      buffers_[i].in_use = true; | 
| -      platform_video_capture_->FeedBuffer(buffer); | 
| -      ppp_videocapture_->OnBufferReady(pp_instance(), pp_resource(), i); | 
| -      return; | 
| -    } | 
| -  } | 
| - | 
| -  // No free slot, just discard the frame and tell the media layer it can | 
| -  // re-use the buffer. | 
| -  platform_video_capture_->FeedBuffer(buffer); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnDeviceInfoReceived( | 
| -    media::VideoCapture* capture, | 
| -    const media::VideoCaptureParams& device_info) { | 
| -  PP_VideoCaptureDeviceInfo_Dev info = { | 
| -    static_cast<uint32_t>(device_info.width), | 
| -    static_cast<uint32_t>(device_info.height), | 
| -    static_cast<uint32_t>(device_info.frame_per_second) | 
| -  }; | 
| -  ReleaseBuffers(); | 
| - | 
| -  // Allocate buffers. We keep a reference to them, that is released in | 
| -  // ReleaseBuffers. | 
| -  // YUV 4:2:0 | 
| -  int uv_width = info.width / 2; | 
| -  int uv_height = info.height / 2; | 
| -  size_t size = info.width * info.height + 2 * uv_width * uv_height; | 
| -  scoped_array<PP_Resource> resources(new PP_Resource[buffer_count_hint_]); | 
| - | 
| -  buffers_.reserve(buffer_count_hint_); | 
| -  for (size_t i = 0; i < buffer_count_hint_; ++i) { | 
| -    resources[i] = PPB_Buffer_Impl::Create(pp_instance(), size); | 
| -    if (!resources[i]) | 
| -      break; | 
| - | 
| -    EnterResourceNoLock<PPB_Buffer_API> enter(resources[i], true); | 
| -    DCHECK(enter.succeeded()); | 
| - | 
| -    BufferInfo info; | 
| -    info.buffer = static_cast<PPB_Buffer_Impl*>(enter.object()); | 
| -    info.data = info.buffer->Map(); | 
| -    if (!info.data) { | 
| -      PpapiGlobals::Get()->GetResourceTracker()->ReleaseResource(resources[i]); | 
| -      break; | 
| -    } | 
| -    buffers_.push_back(info); | 
| -  } | 
| - | 
| -  if (buffers_.empty()) { | 
| -    // We couldn't allocate/map buffers at all. Send an error and stop the | 
| -    // capture. | 
| -    ppp_videocapture_->OnError(pp_instance(), pp_resource(), PP_ERROR_NOMEMORY); | 
| -    SetStatus(PP_VIDEO_CAPTURE_STATUS_STOPPING, true); | 
| -    platform_video_capture_->StopCapture(this); | 
| -    return; | 
| -  } | 
| - | 
| -  ppp_videocapture_->OnDeviceInfo(pp_instance(), pp_resource(), &info, | 
| -                                  buffers_.size(), resources.get()); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::OnInitialized(media::VideoCapture* capture, | 
| -                                          bool succeeded) { | 
| -  DCHECK(capture == platform_video_capture_.get()); | 
| - | 
| -  OnOpenComplete(succeeded ? PP_OK : PP_ERROR_FAILED); | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalEnumerateDevices( | 
| -    PP_Resource* devices, | 
| -    scoped_refptr<TrackedCallback> callback) { | 
| -  PluginInstance* instance = ResourceHelper::GetPluginInstance(this); | 
| -  if (!instance) | 
| -    return PP_ERROR_FAILED; | 
| - | 
| -  devices_ = devices; | 
| -  enumerate_devices_callback_ = callback; | 
| -  instance->delegate()->EnumerateDevices( | 
| -      PP_DEVICETYPE_DEV_VIDEOCAPTURE, | 
| -      base::Bind(&PPB_VideoCapture_Impl::EnumerateDevicesCallbackFunc, | 
| -                 AsWeakPtr())); | 
| -  return PP_OK_COMPLETIONPENDING; | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalOpen( | 
| -    const std::string& device_id, | 
| -    const PP_VideoCaptureDeviceInfo_Dev& requested_info, | 
| -    uint32_t buffer_count, | 
| -    scoped_refptr<TrackedCallback> callback) { | 
| -  // It is able to complete synchronously if the default device is used. | 
| -  bool sync_completion = device_id.empty(); | 
| - | 
| -  PluginInstance* instance = ResourceHelper::GetPluginInstance(this); | 
| -  if (!instance) | 
| -    return PP_ERROR_FAILED; | 
| - | 
| -  SetRequestedInfo(requested_info, buffer_count); | 
| - | 
| -  DCHECK(!platform_video_capture_.get()); | 
| -  platform_video_capture_ = | 
| -      instance->delegate()->CreateVideoCapture(device_id, this); | 
| - | 
| -  if (sync_completion) { | 
| -    OnInitialized(platform_video_capture_.get(), true); | 
| -    return PP_OK; | 
| -  } else { | 
| -    open_callback_ = callback; | 
| -    return PP_OK_COMPLETIONPENDING; | 
| -  } | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalStartCapture() { | 
| -  DCHECK(buffers_.empty()); | 
| -  platform_video_capture_->StartCapture(this, capability_); | 
| -  return PP_OK; | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalReuseBuffer(uint32_t buffer) { | 
| -  if (buffer >= buffers_.size() || !buffers_[buffer].in_use) | 
| -    return PP_ERROR_BADARGUMENT; | 
| -  buffers_[buffer].in_use = false; | 
| -  return PP_OK; | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalStopCapture() { | 
| -  ReleaseBuffers(); | 
| -  platform_video_capture_->StopCapture(this); | 
| -  return PP_OK; | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::InternalClose() { | 
| -  StopCapture(); | 
| -  DCHECK(buffers_.empty()); | 
| - | 
| -  DetachPlatformVideoCapture(); | 
| -} | 
| - | 
| -int32_t PPB_VideoCapture_Impl::InternalStartCapture0_1( | 
| -    const PP_VideoCaptureDeviceInfo_Dev& requested_info, | 
| -    uint32_t buffer_count) { | 
| -  PluginInstance* instance = ResourceHelper::GetPluginInstance(this); | 
| -  if (!instance) { | 
| -    SetStatus(PP_VIDEO_CAPTURE_STATUS_STOPPED, true); | 
| -    return PP_ERROR_FAILED; | 
| -  } | 
| - | 
| -  DCHECK(buffers_.empty()); | 
| - | 
| -  SetRequestedInfo(requested_info, buffer_count); | 
| - | 
| -  DetachPlatformVideoCapture(); | 
| -  platform_video_capture_ = | 
| -      instance->delegate()->CreateVideoCapture("", this); | 
| -  platform_video_capture_->StartCapture(this, capability_); | 
| - | 
| -  return PP_OK; | 
| -} | 
| - | 
| -const PPB_VideoCapture_Impl::DeviceRefDataVector& | 
| -    PPB_VideoCapture_Impl::InternalGetDeviceRefData() const { | 
| -  return devices_data_; | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::ReleaseBuffers() { | 
| -  ::ppapi::ResourceTracker* tracker = PpapiGlobals::Get()->GetResourceTracker(); | 
| -  for (size_t i = 0; i < buffers_.size(); ++i) { | 
| -    buffers_[i].buffer->Unmap(); | 
| -    tracker->ReleaseResource(buffers_[i].buffer->pp_resource()); | 
| -  } | 
| -  buffers_.clear(); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::SendStatus() { | 
| -  ppp_videocapture_->OnStatus(pp_instance(), pp_resource(), status_); | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::SetRequestedInfo( | 
| -    const PP_VideoCaptureDeviceInfo_Dev& device_info, | 
| -    uint32_t buffer_count) { | 
| -  // Clamp the buffer count to between 1 and |kMaxBuffers|. | 
| -  buffer_count_hint_ = std::min(std::max(buffer_count, 1U), kMaxBuffers); | 
| - | 
| -  capability_.width = device_info.width; | 
| -  capability_.height = device_info.height; | 
| -  capability_.frame_rate = device_info.frames_per_second; | 
| -  capability_.expected_capture_delay = 0;  // Ignored. | 
| -  capability_.color = media::VideoCaptureCapability::kI420; | 
| -  capability_.interlaced = false;  // Ignored. | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::DetachPlatformVideoCapture() { | 
| -  if (platform_video_capture_.get()) { | 
| -    platform_video_capture_->DetachEventHandler(); | 
| -    platform_video_capture_ = NULL; | 
| -  } | 
| -} | 
| - | 
| -void PPB_VideoCapture_Impl::EnumerateDevicesCallbackFunc( | 
| -    int request_id, | 
| -    bool succeeded, | 
| -    const DeviceRefDataVector& devices) { | 
| -  devices_data_.clear(); | 
| -  if (succeeded) | 
| -    devices_data_ = devices; | 
| - | 
| -  PluginInstance* instance = ResourceHelper::GetPluginInstance(this); | 
| -  if (instance) | 
| -    instance->delegate()->StopEnumerateDevices(request_id); | 
| - | 
| -  OnEnumerateDevicesComplete(succeeded ? PP_OK : PP_ERROR_FAILED, devices); | 
| -} | 
| - | 
| -PPB_VideoCapture_Impl::BufferInfo::BufferInfo() | 
| -    : in_use(false), | 
| -      data(NULL), | 
| -      buffer() { | 
| -} | 
| - | 
| -PPB_VideoCapture_Impl::BufferInfo::~BufferInfo() { | 
| -} | 
| - | 
| -}  // namespace ppapi | 
| -}  // namespace webkit | 
|  |