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

Unified Diff: net/quic/quartc/quartc_packet_writer.cc

Issue 2324833004: Define Stable API for WebRTC/Quartc (Closed)
Patch Set: Patch Set 4 : Create QuartcFactory. Made modification on the API. Change the constructor of QuartcS… Created 4 years, 3 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 side-by-side diff with in-line comments
Download patch
Index: net/quic/quartc/quartc_packet_writer.cc
diff --git a/net/quic/quartc/quartc_packet_writer.cc b/net/quic/quartc/quartc_packet_writer.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c1bb1c56828b1fd1bb105abe059044eb0575de4f
--- /dev/null
+++ b/net/quic/quartc/quartc_packet_writer.cc
@@ -0,0 +1,44 @@
+// Copyright (c) 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "net/quic/quartc/quartc_packet_writer.h"
+
+namespace net {
+QuartcPacketWriter::QuartcPacketWriter(
+ QuartcSessionInterface::Transport* transport)
+ : transport_(transport) {}
+
+WriteResult QuartcPacketWriter::WritePacket(const char* buffer,
+ size_t buf_len,
+ const IPAddress& self_address,
+ const IPEndPoint& peer_address,
+ PerPacketOptions* options) {
+ DCHECK(transport_);
+ int bytes_written = transport_->Write(buffer, buf_len);
+ if (bytes_written <= 0) {
+ return WriteResult(WRITE_STATUS_BLOCKED, EWOULDBLOCK);
+ }
+ return WriteResult(WRITE_STATUS_OK, bytes_written);
+}
+
+bool QuartcPacketWriter::IsWriteBlockedDataBuffered() const {
+ return false;
+}
+
+bool QuartcPacketWriter::IsWriteBlocked() const {
+ DCHECK(transport_);
+ return !transport_->CanWrite();
+}
+
+// TODO(zhihuang) To figure out what is the better value to return. The
+// transport in WebRTC network layer may become the bottleneck when determining
+// the MTU.
+QuicByteCount QuartcPacketWriter::GetMaxPacketSize(
+ const IPEndPoint& peer_address) const {
+ return kMaxPacketSize;
+}
+
+void QuartcPacketWriter::SetWritable() {}
+
+} // namespace net

Powered by Google App Engine
This is Rietveld 408576698