blob: fed0d3a6ecf4d3c7e51e17b69e7c6fc84dbb1f4c [file] [log] [blame]
// Copyright (c) 2018 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.
#ifndef NET_THIRD_PARTY_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_
#define NET_THIRD_PARTY_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_
#include <memory>
#include <ostream>
#include "net/third_party/quic/core/quic_buffer_allocator.h"
#include "net/third_party/quic/core/quic_types.h"
#include "net/third_party/quic/platform/api/quic_export.h"
#include "net/third_party/quic/platform/api/quic_string_piece.h"
namespace quic {
struct QUIC_EXPORT_PRIVATE QuicCryptoFrame {
QuicCryptoFrame();
QuicCryptoFrame(QuicStreamOffset offset, QuicStringPiece data);
~QuicCryptoFrame();
friend QUIC_EXPORT_PRIVATE std::ostream& operator<<(std::ostream& os,
const QuicCryptoFrame& s);
QuicPacketLength data_length;
// When reading, |data_buffer| points to the data that was received in the
// frame. When writing, |data_buffer| must be a valid pointer for the lifetime
// of the frame, which may get serialized some time after creation.
const char* data_buffer;
QuicStreamOffset offset; // Location of this data in the stream.
QuicCryptoFrame(QuicStreamOffset offset,
const char* data_buffer,
QuicPacketLength data_length);
};
static_assert(sizeof(QuicCryptoFrame) <= 64,
"Keep the QuicCryptoFrame size to a cacheline.");
} // namespace quic
#endif // NET_THIRD_PARTY_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_