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

Unified Diff: device/bluetooth/bluetooth_socket_net.h

Issue 267633003: Reimplement BluetoothSocketChromeOS (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 8 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: device/bluetooth/bluetooth_socket_net.h
diff --git a/device/bluetooth/bluetooth_socket_net.h b/device/bluetooth/bluetooth_socket_net.h
new file mode 100644
index 0000000000000000000000000000000000000000..340427a6f1d39167aba39c6b0ce4593b7f640eb1
--- /dev/null
+++ b/device/bluetooth/bluetooth_socket_net.h
@@ -0,0 +1,137 @@
+// Copyright 2014 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.
+
+#ifndef DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_NET_H_
+#define DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_NET_H_
+
+#include <queue>
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/memory/linked_ptr.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/sequenced_task_runner.h"
+#include "device/bluetooth/bluetooth_socket.h"
+#include "device/bluetooth/bluetooth_socket_thread.h"
+#include "net/base/net_log.h"
+#include "net/socket/tcp_socket.h"
+
+namespace net {
+class IOBuffer;
+class IOBufferWithSize;
+} // namespace net
+
+namespace device {
+
+// This class is a base-class for implementations of BluetoothSocket that can
+// use net::TCPSocket. All public methods (including the factory method) must
+// be called on the UI thread, while underlying socket operations are
+// performed on a separate thread.
+class BluetoothSocketNet : public BluetoothSocket {
+ public:
+ static scoped_refptr<BluetoothSocketNet> CreateBluetoothSocket(
+ scoped_refptr<base::SequencedTaskRunner> ui_task_runner,
+ scoped_refptr<BluetoothSocketThread> socket_thread,
+ net::NetLog* net_log,
+ const net::NetLog::Source& source);
+
+ // BluetoothSocket:
+ virtual void Close() OVERRIDE;
+ virtual void Disconnect(const base::Closure& callback) OVERRIDE;
+ virtual void Receive(int buffer_size,
+ const ReceiveCompletionCallback& success_callback,
+ const ReceiveErrorCompletionCallback& error_callback)
+ OVERRIDE;
+ virtual void Send(scoped_refptr<net::IOBuffer> buffer,
+ int buffer_size,
+ const SendCompletionCallback& success_callback,
+ const ErrorCompletionCallback& error_callback) OVERRIDE;
+
+ protected:
+ BluetoothSocketNet(scoped_refptr<base::SequencedTaskRunner> ui_task_runner,
+ scoped_refptr<BluetoothSocketThread> socket_thread,
+ net::NetLog* net_log,
+ const net::NetLog::Source& source);
+ virtual ~BluetoothSocketNet();
+
+ // Resets locally held data after a socket is closed. Default implementation
+ // does nothing, subclasses may override.
+ void ResetData();
armansito 2014/05/01 00:14:25 You should make this virtual if the intention is t
keybuk 2014/05/01 00:24:09 Done.
+
+ // Methods for subclasses to obtain the members.
+ scoped_refptr<base::SequencedTaskRunner> ui_task_runner() {
+ return ui_task_runner_;
+ }
+
+ scoped_refptr<BluetoothSocketThread> socket_thread() {
+ return socket_thread_;
+ }
+
+ net::NetLog* net_log() { return net_log_; }
+ const net::NetLog::Source& source() { return source_; }
+
+ net::TCPSocket* tcp_socket() { return tcp_socket_.get(); }
+
+ void ResetTCPSocket();
+ void SetTCPSocket(scoped_ptr<net::TCPSocket> tcp_socket);
+
+ void PostSuccess(const base::Closure& callback);
+ void PostErrorCompletion(const ErrorCompletionCallback& callback,
+ const std::string& error);
+
+ private:
+ struct WriteRequest {
+ WriteRequest();
+ ~WriteRequest();
+
+ scoped_refptr<net::IOBuffer> buffer;
+ int buffer_size;
+ SendCompletionCallback success_callback;
+ ErrorCompletionCallback error_callback;
+ };
+
+ void DoClose();
+ void DoDisconnect(const base::Closure& success_callback);
+ void DoReceive(int buffer_size,
+ const ReceiveCompletionCallback& success_callback,
+ const ReceiveErrorCompletionCallback& error_callback);
+ void OnSocketReadComplete(
+ const ReceiveCompletionCallback& success_callback,
+ const ReceiveErrorCompletionCallback& error_callback,
+ int read_result);
+ void DoSend(scoped_refptr<net::IOBuffer> buffer,
+ int buffer_size,
+ const SendCompletionCallback& success_callback,
+ const ErrorCompletionCallback& error_callback);
+ void SendFrontWriteRequest();
+ void OnSocketWriteComplete(const SendCompletionCallback& success_callback,
+ const ErrorCompletionCallback& error_callback,
+ int send_result);
+
+ void PostReceiveCompletion(const ReceiveCompletionCallback& callback,
+ int io_buffer_size,
+ scoped_refptr<net::IOBuffer> io_buffer);
+ void PostReceiveErrorCompletion(
+ const ReceiveErrorCompletionCallback& callback,
+ ErrorReason reason,
+ const std::string& error_message);
+ void PostSendCompletion(const SendCompletionCallback& callback,
+ int bytes_written);
+
+ scoped_refptr<base::SequencedTaskRunner> ui_task_runner_;
+ scoped_refptr<BluetoothSocketThread> socket_thread_;
+ net::NetLog* net_log_;
+ const net::NetLog::Source source_;
+
+ scoped_ptr<net::TCPSocket> tcp_socket_;
+ scoped_refptr<net::IOBufferWithSize> read_buffer_;
+ std::queue<linked_ptr<WriteRequest> > write_queue_;
+
+ DISALLOW_COPY_AND_ASSIGN(BluetoothSocketNet);
+};
+
+} // namespace device
+
+#endif // DEVICE_BLUETOOTH_BLUETOOTH_SOCKET_NET_H_

Powered by Google App Engine
This is Rietveld 408576698