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

Unified Diff: Source/modules/webusb/USB.cpp

Issue 1288793003: WebUSB: Create a requestDevice method separate from getDevice. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Update stale reference in modules.gypi. 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 | « Source/modules/webusb/USB.h ('k') | Source/modules/webusb/USB.idl » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/modules/webusb/USB.cpp
diff --git a/Source/modules/webusb/USB.cpp b/Source/modules/webusb/USB.cpp
index 859334df20658a6454354c370459f49528004e2a..5acd9acac742004e5bd733717f624432d60d89da 100644
--- a/Source/modules/webusb/USB.cpp
+++ b/Source/modules/webusb/USB.cpp
@@ -12,41 +12,44 @@
#include "core/dom/Document.h"
#include "core/dom/ExceptionCode.h"
#include "modules/webusb/USBDevice.h"
-#include "modules/webusb/USBDeviceEnumerationOptions.h"
#include "modules/webusb/USBDeviceFilter.h"
+#include "modules/webusb/USBDeviceRequestOptions.h"
#include "modules/webusb/USBError.h"
#include "public/platform/Platform.h"
#include "public/platform/WebVector.h"
#include "public/platform/modules/webusb/WebUSBClient.h"
-#include "public/platform/modules/webusb/WebUSBDeviceEnumerationOptions.h"
#include "public/platform/modules/webusb/WebUSBDeviceFilter.h"
+#include "public/platform/modules/webusb/WebUSBDeviceRequestOptions.h"
#include "public/platform/modules/webusb/WebUSBError.h"
namespace blink {
namespace {
-void convertDeviceEnumerationOptions(const USBDeviceEnumerationOptions& options, WebUSBDeviceEnumerationOptions* webOptions)
+void convertDeviceFilter(const USBDeviceFilter& filter, WebUSBDeviceFilter* webFilter)
+{
+ webFilter->hasVendorID = filter.hasVendorId();
+ if (filter.hasVendorId())
+ webFilter->vendorID = filter.vendorId();
+ webFilter->hasProductID = filter.hasProductId();
+ if (filter.hasProductId())
+ webFilter->productID = filter.productId();
+ webFilter->hasClassCode = filter.hasClassCode();
+ if (filter.hasClassCode())
+ webFilter->classCode = filter.classCode();
+ webFilter->hasSubclassCode = filter.hasSubclassCode();
+ if (filter.hasSubclassCode())
+ webFilter->subclassCode = filter.subclassCode();
+ webFilter->hasProtocolCode = filter.hasProtocolCode();
+ if (filter.hasProtocolCode())
+ webFilter->protocolCode = filter.protocolCode();
+}
+
+void convertDeviceRequestOptions(const USBDeviceRequestOptions& options, WebUSBDeviceRequestOptions* webOptions)
{
ASSERT(options.hasFilters());
webOptions->filters = WebVector<WebUSBDeviceFilter>(options.filters().size());
for (size_t i = 0; i < options.filters().size(); ++i) {
- const USBDeviceFilter& filter = options.filters()[i];
- WebUSBDeviceFilter& webFilter = webOptions->filters[i];
- webFilter.hasVendorID = filter.hasVendorId();
- if (filter.hasVendorId())
- webFilter.vendorID = filter.vendorId();
- webFilter.hasProductID = filter.hasProductId();
- if (filter.hasProductId())
- webFilter.productID = filter.productId();
- webFilter.hasClassCode = filter.hasClassCode();
- if (filter.hasClassCode())
- webFilter.classCode = filter.classCode();
- webFilter.hasSubclassCode = filter.hasSubclassCode();
- if (filter.hasSubclassCode())
- webFilter.subclassCode = filter.subclassCode();
- webFilter.hasProtocolCode = filter.hasProtocolCode();
- if (filter.hasProtocolCode())
- webFilter.protocolCode = filter.protocolCode();
+ convertDeviceFilter(options.filters()[i], &webOptions->filters[i]);
}
}
@@ -76,7 +79,7 @@ USB::USB(LocalFrame& frame)
{
}
-ScriptPromise USB::getDevices(ScriptState* scriptState, const USBDeviceEnumerationOptions& options)
+ScriptPromise USB::getDevices(ScriptState* scriptState)
{
WebUSBClient* client = m_controller->client();
if (!client)
@@ -84,10 +87,24 @@ ScriptPromise USB::getDevices(ScriptState* scriptState, const USBDeviceEnumerati
ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState);
ScriptPromise promise = resolver->promise();
+ client->getDevices(new CallbackPromiseAdapter<DeviceArray, USBError>(resolver));
+
+ return promise;
+}
+
+ScriptPromise USB::requestDevice(ScriptState* scriptState, const USBDeviceRequestOptions& options)
+{
+ WebUSBClient* client = m_controller->client();
+ if (!client)
+ return ScriptPromise::rejectWithDOMException(scriptState, DOMException::create(NotSupportedError));
+
+ ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState);
+ ScriptPromise promise = resolver->promise();
+
+ WebUSBDeviceRequestOptions webOptions;
+ convertDeviceRequestOptions(options, &webOptions);
+ client->requestDevice(webOptions, new CallbackPromiseAdapter<USBDevice, USBError>(resolver));
- WebUSBDeviceEnumerationOptions webOptions;
- convertDeviceEnumerationOptions(options, &webOptions);
- client->getDevices(webOptions, new CallbackPromiseAdapter<DeviceArray, USBError>(resolver));
return promise;
}
« no previous file with comments | « Source/modules/webusb/USB.h ('k') | Source/modules/webusb/USB.idl » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698