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

Unified Diff: blimp/net/grpc_stream.h

Issue 2462183002: GRPC Stream implementation of HeliumStream
Patch Set: Created 4 years, 1 month 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: blimp/net/grpc_stream.h
diff --git a/blimp/net/grpc_stream.h b/blimp/net/grpc_stream.h
new file mode 100644
index 0000000000000000000000000000000000000000..5158c8cc75f200143f134810bb0d63f5e744a599
--- /dev/null
+++ b/blimp/net/grpc_stream.h
@@ -0,0 +1,108 @@
+// 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.
+
+#ifndef BLIMP_NET_GRPC_STREAM_DELEGATE_H_
+#define BLIMP_NET_GRPC_STREAM_DELEGATE_H_
+
+#include <list>
+
+#include "base/macros.h"
+
+#include "base/callback.h"
+#include "base/command_line.h"
+#include "base/memory/ptr_util.h"
+#include "base/synchronization/lock.h"
+#include "base/threading/thread.h"
+
+#include "blimp/common/proto/helium_service.grpc.pb.h"
+#include "net/base/completion_callback.h"
+
+namespace blimp {
+
+// Callbacks are always invoked in the IO thread.
+class GrpcStream {
Kevin M 2016/10/31 21:33:26 Why doesn't this implement HeliumStream?
+ public:
+ explicit GrpcStream(const net::CompletionCallback& connection_callback);
+
+ // TODO(perumaal): Currently the result is an 'int', but in the future it will
+ // be HeliumResult.
+ using HeliumMessageReceivedCb =
+ base::Callback<void(std::unique_ptr<HeliumWrapper>, int)>;
+
+ using HeliumMessageSentCb = base::Callback<void(int)>;
+
+ // TODO(perumaal): Convert to HeliumStream/HeliumResult next.
+ virtual void SendMessage(std::unique_ptr<HeliumWrapper> helium_message,
+ const HeliumMessageSentCb& callback) = 0;
+
+ virtual void ReceiveMessage(const HeliumMessageReceivedCb& received_cb) = 0;
+
+ virtual ~GrpcStream();
+
+ protected:
+ class GrpcTag {
+ public:
+ static GrpcTag* Connect(const net::CompletionCallback& connection_cb);
+ static GrpcTag* Write(const GrpcStream::HeliumMessageSentCb& callback);
+ static GrpcTag* Read(const GrpcStream::HeliumMessageReceivedCb& callback);
+ static GrpcTag* WritesDone();
+
+ ~GrpcTag();
+
+ HeliumWrapper* GetReceivedMsg() const;
+
+ private:
+ GrpcTag();
+
+ void ApplyCallbackOnCbThread(bool ok);
+
+ enum class TagType {
+ // Invalid tag type.
+ UNKNOWN = 0,
+ // Tag used during initial connection.
+ CONNECT = 1,
+ // Tag used during waiting for a read to finish.
+ READ = 2,
+ // Tag used during waiting for a single write to finish.
+ WRITE = 3,
+ // Tag used when a sequence of writes has finished.
+ WRITES_DONE = 4
+ };
+
+ TagType tag_type_;
+
+ // For initial connection.
+ net::CompletionCallback connection_cb_;
+
+ // For sending.
+ GrpcStream::HeliumMessageSentCb sent_cb_;
+
+ // For receiving.
+ std::unique_ptr<HeliumWrapper> received_msg_;
+ GrpcStream::HeliumMessageReceivedCb received_cb_;
+
+ friend class GrpcStream;
+ };
+
+ GrpcStream::GrpcTag* GrpcConnectTag();
+ GrpcStream::GrpcTag* GrpcReadTag(const HeliumMessageReceivedCb& received_cb);
+ GrpcStream::GrpcTag* GrpcWriteTag(const HeliumMessageSentCb& sent_cb);
+ GrpcStream::GrpcTag* GrpcWritesDoneTag();
+
+ void StartCompletionQueueThread(grpc::CompletionQueue* completion_q);
+
+ private:
+ static void CompletionQueueThread(
+ grpc::CompletionQueue* completion_q,
+ scoped_refptr<base::SingleThreadTaskRunner> callback_task_runner);
+
Kevin M 2016/10/31 21:33:25 Use a ThreadChecker?
+ scoped_refptr<base::SingleThreadTaskRunner> callback_task_runner_;
+ net::CompletionCallback connection_callback_;
+ std::unique_ptr<base::Thread> grpc_thread_;
+ base::WeakPtrFactory<GrpcStream> weak_factory_;
+};
+
+} // namespace blimp
+
+#endif // BLIMP_NET_GRPC_STREAM_DELEGATE_H_

Powered by Google App Engine
This is Rietveld 408576698