OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "remoting/protocol/client_control_dispatcher.h" | 5 #include "remoting/protocol/client_control_dispatcher.h" |
6 | 6 |
7 #include "base/bind_helpers.h" | 7 #include "base/bind_helpers.h" |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/message_loop_proxy.h" | 9 #include "base/message_loop_proxy.h" |
10 #include "net/socket/stream_socket.h" | 10 #include "net/socket/stream_socket.h" |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
57 void ClientControlDispatcher::ControlAudio(const AudioControl& audio_control) { | 57 void ClientControlDispatcher::ControlAudio(const AudioControl& audio_control) { |
58 ControlMessage message; | 58 ControlMessage message; |
59 message.mutable_audio_control()->CopyFrom(audio_control); | 59 message.mutable_audio_control()->CopyFrom(audio_control); |
60 writer_.Write(SerializeAndFrameMessage(message), base::Closure()); | 60 writer_.Write(SerializeAndFrameMessage(message), base::Closure()); |
61 } | 61 } |
62 | 62 |
63 void ClientControlDispatcher::SetCapabilities( | 63 void ClientControlDispatcher::SetCapabilities( |
64 const Capabilities& capabilities) { | 64 const Capabilities& capabilities) { |
65 ControlMessage message; | 65 ControlMessage message; |
66 message.mutable_capabilities()->CopyFrom(capabilities); | 66 message.mutable_capabilities()->CopyFrom(capabilities); |
67 } | |
68 | |
69 void ClientControlDispatcher::RequestPairing( | |
70 const PairingRequest& pairing_request, | |
71 const base::Callback<void(const PairingReply&)>& callback) { | |
72 // TODO(jamiewalch): Add a request id to the pairing requests to allow us to | |
73 // route the response to the correct callback. | |
74 latest_pairing_callback_ = callback; | |
75 ControlMessage message; | |
76 message.mutable_pairing_request()->CopyFrom(pairing_request); | |
67 writer_.Write(SerializeAndFrameMessage(message), base::Closure()); | 77 writer_.Write(SerializeAndFrameMessage(message), base::Closure()); |
68 } | 78 } |
69 | 79 |
70 void ClientControlDispatcher::OnMessageReceived( | 80 void ClientControlDispatcher::OnMessageReceived( |
71 scoped_ptr<ControlMessage> message, const base::Closure& done_task) { | 81 scoped_ptr<ControlMessage> message, const base::Closure& done_task) { |
72 DCHECK(client_stub_); | 82 DCHECK(client_stub_); |
73 DCHECK(clipboard_stub_); | 83 DCHECK(clipboard_stub_); |
74 base::ScopedClosureRunner done_runner(done_task); | 84 base::ScopedClosureRunner done_runner(done_task); |
75 | 85 |
76 if (message->has_clipboard_event()) { | 86 if (message->has_clipboard_event()) { |
77 clipboard_stub_->InjectClipboardEvent(message->clipboard_event()); | 87 clipboard_stub_->InjectClipboardEvent(message->clipboard_event()); |
78 } else if (message->has_capabilities()) { | 88 } else if (message->has_capabilities()) { |
79 client_stub_->SetCapabilities(message->capabilities()); | 89 client_stub_->SetCapabilities(message->capabilities()); |
80 } else if (message->has_cursor_shape()) { | 90 } else if (message->has_cursor_shape()) { |
81 client_stub_->SetCursorShape(message->cursor_shape()); | 91 client_stub_->SetCursorShape(message->cursor_shape()); |
92 } else if (message->has_pairing_reply()) { | |
93 if (!latest_pairing_callback_.is_null()) { | |
alexeypa (please no reviews)
2013/05/09 02:49:20
nit: LOG(WARNING) << some message if no callback a
Jamie
2013/05/09 17:59:52
No longer needed in light of your and Renato's com
| |
94 latest_pairing_callback_.Run(message->pairing_reply()); | |
95 latest_pairing_callback_.Reset(); | |
alexeypa (please no reviews)
2013/05/09 02:49:20
I'd say this logic belongs to |client_stub|. Up un
rmsousa
2013/05/09 03:55:02
Agreed. ClientStub is already essentially a callba
Jamie
2013/05/09 17:59:52
Fair enough. It gets rid of a TODO and makes this
| |
96 } | |
82 } else { | 97 } else { |
83 LOG(WARNING) << "Unknown control message received."; | 98 LOG(WARNING) << "Unknown control message received."; |
84 } | 99 } |
85 } | 100 } |
86 | 101 |
87 } // namespace protocol | 102 } // namespace protocol |
88 } // namespace remoting | 103 } // namespace remoting |
OLD | NEW |