Chromium Code Reviews| Index: remoting/protocol/host_event_dispatcher.cc |
| diff --git a/remoting/protocol/host_event_dispatcher.cc b/remoting/protocol/host_event_dispatcher.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..f5a8fff8a10cf4263ec8d00fa85ff5e4739dda17 |
| --- /dev/null |
| +++ b/remoting/protocol/host_event_dispatcher.cc |
| @@ -0,0 +1,52 @@ |
| +// 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. |
| + |
| +#include "remoting/protocol/host_event_dispatcher.h" |
| + |
| +#include "remoting/proto/event.pb.h" |
| +#include "remoting/proto/internal.pb.h" |
| +#include "remoting/protocol/input_stub.h" |
| +#include "remoting/protocol/session.h" |
| + |
| +namespace remoting { |
| +namespace protocol { |
| + |
| +HostEventDispatcher::HostEventDispatcher() |
| + : input_stub_(NULL) { |
| +} |
| + |
| +HostEventDispatcher::~HostEventDispatcher() { |
| +} |
| + |
| +void HostEventDispatcher::Init(Session* session) { |
| + DCHECK(session); |
| + reader_.Init(session->event_channel(), base::Bind( |
| + &HostEventDispatcher::OnMessageReceived, base::Unretained(this))); |
| +} |
| + |
| +void HostEventDispatcher::OnMessageReceived( |
| + EventMessage* message, const base::Closure& done_task) { |
| + DCHECK(input_stub_); |
| + |
| + base::ScopedClosureRunner done_runner(done_task); |
| + |
| + sequence_number_callback_.Run(message->sequence_number()); |
| + |
| + if (message->has_key_event()) { |
| + const KeyEvent& event = message->key_event(); |
| + if (event.has_keycode() && event.has_pressed()) { |
| + input_stub_->InjectKeyEvent(event); |
|
Wez
2011/11/17 22:25:16
Is there a risk that InjectKeyEvent() triggers a t
Sergey Ulanov
2011/11/17 22:41:39
I don't think so.
|
| + } else { |
| + LOG(WARNING) << "Received invalid key event."; |
| + } |
| + } else if (message->has_mouse_event()) { |
| + input_stub_->InjectMouseEvent(message->mouse_event()); |
| + return; |
|
Wez
2011/11/17 22:25:16
nit: Lose the return?
Sergey Ulanov
2011/11/17 22:41:39
Done.
|
| + } else { |
| + LOG(WARNING) << "Unknown event message received."; |
| + } |
| +} |
| + |
| +} // namespace protocol |
| +} // namespace remoting |