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

Unified Diff: net/socket/socket.h

Issue 2593063003: Add Socket::ReadIfReady() (Closed)
Patch Set: self review. remove unused include Created 3 years, 10 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: net/socket/socket.h
diff --git a/net/socket/socket.h b/net/socket/socket.h
index cda54063f3059e76726c896b5e6ae87508a5f483..4876c48ddb6e3c687da6a205de0aa8d0ee9fffd3 100644
--- a/net/socket/socket.h
+++ b/net/socket/socket.h
@@ -7,6 +7,7 @@
#include <stdint.h>
+#include "base/feature_list.h"
#include "net/base/completion_callback.h"
#include "net/base/net_export.h"
@@ -17,6 +18,9 @@ class IOBuffer;
// Represents a read/write socket.
class NET_EXPORT Socket {
public:
+ // Name of the field trial for using ReadyIfReady() instead of Read().
+ static const base::Feature kReadIfReadyExperiment;
+
virtual ~Socket() {}
// Reads data, up to |buf_len| bytes, from the socket. The number of bytes
Bence 2017/03/03 16:33:40 Optional: add a note at the beginning of the comme
xunjieli 2017/03/03 19:41:05 There is a comment about this actually in the para
@@ -33,6 +37,21 @@ class NET_EXPORT Socket {
virtual int Read(IOBuffer* buf, int buf_len,
Bence 2017/03/03 16:33:40 <rant> I am unhappy with how a scoped_refptr is p
xunjieli 2017/03/03 19:41:05 Acknowledged. Rant acknowledged :)
const CompletionCallback& callback) = 0;
+ // Reads as much data as possible into |buf| without blocking. Default
Bence 2017/03/03 16:33:40 Optional: add a note at the beginning of the comme
Bence 2017/03/03 16:33:40 What happens if a caller calls ReadIfReady(), that
Bence 2017/03/03 16:33:40 If it reads as much data as possible, why does it
xunjieli 2017/03/03 19:41:05 I will keep it this way. I have a comment in the l
xunjieli 2017/03/03 19:41:05 Yep, it reads at most |buf_len_|. Clarified in the
xunjieli 2017/03/03 19:41:05 It should be the same as calling Read() twice when
+ // implementation returns ERR_READ_IF_READY_NOT_IMPLEMENTED. Caller should
+ // fall back to Read() if receives ERR_READ_IF_READY_NOT_IMPLEMENTED.
+ // Upon synchronous completion, returns the number of bytes read or an error
+ // code if an error happens; If read cannot be completed synchronously,
Bence 2017/03/03 16:33:40 Optional: replace every semicolon with full stop t
xunjieli 2017/03/03 19:41:05 Done.
+ // returns ERR_IO_PENDING and does not hold on to |buf|. |callback| will be
+ // invoked with OK when data can be read, at which point, caller can call
Bence 2017/03/03 16:33:40 Suppose ReadIfReady() returns ERR_IO_PENDING, late
xunjieli 2017/03/03 19:41:05 Nope. it's not guaranteed. It's legal for an imple
+ // ReadIfReady() again; if an error occurs asynchronously, |callback| will be
+ // invoked with the error code.
+ // Note: if 0 is returned synchronously, it means that EOF is reached; if 0/OK
Bence 2017/03/03 16:33:40 Optional: move "if 0 is returned synchronously" in
xunjieli 2017/03/03 19:41:05 Done.
+ // is returned asynchronously, it means that ReadIfReady() can be retried.
Bence 2017/03/03 16:33:40 Remove "0 is returned asynchronously" case because
xunjieli 2017/03/03 19:41:05 Done.
+ virtual int ReadIfReady(IOBuffer* buf,
+ int buf_len,
+ const CompletionCallback& callback);
+
// Writes data, up to |buf_len| bytes, to the socket. Note: data may be
// written partially. The number of bytes written is returned, or an error
// is returned upon failure. ERR_SOCKET_NOT_CONNECTED should be returned if

Powered by Google App Engine
This is Rietveld 408576698