OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/bluetooth/bluetooth_adapter_win.h" | 5 #include "device/bluetooth/bluetooth_adapter_win.h" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
220 for (auto& observer : observers_) | 220 for (auto& observer : observers_) |
221 observer.AdapterPoweredChanged(this, powered_); | 221 observer.AdapterPoweredChanged(this, powered_); |
222 } | 222 } |
223 if (!initialized_) { | 223 if (!initialized_) { |
224 initialized_ = true; | 224 initialized_ = true; |
225 init_callback_.Run(); | 225 init_callback_.Run(); |
226 } | 226 } |
227 } | 227 } |
228 | 228 |
229 void BluetoothAdapterWin::DevicesPolled( | 229 void BluetoothAdapterWin::DevicesPolled( |
230 const ScopedVector<BluetoothTaskManagerWin::DeviceState>& devices) { | 230 const std::vector<std::unique_ptr<BluetoothTaskManagerWin::DeviceState>>& |
| 231 devices) { |
231 DCHECK(thread_checker_.CalledOnValidThread()); | 232 DCHECK(thread_checker_.CalledOnValidThread()); |
232 | 233 |
233 // We are receiving a new list of all devices known to the system. Merge this | 234 // We are receiving a new list of all devices known to the system. Merge this |
234 // new list with the list we know of (|devices_|) and raise corresponding | 235 // new list with the list we know of (|devices_|) and raise corresponding |
235 // DeviceAdded, DeviceRemoved and DeviceChanged events. | 236 // DeviceAdded, DeviceRemoved and DeviceChanged events. |
236 | 237 |
237 typedef std::set<std::string> DeviceAddressSet; | 238 using DeviceAddressSet = std::set<std::string>; |
238 DeviceAddressSet known_devices; | 239 DeviceAddressSet known_devices; |
239 for (DevicesMap::const_iterator iter = devices_.begin(); | 240 for (DevicesMap::const_iterator iter = devices_.begin(); |
240 iter != devices_.end(); | 241 iter != devices_.end(); |
241 ++iter) { | 242 ++iter) { |
242 known_devices.insert((*iter).first); | 243 known_devices.insert((*iter).first); |
243 } | 244 } |
244 | 245 |
245 DeviceAddressSet new_devices; | 246 DeviceAddressSet new_devices; |
246 for (ScopedVector<BluetoothTaskManagerWin::DeviceState>::const_iterator iter = | 247 for (auto& device : devices) { |
247 devices.begin(); | 248 new_devices.insert(device->address); |
248 iter != devices.end(); | |
249 ++iter) { | |
250 new_devices.insert((*iter)->address); | |
251 } | 249 } |
252 | 250 |
253 // Process device removal first | 251 // Process device removal first |
254 DeviceAddressSet removed_devices = | 252 DeviceAddressSet removed_devices = |
255 base::STLSetDifference<DeviceAddressSet>(known_devices, new_devices); | 253 base::STLSetDifference<DeviceAddressSet>(known_devices, new_devices); |
256 for (DeviceAddressSet::const_iterator iter = removed_devices.begin(); | 254 for (DeviceAddressSet::const_iterator iter = removed_devices.begin(); |
257 iter != removed_devices.end(); | 255 iter != removed_devices.end(); |
258 ++iter) { | 256 ++iter) { |
259 std::unique_ptr<BluetoothDevice> device_win = | 257 auto found = devices_.find(*iter); |
260 devices_.take_and_erase(*iter); | 258 if (found == devices_.end()) |
| 259 continue; |
| 260 auto device_win = std::move(found->second); |
| 261 devices_.erase(*iter); |
261 for (auto& observer : observers_) | 262 for (auto& observer : observers_) |
262 observer.DeviceRemoved(this, device_win.get()); | 263 observer.DeviceRemoved(this, device_win.get()); |
263 } | 264 } |
264 | 265 |
265 // Process added and (maybe) changed devices in one pass | 266 // Process added and (maybe) changed devices in one pass |
266 DeviceAddressSet added_devices = | 267 DeviceAddressSet added_devices = |
267 base::STLSetDifference<DeviceAddressSet>(new_devices, known_devices); | 268 base::STLSetDifference<DeviceAddressSet>(new_devices, known_devices); |
268 DeviceAddressSet changed_devices = | 269 DeviceAddressSet changed_devices = |
269 base::STLSetIntersection<DeviceAddressSet>(known_devices, new_devices); | 270 base::STLSetIntersection<DeviceAddressSet>(known_devices, new_devices); |
270 for (ScopedVector<BluetoothTaskManagerWin::DeviceState>::const_iterator iter = | 271 for (auto& device_state : devices) { |
271 devices.begin(); | |
272 iter != devices.end(); | |
273 ++iter) { | |
274 BluetoothTaskManagerWin::DeviceState* device_state = (*iter); | |
275 if (added_devices.find(device_state->address) != added_devices.end()) { | 272 if (added_devices.find(device_state->address) != added_devices.end()) { |
276 BluetoothDeviceWin* device_win = | 273 auto* device_win = |
277 new BluetoothDeviceWin(this, *device_state, ui_task_runner_, | 274 new BluetoothDeviceWin(this, *device_state, ui_task_runner_, |
278 socket_thread_, NULL, net::NetLogSource()); | 275 socket_thread_, NULL, net::NetLogSource()); |
279 devices_.set(device_state->address, | 276 auto insertion = devices_.insert( |
280 std::unique_ptr<BluetoothDevice>(device_win)); | 277 std::make_pair(device_state->address, std::move(device_win))); |
| 278 if (!insertion.second) |
| 279 continue; |
281 for (auto& observer : observers_) | 280 for (auto& observer : observers_) |
282 observer.DeviceAdded(this, device_win); | 281 observer.DeviceAdded(this, insertion.first->second.get()); |
283 } else if (changed_devices.find(device_state->address) != | 282 } else if (changed_devices.find(device_state->address) != |
284 changed_devices.end()) { | 283 changed_devices.end()) { |
285 DevicesMap::const_iterator iter = devices_.find(device_state->address); | 284 DevicesMap::const_iterator iter = devices_.find(device_state->address); |
286 DCHECK(iter != devices_.end()); | 285 DCHECK(iter != devices_.end()); |
287 BluetoothDeviceWin* device_win = | 286 BluetoothDeviceWin* device_win = |
288 static_cast<BluetoothDeviceWin*>(iter->second); | 287 static_cast<BluetoothDeviceWin*>(iter->second.get()); |
289 if (!device_win->IsEqual(*device_state)) { | 288 if (!device_win->IsEqual(*device_state)) { |
290 device_win->Update(*device_state); | 289 device_win->Update(*device_state); |
291 for (auto& observer : observers_) | 290 for (auto& observer : observers_) |
292 observer.DeviceChanged(this, device_win); | 291 observer.DeviceChanged(this, device_win); |
293 } | 292 } |
294 // Above IsEqual returns true if device name, address, status and services | 293 // Above IsEqual returns true if device name, address, status and services |
295 // (primary services of BLE device) are the same. However, in BLE tests, | 294 // (primary services of BLE device) are the same. However, in BLE tests, |
296 // we may simulate characteristic, descriptor and secondary GATT service | 295 // we may simulate characteristic, descriptor and secondary GATT service |
297 // after device has been initialized. | 296 // after device has been initialized. |
298 if (force_update_device_for_test_) | 297 if (force_update_device_for_test_) |
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
380 num_discovery_listeners_ -= on_stop_discovery_callbacks_.size(); | 379 num_discovery_listeners_ -= on_stop_discovery_callbacks_.size(); |
381 on_stop_discovery_callbacks_.clear(); | 380 on_stop_discovery_callbacks_.clear(); |
382 return; | 381 return; |
383 } | 382 } |
384 | 383 |
385 discovery_status_ = DISCOVERY_STOPPING; | 384 discovery_status_ = DISCOVERY_STOPPING; |
386 task_manager_->PostStopDiscoveryTask(); | 385 task_manager_->PostStopDiscoveryTask(); |
387 } | 386 } |
388 | 387 |
389 } // namespace device | 388 } // namespace device |
OLD | NEW |