| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #ifndef REMOTING_PROTOCOL_MESSAGE_READER_H_ | 5 #ifndef REMOTING_PROTOCOL_MESSAGE_READER_H_ |
| 6 #define REMOTING_PROTOCOL_MESSAGE_READER_H_ | 6 #define REMOTING_PROTOCOL_MESSAGE_READER_H_ |
| 7 | 7 |
| 8 #include "base/bind.h" |
| 8 #include "base/callback.h" | 9 #include "base/callback.h" |
| 9 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
| 10 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 11 #include "base/message_loop_proxy.h" | 12 #include "base/message_loop_proxy.h" |
| 12 #include "base/task.h" | |
| 13 #include "net/base/completion_callback.h" | 13 #include "net/base/completion_callback.h" |
| 14 #include "remoting/base/compound_buffer.h" | 14 #include "remoting/base/compound_buffer.h" |
| 15 #include "remoting/protocol/message_decoder.h" | 15 #include "remoting/protocol/message_decoder.h" |
| 16 | 16 |
| 17 class MessageLoop; | 17 class MessageLoop; |
| 18 | 18 |
| 19 namespace net { | 19 namespace net { |
| 20 class IOBuffer; | 20 class IOBuffer; |
| 21 class Socket; | 21 class Socket; |
| 22 } // namespace net | 22 } // namespace net |
| (...skipping 11 matching lines...) Expand all Loading... |
| 34 // processed by the receiver (|done_task| is called for each message). | 34 // processed by the receiver (|done_task| is called for each message). |
| 35 // It is still possible that the MessageReceivedCallback is called | 35 // It is still possible that the MessageReceivedCallback is called |
| 36 // twice (so that there is more than one outstanding message), | 36 // twice (so that there is more than one outstanding message), |
| 37 // e.g. when we the sender sends multiple messages in one TCP packet. | 37 // e.g. when we the sender sends multiple messages in one TCP packet. |
| 38 class MessageReader : public base::RefCountedThreadSafe<MessageReader> { | 38 class MessageReader : public base::RefCountedThreadSafe<MessageReader> { |
| 39 public: | 39 public: |
| 40 // The callback is given ownership of the second argument | 40 // The callback is given ownership of the second argument |
| 41 // (|done_task|). The buffer (first argument) is owned by | 41 // (|done_task|). The buffer (first argument) is owned by |
| 42 // MessageReader and is freed when the task specified by the second | 42 // MessageReader and is freed when the task specified by the second |
| 43 // argument is called. | 43 // argument is called. |
| 44 typedef Callback2<CompoundBuffer*, Task*>::Type MessageReceivedCallback; | 44 typedef base::Callback<void(CompoundBuffer*, const base::Closure&)> |
| 45 MessageReceivedCallback; |
| 45 | 46 |
| 46 MessageReader(); | 47 MessageReader(); |
| 47 virtual ~MessageReader(); | 48 virtual ~MessageReader(); |
| 48 | 49 |
| 49 // Initialize the MessageReader with a socket. If a message is received | 50 // Initialize the MessageReader with a socket. If a message is received |
| 50 // |callback| is called. | 51 // |callback| is called. |
| 51 void Init(net::Socket* socket, MessageReceivedCallback* callback); | 52 void Init(net::Socket* socket, const MessageReceivedCallback& callback); |
| 52 | 53 |
| 53 private: | 54 private: |
| 54 void DoRead(); | 55 void DoRead(); |
| 55 void OnRead(int result); | 56 void OnRead(int result); |
| 56 void HandleReadResult(int result); | 57 void HandleReadResult(int result); |
| 57 void OnDataReceived(net::IOBuffer* data, int data_size); | 58 void OnDataReceived(net::IOBuffer* data, int data_size); |
| 58 void OnMessageDone(CompoundBuffer* message, | 59 void OnMessageDone(CompoundBuffer* message, |
| 59 scoped_refptr<base::MessageLoopProxy> message_loop); | 60 scoped_refptr<base::MessageLoopProxy> message_loop); |
| 60 void ProcessDoneEvent(); | 61 void ProcessDoneEvent(); |
| 61 | 62 |
| 62 net::Socket* socket_; | 63 net::Socket* socket_; |
| 63 | 64 |
| 64 // Set to true, when we have a socket read pending, and expecting | 65 // Set to true, when we have a socket read pending, and expecting |
| 65 // OnRead() to be called when new data is received. | 66 // OnRead() to be called when new data is received. |
| 66 bool read_pending_; | 67 bool read_pending_; |
| 67 | 68 |
| 68 // Number of messages that we received, but haven't finished | 69 // Number of messages that we received, but haven't finished |
| 69 // processing yet, i.e. |done_task| hasn't been called for these | 70 // processing yet, i.e. |done_task| hasn't been called for these |
| 70 // messages. | 71 // messages. |
| 71 int pending_messages_; | 72 int pending_messages_; |
| 72 | 73 |
| 73 bool closed_; | 74 bool closed_; |
| 74 scoped_refptr<net::IOBuffer> read_buffer_; | 75 scoped_refptr<net::IOBuffer> read_buffer_; |
| 75 net::OldCompletionCallbackImpl<MessageReader> read_callback_; | 76 net::OldCompletionCallbackImpl<MessageReader> read_callback_; |
| 76 | 77 |
| 77 MessageDecoder message_decoder_; | 78 MessageDecoder message_decoder_; |
| 78 | 79 |
| 79 // Callback is called when a message is received. | 80 // Callback is called when a message is received. |
| 80 scoped_ptr<MessageReceivedCallback> message_received_callback_; | 81 MessageReceivedCallback message_received_callback_; |
| 81 }; | 82 }; |
| 82 | 83 |
| 83 // Version of MessageReader for protocol buffer messages, that parses | 84 // Version of MessageReader for protocol buffer messages, that parses |
| 84 // each incoming message. | 85 // each incoming message. |
| 85 template <class T> | 86 template <class T> |
| 86 class ProtobufMessageReader { | 87 class ProtobufMessageReader { |
| 87 public: | 88 public: |
| 88 typedef typename Callback2<T*, Task*>::Type MessageReceivedCallback; | 89 typedef typename base::Callback<void(T*, const base::Closure&)> |
| 90 MessageReceivedCallback; |
| 89 | 91 |
| 90 ProtobufMessageReader() { }; | 92 ProtobufMessageReader() { }; |
| 91 ~ProtobufMessageReader() { }; | 93 ~ProtobufMessageReader() { }; |
| 92 | 94 |
| 93 void Init(net::Socket* socket, MessageReceivedCallback* callback) { | 95 void Init(net::Socket* socket, const MessageReceivedCallback& callback) { |
| 94 message_received_callback_.reset(callback); | 96 DCHECK(!callback.is_null()); |
| 97 message_received_callback_ = callback; |
| 95 message_reader_ = new MessageReader(); | 98 message_reader_ = new MessageReader(); |
| 96 message_reader_->Init( | 99 message_reader_->Init( |
| 97 socket, NewCallback(this, &ProtobufMessageReader<T>::OnNewData)); | 100 socket, base::Bind(&ProtobufMessageReader<T>::OnNewData, |
| 101 base::Unretained(this))); |
| 98 } | 102 } |
| 99 | 103 |
| 100 private: | 104 private: |
| 101 void OnNewData(CompoundBuffer* buffer, Task* done_task) { | 105 void OnNewData(CompoundBuffer* buffer, const base::Closure& done_task) { |
| 102 T* message = new T(); | 106 T* message = new T(); |
| 103 CompoundBufferInputStream stream(buffer); | 107 CompoundBufferInputStream stream(buffer); |
| 104 bool ret = message->ParseFromZeroCopyStream(&stream); | 108 bool ret = message->ParseFromZeroCopyStream(&stream); |
| 105 if (!ret) { | 109 if (!ret) { |
| 106 LOG(WARNING) << "Received message that is not a valid protocol buffer."; | 110 LOG(WARNING) << "Received message that is not a valid protocol buffer."; |
| 107 delete message; | 111 delete message; |
| 108 } else { | 112 } else { |
| 109 DCHECK_EQ(stream.position(), buffer->total_bytes()); | 113 DCHECK_EQ(stream.position(), buffer->total_bytes()); |
| 110 message_received_callback_->Run( | 114 message_received_callback_.Run(message, base::Bind( |
| 111 message, NewRunnableFunction( | 115 &ProtobufMessageReader<T>::OnDone, message, done_task)); |
| 112 &ProtobufMessageReader<T>::OnDone, message, done_task)); | |
| 113 } | 116 } |
| 114 } | 117 } |
| 115 | 118 |
| 116 static void OnDone(T* message, Task* done_task) { | 119 static void OnDone(T* message, const base::Closure& done_task) { |
| 117 delete message; | 120 delete message; |
| 118 done_task->Run(); | 121 done_task.Run(); |
| 119 delete done_task; | |
| 120 } | 122 } |
| 121 | 123 |
| 122 scoped_refptr<MessageReader> message_reader_; | 124 scoped_refptr<MessageReader> message_reader_; |
| 123 scoped_ptr<MessageReceivedCallback> message_received_callback_; | 125 MessageReceivedCallback message_received_callback_; |
| 124 }; | 126 }; |
| 125 | 127 |
| 126 } // namespace protocol | 128 } // namespace protocol |
| 127 } // namespace remoting | 129 } // namespace remoting |
| 128 | 130 |
| 129 #endif // REMOTING_PROTOCOL_MESSAGE_READER_H_ | 131 #endif // REMOTING_PROTOCOL_MESSAGE_READER_H_ |
| OLD | NEW |