Chromium Code Reviews| 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 |