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

Side by Side Diff: extensions/browser/api/hid/hid_device_manager.cc

Issue 514493004: Revert of Adding Select Action Bar Unit test case for input (patchset #3 of https://codereview.chro… (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: copying Created 6 years, 3 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
« no previous file with comments | « extensions/browser/api/hid/hid_device_manager.h ('k') | extensions/shell/app_shell.gyp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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"
12 #include "device/hid/hid_service.h" 11 #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 }
24 21
25 HidDeviceManager::~HidDeviceManager() {} 22 HidDeviceManager::~HidDeviceManager() {}
26 23
27 // static 24 // static
28 BrowserContextKeyedAPIFactory<HidDeviceManager>* 25 BrowserContextKeyedAPIFactory<HidDeviceManager>*
29 HidDeviceManager::GetFactoryInstance() { 26 HidDeviceManager::GetFactoryInstance() {
30 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> > 27 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> >
31 factory = LAZY_INSTANCE_INITIALIZER; 28 factory = LAZY_INSTANCE_INITIALIZER;
32 return &factory.Get(); 29 return &factory.Get();
33 } 30 }
34 31
35 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices( 32 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices(
36 uint16_t vendor_id, 33 uint16_t vendor_id,
37 uint16_t product_id) { 34 uint16_t product_id) {
38 UpdateDevices(); 35 UpdateDevices();
39 36
40 HidService* hid_service = HidService::GetInstance(ui_message_loop_); 37 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
41 DCHECK(hid_service); 38 DCHECK(hid_service);
42 base::ListValue* api_devices = new base::ListValue(); 39 base::ListValue* api_devices = new base::ListValue();
43 for (ResourceIdToDeviceIdMap::const_iterator device_iter = 40 for (ResourceIdToDeviceIdMap::const_iterator device_iter =
44 device_ids_.begin(); 41 device_ids_.begin();
45 device_iter != device_ids_.end(); 42 device_iter != device_ids_.end();
46 ++device_iter) { 43 ++device_iter) {
47 int resource_id = device_iter->first; 44 int resource_id = device_iter->first;
48 device::HidDeviceId device_id = device_iter->second; 45 device::HidDeviceId device_id = device_iter->second;
49 device::HidDeviceInfo device_info; 46 device::HidDeviceInfo device_info;
50 47
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
93 } 90 }
94 } 91 }
95 } 92 }
96 93
97 return scoped_ptr<base::ListValue>(api_devices); 94 return scoped_ptr<base::ListValue>(api_devices);
98 } 95 }
99 96
100 bool HidDeviceManager::GetDeviceInfo(int resource_id, 97 bool HidDeviceManager::GetDeviceInfo(int resource_id,
101 device::HidDeviceInfo* device_info) { 98 device::HidDeviceInfo* device_info) {
102 UpdateDevices(); 99 UpdateDevices();
103 HidService* hid_service = HidService::GetInstance(ui_message_loop_); 100 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
104 DCHECK(hid_service); 101 DCHECK(hid_service);
105 102
106 ResourceIdToDeviceIdMap::const_iterator device_iter = 103 ResourceIdToDeviceIdMap::const_iterator device_iter =
107 device_ids_.find(resource_id); 104 device_ids_.find(resource_id);
108 if (device_iter == device_ids_.end()) 105 if (device_iter == device_ids_.end())
109 return false; 106 return false;
110 107
111 return hid_service->GetDeviceInfo(device_iter->second, device_info); 108 return hid_service->GetDeviceInfo(device_iter->second, device_info);
112 } 109 }
113 110
114 void HidDeviceManager::UpdateDevices() { 111 void HidDeviceManager::UpdateDevices() {
115 thread_checker_.CalledOnValidThread(); 112 thread_checker_.CalledOnValidThread();
116 HidService* hid_service = HidService::GetInstance(ui_message_loop_); 113 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService();
117 DCHECK(hid_service); 114 DCHECK(hid_service);
118 115
119 std::vector<device::HidDeviceInfo> devices; 116 std::vector<device::HidDeviceInfo> devices;
120 hid_service->GetDevices(&devices); 117 hid_service->GetDevices(&devices);
121 118
122 // Build an updated bidi mapping between resource ID and underlying device ID. 119 // Build an updated bidi mapping between resource ID and underlying device ID.
123 DeviceIdToResourceIdMap new_resource_ids; 120 DeviceIdToResourceIdMap new_resource_ids;
124 ResourceIdToDeviceIdMap new_device_ids; 121 ResourceIdToDeviceIdMap new_device_ids;
125 for (std::vector<device::HidDeviceInfo>::const_iterator iter = 122 for (std::vector<device::HidDeviceInfo>::const_iterator iter =
126 devices.begin(); 123 devices.begin();
(...skipping 10 matching lines...) Expand all
137 new_id = next_resource_id_++; 134 new_id = next_resource_id_++;
138 } 135 }
139 new_resource_ids[device_info.device_id] = new_id; 136 new_resource_ids[device_info.device_id] = new_id;
140 new_device_ids[new_id] = device_info.device_id; 137 new_device_ids[new_id] = device_info.device_id;
141 } 138 }
142 device_ids_.swap(new_device_ids); 139 device_ids_.swap(new_device_ids);
143 resource_ids_.swap(new_resource_ids); 140 resource_ids_.swap(new_resource_ids);
144 } 141 }
145 142
146 } // namespace extensions 143 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/browser/api/hid/hid_device_manager.h ('k') | extensions/shell/app_shell.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698