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

Side by Side Diff: device/hid/hid_service.cc

Issue 161823002: Clean up HID backend and API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Many cleanup, such device ID, woww. Created 6 years, 10 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "device/hid/hid_service.h" 5 #include "device/hid/hid_service.h"
6 6
7 #include <vector>
8
9 #include "base/lazy_instance.h" 7 #include "base/lazy_instance.h"
10 #include "base/logging.h" 8 #include "base/logging.h"
11 #include "base/memory/scoped_vector.h" 9 #include "base/memory/scoped_vector.h"
12 #include "base/message_loop/message_loop.h" 10 #include "base/stl_util.h"
13 #include "base/threading/thread_restrictions.h" 11 #include "base/threading/thread_restrictions.h"
14 #include "build/build_config.h"
15 #include "device/hid/hid_device_info.h"
16 12
17 #if defined(OS_LINUX) 13 #if defined(OS_LINUX)
18 #include "device/hid/hid_service_linux.h" 14 #include "device/hid/hid_service_linux.h"
19 #elif defined(OS_MACOSX) 15 #elif defined(OS_MACOSX)
20 #include "device/hid/hid_service_mac.h" 16 #include "device/hid/hid_service_mac.h"
21 #else 17 #else
22 #include "device/hid/hid_service_win.h" 18 #include "device/hid/hid_service_win.h"
23 #endif 19 #endif
24 20
25 namespace device { 21 namespace device {
26 22
27 namespace { 23 namespace {
28 24
29 // The instance will be reset when message loop destroys. 25 // The instance will be reset when message loop destroys.
30 base::LazyInstance<scoped_ptr<HidService> >::Leaky g_hid_service_ptr = 26 base::LazyInstance<scoped_ptr<HidService> >::Leaky g_hid_service_ptr =
31 LAZY_INSTANCE_INITIALIZER; 27 LAZY_INSTANCE_INITIALIZER;
32 28
33 } // namespace 29 } // namespace
34 30
35 HidService::HidService() : initialized_(false) {
36 base::ThreadRestrictions::AssertIOAllowed();
37 DCHECK(thread_checker_.CalledOnValidThread());
38 base::MessageLoop::current()->AddDestructionObserver(this);
39 }
40
41 HidService::~HidService() {
42 DCHECK(thread_checker_.CalledOnValidThread());
43 base::MessageLoop::current()->RemoveDestructionObserver(this);
44 }
45
46 void HidService::WillDestroyCurrentMessageLoop() {
47 DCHECK(thread_checker_.CalledOnValidThread());
48 g_hid_service_ptr.Get().reset(NULL);
49 }
50
51 void HidService::GetDevices(std::vector<HidDeviceInfo>* devices) { 31 void HidService::GetDevices(std::vector<HidDeviceInfo>* devices) {
52 DCHECK(thread_checker_.CalledOnValidThread()); 32 DCHECK(thread_checker_.CalledOnValidThread());
53 STLClearObject(devices); 33 STLClearObject(devices);
54 for (DeviceMap::iterator it = devices_.begin(); 34 for (DeviceMap::iterator it = devices_.begin();
55 it != devices_.end(); 35 it != devices_.end();
56 ++it) { 36 ++it) {
57 devices->push_back(it->second); 37 devices->push_back(it->second);
58 } 38 }
59 } 39 }
60 40
61 // Fills in the device info struct of the given device_id. 41 // Fills in the device info struct of the given device_id.
62 bool HidService::GetInfo(std::string device_id, HidDeviceInfo* info) const { 42 bool HidService::GetInfo(HidDeviceId device_id, HidDeviceInfo* info) const {
63 DeviceMap::const_iterator it = devices_.find(device_id); 43 DeviceMap::const_iterator it = devices_.find(device_id);
64 if (it == devices_.end()) 44 if (it == devices_.end())
65 return false; 45 return false;
66 *info = it->second; 46 *info = it->second;
67 return true; 47 return true;
68 } 48 }
69 49
70 void HidService::AddDevice(HidDeviceInfo info) { 50 void HidService::WillDestroyCurrentMessageLoop() {
71 if (!ContainsKey(devices_, info.device_id)) { 51 DCHECK(thread_checker_.CalledOnValidThread());
72 DCHECK(thread_checker_.CalledOnValidThread()); 52 g_hid_service_ptr.Get().reset(NULL);
73 devices_[info.device_id] = info;
74 }
75 } 53 }
76 54
77 void HidService::RemoveDevice(std::string device_id) { 55 HidService::HidService() : next_device_id_(0) {
78 if (ContainsKey(devices_, device_id)) { 56 base::ThreadRestrictions::AssertIOAllowed();
79 DCHECK(thread_checker_.CalledOnValidThread()); 57 DCHECK(thread_checker_.CalledOnValidThread());
80 devices_.erase(device_id); 58 base::MessageLoop::current()->AddDestructionObserver(this);
81 } 59 }
60
61 HidService::~HidService() {
62 DCHECK(thread_checker_.CalledOnValidThread());
63 base::MessageLoop::current()->RemoveDestructionObserver(this);
82 } 64 }
83 65
84 HidService* HidService::CreateInstance() { 66 HidService* HidService::CreateInstance() {
85 #if defined(OS_LINUX) 67 #if defined(OS_LINUX)
86 return new HidServiceLinux(); 68 return new HidServiceLinux();
87 #elif defined(OS_MACOSX) 69 #elif defined(OS_MACOSX)
88 return new HidServiceMac(); 70 return new HidServiceMac();
89 #elif defined(OS_WIN) 71 #elif defined(OS_WIN)
90 return new HidServiceWin(); 72 return new HidServiceWin();
91 #else 73 #else
92 return NULL; 74 return NULL;
93 #endif 75 #endif
94 } 76 }
95 77
78 HidDeviceId HidService::GenerateDeviceId() { return next_device_id_++; }
79
80 void HidService::AddDevice(const HidDeviceInfo& info) {
81 DCHECK(thread_checker_.CalledOnValidThread());
82 if (!ContainsKey(devices_, info.device_id)) {
83 devices_[info.device_id] = info;
84 }
85 }
86
87 void HidService::RemoveDevice(HidDeviceId device_id) {
88 DCHECK(thread_checker_.CalledOnValidThread());
89 if (ContainsKey(devices_, device_id)) {
90 devices_.erase(device_id);
91 }
92 }
93
96 HidService* HidService::GetInstance() { 94 HidService* HidService::GetInstance() {
97 if (!g_hid_service_ptr.Get().get()){ 95 if (!g_hid_service_ptr.Get().get())
98 scoped_ptr<HidService> service(CreateInstance()); 96 g_hid_service_ptr.Get().reset(CreateInstance());
99
100 if (service && service->initialized())
101 g_hid_service_ptr.Get().reset(service.release());
102 }
103 return g_hid_service_ptr.Get().get(); 97 return g_hid_service_ptr.Get().get();
104 } 98 }
105 99
106 } // namespace device 100 } // namespace device
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698