Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1215)

Side by Side Diff: remoting/protocol/pepper_transport_socket_adapter.cc

Issue 8824006: Migrate net/socket/socket.h, net/socket/stream_socket.h to base::Bind(). (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebased Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 #include "remoting/protocol/pepper_transport_socket_adapter.h" 5 #include "remoting/protocol/pepper_transport_socket_adapter.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "net/base/address_list.h" 8 #include "net/base/address_list.h"
9 #include "net/base/io_buffer.h" 9 #include "net/base/io_buffer.h"
10 #include "net/base/net_errors.h" 10 #include "net/base/net_errors.h"
(...skipping 30 matching lines...) Expand all
41 } // namespace 41 } // namespace
42 42
43 PepperTransportSocketAdapter::PepperTransportSocketAdapter( 43 PepperTransportSocketAdapter::PepperTransportSocketAdapter(
44 pp::Transport_Dev* transport, 44 pp::Transport_Dev* transport,
45 const std::string& name, 45 const std::string& name,
46 Observer* observer) 46 Observer* observer)
47 : name_(name), 47 : name_(name),
48 observer_(observer), 48 observer_(observer),
49 transport_(transport), 49 transport_(transport),
50 connected_(false), 50 connected_(false),
51 get_address_pending_(false), 51 get_address_pending_(false) {
52 old_read_callback_(NULL),
53 write_callback_(NULL) {
54 callback_factory_.Initialize(this); 52 callback_factory_.Initialize(this);
55 } 53 }
56 54
57 PepperTransportSocketAdapter::~PepperTransportSocketAdapter() { 55 PepperTransportSocketAdapter::~PepperTransportSocketAdapter() {
58 observer_->OnChannelDeleted(); 56 observer_->OnChannelDeleted();
59 } 57 }
60 58
61 void PepperTransportSocketAdapter::AddRemoteCandidate( 59 void PepperTransportSocketAdapter::AddRemoteCandidate(
62 const std::string& candidate) { 60 const std::string& candidate) {
63 DCHECK(CalledOnValidThread()); 61 DCHECK(CalledOnValidThread());
64 if (transport_.get()) 62 if (transport_.get())
65 transport_->ReceiveRemoteAddress(candidate); 63 transport_->ReceiveRemoteAddress(candidate);
66 } 64 }
67 65
68 int PepperTransportSocketAdapter::Read(net::IOBuffer* buf, int buf_len,
69 net::OldCompletionCallback* callback) {
70 DCHECK(CalledOnValidThread());
71 DCHECK(!old_read_callback_ && read_callback_.is_null());
72 DCHECK(!read_buffer_);
73
74 if (!transport_.get())
75 return net::ERR_SOCKET_NOT_CONNECTED;
76
77 int result = PPErrorToNetError(transport_->Recv(
78 buf->data(), buf_len,
79 callback_factory_.NewOptionalCallback(
80 &PepperTransportSocketAdapter::OnRead)));
81
82 if (result == net::ERR_IO_PENDING) {
83 old_read_callback_ = callback;
84 read_buffer_ = buf;
85 }
86
87 return result;
88 }
89 int PepperTransportSocketAdapter::Read( 66 int PepperTransportSocketAdapter::Read(
90 net::IOBuffer* buf, int buf_len, 67 net::IOBuffer* buf, int buf_len,
91 const net::CompletionCallback& callback) { 68 const net::CompletionCallback& callback) {
92 DCHECK(CalledOnValidThread()); 69 DCHECK(CalledOnValidThread());
93 DCHECK(!old_read_callback_ && read_callback_.is_null()); 70 DCHECK(read_callback_.is_null());
94 DCHECK(!read_buffer_); 71 DCHECK(!read_buffer_);
95 72
96 if (!transport_.get()) 73 if (!transport_.get())
97 return net::ERR_SOCKET_NOT_CONNECTED; 74 return net::ERR_SOCKET_NOT_CONNECTED;
98 75
99 int result = PPErrorToNetError(transport_->Recv( 76 int result = PPErrorToNetError(transport_->Recv(
100 buf->data(), buf_len, 77 buf->data(), buf_len,
101 callback_factory_.NewOptionalCallback( 78 callback_factory_.NewOptionalCallback(
102 &PepperTransportSocketAdapter::OnRead))); 79 &PepperTransportSocketAdapter::OnRead)));
103 80
104 if (result == net::ERR_IO_PENDING) { 81 if (result == net::ERR_IO_PENDING) {
105 read_callback_ = callback; 82 read_callback_ = callback;
106 read_buffer_ = buf; 83 read_buffer_ = buf;
107 } 84 }
108 85
109 return result; 86 return result;
110 } 87 }
111 88
112 int PepperTransportSocketAdapter::Write(net::IOBuffer* buf, int buf_len, 89 int PepperTransportSocketAdapter::Write(
113 net::OldCompletionCallback* callback) { 90 net::IOBuffer* buf, int buf_len,
91 const net::CompletionCallback& callback) {
114 DCHECK(CalledOnValidThread()); 92 DCHECK(CalledOnValidThread());
115 DCHECK(!write_callback_); 93 DCHECK(write_callback_.is_null());
116 DCHECK(!write_buffer_); 94 DCHECK(!write_buffer_);
117 95
118 if (!transport_.get()) 96 if (!transport_.get())
119 return net::ERR_SOCKET_NOT_CONNECTED; 97 return net::ERR_SOCKET_NOT_CONNECTED;
120 98
121 int result = PPErrorToNetError(transport_->Send( 99 int result = PPErrorToNetError(transport_->Send(
122 buf->data(), buf_len, 100 buf->data(), buf_len,
123 callback_factory_.NewOptionalCallback( 101 callback_factory_.NewOptionalCallback(
124 &PepperTransportSocketAdapter::OnWrite))); 102 &PepperTransportSocketAdapter::OnWrite)));
125 103
(...skipping 13 matching lines...) Expand all
139 } 117 }
140 118
141 bool PepperTransportSocketAdapter::SetSendBufferSize(int32 size) { 119 bool PepperTransportSocketAdapter::SetSendBufferSize(int32 size) {
142 DCHECK(CalledOnValidThread()); 120 DCHECK(CalledOnValidThread());
143 // TODO(sergeyu): Implement this: crbug.com/91439. 121 // TODO(sergeyu): Implement this: crbug.com/91439.
144 NOTIMPLEMENTED(); 122 NOTIMPLEMENTED();
145 return false; 123 return false;
146 } 124 }
147 125
148 int PepperTransportSocketAdapter::Connect( 126 int PepperTransportSocketAdapter::Connect(
149 net::OldCompletionCallback* callback) {
150 DCHECK(CalledOnValidThread());
151
152 if (!transport_.get())
153 return net::ERR_UNEXPECTED;
154
155 old_connect_callback_ = callback;
156
157 // This will return false when GetNextAddress() returns an
158 // error. This helps to detect when the P2P Transport API is not
159 // supported.
160 int result = ProcessCandidates();
161 if (result != net::OK)
162 return result;
163
164 result = transport_->Connect(
165 callback_factory_.NewRequiredCallback(
166 &PepperTransportSocketAdapter::OnConnect));
167 DCHECK_EQ(result, PP_OK_COMPLETIONPENDING);
168
169 return net::ERR_IO_PENDING;
170 }
171 int PepperTransportSocketAdapter::Connect(
172 const net::CompletionCallback& callback) { 127 const net::CompletionCallback& callback) {
173 DCHECK(CalledOnValidThread()); 128 DCHECK(CalledOnValidThread());
174 129
175 if (!transport_.get()) 130 if (!transport_.get())
176 return net::ERR_UNEXPECTED; 131 return net::ERR_UNEXPECTED;
177 132
178 connect_callback_ = callback; 133 connect_callback_ = callback;
179 134
180 // This will return false when GetNextAddress() returns an 135 // This will return false when GetNextAddress() returns an
181 // error. This helps to detect when the P2P Transport API is not 136 // error. This helps to detect when the P2P Transport API is not
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after
293 248
294 void PepperTransportSocketAdapter::OnNextAddress(int32_t result) { 249 void PepperTransportSocketAdapter::OnNextAddress(int32_t result) {
295 DCHECK(CalledOnValidThread()); 250 DCHECK(CalledOnValidThread());
296 251
297 get_address_pending_ = false; 252 get_address_pending_ = false;
298 ProcessCandidates(); 253 ProcessCandidates();
299 } 254 }
300 255
301 void PepperTransportSocketAdapter::OnConnect(int result) { 256 void PepperTransportSocketAdapter::OnConnect(int result) {
302 DCHECK(CalledOnValidThread()); 257 DCHECK(CalledOnValidThread());
303 DCHECK(old_connect_callback_ || !connect_callback_.is_null()); 258 DCHECK(!connect_callback_.is_null());
304 259
305 if (result == PP_OK) 260 if (result == PP_OK)
306 connected_ = true; 261 connected_ = true;
307 262
308 if (old_connect_callback_) { 263 net::CompletionCallback callback = connect_callback_;
309 net::OldCompletionCallback* callback = old_connect_callback_; 264 connect_callback_.Reset();
310 old_connect_callback_ = NULL; 265 callback.Run(PPErrorToNetError(result));
311 callback->Run(PPErrorToNetError(result));
312 } else {
313 net::CompletionCallback callback = connect_callback_;
314 connect_callback_.Reset();
315 callback.Run(PPErrorToNetError(result));
316 }
317 } 266 }
318 267
319 void PepperTransportSocketAdapter::OnRead(int32_t result) { 268 void PepperTransportSocketAdapter::OnRead(int32_t result) {
320 DCHECK(CalledOnValidThread()); 269 DCHECK(CalledOnValidThread());
321 DCHECK(old_read_callback_ || read_callback_.is_null()); 270 DCHECK(!read_callback_.is_null());
322 DCHECK(read_buffer_); 271 DCHECK(read_buffer_);
323 272
324 if (old_read_callback_) { 273 net::CompletionCallback callback = read_callback_;
325 net::OldCompletionCallback* callback = old_read_callback_; 274 read_callback_.Reset();
326 old_read_callback_ = NULL; 275 read_buffer_ = NULL;
327 read_buffer_ = NULL; 276 callback.Run(PPErrorToNetError(result));
328 callback->Run(PPErrorToNetError(result));
329 } else {
330 net::CompletionCallback callback = read_callback_;
331 read_callback_.Reset();
332 read_buffer_ = NULL;
333 callback.Run(PPErrorToNetError(result));
334 }
335 } 277 }
336 278
337 void PepperTransportSocketAdapter::OnWrite(int32_t result) { 279 void PepperTransportSocketAdapter::OnWrite(int32_t result) {
338 DCHECK(CalledOnValidThread()); 280 DCHECK(CalledOnValidThread());
339 DCHECK(write_callback_); 281 DCHECK(!write_callback_.is_null());
340 DCHECK(write_buffer_); 282 DCHECK(write_buffer_);
341 283
342 net::OldCompletionCallback* callback = write_callback_; 284 net::CompletionCallback callback = write_callback_;
343 write_callback_ = NULL; 285 write_callback_.Reset();
344 write_buffer_ = NULL; 286 write_buffer_ = NULL;
345 callback->Run(PPErrorToNetError(result)); 287 callback.Run(PPErrorToNetError(result));
346 } 288 }
347 289
348 } // namespace protocol 290 } // namespace protocol
349 } // namespace remoting 291 } // namespace remoting
OLDNEW
« no previous file with comments | « remoting/protocol/pepper_transport_socket_adapter.h ('k') | remoting/protocol/socket_reader_base.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698