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

Unified Diff: content/renderer/render_frame_impl.cc

Issue 1293253002: Connect WebUSB client interface to the devices app (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix memory leak in WeakBindingSet Created 5 years, 4 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/renderer/render_frame_impl.h ('k') | content/renderer/usb/DEPS » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/render_frame_impl.cc
diff --git a/content/renderer/render_frame_impl.cc b/content/renderer/render_frame_impl.cc
index 84eae435c58988cf66c930b08386f38124a17e9f..cb505b19a2300a8e0de7036d7e06bfe70116db16 100644
--- a/content/renderer/render_frame_impl.cc
+++ b/content/renderer/render_frame_impl.cc
@@ -115,6 +115,7 @@
#include "media/blink/webmediaplayer_impl.h"
#include "media/blink/webmediaplayer_params.h"
#include "media/renderers/gpu_video_accelerator_factories.h"
+#include "mojo/common/url_type_converters.h"
#include "net/base/data_url.h"
#include "net/base/net_errors.h"
#include "net/base/registry_controlled_domains/registry_controlled_domain.h"
@@ -125,6 +126,7 @@
#include "third_party/WebKit/public/platform/WebURLError.h"
#include "third_party/WebKit/public/platform/WebURLResponse.h"
#include "third_party/WebKit/public/platform/WebVector.h"
+#include "third_party/WebKit/public/platform/modules/webusb/WebUSBClient.h"
#include "third_party/WebKit/public/web/WebColorSuggestion.h"
#include "third_party/WebKit/public/web/WebDocument.h"
#include "third_party/WebKit/public/web/WebFrameWidget.h"
@@ -174,6 +176,8 @@
#include "content/renderer/media/android/webmediaplayer_android.h"
#else
#include "cc/blink/context_provider_web_context.h"
+#include "content/renderer/usb/web_usb_client_impl.h"
+#include "device/devices_app/public/cpp/constants.h"
#endif
#if defined(ENABLE_PEPPER_CDMS)
@@ -705,6 +709,8 @@ RenderFrameImpl::RenderFrameImpl(const CreateParams& params)
#endif
manifest_manager_ = new ManifestManager(this);
+
+ GetServiceRegistry()->ConnectToRemoteService(mojo::GetProxy(&mojo_shell_));
}
RenderFrameImpl::~RenderFrameImpl() {
@@ -3811,6 +3817,17 @@ blink::WebBluetooth* RenderFrameImpl::bluetooth() {
return bluetooth_.get();
}
+blink::WebUSBClient* RenderFrameImpl::usbClient() {
+#if !defined(OS_ANDROID)
+ if (!usb_client_) {
+ mojo::ServiceProviderPtr device_services =
+ ConnectToApplication(GURL(device::kDevicesMojoAppUrl));
+ usb_client_.reset(new WebUSBClientImpl(device_services.Pass()));
+ }
+#endif
+ return usb_client_.get();
+}
+
#if defined(ENABLE_WEBVR)
blink::WebVRClient* RenderFrameImpl::webVRClient() {
if (!vr_dispatcher_)
@@ -5002,17 +5019,9 @@ media::MediaPermission* RenderFrameImpl::GetMediaPermission() {
#if defined(ENABLE_MOJO_MEDIA)
media::interfaces::ServiceFactory* RenderFrameImpl::GetMediaServiceFactory() {
if (!media_service_factory_) {
- mojo::InterfacePtr<mojo::Shell> shell_ptr;
- GetServiceRegistry()->ConnectToRemoteService(mojo::GetProxy(&shell_ptr));
-
- mojo::ServiceProviderPtr service_provider;
- mojo::URLRequestPtr request(mojo::URLRequest::New());
- request->url = mojo::String::From("mojo:media");
- shell_ptr->ConnectToApplication(request.Pass(), GetProxy(&service_provider),
- nullptr, nullptr);
-
+ mojo::ServiceProviderPtr service_provider =
+ ConnectToApplication(GURL("mojo:media"));
mojo::ConnectToService(service_provider.get(), &media_service_factory_);
-
media_service_factory_.set_connection_error_handler(
base::Bind(&RenderFrameImpl::OnMediaServiceFactoryConnectionError,
base::Unretained(this)));
@@ -5074,4 +5083,15 @@ void RenderFrameImpl::RegisterMojoServices() {
}
}
+mojo::ServiceProviderPtr RenderFrameImpl::ConnectToApplication(
+ const GURL& url) {
+ DCHECK(mojo_shell_);
+ mojo::ServiceProviderPtr service_provider;
+ mojo::URLRequestPtr request(mojo::URLRequest::New());
+ request->url = mojo::String::From(url);
+ mojo_shell_->ConnectToApplication(request.Pass(), GetProxy(&service_provider),
+ nullptr, nullptr);
+ return service_provider.Pass();
+}
+
} // namespace content
« no previous file with comments | « content/renderer/render_frame_impl.h ('k') | content/renderer/usb/DEPS » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698