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

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

Issue 1245363002: Add WebUSB bindings and client interface (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: cleanup, better error reporting Created 5 years, 5 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
Index: Source/modules/webusb/USBAlternateInterface.cpp
diff --git a/Source/modules/webusb/USBAlternateInterface.cpp b/Source/modules/webusb/USBAlternateInterface.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..cf1c3424d1345b1c9bf264c76a93b802a4311d49
--- /dev/null
+++ b/Source/modules/webusb/USBAlternateInterface.cpp
@@ -0,0 +1,70 @@
+// Copyright 2015 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 "config.h"
+#include "modules/webusb/USBAlternateInterface.h"
+
+#include "modules/webusb/USBEndpoint.h"
+#include "modules/webusb/USBInterface.h"
+
+namespace blink {
+
+// static
+USBAlternateInterface* USBAlternateInterface::create(const USBInterface* interface, size_t alternateIndex)
+{
+ return new USBAlternateInterface(interface, alternateIndex);
+}
+
+USBAlternateInterface::USBAlternateInterface(const USBInterface* interface, size_t alternateIndex)
+ : m_interface(interface)
+ , m_alternateIndex(alternateIndex)
+{
+}
+
+const WebUSBDeviceInfo::AlternateInterface& USBAlternateInterface::info() const
+{
+ const WebUSBDeviceInfo::Interface& interfaceInfo = m_interface->info();
+ ASSERT(m_alternateIndex < interfaceInfo.alternates.size());
+ return interfaceInfo.alternates[m_alternateIndex];
+}
+
+uint8_t USBAlternateInterface::alternateSetting() const
+{
+ return info().alternateSetting;
+}
+
+uint8_t USBAlternateInterface::interfaceClass() const
+{
+ return info().classCode;
+}
+
+uint8_t USBAlternateInterface::interfaceSubclass() const
+{
+ return info().subclassCode;
+}
+
+uint8_t USBAlternateInterface::interfaceProtocol() const
+{
+ return info().protocolCode;
+}
+
+String USBAlternateInterface::interfaceName() const
+{
+ return info().interfaceName;
+}
+
+HeapVector<Member<USBEndpoint>> USBAlternateInterface::endpoints() const
+{
+ HeapVector<Member<USBEndpoint>> endpoints;
+ for (size_t i = 0; i < info().endpoints.size(); ++i)
+ endpoints.append(USBEndpoint::create(this, i));
+ return endpoints;
+}
+
+DEFINE_TRACE(USBAlternateInterface)
+{
+ visitor->trace(m_interface);
Reilly Grant (use Gerrit) 2015/07/28 22:51:42 #ifdef ENABLE(OILPAN)?
Ken Rockot(use gerrit already) 2015/07/28 23:21:39 Nah. Only necessary in cases where you're tracing
+}
+
+} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698