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

Side by Side Diff: net/curvecp/messenger.cc

Issue 8801005: base::Bind: Convert Socket::Read. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: 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 "net/curvecp/messenger.h" 5 #include "net/curvecp/messenger.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/message_loop.h" 8 #include "base/message_loop.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 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
52 52
53 // Size of the send buffer. 53 // Size of the send buffer.
54 static const size_t kSendBufferSize = (128 * 1024); 54 static const size_t kSendBufferSize = (128 * 1024);
55 // Size of the receive buffer. 55 // Size of the receive buffer.
56 static const size_t kReceiveBufferSize = (128 * 1024); 56 static const size_t kReceiveBufferSize = (128 * 1024);
57 57
58 Messenger::Messenger(Packetizer* packetizer) 58 Messenger::Messenger(Packetizer* packetizer)
59 : packetizer_(packetizer), 59 : packetizer_(packetizer),
60 send_buffer_(kSendBufferSize), 60 send_buffer_(kSendBufferSize),
61 send_complete_callback_(NULL), 61 send_complete_callback_(NULL),
62 receive_complete_callback_(NULL), 62 old_receive_complete_callback_(NULL),
63 pending_receive_length_(0), 63 pending_receive_length_(0),
64 send_message_in_progress_(false), 64 send_message_in_progress_(false),
65 ALLOW_THIS_IN_INITIALIZER_LIST( 65 ALLOW_THIS_IN_INITIALIZER_LIST(
66 send_message_callback_(this, &Messenger::OnSendMessageComplete)), 66 send_message_callback_(this, &Messenger::OnSendMessageComplete)),
67 ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) { 67 ALLOW_THIS_IN_INITIALIZER_LIST(factory_(this)) {
68 } 68 }
69 69
70 Messenger::~Messenger() { 70 Messenger::~Messenger() {
71 } 71 }
72 72
73 int Messenger::Read(IOBuffer* buf, int buf_len, OldCompletionCallback* callback) { 73 int Messenger::Read(IOBuffer* buf, int buf_len, OldCompletionCallback* callback) {
74 DCHECK(CalledOnValidThread()); 74 DCHECK(CalledOnValidThread());
75 DCHECK(!receive_complete_callback_); 75 DCHECK(!old_receive_complete_callback_);
csilv 2011/12/07 00:03:48 change this to match line 91
James Hawkins 2011/12/07 00:19:37 Done.
76
77 if (!received_list_.bytes_available()) {
78 old_receive_complete_callback_ = callback;
79 pending_receive_ = buf;
80 pending_receive_length_ = buf_len;
81 return ERR_IO_PENDING;
82 }
83
84 int bytes_read = InternalRead(buf, buf_len);
85 DCHECK_LT(0, bytes_read);
86 return bytes_read;
87 }
88 int Messenger::Read(IOBuffer* buf, int buf_len,
89 const CompletionCallback& callback) {
90 DCHECK(CalledOnValidThread());
91 DCHECK(!old_receive_complete_callback_ &&
92 receive_complete_callback_.is_null());
76 93
77 if (!received_list_.bytes_available()) { 94 if (!received_list_.bytes_available()) {
78 receive_complete_callback_ = callback; 95 receive_complete_callback_ = callback;
79 pending_receive_ = buf; 96 pending_receive_ = buf;
80 pending_receive_length_ = buf_len; 97 pending_receive_length_ = buf_len;
81 return ERR_IO_PENDING; 98 return ERR_IO_PENDING;
82 } 99 }
83 100
84 int bytes_read = InternalRead(buf, buf_len); 101 int bytes_read = InternalRead(buf, buf_len);
85 DCHECK_LT(0, bytes_read); 102 DCHECK_LT(0, bytes_read);
(...skipping 245 matching lines...) Expand 10 before | Expand all | Expand 10 after
331 // Add to our received block list 348 // Add to our received block list
332 uint64 position = uint64_unpack(header->position); 349 uint64 position = uint64_unpack(header->position);
333 scoped_refptr<IOBuffer> buffer(new IOBuffer(body_length)); 350 scoped_refptr<IOBuffer> buffer(new IOBuffer(body_length));
334 memcpy(buffer->data(), message->data() + sizeof(Message), body_length); 351 memcpy(buffer->data(), message->data() + sizeof(Message), body_length);
335 received_list_.AddBlock(position, buffer, body_length); 352 received_list_.AddBlock(position, buffer, body_length);
336 353
337 SendAck(message_id); 354 SendAck(message_id);
338 } 355 }
339 356
340 // If we have data available, and a read is pending, notify the callback. 357 // If we have data available, and a read is pending, notify the callback.
341 if (received_list_.bytes_available() && receive_complete_callback_) { 358 if (received_list_.bytes_available() &&
359 (old_receive_complete_callback_ ||
360 !receive_complete_callback_.is_null())) {
342 // Pass the data up to the caller. 361 // Pass the data up to the caller.
343 int bytes_read = InternalRead(pending_receive_, pending_receive_length_); 362 int bytes_read = InternalRead(pending_receive_, pending_receive_length_);
344 OldCompletionCallback* callback = receive_complete_callback_; 363 if (old_receive_complete_callback_) {
345 receive_complete_callback_ = NULL; 364 OldCompletionCallback* callback = old_receive_complete_callback_;
346 callback->Run(bytes_read); 365 old_receive_complete_callback_ = NULL;
366 callback->Run(bytes_read);
367 } else {
368 CompletionCallback callback = receive_complete_callback_;
369 receive_complete_callback_.Reset();
370 callback.Run(bytes_read);
371 }
347 } 372 }
348 } 373 }
349 374
350 void Messenger::SendAck(uint32 last_message_received) { 375 void Messenger::SendAck(uint32 last_message_received) {
351 scoped_refptr<IOBuffer> buffer(new IOBuffer(sizeof(Message))); 376 scoped_refptr<IOBuffer> buffer(new IOBuffer(sizeof(Message)));
352 memset(buffer->data(), 0, sizeof(Message)); 377 memset(buffer->data(), 0, sizeof(Message));
353 Message* message = reinterpret_cast<Message*>(buffer->data()); 378 Message* message = reinterpret_cast<Message*>(buffer->data());
354 uint32_pack(message->last_message_received, last_message_received); 379 uint32_pack(message->last_message_received, last_message_received);
355 uint64_pack(message->acknowledge_1, received_list_.bytes_received()); 380 uint64_pack(message->acknowledge_1, received_list_.bytes_received());
356 LOG(ERROR) << "SendAck " << received_list_.bytes_received(); 381 LOG(ERROR) << "SendAck " << received_list_.bytes_received();
357 // TODO(mbelshe): fill in remainder of selective acknowledgements 382 // TODO(mbelshe): fill in remainder of selective acknowledgements
358 383
359 // TODO(mbelshe): Fix this - it is totally possible to have a send message 384 // TODO(mbelshe): Fix this - it is totally possible to have a send message
360 // in progress here... 385 // in progress here...
361 DCHECK(!send_message_in_progress_); 386 DCHECK(!send_message_in_progress_);
362 387
363 int rv = packetizer_->SendMessage(key_, 388 int rv = packetizer_->SendMessage(key_,
364 buffer->data(), 389 buffer->data(),
365 sizeof(Message), 390 sizeof(Message),
366 &send_message_callback_); 391 &send_message_callback_);
367 // TODO(mbelshe): Fix me! Deal with the error cases 392 // TODO(mbelshe): Fix me! Deal with the error cases
368 DCHECK(rv == sizeof(Message)); 393 DCHECK(rv == sizeof(Message));
369 } 394 }
370 395
371 } // namespace net 396 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698