blob: bbf8ea0c00488237ae2d81d385c5b1d4dfbc7a6e [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 QUICHE_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_
#define QUICHE_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_
#include <memory>
#include <ostream>
#include "net/third_party/quiche/src/quic/core/quic_buffer_allocator.h"
#include "net/third_party/quiche/src/quic/core/quic_types.h"
#include "net/third_party/quiche/src/quic/platform/api/quic_export.h"
#include "net/third_party/quiche/src/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 // QUICHE_QUIC_CORE_FRAMES_QUIC_CRYPTO_FRAME_H_