Index: trunk/src/device/hid/hid_connection.h |
=================================================================== |
--- trunk/src/device/hid/hid_connection.h (revision 281281) |
+++ trunk/src/device/hid/hid_connection.h (working copy) |
@@ -9,7 +9,6 @@ |
#include "base/callback.h" |
#include "base/memory/ref_counted.h" |
-#include "base/threading/thread_checker.h" |
#include "device/hid/hid_device_info.h" |
#include "net/base/io_buffer.h" |
@@ -17,65 +16,31 @@ |
class HidConnection : public base::RefCountedThreadSafe<HidConnection> { |
public: |
- enum SpecialReportIds { |
- kNullReportId = 0x00, |
- kAnyReportId = 0xFF, |
- }; |
- |
typedef base::Callback<void(bool success, size_t size)> IOCallback; |
+ virtual void Read(scoped_refptr<net::IOBufferWithSize> buffer, |
+ const IOCallback& callback) = 0; |
+ virtual void Write(uint8_t report_id, |
+ scoped_refptr<net::IOBufferWithSize> buffer, |
+ const IOCallback& callback) = 0; |
+ virtual void GetFeatureReport(uint8_t report_id, |
+ scoped_refptr<net::IOBufferWithSize> buffer, |
+ const IOCallback& callback) = 0; |
+ virtual void SendFeatureReport(uint8_t report_id, |
+ scoped_refptr<net::IOBufferWithSize> buffer, |
+ const IOCallback& callback) = 0; |
+ |
const HidDeviceInfo& device_info() const { return device_info_; } |
- bool has_protected_collection() const { return has_protected_collection_; } |
- bool has_report_id() const { return has_report_id_; } |
- const base::ThreadChecker& thread_checker() const { return thread_checker_; } |
- void Read(scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback); |
- void Write(uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback); |
- void GetFeatureReport(uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback); |
- void SendFeatureReport(uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback); |
- |
protected: |
friend class base::RefCountedThreadSafe<HidConnection>; |
+ friend struct HidDeviceInfo; |
explicit HidConnection(const HidDeviceInfo& device_info); |
virtual ~HidConnection(); |
- virtual void PlatformRead(scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback) = 0; |
- virtual void PlatformWrite(uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback) = 0; |
- virtual void PlatformGetFeatureReport( |
- uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback) = 0; |
- virtual void PlatformSendFeatureReport( |
- uint8_t report_id, |
- scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback) = 0; |
- |
- // PlatformRead implementation must call this method on read |
- // success, rather than directly running the callback. |
- // In case incoming buffer is empty or protected, it is filtered |
- // and this method returns false. Otherwise it runs the callback |
- // and returns true. |
- bool CompleteRead(scoped_refptr<net::IOBufferWithSize> buffer, |
- const IOCallback& callback); |
- |
private: |
- bool IsReportIdProtected(const uint8_t report_id); |
- |
const HidDeviceInfo device_info_; |
- bool has_report_id_; |
- bool has_protected_collection_; |
- base::ThreadChecker thread_checker_; |
DISALLOW_COPY_AND_ASSIGN(HidConnection); |
}; |