Index: chrome/browser/android/usb/web_usb_chooser_service_android.cc |
diff --git a/chrome/browser/android/usb/web_usb_chooser_service_android.cc b/chrome/browser/android/usb/web_usb_chooser_service_android.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d31b7b06252475d1d69caa7b7097498029410d0b |
--- /dev/null |
+++ b/chrome/browser/android/usb/web_usb_chooser_service_android.cc |
@@ -0,0 +1,33 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/android/usb/web_usb_chooser_service_android.h" |
+ |
+#include <utility> |
+ |
+#include "chrome/browser/ui/android/usb_chooser_dialog_android.h" |
+#include "content/public/browser/browser_thread.h" |
+ |
+WebUsbChooserServiceAndroid::WebUsbChooserServiceAndroid( |
+ content::RenderFrameHost* render_frame_host) |
+ : render_frame_host_(render_frame_host) { |
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
+ DCHECK(render_frame_host_); |
+} |
+ |
+WebUsbChooserServiceAndroid::~WebUsbChooserServiceAndroid() {} |
+ |
+void WebUsbChooserServiceAndroid::GetPermission( |
+ mojo::Array<device::usb::DeviceFilterPtr> device_filters, |
+ const GetPermissionCallback& callback) { |
+ usb_chooser_dialog_android_.push_back( |
+ make_scoped_ptr(new UsbChooserDialogAndroid( |
+ std::move(device_filters), render_frame_host_, callback))); |
+} |
+ |
+void WebUsbChooserServiceAndroid::Bind( |
+ mojo::InterfaceRequest<device::usb::ChooserService> request) { |
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
+ bindings_.AddBinding(this, std::move(request)); |
+} |