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

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

Issue 523743005: Fix HidService lifetime issues (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: where did that stupid line come from 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 "device/core/device_client.h"
11 #include "device/hid/hid_device_filter.h" 12 #include "device/hid/hid_device_filter.h"
12 #include "device/hid/hid_service.h" 13 #include "device/hid/hid_service.h"
13 #include "extensions/browser/api/extensions_api_client.h" 14 #include "extensions/browser/api/extensions_api_client.h"
14 #include "extensions/common/permissions/permissions_data.h" 15 #include "extensions/common/permissions/permissions_data.h"
15 #include "extensions/common/permissions/usb_device_permission.h" 16 #include "extensions/common/permissions/usb_device_permission.h"
16 17
17 using device::HidDeviceFilter; 18 using device::HidDeviceFilter;
18 using device::HidService; 19 using device::HidService;
19 using device::HidUsageAndPage; 20 using device::HidUsageAndPage;
20 21
21 namespace extensions { 22 namespace extensions {
22 23
23 HidDeviceManager::HidDeviceManager(content::BrowserContext* context) 24 HidDeviceManager::HidDeviceManager(content::BrowserContext* context)
24 : next_resource_id_(0) {} 25 : next_resource_id_(0) {
26 }
25 27
26 HidDeviceManager::~HidDeviceManager() {} 28 HidDeviceManager::~HidDeviceManager() {}
27 29
28 // static 30 // static
29 BrowserContextKeyedAPIFactory<HidDeviceManager>* 31 BrowserContextKeyedAPIFactory<HidDeviceManager>*
30 HidDeviceManager::GetFactoryInstance() { 32 HidDeviceManager::GetFactoryInstance() {
31 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> > 33 static base::LazyInstance<BrowserContextKeyedAPIFactory<HidDeviceManager> >
32 factory = LAZY_INSTANCE_INITIALIZER; 34 factory = LAZY_INSTANCE_INITIALIZER;
33 return &factory.Get(); 35 return &factory.Get();
34 } 36 }
35 37
36 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices( 38 scoped_ptr<base::ListValue> HidDeviceManager::GetApiDevices(
37 const Extension* extension, 39 const Extension* extension,
38 const std::vector<HidDeviceFilter>& filters) { 40 const std::vector<HidDeviceFilter>& filters) {
39 UpdateDevices(); 41 UpdateDevices();
40 42
41 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); 43 HidService* hid_service = device::DeviceClient::Get()->GetHidService();
42 DCHECK(hid_service); 44 DCHECK(hid_service);
43 base::ListValue* api_devices = new base::ListValue(); 45 base::ListValue* api_devices = new base::ListValue();
44 for (ResourceIdToDeviceIdMap::const_iterator device_iter = 46 for (ResourceIdToDeviceIdMap::const_iterator device_iter =
45 device_ids_.begin(); 47 device_ids_.begin();
46 device_iter != device_ids_.end(); 48 device_iter != device_ids_.end();
47 ++device_iter) { 49 ++device_iter) {
48 int resource_id = device_iter->first; 50 int resource_id = device_iter->first;
49 device::HidDeviceId device_id = device_iter->second; 51 device::HidDeviceId device_id = device_iter->second;
50 device::HidDeviceInfo device_info; 52 device::HidDeviceInfo device_info;
51 53
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 } 101 }
100 } 102 }
101 } 103 }
102 104
103 return scoped_ptr<base::ListValue>(api_devices); 105 return scoped_ptr<base::ListValue>(api_devices);
104 } 106 }
105 107
106 bool HidDeviceManager::GetDeviceInfo(int resource_id, 108 bool HidDeviceManager::GetDeviceInfo(int resource_id,
107 device::HidDeviceInfo* device_info) { 109 device::HidDeviceInfo* device_info) {
108 UpdateDevices(); 110 UpdateDevices();
109 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); 111 HidService* hid_service = device::DeviceClient::Get()->GetHidService();
110 DCHECK(hid_service); 112 DCHECK(hid_service);
111 113
112 ResourceIdToDeviceIdMap::const_iterator device_iter = 114 ResourceIdToDeviceIdMap::const_iterator device_iter =
113 device_ids_.find(resource_id); 115 device_ids_.find(resource_id);
114 if (device_iter == device_ids_.end()) 116 if (device_iter == device_ids_.end())
115 return false; 117 return false;
116 118
117 return hid_service->GetDeviceInfo(device_iter->second, device_info); 119 return hid_service->GetDeviceInfo(device_iter->second, device_info);
118 } 120 }
119 121
(...skipping 15 matching lines...) Expand all
135 if (u2f_filter.Matches(device_info)) { 137 if (u2f_filter.Matches(device_info)) {
136 return true; 138 return true;
137 } 139 }
138 } 140 }
139 141
140 return false; 142 return false;
141 } 143 }
142 144
143 void HidDeviceManager::UpdateDevices() { 145 void HidDeviceManager::UpdateDevices() {
144 thread_checker_.CalledOnValidThread(); 146 thread_checker_.CalledOnValidThread();
145 HidService* hid_service = ExtensionsAPIClient::Get()->GetHidService(); 147 HidService* hid_service = device::DeviceClient::Get()->GetHidService();
146 DCHECK(hid_service); 148 DCHECK(hid_service);
147 149
148 std::vector<device::HidDeviceInfo> devices; 150 std::vector<device::HidDeviceInfo> devices;
149 hid_service->GetDevices(&devices); 151 hid_service->GetDevices(&devices);
150 152
151 // Build an updated bidi mapping between resource ID and underlying device ID. 153 // Build an updated bidi mapping between resource ID and underlying device ID.
152 DeviceIdToResourceIdMap new_resource_ids; 154 DeviceIdToResourceIdMap new_resource_ids;
153 ResourceIdToDeviceIdMap new_device_ids; 155 ResourceIdToDeviceIdMap new_device_ids;
154 for (std::vector<device::HidDeviceInfo>::const_iterator iter = 156 for (std::vector<device::HidDeviceInfo>::const_iterator iter =
155 devices.begin(); 157 devices.begin();
(...skipping 10 matching lines...) Expand all
166 new_id = next_resource_id_++; 168 new_id = next_resource_id_++;
167 } 169 }
168 new_resource_ids[device_info.device_id] = new_id; 170 new_resource_ids[device_info.device_id] = new_id;
169 new_device_ids[new_id] = device_info.device_id; 171 new_device_ids[new_id] = device_info.device_id;
170 } 172 }
171 device_ids_.swap(new_device_ids); 173 device_ids_.swap(new_device_ids);
172 resource_ids_.swap(new_resource_ids); 174 resource_ids_.swap(new_resource_ids);
173 } 175 }
174 176
175 } // namespace extensions 177 } // 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