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

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

Issue 340433002: Port QuicServer to Chrome network stack (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address review comments and fix blocked writers using callbacks Created 6 years, 6 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
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) 12 QuicDefaultPacketWriter::QuicDefaultPacketWriter(int fd)
13 : fd_(fd), 13 : fd_(fd),
14 write_blocked_(false) {} 14 write_blocked_(false) {}
15 15
16 QuicDefaultPacketWriter::~QuicDefaultPacketWriter() {} 16 QuicDefaultPacketWriter::~QuicDefaultPacketWriter() {}
17 17
18 WriteResult QuicDefaultPacketWriter::WritePacket( 18 WriteResult QuicDefaultPacketWriter::WritePacket(
19 const char* buffer, size_t buf_len, 19 const char* buffer, size_t buf_len,
20 const net::IPAddressNumber& self_address, 20 const net::IPAddressNumber& self_address,
21 const net::IPEndPoint& peer_address) { 21 const net::IPEndPoint& peer_address,
22 base::Callback<void(WriteResult wr)> callback) {
22 DCHECK(!IsWriteBlocked()); 23 DCHECK(!IsWriteBlocked());
23 WriteResult result = QuicSocketUtils::WritePacket( 24 WriteResult result = QuicSocketUtils::WritePacket(
24 fd_, buffer, buf_len, self_address, peer_address); 25 fd_, buffer, buf_len, self_address, peer_address);
25 if (result.status == WRITE_STATUS_BLOCKED) { 26 if (result.status == WRITE_STATUS_BLOCKED) {
26 write_blocked_ = true; 27 write_blocked_ = true;
27 } 28 }
28 return result; 29 return result;
29 } 30 }
30 31
31 bool QuicDefaultPacketWriter::IsWriteBlockedDataBuffered() const { 32 bool QuicDefaultPacketWriter::IsWriteBlockedDataBuffered() const {
32 return false; 33 return false;
33 } 34 }
34 35
35 bool QuicDefaultPacketWriter::IsWriteBlocked() const { 36 bool QuicDefaultPacketWriter::IsWriteBlocked() const {
36 return write_blocked_; 37 return write_blocked_;
37 } 38 }
38 39
39 void QuicDefaultPacketWriter::SetWritable() { 40 void QuicDefaultPacketWriter::SetWritable() {
40 write_blocked_ = false; 41 write_blocked_ = false;
41 } 42 }
42 43
43 } // namespace tools 44 } // namespace tools
44 } // namespace net 45 } // namespace net
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698