| Index: device/hid/hid_connection_win.h
|
| diff --git a/device/hid/hid_connection_win.h b/device/hid/hid_connection_win.h
|
| index 6cbb9e992e780aca5716e388a3817b69fc3de72d..263897a7eef21f591081d9121115b1edb5ad6dd4 100644
|
| --- a/device/hid/hid_connection_win.h
|
| +++ b/device/hid/hid_connection_win.h
|
| @@ -5,90 +5,51 @@
|
| #ifndef DEVICE_HID_HID_CONNECTION_WIN_H_
|
| #define DEVICE_HID_HID_CONNECTION_WIN_H_
|
|
|
| -#include <set>
|
| #include <windows.h>
|
|
|
| +#include <set>
|
| +
|
| #include "base/callback.h"
|
| #include "base/memory/ref_counted.h"
|
| #include "base/message_loop/message_loop.h"
|
| #include "base/threading/thread_checker.h"
|
| -#include "base/win/object_watcher.h"
|
| #include "device/hid/hid_connection.h"
|
| #include "device/hid/hid_device_info.h"
|
| -#include "net/base/io_buffer.h"
|
|
|
| namespace device {
|
|
|
| +struct PendingHidTransfer;
|
| +
|
| class HidConnectionWin : public HidConnection {
|
| public:
|
| - struct PendingTransfer : public base::RefCounted<PendingTransfer>,
|
| - public base::win::ObjectWatcher::Delegate,
|
| - public base::MessageLoop::DestructionObserver {
|
| - public:
|
| - PendingTransfer(scoped_refptr<HidConnectionWin> conn,
|
| - scoped_refptr<net::IOBuffer> target,
|
| - scoped_refptr<net::IOBuffer> receiving,
|
| - bool is_input,
|
| - IOCallback callback);
|
| -
|
| - void TakeResultFromWindowsAPI(BOOL result);
|
| -
|
| - OVERLAPPED* GetOverlapped() { return &overlapped_; }
|
| -
|
| - // Implements base::win::ObjectWatcher::Delegate.
|
| - virtual void OnObjectSignaled(HANDLE object) OVERRIDE;
|
| -
|
| - // Implements base::MessageLoop::DestructionObserver
|
| - virtual void WillDestroyCurrentMessageLoop() OVERRIDE;
|
| + explicit HidConnectionWin(const HidDeviceInfo& device_info);
|
|
|
| + bool available() const;
|
|
|
| - private:
|
| - friend class base::RefCounted<PendingTransfer>;
|
| - friend class HidConnectionWin;
|
| -
|
| - virtual ~PendingTransfer();
|
| -
|
| - scoped_refptr<HidConnectionWin> conn_;
|
| - bool is_input_;
|
| - scoped_refptr<net::IOBuffer> target_;
|
| - scoped_refptr<net::IOBuffer> receiving_;
|
| - IOCallback callback_;
|
| - OVERLAPPED overlapped_;
|
| - base::win::ScopedHandle event_;
|
| - base::win::ObjectWatcher watcher_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(PendingTransfer);
|
| - };
|
| -
|
| - HidConnectionWin(HidDeviceInfo device_info);
|
| -
|
| - virtual void Read(scoped_refptr<net::IOBuffer> buffer,
|
| - size_t size,
|
| + virtual void Read(scoped_refptr<net::IOBufferWithSize> buffer,
|
| const IOCallback& callback) OVERRIDE;
|
| - virtual void Write(scoped_refptr<net::IOBuffer> buffer,
|
| - size_t size,
|
| + virtual void Write(uint8_t report_id,
|
| + scoped_refptr<net::IOBufferWithSize> buffer,
|
| const IOCallback& callback) OVERRIDE;
|
| - virtual void GetFeatureReport(scoped_refptr<net::IOBuffer> buffer,
|
| - size_t size,
|
| + virtual void GetFeatureReport(uint8_t report_id,
|
| + scoped_refptr<net::IOBufferWithSize> buffer,
|
| const IOCallback& callback) OVERRIDE;
|
| - virtual void SendFeatureReport(scoped_refptr<net::IOBuffer> buffer,
|
| - size_t size,
|
| + virtual void SendFeatureReport(uint8_t report_id,
|
| + scoped_refptr<net::IOBufferWithSize> buffer,
|
| const IOCallback& callback) OVERRIDE;
|
|
|
| - void OnTransferFinished(scoped_refptr<PendingTransfer> transfer);
|
| - void OnTransferCanceled(scoped_refptr<PendingTransfer> transfer);
|
| -
|
| - bool available() const { return available_; }
|
| + void OnTransferFinished(scoped_refptr<PendingHidTransfer> transfer);
|
| + void OnTransferCanceled(scoped_refptr<PendingHidTransfer> transfer);
|
|
|
| private:
|
| ~HidConnectionWin();
|
|
|
| base::win::ScopedHandle file_;
|
| - std::set<scoped_refptr<PendingTransfer> > transfers_;
|
| + std::set<scoped_refptr<PendingHidTransfer> > transfers_;
|
|
|
| - DISALLOW_COPY_AND_ASSIGN(HidConnectionWin);
|
| + base::ThreadChecker thread_checker_;
|
|
|
| - bool available_;
|
| + DISALLOW_COPY_AND_ASSIGN(HidConnectionWin);
|
| };
|
|
|
| } // namespace device
|
|
|