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

Side by Side Diff: net/tools/quic/quic_default_packet_writer.cc

Issue 127503002: Make QuicPacketWriter keep track of socket writability; expose the (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 11 months 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/tools/quic/quic_default_packet_writer.h" 5 #include "net/tools/quic/quic_default_packet_writer.h"
6 6
7 #include "net/tools/quic/quic_socket_utils.h" 7 #include "net/tools/quic/quic_socket_utils.h"
8 8
9 namespace net { 9 namespace net {
10 namespace tools { 10 namespace tools {
11 11
12 QuicDefaultPacketWriter::QuicDefaultPacketWriter(int fd) : fd_(fd) {} 12 QuicDefaultPacketWriter::QuicDefaultPacketWriter(int fd)
13 : fd_(fd),
14 write_blocked_(false) {}
13 15
14 QuicDefaultPacketWriter::~QuicDefaultPacketWriter() {} 16 QuicDefaultPacketWriter::~QuicDefaultPacketWriter() {}
15 17
16 WriteResult QuicDefaultPacketWriter::WritePacket( 18 WriteResult QuicDefaultPacketWriter::WritePacket(
17 const char* buffer, size_t buf_len, 19 const char* buffer, size_t buf_len,
18 const net::IPAddressNumber& self_address, 20 const net::IPAddressNumber& self_address,
19 const net::IPEndPoint& peer_address, 21 const net::IPEndPoint& peer_address,
20 QuicBlockedWriterInterface* blocked_writer) { 22 QuicBlockedWriterInterface* blocked_writer) {
21 return QuicSocketUtils::WritePacket(fd_, buffer, buf_len, 23 DCHECK(!IsWriteBlocked());
22 self_address, peer_address); 24 WriteResult result = QuicSocketUtils::WritePacket(
25 fd_, buffer, buf_len, self_address, peer_address);
26 if (result.status == WRITE_STATUS_BLOCKED) {
27 write_blocked_ = true;
28 }
29 return result;
23 } 30 }
24 31
25 bool QuicDefaultPacketWriter::IsWriteBlockedDataBuffered() const { 32 bool QuicDefaultPacketWriter::IsWriteBlockedDataBuffered() const {
26 return false; 33 return false;
27 } 34 }
28 35
36 bool QuicDefaultPacketWriter::IsWriteBlocked() const {
37 return write_blocked_;
38 }
39
40 void QuicDefaultPacketWriter::SetWritable() {
41 write_blocked_ = false;
42 }
43
29 } // namespace tools 44 } // namespace tools
30 } // namespace net 45 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698