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

Side by Side Diff: device/usb/mojo/device_manager_impl.cc

Issue 1946063002: Replace DeviceManager::GetDeviceChanges with a client interface. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@proper_stubs
Patch Set: Rebase.d Created 4 years, 7 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 | « device/usb/mojo/device_manager_impl.h ('k') | device/usb/mojo/device_manager_impl_unittest.cc » ('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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/usb/mojo/device_manager_impl.h" 5 #include "device/usb/mojo/device_manager_impl.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <memory> 9 #include <memory>
10 #include <utility> 10 #include <utility>
11 11
12 #include "base/bind.h" 12 #include "base/bind.h"
13 #include "base/location.h"
14 #include "base/stl_util.h"
15 #include "device/core/device_client.h" 13 #include "device/core/device_client.h"
16 #include "device/usb/mojo/device_impl.h" 14 #include "device/usb/mojo/device_impl.h"
17 #include "device/usb/mojo/permission_provider.h" 15 #include "device/usb/mojo/permission_provider.h"
18 #include "device/usb/mojo/type_converters.h" 16 #include "device/usb/mojo/type_converters.h"
19 #include "device/usb/public/interfaces/device.mojom.h" 17 #include "device/usb/public/interfaces/device.mojom.h"
20 #include "device/usb/usb_device.h" 18 #include "device/usb/usb_device.h"
21 #include "device/usb/usb_device_filter.h" 19 #include "device/usb/usb_device_filter.h"
22 #include "device/usb/usb_service.h" 20 #include "device/usb/usb_service.h"
23 #include "mojo/public/cpp/bindings/array.h" 21 #include "mojo/public/cpp/bindings/array.h"
24 #include "mojo/public/cpp/bindings/interface_request.h" 22 #include "mojo/public/cpp/bindings/interface_request.h"
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
56 connection_error_handler_.Run(); 54 connection_error_handler_.Run();
57 } 55 }
58 56
59 void DeviceManagerImpl::GetDevices(EnumerationOptionsPtr options, 57 void DeviceManagerImpl::GetDevices(EnumerationOptionsPtr options,
60 const GetDevicesCallback& callback) { 58 const GetDevicesCallback& callback) {
61 usb_service_->GetDevices(base::Bind(&DeviceManagerImpl::OnGetDevices, 59 usb_service_->GetDevices(base::Bind(&DeviceManagerImpl::OnGetDevices,
62 weak_factory_.GetWeakPtr(), 60 weak_factory_.GetWeakPtr(),
63 base::Passed(&options), callback)); 61 base::Passed(&options), callback));
64 } 62 }
65 63
66 void DeviceManagerImpl::GetDeviceChanges(
67 const GetDeviceChangesCallback& callback) {
68 device_change_callbacks_.push(callback);
69 MaybeRunDeviceChangesCallback();
70 }
71
72 void DeviceManagerImpl::GetDevice( 64 void DeviceManagerImpl::GetDevice(
73 const mojo::String& guid, 65 const mojo::String& guid,
74 mojo::InterfaceRequest<Device> device_request) { 66 mojo::InterfaceRequest<Device> device_request) {
75 scoped_refptr<UsbDevice> device = usb_service_->GetDevice(guid); 67 scoped_refptr<UsbDevice> device = usb_service_->GetDevice(guid);
76 if (!device) 68 if (!device)
77 return; 69 return;
78 70
79 if (permission_provider_ && 71 if (permission_provider_ &&
80 permission_provider_->HasDevicePermission(device)) { 72 permission_provider_->HasDevicePermission(device)) {
81 new DeviceImpl(device, DeviceInfo::From(*device), permission_provider_, 73 new DeviceImpl(device, DeviceInfo::From(*device), permission_provider_,
82 std::move(device_request)); 74 std::move(device_request));
83 } 75 }
84 } 76 }
85 77
78 void DeviceManagerImpl::SetClient(DeviceManagerClientPtr client) {
79 client_ = std::move(client);
80 }
81
86 void DeviceManagerImpl::OnGetDevices( 82 void DeviceManagerImpl::OnGetDevices(
87 EnumerationOptionsPtr options, 83 EnumerationOptionsPtr options,
88 const GetDevicesCallback& callback, 84 const GetDevicesCallback& callback,
89 const std::vector<scoped_refptr<UsbDevice>>& devices) { 85 const std::vector<scoped_refptr<UsbDevice>>& devices) {
90 std::vector<UsbDeviceFilter> filters; 86 std::vector<UsbDeviceFilter> filters;
91 if (options) 87 if (options)
92 filters = options->filters.To<std::vector<UsbDeviceFilter>>(); 88 filters = options->filters.To<std::vector<UsbDeviceFilter>>();
93 89
94 mojo::Array<DeviceInfoPtr> device_infos; 90 mojo::Array<DeviceInfoPtr> device_infos;
95 for (const auto& device : devices) { 91 for (const auto& device : devices) {
96 if (filters.empty() || UsbDeviceFilter::MatchesAny(device, filters)) { 92 if (filters.empty() || UsbDeviceFilter::MatchesAny(device, filters)) {
97 if (permission_provider_ && 93 if (permission_provider_ &&
98 permission_provider_->HasDevicePermission(device)) { 94 permission_provider_->HasDevicePermission(device)) {
99 device_infos.push_back(DeviceInfo::From(*device)); 95 device_infos.push_back(DeviceInfo::From(*device));
100 } 96 }
101 } 97 }
102 } 98 }
103 99
104 callback.Run(std::move(device_infos)); 100 callback.Run(std::move(device_infos));
105 } 101 }
106 102
107 void DeviceManagerImpl::OnDeviceAdded(scoped_refptr<UsbDevice> device) { 103 void DeviceManagerImpl::OnDeviceAdded(scoped_refptr<UsbDevice> device) {
108 if (permission_provider_ && 104 if (client_ && permission_provider_ &&
109 permission_provider_->HasDevicePermission(device)) { 105 permission_provider_->HasDevicePermission(device))
110 devices_added_[device->guid()] = DeviceInfo::From(*device); 106 client_->OnDeviceAdded(DeviceInfo::From(*device));
111 MaybeRunDeviceChangesCallback();
112 }
113 } 107 }
114 108
115 void DeviceManagerImpl::OnDeviceRemoved(scoped_refptr<UsbDevice> device) { 109 void DeviceManagerImpl::OnDeviceRemoved(scoped_refptr<UsbDevice> device) {
116 if (devices_added_.erase(device->guid()) == 0) { 110 if (client_ && permission_provider_ &&
117 if (permission_provider_ && 111 permission_provider_->HasDevicePermission(device))
118 permission_provider_->HasDevicePermission(device)) { 112 client_->OnDeviceRemoved(DeviceInfo::From(*device));
119 devices_removed_.push_back(DeviceInfo::From(*device));
120 MaybeRunDeviceChangesCallback();
121 }
122 }
123 } 113 }
124 114
125 void DeviceManagerImpl::WillDestroyUsbService() { 115 void DeviceManagerImpl::WillDestroyUsbService() {
126 delete this; 116 delete this;
127 } 117 }
128 118
129 void DeviceManagerImpl::MaybeRunDeviceChangesCallback() {
130 if (!device_change_callbacks_.empty() &&
131 !(devices_added_.empty() && devices_removed_.empty())) {
132 DeviceChangeNotificationPtr notification = DeviceChangeNotification::New();
133 notification->devices_added.SetToEmpty();
134 notification->devices_removed.SetToEmpty();
135 for (auto& map_entry : devices_added_)
136 notification->devices_added.push_back(std::move(map_entry.second));
137 devices_added_.clear();
138 notification->devices_removed.Swap(&devices_removed_);
139
140 device_change_callbacks_.front().Run(std::move(notification));
141 device_change_callbacks_.pop();
142 }
143 }
144
145 } // namespace usb 119 } // namespace usb
146 } // namespace device 120 } // namespace device
OLDNEW
« no previous file with comments | « device/usb/mojo/device_manager_impl.h ('k') | device/usb/mojo/device_manager_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698