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

Unified Diff: device/hid/hid_service_mac.h

Issue 143883005: HID backend (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@hid-impl-base
Patch Set: Really fix tests for lack of testing hardware; adapt to ancient libudev in the cros distro Created 6 years, 11 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
Index: device/hid/hid_service_mac.h
diff --git a/device/hid/hid_service_mac.h b/device/hid/hid_service_mac.h
new file mode 100644
index 0000000000000000000000000000000000000000..9351d1ea15f22a987a328d0c6460f7d54a950403
--- /dev/null
+++ b/device/hid/hid_service_mac.h
@@ -0,0 +1,81 @@
+// Copyright (c) 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.
+
+#ifndef DEVICE_HID_HID_SERVICE_MAC_H_
+#define DEVICE_HID_HID_SERVICE_MAC_H_
+
+#include <map>
+#include <string>
+#include <vector>
+
+#include "base/basictypes.h"
+#include "base/mac/foundation_util.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/singleton.h"
+#include "base/message_loop/message_loop.h"
+#include "base/strings/string16.h"
+#include "base/synchronization/waitable_event.h"
+#include "base/threading/thread.h"
+#include "base/threading/thread_checker.h"
+#include "build/build_config.h"
+#include "device/hid/hid_device_info.h"
+#include "device/hid/hid_service.h"
+
+#include <CoreFoundation/CoreFoundation.h>
+#include <IOKit/hid/IOHIDManager.h>
+
+namespace device {
+
+class HidConnection;
+class HidService;
+
+class HidServiceMac : public HidService {
+ public:
+ HidServiceMac();
+
+ virtual scoped_refptr<HidConnection> Connect(std::string device_id) OVERRIDE;
+
+ private:
+ virtual ~HidServiceMac();
+
+ void ScheduleRunLoop();
+ void UnscheduleRunLoop();
+
+ // Device changing callbacks.
+ static void AddDeviceCallback(void* context,
+ IOReturn result,
+ void* sender,
+ IOHIDDeviceRef ref);
+ static void RemoveDeviceCallback(void* context,
+ IOReturn result,
+ void* sender,
+ IOHIDDeviceRef ref);
+ static HidServiceMac* InstanceFromContext(void* context);
+
+ IOHIDDeviceRef FindDevice(std::string id);
Mark Mentovai 2014/02/12 19:35:59 The name “id” will cause trouble if this is #inclu
+
+ void Enumerate();
+
+ void PlatformAddDevice(IOHIDDeviceRef ref);
+ void PlatformRemoveDevice(IOHIDDeviceRef ref);
+
+ // The message loop this object belongs to.
+ scoped_refptr<base::MessageLoopProxy> message_loop_;
+
+ // Platform HID Manager
+ base::ScopedCFTypeRef<IOHIDManagerRef> hid_manager_ref_;
+
+ // Enumeration thread.
+ scoped_ptr<base::Thread> enumeration_runloop_thread_;
+ CFRunLoopRef enumeration_runloop_;
+ base::WaitableEvent enumeration_runloop_init_;
+
+ bool available_;
+
+ DISALLOW_COPY_AND_ASSIGN(HidServiceMac);
+};
+
+} // namespace device
+
+#endif // DEVICE_HID_HID_SERVICE_MAC_H_

Powered by Google App Engine
This is Rietveld 408576698