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

Unified Diff: blimp/net/blimp_message_dispatcher.h

Issue 1324263003: Blimp: create MessageDispatcher class. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@blimp-protos
Patch Set: Addressed wez's feedback. Created 5 years, 2 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: blimp/net/blimp_message_dispatcher.h
diff --git a/blimp/net/blimp_message_dispatcher.h b/blimp/net/blimp_message_dispatcher.h
new file mode 100644
index 0000000000000000000000000000000000000000..5a6f0fd19158163afc33fa4850ebec485cbc2ed9
--- /dev/null
+++ b/blimp/net/blimp_message_dispatcher.h
@@ -0,0 +1,51 @@
+// 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.
+
+#ifndef BLIMP_NET_BLIMP_MESSAGE_DISPATCHER_H_
+#define BLIMP_NET_BLIMP_MESSAGE_DISPATCHER_H_
+
+#include <map>
+
+#include "base/containers/small_map.h"
+#include "base/threading/thread_checker.h"
+#include "blimp/common/proto/blimp_message.pb.h"
+#include "blimp/net/blimp_message_receiver.h"
+#include "blimp/net/blimp_net_export.h"
+
+namespace blimp {
+
+// Multiplexing BlimpMessageReceiver which routes BlimpMessages to other
+// receivers based on the messages' feature type.
+class BLIMP_NET_EXPORT BlimpMessageDispatcher : public BlimpMessageReceiver {
+ public:
+ BlimpMessageDispatcher();
+ ~BlimpMessageDispatcher() override;
+
+ // Registers a message receiver which will process all messages
+ // with the type |type|.
Wez 2015/10/09 23:15:34 nit: Suggest "... of the specified |type|."
Kevin M 2015/10/10 00:42:34 Done.
+ // Only one handler may be added per type.
+ //
+ // The caller must ensure that the lifetime of |handler| exceeds the lifetime
+ // of |this|.
Wez 2015/10/09 23:15:34 nit: Strictly |handler| only need be valid when On
Kevin M 2015/10/10 00:42:34 Done.
+ void AddReceiver(BlimpMessage::Type type, BlimpMessageReceiver* handler);
+
+ // Takes a BlimpMessage and dispatches it to the appropriate tab and
+ // feature-specific handler, based on the value of |message.type|.
+ //
+ // Logs an error if there is no BlimpMessageReceiver registered for
+ // |message.type|, or if the BlimpMessageReceiver failed to validate the
+ // message.
Wez 2015/10/09 23:15:34 This API is part of the BlimpMessageReceiver inter
Kevin M 2015/10/10 00:42:34 Done.
+ bool OnMessage(const BlimpMessage& message) override;
+
+ private:
+ base::SmallMap<std::map<BlimpMessage::Type, BlimpMessageReceiver*>>
+ feature_receiver_map_;
+ base::ThreadChecker thread_checker_;
Wez 2015/10/09 23:15:34 nit: This seems overkill - I don't think there's a
Kevin M 2015/10/10 00:42:34 OK, I'm still figuring out the right degree of ana
Wez 2015/10/12 23:47:21 Yeah, it's a fine line!
+
+ DISALLOW_COPY_AND_ASSIGN(BlimpMessageDispatcher);
+};
+
+} // namespace blimp
+
+#endif // BLIMP_NET_BLIMP_MESSAGE_DISPATCHER_H_

Powered by Google App Engine
This is Rietveld 408576698