OLD | NEW |
1 // Copyright 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 "extensions/browser/api/hid/hid_device_manager.h" | 5 #include "extensions/browser/api/hid/hid_device_manager.h" |
6 | 6 |
7 #include <limits> | 7 #include <limits> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| 11 #include "content/public/browser/browser_thread.h" |
11 #include "device/hid/hid_service.h" | 12 #include "device/hid/hid_service.h" |
12 #include "extensions/browser/api/extensions_api_client.h" | |
13 | 13 |
14 using device::HidService; | 14 using device::HidService; |
15 using device::HidUsageAndPage; | 15 using device::HidUsageAndPage; |
16 | 16 |
17 namespace extensions { | 17 namespace extensions { |
18 | 18 |
19 HidDeviceManager::HidDeviceManager(content::BrowserContext* context) | 19 HidDeviceManager::HidDeviceManager(content::BrowserContext* context) |
20 : next_resource_id_(0) {} | 20 : next_resource_id_(0), |
| 21 ui_message_loop_(content::BrowserThread::GetMessageLoopProxyForThread( |
| 22 content::BrowserThread::UI)) { |
| 23 } |
21 | 24 |
22 HidDeviceManager::~HidDeviceManager() {} | 25 HidDeviceManager::~HidDeviceManager() {} |
23 | 26 |
24 // static | 27 // static |
25 BrowserContextKeyedAPIFactory<HidDeviceManager>* | 28 BrowserContextKeyedAPIFactory<HidDeviceManager>* |
26 HidDeviceManager::GetFactoryInstance() { | 29 HidDeviceManager::GetFactoryInstance() { |
27 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> > | 30 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> > |
28 factory = LAZY_INSTANCE_INITIALIZER; | 31 factory = LAZY_INSTANCE_INITIALIZER; |
29 return &factory.Get(); | 32 return &factory.Get(); |
30 } | 33 } |
31 | 34 |
32 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices( | 35 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices( |
33 uint16_t vendor_id, | 36 uint16_t vendor_id, |
34 uint16_t product_id) { | 37 uint16_t product_id) { |
35 UpdateDevices(); | 38 UpdateDevices(); |
36 | 39 |
37 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); | 40 HidService* hid_service = HidService::GetInstance(ui_message_loop_); |
38 DCHECK(hid_service); | 41 DCHECK(hid_service); |
39 base::ListValue* api_devices = new base::ListValue(); | 42 base::ListValue* api_devices = new base::ListValue(); |
40 for (ResourceIdToDeviceIdMap::const_iterator device_iter = | 43 for (ResourceIdToDeviceIdMap::const_iterator device_iter = |
41 device_ids_.begin(); | 44 device_ids_.begin(); |
42 device_iter != device_ids_.end(); | 45 device_iter != device_ids_.end(); |
43 ++device_iter) { | 46 ++device_iter) { |
44 int resource_id = device_iter->first; | 47 int resource_id = device_iter->first; |
45 device::HidDeviceId device_id = device_iter->second; | 48 device::HidDeviceId device_id = device_iter->second; |
46 device::HidDeviceInfo device_info; | 49 device::HidDeviceInfo device_info; |
47 | 50 |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
90 } | 93 } |
91 } | 94 } |
92 } | 95 } |
93 | 96 |
94 return scoped_ptr<base::ListValue>(api_devices); | 97 return scoped_ptr<base::ListValue>(api_devices); |
95 } | 98 } |
96 | 99 |
97 bool HidDeviceManager::GetDeviceInfo(int resource_id, | 100 bool HidDeviceManager::GetDeviceInfo(int resource_id, |
98 device::HidDeviceInfo* device_info) { | 101 device::HidDeviceInfo* device_info) { |
99 UpdateDevices(); | 102 UpdateDevices(); |
100 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); | 103 HidService* hid_service = HidService::GetInstance(ui_message_loop_); |
101 DCHECK(hid_service); | 104 DCHECK(hid_service); |
102 | 105 |
103 ResourceIdToDeviceIdMap::const_iterator device_iter = | 106 ResourceIdToDeviceIdMap::const_iterator device_iter = |
104 device_ids_.find(resource_id); | 107 device_ids_.find(resource_id); |
105 if (device_iter == device_ids_.end()) | 108 if (device_iter == device_ids_.end()) |
106 return false; | 109 return false; |
107 | 110 |
108 return hid_service->GetDeviceInfo(device_iter->second, device_info); | 111 return hid_service->GetDeviceInfo(device_iter->second, device_info); |
109 } | 112 } |
110 | 113 |
111 void HidDeviceManager::UpdateDevices() { | 114 void HidDeviceManager::UpdateDevices() { |
112 thread_checker_.CalledOnValidThread(); | 115 thread_checker_.CalledOnValidThread(); |
113 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); | 116 HidService* hid_service = HidService::GetInstance(ui_message_loop_); |
114 DCHECK(hid_service); | 117 DCHECK(hid_service); |
115 | 118 |
116 std::vector<device::HidDeviceInfo> devices; | 119 std::vector<device::HidDeviceInfo> devices; |
117 hid_service->GetDevices(&devices); | 120 hid_service->GetDevices(&devices); |
118 | 121 |
119 // Build an updated bidi mapping between resource ID and underlying device ID. | 122 // Build an updated bidi mapping between resource ID and underlying device ID. |
120 DeviceIdToResourceIdMap new_resource_ids; | 123 DeviceIdToResourceIdMap new_resource_ids; |
121 ResourceIdToDeviceIdMap new_device_ids; | 124 ResourceIdToDeviceIdMap new_device_ids; |
122 for (std::vector<device::HidDeviceInfo>::const_iterator iter = | 125 for (std::vector<device::HidDeviceInfo>::const_iterator iter = |
123 devices.begin(); | 126 devices.begin(); |
(...skipping 10 matching lines...) Expand all Loading... |
134 new_id = next_resource_id_++; | 137 new_id = next_resource_id_++; |
135 } | 138 } |
136 new_resource_ids[device_info.device_id] = new_id; | 139 new_resource_ids[device_info.device_id] = new_id; |
137 new_device_ids[new_id] = device_info.device_id; | 140 new_device_ids[new_id] = device_info.device_id; |
138 } | 141 } |
139 device_ids_.swap(new_device_ids); | 142 device_ids_.swap(new_device_ids); |
140 resource_ids_.swap(new_resource_ids); | 143 resource_ids_.swap(new_resource_ids); |
141 } | 144 } |
142 | 145 |
143 } // namespace extensions | 146 } // namespace extensions |
OLD | NEW |