Commit 657f4b1b authored by Miyoung Shin's avatar Miyoung Shin Committed by Commit Bot

Convert HidManagerClient to new Mojo types

This CL converts HidManagerClient{AssociatedPtr, AssociatedPtrInfo
and AssociatedRequest} in device, services and extensions to the
new Mojo type.

Bug: 955171
Change-Id: I86e47ad4d6bdb35a89cca8337bd066aa167b2c5c
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/1803938
Commit-Queue: Miyoung Shin <myid.shin@igalia.com>
Reviewed-by: default avatarOksana Zhuravlova <oksamyt@chromium.org>
Reviewed-by: default avatarReilly Grant <reillyg@chromium.org>
Reviewed-by: default avatarDominick Ng <dominickn@chromium.org>
Cr-Commit-Position: refs/heads/master@{#697482}
parent 35e8900d
...@@ -156,9 +156,7 @@ void FakeFidoHidManager::GetDevicesAndSetClient( ...@@ -156,9 +156,7 @@ void FakeFidoHidManager::GetDevicesAndSetClient(
GetDevicesCallback callback) { GetDevicesCallback callback) {
GetDevices(std::move(callback)); GetDevices(std::move(callback));
device::mojom::HidManagerClientAssociatedPtr client_ptr; clients_.Add(std::move(client));
client_ptr.Bind(std::move(client));
clients_.AddPtr(std::move(client_ptr));
} }
void FakeFidoHidManager::GetDevices(GetDevicesCallback callback) { void FakeFidoHidManager::GetDevices(GetDevicesCallback callback) {
...@@ -185,9 +183,8 @@ void FakeFidoHidManager::Connect( ...@@ -185,9 +183,8 @@ void FakeFidoHidManager::Connect(
void FakeFidoHidManager::AddDevice(device::mojom::HidDeviceInfoPtr device) { void FakeFidoHidManager::AddDevice(device::mojom::HidDeviceInfoPtr device) {
device::mojom::HidDeviceInfo* device_info = device.get(); device::mojom::HidDeviceInfo* device_info = device.get();
clients_.ForAllPtrs([device_info](device::mojom::HidManagerClient* client) { for (auto& client : clients_)
client->DeviceAdded(device_info->Clone()); client->DeviceAdded(device_info->Clone());
});
devices_[device->guid] = std::move(device); devices_[device->guid] = std::move(device);
} }
...@@ -205,9 +202,8 @@ void FakeFidoHidManager::RemoveDevice(const std::string device_guid) { ...@@ -205,9 +202,8 @@ void FakeFidoHidManager::RemoveDevice(const std::string device_guid) {
return; return;
device::mojom::HidDeviceInfo* device_info = it->second.get(); device::mojom::HidDeviceInfo* device_info = it->second.get();
clients_.ForAllPtrs([device_info](device::mojom::HidManagerClient* client) { for (auto& client : clients_)
client->DeviceRemoved(device_info->Clone()); client->DeviceRemoved(device_info->Clone());
});
devices_.erase(it); devices_.erase(it);
} }
......
...@@ -14,9 +14,9 @@ ...@@ -14,9 +14,9 @@
#include "base/macros.h" #include "base/macros.h"
#include "base/memory/ptr_util.h" #include "base/memory/ptr_util.h"
#include "device/fido/fido_constants.h" #include "device/fido/fido_constants.h"
#include "mojo/public/cpp/bindings/interface_ptr_set.h"
#include "mojo/public/cpp/bindings/pending_receiver.h" #include "mojo/public/cpp/bindings/pending_receiver.h"
#include "mojo/public/cpp/bindings/receiver_set.h" #include "mojo/public/cpp/bindings/receiver_set.h"
#include "mojo/public/cpp/bindings/remote_set.h"
#include "mojo/public/cpp/bindings/strong_binding.h" #include "mojo/public/cpp/bindings/strong_binding.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
#include "testing/gmock/include/gmock/gmock.h" #include "testing/gmock/include/gmock/gmock.h"
...@@ -122,7 +122,7 @@ class FakeFidoHidManager : public device::mojom::HidManager { ...@@ -122,7 +122,7 @@ class FakeFidoHidManager : public device::mojom::HidManager {
private: private:
std::map<std::string, device::mojom::HidDeviceInfoPtr> devices_; std::map<std::string, device::mojom::HidDeviceInfoPtr> devices_;
std::map<std::string, device::mojom::HidConnectionPtr> connections_; std::map<std::string, device::mojom::HidConnectionPtr> connections_;
mojo::AssociatedInterfacePtrSet<device::mojom::HidManagerClient> clients_; mojo::AssociatedRemoteSet<device::mojom::HidManagerClient> clients_;
mojo::ReceiverSet<device::mojom::HidManager> receivers_; mojo::ReceiverSet<device::mojom::HidManager> receivers_;
DISALLOW_COPY_AND_ASSIGN(FakeFidoHidManager); DISALLOW_COPY_AND_ASSIGN(FakeFidoHidManager);
......
...@@ -8,7 +8,6 @@ ...@@ -8,7 +8,6 @@
#include "base/bind.h" #include "base/bind.h"
#include "device/fido/hid/fido_hid_device.h" #include "device/fido/hid/fido_hid_device.h"
#include "mojo/public/cpp/bindings/interface_request.h"
#include "services/device/public/mojom/constants.mojom.h" #include "services/device/public/mojom/constants.mojom.h"
#include "services/service_manager/public/cpp/connector.h" #include "services/service_manager/public/cpp/connector.h"
...@@ -16,8 +15,7 @@ namespace device { ...@@ -16,8 +15,7 @@ namespace device {
FidoHidDiscovery::FidoHidDiscovery(::service_manager::Connector* connector) FidoHidDiscovery::FidoHidDiscovery(::service_manager::Connector* connector)
: FidoDeviceDiscovery(FidoTransportProtocol::kUsbHumanInterfaceDevice), : FidoDeviceDiscovery(FidoTransportProtocol::kUsbHumanInterfaceDevice),
connector_(connector), connector_(connector) {
binding_(this) {
// TODO(piperc@): Give this constant a name. // TODO(piperc@): Give this constant a name.
filter_.SetUsagePage(0xf1d0); filter_.SetUsagePage(0xf1d0);
} }
...@@ -28,12 +26,11 @@ void FidoHidDiscovery::StartInternal() { ...@@ -28,12 +26,11 @@ void FidoHidDiscovery::StartInternal() {
DCHECK(connector_); DCHECK(connector_);
connector_->Connect(device::mojom::kServiceName, connector_->Connect(device::mojom::kServiceName,
hid_manager_.BindNewPipeAndPassReceiver()); hid_manager_.BindNewPipeAndPassReceiver());
device::mojom::HidManagerClientAssociatedPtrInfo client;
binding_.Bind(mojo::MakeRequest(&client));
hid_manager_->GetDevicesAndSetClient( hid_manager_->GetDevicesAndSetClient(
std::move(client), base::BindOnce(&FidoHidDiscovery::OnGetDevices, receiver_.BindNewEndpointAndPassRemote(),
weak_factory_.GetWeakPtr())); base::BindOnce(&FidoHidDiscovery::OnGetDevices,
weak_factory_.GetWeakPtr()));
} }
void FidoHidDiscovery::DeviceAdded( void FidoHidDiscovery::DeviceAdded(
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#include "base/macros.h" #include "base/macros.h"
#include "base/memory/weak_ptr.h" #include "base/memory/weak_ptr.h"
#include "device/fido/fido_device_discovery.h" #include "device/fido/fido_device_discovery.h"
#include "mojo/public/cpp/bindings/associated_binding.h" #include "mojo/public/cpp/bindings/associated_receiver.h"
#include "mojo/public/cpp/bindings/remote.h" #include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/cpp/hid/hid_device_filter.h" #include "services/device/public/cpp/hid/hid_device_filter.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
...@@ -45,7 +45,7 @@ class COMPONENT_EXPORT(DEVICE_FIDO) FidoHidDiscovery ...@@ -45,7 +45,7 @@ class COMPONENT_EXPORT(DEVICE_FIDO) FidoHidDiscovery
service_manager::Connector* connector_; service_manager::Connector* connector_;
mojo::Remote<device::mojom::HidManager> hid_manager_; mojo::Remote<device::mojom::HidManager> hid_manager_;
mojo::AssociatedBinding<device::mojom::HidManagerClient> binding_; mojo::AssociatedReceiver<device::mojom::HidManagerClient> receiver_{this};
HidDeviceFilter filter_; HidDeviceFilter filter_;
base::WeakPtrFactory<FidoHidDiscovery> weak_factory_{this}; base::WeakPtrFactory<FidoHidDiscovery> weak_factory_{this};
......
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
namespace device { namespace device {
NintendoDataFetcher::NintendoDataFetcher() : binding_(this) {} NintendoDataFetcher::NintendoDataFetcher() = default;
NintendoDataFetcher::~NintendoDataFetcher() { NintendoDataFetcher::~NintendoDataFetcher() {
for (auto& entry : controllers_) { for (auto& entry : controllers_) {
...@@ -32,11 +32,10 @@ void NintendoDataFetcher::OnAddedToProvider() { ...@@ -32,11 +32,10 @@ void NintendoDataFetcher::OnAddedToProvider() {
// OnGetDevices will be called with a list of connected HID devices. // OnGetDevices will be called with a list of connected HID devices.
connector()->Connect(mojom::kServiceName, connector()->Connect(mojom::kServiceName,
hid_manager_.BindNewPipeAndPassReceiver()); hid_manager_.BindNewPipeAndPassReceiver());
mojom::HidManagerClientAssociatedPtrInfo client;
binding_.Bind(mojo::MakeRequest(&client));
hid_manager_->GetDevicesAndSetClient( hid_manager_->GetDevicesAndSetClient(
std::move(client), base::BindOnce(&NintendoDataFetcher::OnGetDevices, receiver_.BindNewEndpointAndPassRemote(),
weak_factory_.GetWeakPtr())); base::BindOnce(&NintendoDataFetcher::OnGetDevices,
weak_factory_.GetWeakPtr()));
} }
void NintendoDataFetcher::OnGetDevices( void NintendoDataFetcher::OnGetDevices(
......
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
#include "device/gamepad/gamepad_data_fetcher.h" #include "device/gamepad/gamepad_data_fetcher.h"
#include "device/gamepad/nintendo_controller.h" #include "device/gamepad/nintendo_controller.h"
#include "device/gamepad/public/cpp/gamepads.h" #include "device/gamepad/public/cpp/gamepads.h"
#include "mojo/public/cpp/bindings/associated_binding.h" #include "mojo/public/cpp/bindings/associated_receiver.h"
#include "mojo/public/cpp/bindings/remote.h" #include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
...@@ -112,7 +112,7 @@ class DEVICE_GAMEPAD_EXPORT NintendoDataFetcher : public GamepadDataFetcher, ...@@ -112,7 +112,7 @@ class DEVICE_GAMEPAD_EXPORT NintendoDataFetcher : public GamepadDataFetcher,
ControllerMap controllers_; ControllerMap controllers_;
mojo::Remote<mojom::HidManager> hid_manager_; mojo::Remote<mojom::HidManager> hid_manager_;
mojo::AssociatedBinding<mojom::HidManagerClient> binding_; mojo::AssociatedReceiver<mojom::HidManagerClient> receiver_{this};
base::WeakPtrFactory<NintendoDataFetcher> weak_factory_{this}; base::WeakPtrFactory<NintendoDataFetcher> weak_factory_{this};
DISALLOW_COPY_AND_ASSIGN(NintendoDataFetcher); DISALLOW_COPY_AND_ASSIGN(NintendoDataFetcher);
......
...@@ -20,8 +20,7 @@ ...@@ -20,8 +20,7 @@
#include "extensions/browser/api/device_permissions_manager.h" #include "extensions/browser/api/device_permissions_manager.h"
#include "extensions/browser/api/usb/usb_device_manager.h" #include "extensions/browser/api/usb/usb_device_manager.h"
#include "extensions/common/extension.h" #include "extensions/common/extension.h"
#include "mojo/public/cpp/bindings/associated_binding.h" #include "mojo/public/cpp/bindings/associated_receiver.h"
#include "mojo/public/cpp/bindings/interface_request.h"
#include "mojo/public/cpp/bindings/remote.h" #include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/cpp/hid/hid_device_filter.h" #include "services/device/public/cpp/hid/hid_device_filter.h"
#include "services/device/public/cpp/hid/hid_usage_and_page.h" #include "services/device/public/cpp/hid/hid_usage_and_page.h"
...@@ -195,8 +194,7 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt, ...@@ -195,8 +194,7 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt,
: Prompt(extension, context, multiple), : Prompt(extension, context, multiple),
initialized_(false), initialized_(false),
filters_(filters), filters_(filters),
callback_(callback), callback_(callback) {}
binding_(this) {}
private: private:
~HidDevicePermissionsPrompt() override {} ~HidDevicePermissionsPrompt() override {}
...@@ -221,11 +219,8 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt, ...@@ -221,11 +219,8 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt,
connector->Connect(device::mojom::kServiceName, connector->Connect(device::mojom::kServiceName,
hid_manager_.BindNewPipeAndPassReceiver()); hid_manager_.BindNewPipeAndPassReceiver());
device::mojom::HidManagerClientAssociatedPtrInfo client;
binding_.Bind(mojo::MakeRequest(&client));
hid_manager_->GetDevicesAndSetClient( hid_manager_->GetDevicesAndSetClient(
std::move(client), receiver_.BindNewEndpointAndPassRemote(),
base::BindOnce(&HidDevicePermissionsPrompt::OnDevicesEnumerated, this)); base::BindOnce(&HidDevicePermissionsPrompt::OnDevicesEnumerated, this));
initialized_ = true; initialized_ = true;
...@@ -300,7 +295,7 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt, ...@@ -300,7 +295,7 @@ class HidDevicePermissionsPrompt : public DevicePermissionsPrompt::Prompt,
std::vector<HidDeviceFilter> filters_; std::vector<HidDeviceFilter> filters_;
mojo::Remote<device::mojom::HidManager> hid_manager_; mojo::Remote<device::mojom::HidManager> hid_manager_;
DevicePermissionsPrompt::HidDevicesCallback callback_; DevicePermissionsPrompt::HidDevicesCallback callback_;
mojo::AssociatedBinding<device::mojom::HidManagerClient> binding_; mojo::AssociatedReceiver<device::mojom::HidManagerClient> receiver_{this};
}; };
} // namespace } // namespace
......
...@@ -23,7 +23,6 @@ ...@@ -23,7 +23,6 @@
#include "extensions/common/permissions/permissions_data.h" #include "extensions/common/permissions/permissions_data.h"
#include "extensions/common/permissions/usb_device_permission.h" #include "extensions/common/permissions/usb_device_permission.h"
#include "mojo/public/cpp/bindings/callback_helpers.h" #include "mojo/public/cpp/bindings/callback_helpers.h"
#include "mojo/public/cpp/bindings/interface_request.h"
#include "mojo/public/cpp/bindings/pending_remote.h" #include "mojo/public/cpp/bindings/pending_remote.h"
#include "services/device/public/cpp/hid/hid_device_filter.h" #include "services/device/public/cpp/hid/hid_device_filter.h"
#include "services/device/public/cpp/hid/hid_usage_and_page.h" #include "services/device/public/cpp/hid/hid_usage_and_page.h"
...@@ -102,7 +101,7 @@ struct HidDeviceManager::GetApiDevicesParams { ...@@ -102,7 +101,7 @@ struct HidDeviceManager::GetApiDevicesParams {
}; };
HidDeviceManager::HidDeviceManager(content::BrowserContext* context) HidDeviceManager::HidDeviceManager(content::BrowserContext* context)
: browser_context_(context), binding_(this) { : browser_context_(context) {
event_router_ = EventRouter::Get(context); event_router_ = EventRouter::Get(context);
if (event_router_) { if (event_router_) {
event_router_->RegisterObserver(this, hid::OnDeviceAdded::kEventName); event_router_->RegisterObserver(this, hid::OnDeviceAdded::kEventName);
...@@ -296,10 +295,8 @@ void HidDeviceManager::LazyInitialize() { ...@@ -296,10 +295,8 @@ void HidDeviceManager::LazyInitialize() {
} }
// Enumerate HID devices and set client. // Enumerate HID devices and set client.
std::vector<device::mojom::HidDeviceInfoPtr> empty_devices; std::vector<device::mojom::HidDeviceInfoPtr> empty_devices;
device::mojom::HidManagerClientAssociatedPtrInfo client;
binding_.Bind(mojo::MakeRequest(&client));
hid_manager_->GetDevicesAndSetClient( hid_manager_->GetDevicesAndSetClient(
std::move(client), receiver_.BindNewEndpointAndPassRemote(),
mojo::WrapCallbackWithDefaultInvokeIfNotRun( mojo::WrapCallbackWithDefaultInvokeIfNotRun(
base::BindOnce(&HidDeviceManager::OnEnumerationComplete, base::BindOnce(&HidDeviceManager::OnEnumerationComplete,
weak_factory_.GetWeakPtr()), weak_factory_.GetWeakPtr()),
......
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
#include "extensions/browser/event_router.h" #include "extensions/browser/event_router.h"
#include "extensions/browser/extension_event_histogram_value.h" #include "extensions/browser/extension_event_histogram_value.h"
#include "extensions/common/api/hid.h" #include "extensions/common/api/hid.h"
#include "mojo/public/cpp/bindings/associated_binding.h" #include "mojo/public/cpp/bindings/associated_receiver.h"
#include "mojo/public/cpp/bindings/pending_remote.h" #include "mojo/public/cpp/bindings/pending_remote.h"
#include "mojo/public/cpp/bindings/remote.h" #include "mojo/public/cpp/bindings/remote.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
...@@ -125,7 +125,7 @@ class HidDeviceManager : public BrowserContextKeyedAPI, ...@@ -125,7 +125,7 @@ class HidDeviceManager : public BrowserContextKeyedAPI,
EventRouter* event_router_ = nullptr; EventRouter* event_router_ = nullptr;
bool initialized_ = false; bool initialized_ = false;
mojo::Remote<device::mojom::HidManager> hid_manager_; mojo::Remote<device::mojom::HidManager> hid_manager_;
mojo::AssociatedBinding<device::mojom::HidManagerClient> binding_; mojo::AssociatedReceiver<device::mojom::HidManagerClient> receiver_{this};
bool enumeration_ready_ = false; bool enumeration_ready_ = false;
std::vector<std::unique_ptr<GetApiDevicesParams>> pending_enumerations_; std::vector<std::unique_ptr<GetApiDevicesParams>> pending_enumerations_;
int next_resource_id_ = 0; int next_resource_id_ = 0;
......
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include "base/callback_helpers.h" #include "base/callback_helpers.h"
#include "base/lazy_instance.h" #include "base/lazy_instance.h"
#include "base/stl_util.h" #include "base/stl_util.h"
#include "mojo/public/cpp/bindings/associated_remote.h"
#include "mojo/public/cpp/bindings/strong_binding.h" #include "mojo/public/cpp/bindings/strong_binding.h"
#include "services/device/hid/hid_connection_impl.h" #include "services/device/hid/hid_connection_impl.h"
...@@ -50,23 +51,21 @@ void HidManagerImpl::GetDevicesAndSetClient( ...@@ -50,23 +51,21 @@ void HidManagerImpl::GetDevicesAndSetClient(
} }
void HidManagerImpl::GetDevices(GetDevicesCallback callback) { void HidManagerImpl::GetDevices(GetDevicesCallback callback) {
hid_service_->GetDevices(base::BindOnce(&HidManagerImpl::CreateDeviceList, hid_service_->GetDevices(base::BindOnce(
weak_factory_.GetWeakPtr(), &HidManagerImpl::CreateDeviceList, weak_factory_.GetWeakPtr(),
std::move(callback), nullptr)); std::move(callback), mojo::NullAssociatedRemote()));
} }
void HidManagerImpl::CreateDeviceList( void HidManagerImpl::CreateDeviceList(
GetDevicesCallback callback, GetDevicesCallback callback,
mojom::HidManagerClientAssociatedPtrInfo client, mojo::PendingAssociatedRemote<mojom::HidManagerClient> client,
std::vector<mojom::HidDeviceInfoPtr> devices) { std::vector<mojom::HidDeviceInfoPtr> devices) {
std::move(callback).Run(std::move(devices)); std::move(callback).Run(std::move(devices));
if (!client.is_valid()) if (!client.is_valid())
return; return;
mojom::HidManagerClientAssociatedPtr client_ptr; clients_.Add(std::move(client));
client_ptr.Bind(std::move(client));
clients_.AddPtr(std::move(client_ptr));
} }
void HidManagerImpl::Connect( void HidManagerImpl::Connect(
...@@ -98,17 +97,13 @@ void HidManagerImpl::CreateConnection( ...@@ -98,17 +97,13 @@ void HidManagerImpl::CreateConnection(
} }
void HidManagerImpl::OnDeviceAdded(mojom::HidDeviceInfoPtr device) { void HidManagerImpl::OnDeviceAdded(mojom::HidDeviceInfoPtr device) {
mojom::HidDeviceInfo* device_info = device.get(); for (auto& client : clients_)
clients_.ForAllPtrs([device_info](mojom::HidManagerClient* client) { client->DeviceAdded(device->Clone());
client->DeviceAdded(device_info->Clone());
});
} }
void HidManagerImpl::OnDeviceRemoved(mojom::HidDeviceInfoPtr device) { void HidManagerImpl::OnDeviceRemoved(mojom::HidDeviceInfoPtr device) {
mojom::HidDeviceInfo* device_info = device.get(); for (auto& client : clients_)
clients_.ForAllPtrs([device_info](mojom::HidManagerClient* client) { client->DeviceRemoved(device->Clone());
client->DeviceRemoved(device_info->Clone());
});
} }
} // namespace device } // namespace device
...@@ -9,9 +9,10 @@ ...@@ -9,9 +9,10 @@
#include "base/memory/ref_counted.h" #include "base/memory/ref_counted.h"
#include "base/memory/weak_ptr.h" #include "base/memory/weak_ptr.h"
#include "base/scoped_observer.h" #include "base/scoped_observer.h"
#include "mojo/public/cpp/bindings/interface_ptr_set.h" #include "mojo/public/cpp/bindings/pending_associated_remote.h"
#include "mojo/public/cpp/bindings/pending_receiver.h" #include "mojo/public/cpp/bindings/pending_receiver.h"
#include "mojo/public/cpp/bindings/receiver_set.h" #include "mojo/public/cpp/bindings/receiver_set.h"
#include "mojo/public/cpp/bindings/remote_set.h"
#include "services/device/hid/hid_device_info.h" #include "services/device/hid/hid_device_info.h"
#include "services/device/hid/hid_service.h" #include "services/device/hid/hid_service.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
...@@ -43,9 +44,10 @@ class HidManagerImpl : public mojom::HidManager, public HidService::Observer { ...@@ -43,9 +44,10 @@ class HidManagerImpl : public mojom::HidManager, public HidService::Observer {
ConnectCallback callback) override; ConnectCallback callback) override;
private: private:
void CreateDeviceList(GetDevicesCallback callback, void CreateDeviceList(
mojom::HidManagerClientAssociatedPtrInfo client, GetDevicesCallback callback,
std::vector<mojom::HidDeviceInfoPtr> devices); mojo::PendingAssociatedRemote<mojom::HidManagerClient> client,
std::vector<mojom::HidDeviceInfoPtr> devices);
void CreateConnection( void CreateConnection(
ConnectCallback callback, ConnectCallback callback,
...@@ -58,7 +60,7 @@ class HidManagerImpl : public mojom::HidManager, public HidService::Observer { ...@@ -58,7 +60,7 @@ class HidManagerImpl : public mojom::HidManager, public HidService::Observer {
std::unique_ptr<HidService> hid_service_; std::unique_ptr<HidService> hid_service_;
mojo::ReceiverSet<mojom::HidManager> receivers_; mojo::ReceiverSet<mojom::HidManager> receivers_;
mojo::AssociatedInterfacePtrSet<mojom::HidManagerClient> clients_; mojo::AssociatedRemoteSet<mojom::HidManagerClient> clients_;
ScopedObserver<HidService, HidService::Observer> hid_service_observer_; ScopedObserver<HidService, HidService::Observer> hid_service_observer_;
base::WeakPtrFactory<HidManagerImpl> weak_factory_{this}; base::WeakPtrFactory<HidManagerImpl> weak_factory_{this};
......
...@@ -8,7 +8,8 @@ ...@@ -8,7 +8,8 @@
#include "base/memory/ref_counted.h" #include "base/memory/ref_counted.h"
#include "base/run_loop.h" #include "base/run_loop.h"
#include "build/build_config.h" #include "build/build_config.h"
#include "mojo/public/cpp/bindings/associated_binding.h" #include "mojo/public/cpp/bindings/associated_receiver.h"
#include "mojo/public/cpp/bindings/pending_associated_receiver.h"
#include "mojo/public/cpp/bindings/remote.h" #include "mojo/public/cpp/bindings/remote.h"
#include "services/device/device_service_test_base.h" #include "services/device/device_service_test_base.h"
#include "services/device/hid/hid_manager_impl.h" #include "services/device/hid/hid_manager_impl.h"
...@@ -29,10 +30,11 @@ const char* kTestDeviceIds[] = {"A", "B"}; ...@@ -29,10 +30,11 @@ const char* kTestDeviceIds[] = {"A", "B"};
class MockHidManagerClient : public mojom::HidManagerClient { class MockHidManagerClient : public mojom::HidManagerClient {
public: public:
MockHidManagerClient() : binding_(this) {} MockHidManagerClient() = default;
~MockHidManagerClient() override = default;
void Bind(mojom::HidManagerClientAssociatedRequest request) { void Bind(mojo::PendingAssociatedReceiver<mojom::HidManagerClient> receiver) {
binding_.Bind(std::move(request)); receiver_.Bind(std::move(receiver));
} }
void DeviceAdded(mojom::HidDeviceInfoPtr device_info) override { void DeviceAdded(mojom::HidDeviceInfoPtr device_info) override {
...@@ -58,7 +60,7 @@ class MockHidManagerClient : public mojom::HidManagerClient { ...@@ -58,7 +60,7 @@ class MockHidManagerClient : public mojom::HidManagerClient {
void SetExpectGUID(std::string guid) { expect_guid_ = guid; } void SetExpectGUID(std::string guid) { expect_guid_ = guid; }
private: private:
mojo::AssociatedBinding<mojom::HidManagerClient> binding_; mojo::AssociatedReceiver<mojom::HidManagerClient> receiver_{this};
mojom::HidConnectionPtr hid_connection_; mojom::HidConnectionPtr hid_connection_;
base::OnceClosure quit_closure_; base::OnceClosure quit_closure_;
std::string expect_guid_; std::string expect_guid_;
...@@ -181,8 +183,8 @@ TEST_F(HidManagerTest, GetDevicesAndSetClient) { ...@@ -181,8 +183,8 @@ TEST_F(HidManagerTest, GetDevicesAndSetClient) {
mock_hid_service_->FirstEnumerationComplete(); mock_hid_service_->FirstEnumerationComplete();
auto client = std::make_unique<MockHidManagerClient>(); auto client = std::make_unique<MockHidManagerClient>();
mojom::HidManagerClientAssociatedPtrInfo hid_manager_client; mojo::PendingAssociatedRemote<mojom::HidManagerClient> hid_manager_client;
client->Bind(mojo::MakeRequest(&hid_manager_client)); client->Bind(hid_manager_client.InitWithNewEndpointAndPassReceiver());
// Call GetDevicesAndSetClient, expect 1 device will be received in // Call GetDevicesAndSetClient, expect 1 device will be received in
// OnGetDevices(). // OnGetDevices().
...@@ -230,8 +232,8 @@ TEST_F(HidManagerTest, TestHidConnectionInterface) { ...@@ -230,8 +232,8 @@ TEST_F(HidManagerTest, TestHidConnectionInterface) {
mock_hid_service_->FirstEnumerationComplete(); mock_hid_service_->FirstEnumerationComplete();
auto client = std::make_unique<MockHidManagerClient>(); auto client = std::make_unique<MockHidManagerClient>();
mojom::HidManagerClientAssociatedPtrInfo hid_manager_client; mojo::PendingAssociatedRemote<mojom::HidManagerClient> hid_manager_client;
client->Bind(mojo::MakeRequest(&hid_manager_client)); client->Bind(hid_manager_client.InitWithNewEndpointAndPassReceiver());
// Call GetDevicesAndSetClient, expect 1 device will be received in // Call GetDevicesAndSetClient, expect 1 device will be received in
// OnGetDevices(). // OnGetDevices().
......
...@@ -104,9 +104,7 @@ void FakeHidManager::GetDevicesAndSetClient( ...@@ -104,9 +104,7 @@ void FakeHidManager::GetDevicesAndSetClient(
GetDevicesCallback callback) { GetDevicesCallback callback) {
GetDevices(std::move(callback)); GetDevices(std::move(callback));
mojom::HidManagerClientAssociatedPtr client_ptr; clients_.Add(std::move(client));
client_ptr.Bind(std::move(client));
clients_.AddPtr(std::move(client_ptr));
} }
void FakeHidManager::GetDevices(GetDevicesCallback callback) { void FakeHidManager::GetDevices(GetDevicesCallback callback) {
...@@ -184,17 +182,15 @@ void FakeHidManager::AddDevice(mojom::HidDeviceInfoPtr device) { ...@@ -184,17 +182,15 @@ void FakeHidManager::AddDevice(mojom::HidDeviceInfoPtr device) {
devices_[guid] = std::move(device); devices_[guid] = std::move(device);
mojom::HidDeviceInfo* device_info = devices_[guid].get(); mojom::HidDeviceInfo* device_info = devices_[guid].get();
clients_.ForAllPtrs([device_info](mojom::HidManagerClient* client) { for (auto& client : clients_)
client->DeviceAdded(device_info->Clone()); client->DeviceAdded(device_info->Clone());
});
} }
void FakeHidManager::RemoveDevice(const std::string& guid) { void FakeHidManager::RemoveDevice(const std::string& guid) {
if (base::Contains(devices_, guid)) { if (base::Contains(devices_, guid)) {
mojom::HidDeviceInfo* device_info = devices_[guid].get(); mojom::HidDeviceInfo* device_info = devices_[guid].get();
clients_.ForAllPtrs([device_info](mojom::HidManagerClient* client) { for (auto& client : clients_)
client->DeviceRemoved(device_info->Clone()); client->DeviceRemoved(device_info->Clone());
});
devices_.erase(guid); devices_.erase(guid);
} }
} }
......
...@@ -9,9 +9,9 @@ ...@@ -9,9 +9,9 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include "mojo/public/cpp/bindings/interface_ptr_set.h"
#include "mojo/public/cpp/bindings/pending_remote.h" #include "mojo/public/cpp/bindings/pending_remote.h"
#include "mojo/public/cpp/bindings/receiver_set.h" #include "mojo/public/cpp/bindings/receiver_set.h"
#include "mojo/public/cpp/bindings/remote_set.h"
#include "services/device/public/mojom/hid.mojom.h" #include "services/device/public/mojom/hid.mojom.h"
namespace device { namespace device {
...@@ -71,7 +71,7 @@ class FakeHidManager : public mojom::HidManager { ...@@ -71,7 +71,7 @@ class FakeHidManager : public mojom::HidManager {
private: private:
std::map<std::string, mojom::HidDeviceInfoPtr> devices_; std::map<std::string, mojom::HidDeviceInfoPtr> devices_;
mojo::AssociatedInterfacePtrSet<mojom::HidManagerClient> clients_; mojo::AssociatedRemoteSet<mojom::HidManagerClient> clients_;
mojo::ReceiverSet<mojom::HidManager> receivers_; mojo::ReceiverSet<mojom::HidManager> receivers_;
}; };
......
...@@ -314,6 +314,9 @@ interface HidManager { ...@@ -314,6 +314,9 @@ interface HidManager {
// Enumerates available devices and set as a client of HidManager. // Enumerates available devices and set as a client of HidManager.
// The implementation of HidManager guarantees that the returned callback // The implementation of HidManager guarantees that the returned callback
// will always be posted earlier than DeviceAdded() and DeviceRemoved(). // will always be posted earlier than DeviceAdded() and DeviceRemoved().
// TODO(crbug.com/955171): Use |pending_associated_remote| instead of
// |associated| after supporting mojom_js_generator.py completely for
// associated interfaces.
GetDevicesAndSetClient(associated HidManagerClient client) => GetDevicesAndSetClient(associated HidManagerClient client) =>
(array<HidDeviceInfo> devices); (array<HidDeviceInfo> devices);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment