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

Unified Diff: components/usb_service/usb_service_impl.cc

Issue 497363004: Merge components/usb_service into device/usb. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased. Created 6 years, 3 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
« no previous file with comments | « components/usb_service/usb_service_export.h ('k') | device/core/device_client.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/usb_service/usb_service_impl.cc
diff --git a/components/usb_service/usb_service_impl.cc b/components/usb_service/usb_service_impl.cc
deleted file mode 100644
index 051bead8634bcadc6504934a32b63791e788cc24..0000000000000000000000000000000000000000
--- a/components/usb_service/usb_service_impl.cc
+++ /dev/null
@@ -1,190 +0,0 @@
-// Copyright 2014 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 "components/usb_service/usb_service.h"
-
-#include <map>
-#include <set>
-
-#include "base/lazy_instance.h"
-#include "base/message_loop/message_loop.h"
-#include "base/single_thread_task_runner.h"
-#include "base/stl_util.h"
-#include "components/usb_service/usb_context.h"
-#include "components/usb_service/usb_device_impl.h"
-#include "components/usb_service/usb_error.h"
-#include "third_party/libusb/src/libusb/libusb.h"
-
-namespace usb_service {
-
-namespace {
-
-base::LazyInstance<scoped_ptr<UsbService> >::Leaky g_usb_service_instance =
- LAZY_INSTANCE_INITIALIZER;
-
-} // namespace
-
-typedef struct libusb_device* PlatformUsbDevice;
-typedef struct libusb_context* PlatformUsbContext;
-
-class UsbServiceImpl
- : public UsbService,
- private base::MessageLoop::DestructionObserver {
- public:
- explicit UsbServiceImpl(
- PlatformUsbContext context,
- scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner);
- virtual ~UsbServiceImpl();
-
- private:
- // usb_service::UsbService implementation
- virtual scoped_refptr<UsbDevice> GetDeviceById(uint32 unique_id) OVERRIDE;
- virtual void GetDevices(
- std::vector<scoped_refptr<UsbDevice> >* devices) OVERRIDE;
-
- // base::MessageLoop::DestructionObserver implementation.
- virtual void WillDestroyCurrentMessageLoop() OVERRIDE;
-
- // Enumerate USB devices from OS and Update devices_ map.
- void RefreshDevices();
-
- scoped_refptr<UsbContext> context_;
- scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
- scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner_;
-
- // TODO(ikarienator): Figure out a better solution.
- uint32 next_unique_id_;
-
- // The map from PlatformUsbDevices to UsbDevices.
- typedef std::map<PlatformUsbDevice, scoped_refptr<UsbDeviceImpl> > DeviceMap;
- DeviceMap devices_;
-
- DISALLOW_COPY_AND_ASSIGN(UsbServiceImpl);
-};
-
-scoped_refptr<UsbDevice> UsbServiceImpl::GetDeviceById(uint32 unique_id) {
- DCHECK(CalledOnValidThread());
- RefreshDevices();
- for (DeviceMap::iterator it = devices_.begin(); it != devices_.end(); ++it) {
- if (it->second->unique_id() == unique_id)
- return it->second;
- }
- return NULL;
-}
-
-void UsbServiceImpl::GetDevices(
- std::vector<scoped_refptr<UsbDevice> >* devices) {
- DCHECK(CalledOnValidThread());
- STLClearObject(devices);
- RefreshDevices();
-
- for (DeviceMap::iterator it = devices_.begin(); it != devices_.end(); ++it) {
- devices->push_back(it->second);
- }
-}
-
-void UsbServiceImpl::WillDestroyCurrentMessageLoop() {
- DCHECK(CalledOnValidThread());
- g_usb_service_instance.Get().reset(NULL);
-}
-
-UsbServiceImpl::UsbServiceImpl(
- PlatformUsbContext context,
- scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner)
- : context_(new UsbContext(context)),
- ui_task_runner_(ui_task_runner),
- next_unique_id_(0) {
- base::MessageLoop::current()->AddDestructionObserver(this);
-}
-
-UsbServiceImpl::~UsbServiceImpl() {
- base::MessageLoop::current()->RemoveDestructionObserver(this);
- for (DeviceMap::iterator it = devices_.begin(); it != devices_.end(); ++it) {
- it->second->OnDisconnect();
- }
-}
-
-void UsbServiceImpl::RefreshDevices() {
- DCHECK(CalledOnValidThread());
-
- libusb_device** platform_devices = NULL;
- const ssize_t device_count =
- libusb_get_device_list(context_->context(), &platform_devices);
- if (device_count < 0) {
- VLOG(1) << "Failed to get device list: "
- << ConvertErrorToString(device_count);
- }
-
- std::set<UsbDevice*> connected_devices;
- std::vector<PlatformUsbDevice> disconnected_devices;
-
- // Populates new devices.
- for (ssize_t i = 0; i < device_count; ++i) {
- if (!ContainsKey(devices_, platform_devices[i])) {
- libusb_device_descriptor descriptor;
- const int rv =
- libusb_get_device_descriptor(platform_devices[i], &descriptor);
- // This test is needed. A valid vendor/produce pair is required.
- if (rv != LIBUSB_SUCCESS) {
- VLOG(1) << "Failed to get device descriptor: "
- << ConvertErrorToString(rv);
- continue;
- }
- UsbDeviceImpl* new_device = new UsbDeviceImpl(context_,
- ui_task_runner_,
- platform_devices[i],
- descriptor.idVendor,
- descriptor.idProduct,
- ++next_unique_id_);
- devices_[platform_devices[i]] = new_device;
- connected_devices.insert(new_device);
- } else {
- connected_devices.insert(devices_[platform_devices[i]].get());
- }
- }
-
- // Find disconnected devices.
- for (DeviceMap::iterator it = devices_.begin(); it != devices_.end(); ++it) {
- if (!ContainsKey(connected_devices, it->second)) {
- disconnected_devices.push_back(it->first);
- }
- }
-
- // Remove disconnected devices from devices_.
- for (size_t i = 0; i < disconnected_devices.size(); ++i) {
- // UsbDevice will be destroyed after this. The corresponding
- // PlatformUsbDevice will be unref'ed during this process.
- devices_.erase(disconnected_devices[i]);
- }
-
- libusb_free_device_list(platform_devices, true);
-}
-
-// static
-UsbService* UsbService::GetInstance(
- scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner) {
- UsbService* instance = g_usb_service_instance.Get().get();
- if (!instance) {
- PlatformUsbContext context = NULL;
-
- const int rv = libusb_init(&context);
- if (rv != LIBUSB_SUCCESS) {
- VLOG(1) << "Failed to initialize libusb: " << ConvertErrorToString(rv);
- return NULL;
- }
- if (!context)
- return NULL;
-
- instance = new UsbServiceImpl(context, ui_task_runner);
- g_usb_service_instance.Get().reset(instance);
- }
- return instance;
-}
-
-// static
-void UsbService::SetInstanceForTest(UsbService* instance) {
- g_usb_service_instance.Get().reset(instance);
-}
-
-} // namespace usb_service
« no previous file with comments | « components/usb_service/usb_service_export.h ('k') | device/core/device_client.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698