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

Unified Diff: net/quic/core/frames/quic_stream_frame.cc

Issue 2547583002: Landing Recent QUIC changes until Fri Nov 18 23:21:04 2016 +0000 (Closed)
Patch Set: Remove explicit HTTP/2 enum usage Created 4 years 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
« no previous file with comments | « net/quic/core/frames/quic_stream_frame.h ('k') | net/quic/core/frames/quic_window_update_frame.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/quic/core/frames/quic_stream_frame.cc
diff --git a/net/quic/core/frames/quic_stream_frame.cc b/net/quic/core/frames/quic_stream_frame.cc
new file mode 100644
index 0000000000000000000000000000000000000000..022bf69e10fba0ae7fbb8d7909f608b20dfa16b8
--- /dev/null
+++ b/net/quic/core/frames/quic_stream_frame.cc
@@ -0,0 +1,82 @@
+// 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/core/frames/quic_stream_frame.h"
+
+#include "base/logging.h"
+
+using base::StringPiece;
+using std::ostream;
+
+namespace net {
+
+void StreamBufferDeleter::operator()(char* buffer) const {
+ if (allocator_ != nullptr && buffer != nullptr) {
+ allocator_->Delete(buffer);
+ }
+}
+
+UniqueStreamBuffer NewStreamBuffer(QuicBufferAllocator* allocator,
+ size_t size) {
+ return UniqueStreamBuffer(allocator->New(size),
+ StreamBufferDeleter(allocator));
+}
+
+QuicStreamFrame::QuicStreamFrame()
+ : QuicStreamFrame(0, false, 0, nullptr, 0, nullptr) {}
+
+QuicStreamFrame::QuicStreamFrame(QuicStreamId stream_id,
+ bool fin,
+ QuicStreamOffset offset,
+ StringPiece data)
+ : QuicStreamFrame(stream_id,
+ fin,
+ offset,
+ data.data(),
+ data.length(),
+ nullptr) {}
+
+QuicStreamFrame::QuicStreamFrame(QuicStreamId stream_id,
+ bool fin,
+ QuicStreamOffset offset,
+ QuicPacketLength data_length,
+ UniqueStreamBuffer buffer)
+ : QuicStreamFrame(stream_id,
+ fin,
+ offset,
+ nullptr,
+ data_length,
+ std::move(buffer)) {
+ DCHECK(this->buffer != nullptr);
+ DCHECK_EQ(data_buffer, this->buffer.get());
+}
+
+QuicStreamFrame::QuicStreamFrame(QuicStreamId stream_id,
+ bool fin,
+ QuicStreamOffset offset,
+ const char* data_buffer,
+ QuicPacketLength data_length,
+ UniqueStreamBuffer buffer)
+ : stream_id(stream_id),
+ fin(fin),
+ data_length(data_length),
+ data_buffer(data_buffer),
+ offset(offset),
+ buffer(std::move(buffer)) {
+ if (this->buffer != nullptr) {
+ DCHECK(data_buffer == nullptr);
+ this->data_buffer = this->buffer.get();
+ }
+}
+
+QuicStreamFrame::~QuicStreamFrame() {}
+
+ostream& operator<<(ostream& os, const QuicStreamFrame& stream_frame) {
+ os << "{ stream_id: " << stream_frame.stream_id
+ << ", fin: " << stream_frame.fin << ", offset: " << stream_frame.offset
+ << ", length: " << stream_frame.data_length << " }\n";
+ return os;
+}
+
+} // namespace net
« no previous file with comments | « net/quic/core/frames/quic_stream_frame.h ('k') | net/quic/core/frames/quic_window_update_frame.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698