Index: components/usb_service/usb_service.h |
diff --git a/components/usb_service/usb_service.h b/components/usb_service/usb_service.h |
index 3bf0a40a0bc22d5c4303cd62c47b920725d8b85f..133cacd7e57374c23a331bcc53ff29b4344b34a1 100644 |
--- a/components/usb_service/usb_service.h |
+++ b/components/usb_service/usb_service.h |
@@ -5,71 +5,40 @@ |
#ifndef COMPONENTS_USB_SERVICE_USB_SERVICE_H_ |
#define COMPONENTS_USB_SERVICE_USB_SERVICE_H_ |
-#include <map> |
-#include <utility> |
#include <vector> |
-#include "base/basictypes.h" |
#include "base/memory/ref_counted.h" |
#include "base/memory/scoped_ptr.h" |
-#include "base/message_loop/message_loop.h" |
#include "base/threading/non_thread_safe.h" |
#include "components/usb_service/usb_service_export.h" |
-struct libusb_device; |
-struct libusb_context; |
- |
namespace usb_service { |
-typedef struct libusb_device* PlatformUsbDevice; |
-typedef struct libusb_context* PlatformUsbContext; |
- |
-class UsbContext; |
class UsbDevice; |
// The USB service handles creating and managing an event handler thread that is |
// used to manage and dispatch USB events. It is also responsible for device |
// discovery on the system, which allows it to re-use device handles to prevent |
// competition for the same USB device. |
-class USB_SERVICE_EXPORT UsbService |
- : public base::MessageLoop::DestructionObserver, |
- public base::NonThreadSafe { |
+class USB_SERVICE_EXPORT UsbService : public base::NonThreadSafe { |
public: |
- typedef scoped_ptr<std::vector<scoped_refptr<UsbDevice> > > |
- ScopedDeviceVector; |
- |
// Must be called on FILE thread. |
// Returns NULL when failed to initialized. |
static UsbService* GetInstance(); |
- scoped_refptr<UsbDevice> GetDeviceById(uint32 unique_id); |
+ static void SetInstanceForTest(UsbService* instance); |
+ |
+ virtual scoped_refptr<UsbDevice> GetDeviceById(uint32 unique_id) = 0; |
// Get all of the devices attached to the system, inserting them into |
// |devices|. Clears |devices| before use. The result will be sorted by id |
// in increasing order. Must be called on FILE thread. |
- void GetDevices(std::vector<scoped_refptr<UsbDevice> >* devices); |
- |
- // base::MessageLoop::DestructionObserver implementation. |
- virtual void WillDestroyCurrentMessageLoop() OVERRIDE; |
+ virtual void GetDevices(std::vector<scoped_refptr<UsbDevice> >* devices) = 0; |
- private: |
+ protected: |
friend struct base::DefaultDeleter<UsbService>; |
- |
- explicit UsbService(PlatformUsbContext context); |
- virtual ~UsbService(); |
- |
- // Enumerate USB devices from OS and Update devices_ map. |
- void RefreshDevices(); |
- |
- scoped_refptr<UsbContext> context_; |
- |
- // TODO(ikarienator): Figure out a better solution. |
- uint32 next_unique_id_; |
- |
- // The map from PlatformUsbDevices to UsbDevices. |
- typedef std::map<PlatformUsbDevice, scoped_refptr<UsbDevice> > DeviceMap; |
- DeviceMap devices_; |
- |
+ UsbService() {} |
+ virtual ~UsbService() {} |
DISALLOW_COPY_AND_ASSIGN(UsbService); |
}; |