Index: blimp/client/render_widget_message_processor.h |
diff --git a/blimp/client/render_widget_message_processor.h b/blimp/client/render_widget_message_processor.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b7cdf1f5ce4b82baff61e01b05a13ad7c5b8a3e4 |
--- /dev/null |
+++ b/blimp/client/render_widget_message_processor.h |
@@ -0,0 +1,90 @@ |
+// 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_CLIENT_RENDER_WIDGET_MESSAGE_PROCESSOR_H_ |
nyquist
2015/11/24 08:55:43
Would it make sense to put these in some subfolder
David Trainor- moved to gerrit
2015/11/25 17:56:42
Put these in compositor, as that's where they're a
|
+#define BLIMP_CLIENT_RENDER_WIDGET_MESSAGE_PROCESSOR_H_ |
+ |
+#include "base/containers/small_map.h" |
+#include "base/macros.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "blimp/client/blimp_client_export.h" |
+#include "blimp/net/blimp_message_processor.h" |
+#include "blimp/net/input_message_generator.h" |
+ |
+namespace blink { |
+class WebInputEvent; |
+} |
nyquist
2015/11/24 08:55:43
Nit: // namespace blink?
David Trainor- moved to gerrit
2015/11/25 17:56:42
I was explicitly asked not to for short namespace
|
+ |
+namespace cc { |
+namespace proto { |
+class CompositorMessage; |
+} |
nyquist
2015/11/24 08:55:43
Nit: end of namespace comment here and below?
David Trainor- moved to gerrit
2015/11/25 17:56:42
See above.
|
+} |
+ |
+namespace blimp { |
+ |
+// Handles all incoming and outgoing protobuf message types tied to a specific |
+// RenderWidget. This includes BlimpMessage::INPUT, BlimpMessage::COMPOSITOR, |
+// and BlimpMessage::RENDER_WIDGET messages. Delegates can be added to be |
+// notified of incoming messages. This class automatically attaches a specific |
+// id so that the engine can drop stale RenderWidget related messages after it |
+// sends a RenderWidgetMessage::INITIALIZE message. |
+class BLIMP_CLIENT_EXPORT RenderWidgetMessageProcessor |
+ : public BlimpMessageProcessor { |
+ public: |
+ // A delegate to be notified of specific RenderWidget related incoming events. |
+ class RenderWidgetMessageDelegate { |
+ public: |
+ // Called when the engine's RenderWidget has changed for a particular |
+ // WebContents. When this is received all state related to the existing |
+ // client RenderWidget should be reset. |
+ virtual void OnRenderWidgetInitialized() = 0; |
+ |
+ // Called when the engine sent a CompositorMessage. These messages should |
+ // be sent to the client's RemoteChannel of the compositor. |
+ virtual void OnCompositorMessageReceived( |
+ scoped_ptr<cc::proto::CompositorMessage> message) = 0; |
+ }; |
+ |
+ RenderWidgetMessageProcessor( |
+ BlimpMessageProcessor* outgoing_message_processor); |
+ ~RenderWidgetMessageProcessor() override; |
+ |
+ // Sends a WebInputEvent for |tab_id| to the engine. |
+ void SendInputEvent(const int tab_id, const blink::WebInputEvent& event); |
+ |
+ // Sends a CompositorMessage for |tab_id| to the engine. |
+ void SendCompositorMessage(const int tab_id, |
+ const cc::proto::CompositorMessage& message); |
+ |
+ // Sets a RenderWidgetMessageDelegate to be notified of all incoming |
+ // RenderWidget related messages for |tab_id| from the engine. |
+ void SetDelegate(const int tab_id, RenderWidgetMessageDelegate* delegate); |
nyquist
2015/11/24 08:55:43
Nit: Could you add a comment saying there can only
David Trainor- moved to gerrit
2015/11/25 17:56:42
Done.
|
+ void RemoveDelegate(const int tab_id); |
+ |
+ // BlimpMessageProcessor implementation. |
+ void ProcessMessage(scoped_ptr<BlimpMessage> message, |
+ const net::CompletionCallback& callback) override; |
+ |
+ private: |
+ RenderWidgetMessageDelegate* FindDelegate(const int tab_id); |
nyquist
2015/11/24 08:55:43
Optional nit: Do we want to add a comment saying t
David Trainor- moved to gerrit
2015/11/25 17:56:42
I assumed it was implicit. I can add a comment th
|
+ uint32_t GetRenderWidgetId(const int tab_id); |
+ |
+ typedef base::SmallMap<std::map<int, RenderWidgetMessageDelegate*> > |
+ DelegateMap; |
+ typedef base::SmallMap<std::map<int, uint32_t> > RenderWidgetIdMap; |
+ |
+ DelegateMap delegates_; |
+ RenderWidgetIdMap render_widget_ids_; |
+ |
+ InputMessageGenerator input_message_generator_; |
+ |
+ BlimpMessageProcessor* outgoing_message_processor_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(RenderWidgetMessageProcessor); |
+}; |
+ |
+} // namespace blimp |
+ |
+#endif // BLIMP_CLIENT_RENDER_WIDGET_MESSAGE_PROCESSOR_H_ |