OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // This stub is thread safe because of the use of BufferedSocketWriter. | 5 // This stub is thread safe because of the use of BufferedSocketWriter. |
6 // BufferedSocketWriter buffers messages and send them on them right thread. | 6 // BufferedSocketWriter buffers messages and send them on them right thread. |
7 | 7 |
8 #include "remoting/protocol/input_sender.h" | 8 #include "remoting/protocol/input_sender.h" |
9 | 9 |
10 #include "base/task.h" | 10 #include "base/task.h" |
11 #include "remoting/proto/event.pb.h" | 11 #include "remoting/proto/event.pb.h" |
| 12 #include "remoting/proto/internal.pb.h" |
12 #include "remoting/protocol/buffered_socket_writer.h" | 13 #include "remoting/protocol/buffered_socket_writer.h" |
13 #include "remoting/protocol/util.h" | 14 #include "remoting/protocol/util.h" |
14 | 15 |
15 namespace remoting { | 16 namespace remoting { |
16 namespace protocol { | 17 namespace protocol { |
17 | 18 |
18 InputSender::InputSender(net::Socket* socket) | 19 InputSender::InputSender(net::Socket* socket) |
19 : buffered_writer_(new BufferedSocketWriter()) { | 20 : buffered_writer_(new BufferedSocketWriter()) { |
20 // TODO(garykac) Set write failed callback. | 21 // TODO(garykac) Set write failed callback. |
21 DCHECK(socket); | 22 DCHECK(socket); |
22 buffered_writer_->Init(socket, NULL); | 23 buffered_writer_->Init(socket, NULL); |
23 } | 24 } |
24 | 25 |
25 InputSender::~InputSender() { | 26 InputSender::~InputSender() { |
26 } | 27 } |
27 | 28 |
28 void InputSender::InjectKeyEvent(const KeyEvent* event, Task* done) { | 29 void InputSender::InjectKeyEvent(const KeyEvent* event, Task* done) { |
29 EventMessage message; | 30 EventMessage message; |
30 Event* evt = message.add_event(); | |
31 // TODO(hclam): Provide timestamp. | 31 // TODO(hclam): Provide timestamp. |
32 evt->set_timestamp(0); | 32 message.set_timestamp(0); |
33 evt->mutable_key()->CopyFrom(*event); | 33 message.mutable_key_event()->CopyFrom(*event); |
34 buffered_writer_->Write(SerializeAndFrameMessage(message), done); | 34 buffered_writer_->Write(SerializeAndFrameMessage(message), done); |
35 } | 35 } |
36 | 36 |
37 void InputSender::InjectMouseEvent(const MouseEvent* event, Task* done) { | 37 void InputSender::InjectMouseEvent(const MouseEvent* event, Task* done) { |
38 EventMessage message; | 38 EventMessage message; |
39 Event* evt = message.add_event(); | |
40 // TODO(hclam): Provide timestamp. | 39 // TODO(hclam): Provide timestamp. |
41 evt->set_timestamp(0); | 40 message.set_timestamp(0); |
42 evt->mutable_mouse()->CopyFrom(*event); | 41 message.mutable_mouse_event()->CopyFrom(*event); |
43 buffered_writer_->Write(SerializeAndFrameMessage(message), done); | 42 buffered_writer_->Write(SerializeAndFrameMessage(message), done); |
44 } | 43 } |
45 | 44 |
46 } // namespace protocol | 45 } // namespace protocol |
47 } // namespace remoting | 46 } // namespace remoting |
OLD | NEW |