| 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),
|
| 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
|
|
|