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

Unified Diff: remoting/protocol/client_control_dispatcher.h

Issue 8574025: Refactor client channel dispatchers. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 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: remoting/protocol/client_control_dispatcher.h
diff --git a/remoting/protocol/client_control_dispatcher.h b/remoting/protocol/client_control_dispatcher.h
new file mode 100644
index 0000000000000000000000000000000000000000..4f75a9bed89b7dd2ce011541121ff4fdfbf824d5
--- /dev/null
+++ b/remoting/protocol/client_control_dispatcher.h
@@ -0,0 +1,55 @@
+// Copyright (c) 2011 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 REMOTING_PROTOCOL_CLIENT_CONTROL_DISPATCHER_H_
+#define REMOTING_PROTOCOL_CLIENT_CONTROL_DISPATCHER_H_
+
+#include "base/basictypes.h"
+#include "base/memory/ref_counted.h"
+#include "remoting/protocol/host_stub.h"
+#include "remoting/protocol/message_reader.h"
+
+namespace base {
+class MessageLoopProxy;
+} // namespace base
+
+namespace remoting {
+namespace protocol {
+
+class ClientStub;
+class ControlMessage;
+class BufferedSocketWriter;
+class Session;
+
+// ClientControlDispatcher manages control channel on the client
Wez 2011/11/17 01:51:56 typo: manages _the_ control channel Although I th
Sergey Ulanov 2011/11/17 19:29:06 Done.
+// side. It dispatches incoming messages on the control channel to
+// ClientStub, and also implements HostStub for outgoing messages.
Wez 2011/11/17 01:51:56 I think perhaps ClientStub and HostStub need renam
Sergey Ulanov 2011/11/17 19:29:06 Agree. Any suggestions for new names?
+class ClientControlDispatcher : public HostStub {
+ public:
+ // Construct a message dispatcher.
Wez 2011/11/17 01:51:56 What is the |message_loop| parameter used for?
Sergey Ulanov 2011/11/17 19:29:06 Removed this comment and |message_loop|
+ ClientControlDispatcher(base::MessageLoopProxy* message_loop);
Wez 2011/11/17 01:51:56 Why is the |message_loop| supplied to the ctor, ra
Wez 2011/11/17 01:51:56 Missing explicit here.
Sergey Ulanov 2011/11/17 19:29:06 Done.
Sergey Ulanov 2011/11/17 19:29:06 not needed anymore
+ virtual ~ClientControlDispatcher();
+
+ // Initialize the message dispatcher with the given connection and
+ // message handlers.
Wez 2011/11/17 01:51:56 Who owns them?
Sergey Ulanov 2011/11/17 19:29:06 Done.
+ void Init(protocol::Session* session, ClientStub* client_stub);
+
+ void Close();
Wez 2011/11/17 01:51:56 What does this do? Who uses it?
Sergey Ulanov 2011/11/17 19:29:06 Done.
+
+ private:
+ void OnMessageReceived(ControlMessage* message,
+ const base::Closure& done_task);
+
+ ClientStub* client_stub_;
+
+ ProtobufMessageReader<ControlMessage> reader_;
+ scoped_refptr<BufferedSocketWriter> writer_;
+
+ DISALLOW_COPY_AND_ASSIGN(ClientControlDispatcher);
+};
+
+} // namespace protocol
+} // namespace remoting
+
+#endif // REMOTING_PROTOCOL_CLIENT_CONTROL_DISPATCHER_H_
« no previous file with comments | « no previous file | remoting/protocol/client_control_dispatcher.cc » ('j') | remoting/protocol/client_control_dispatcher.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698