Index: net/quic/quic_server_packet_writer.cc |
diff --git a/net/quic/quic_server_packet_writer.cc b/net/quic/quic_server_packet_writer.cc |
index c2635b699eb3efd06713015d8ba6fcd1a2d93a4e..6e392c57262d293a383a52b71a8fdbf4f9d33b0c 100644 |
--- a/net/quic/quic_server_packet_writer.cc |
+++ b/net/quic/quic_server_packet_writer.cc |
@@ -4,20 +4,22 @@ |
#include "net/quic/quic_server_packet_writer.h" |
+#include "base/callback_helpers.h" |
#include "base/location.h" |
#include "base/logging.h" |
#include "base/metrics/sparse_histogram.h" |
#include "net/base/io_buffer.h" |
#include "net/base/net_errors.h" |
+#include "net/udp/udp_server_socket.h" |
namespace net { |
-QuicServerPacketWriter::QuicServerPacketWriter() : weak_factory_(this) { |
-} |
- |
-QuicServerPacketWriter::QuicServerPacketWriter(UDPServerSocket* socket) |
+QuicServerPacketWriter::QuicServerPacketWriter( |
+ UDPServerSocket* socket, |
+ QuicBlockedWriterInterface* blocked_writer) |
: weak_factory_(this), |
socket_(socket), |
+ blocked_writer_(blocked_writer), |
write_blocked_(false) { |
} |
@@ -25,14 +27,16 @@ QuicServerPacketWriter::~QuicServerPacketWriter() { |
} |
WriteResult QuicServerPacketWriter::WritePacket( |
- const char* buffer, size_t buf_len, |
- const net::IPAddressNumber& self_address, |
- const net::IPEndPoint& peer_address) { |
+ const char* buffer, |
+ size_t buf_len, |
+ const IPAddressNumber& self_address, |
+ const IPEndPoint& peer_address) { |
scoped_refptr<StringIOBuffer> buf( |
new StringIOBuffer(std::string(buffer, buf_len))); |
DCHECK(!IsWriteBlocked()); |
+ DCHECK(!callback_.is_null()); |
int rv = socket_->SendTo(buf.get(), |
- buf_len, |
+ static_cast<int>(buf_len), |
wtc
2014/06/24 01:06:48
IMPORTANT: we should check whether buf_len <= MAX_
dmziegler
2014/06/24 19:01:18
Done.
|
peer_address, |
base::Bind(&QuicServerPacketWriter::OnWriteComplete, |
weak_factory_.GetWeakPtr())); |
@@ -46,10 +50,24 @@ WriteResult QuicServerPacketWriter::WritePacket( |
write_blocked_ = true; |
} |
} |
- |
return WriteResult(status, rv); |
} |
+WriteResult QuicServerPacketWriter::WritePacketWithCallback( |
+ const char* buffer, |
+ size_t buf_len, |
+ const IPAddressNumber& self_address, |
+ const IPEndPoint& peer_address, |
+ WriteCallback callback) { |
+ DCHECK(callback_.is_null()); |
+ callback_ = callback; |
+ WriteResult result = WritePacket(buffer, buf_len, self_address, peer_address); |
+ if (result.status != WRITE_STATUS_BLOCKED) { |
+ callback_.Reset(); |
+ } |
+ return result; |
+} |
+ |
bool QuicServerPacketWriter::IsWriteBlockedDataBuffered() const { |
// UDPServerSocket::SendTo buffers the data until the Write is permitted. |
return true; |
@@ -67,8 +85,8 @@ void QuicServerPacketWriter::OnWriteComplete(int rv) { |
DCHECK_NE(rv, ERR_IO_PENDING); |
write_blocked_ = false; |
WriteResult result(rv < 0 ? WRITE_STATUS_ERROR : WRITE_STATUS_OK, rv); |
- connection_->OnPacketSent(result); |
- connection_->OnCanWrite(); |
+ base::ResetAndReturn(&callback_).Run(result); |
+ blocked_writer_->OnCanWrite(); |
} |
} // namespace net |