1#ifndef HEADER_VARIANT_HPP
2#define HEADER_VARIANT_HPP
4#include <vanetza/geonet/serialization.hpp>
5#include <vanetza/geonet/beacon_header.hpp>
6#include <vanetza/geonet/gbc_header.hpp>
7#include <vanetza/geonet/shb_header.hpp>
8#include <vanetza/geonet/tsb_header.hpp>
9#include <boost/variant/variant.hpp>
21
22
23
24
25
26std::size_t get_length(
const HeaderVariant& header);
27std::size_t get_length(
const HeaderRefVariant& header);
28std::size_t get_length(
const HeaderConstRefVariant& header);
37
38
39
40
41
42void serialize(
const vanetza::geonet::HeaderVariant& header, vanetza::
OutputArchive& ar);
43void serialize(
const vanetza::geonet::HeaderRefVariant& header, vanetza::
OutputArchive& ar);
44void serialize(
const vanetza::geonet::HeaderConstRefVariant& header, vanetza::
OutputArchive& ar);
ChunckPacket is a packet consisting of several memory chunks.
std::size_t size(OsiLayer from, OsiLayer to) const
virtual void cancel(const void *scope)=0
virtual Clock::time_point now() const =0
std::size_t counter(const Identifier &packet) const
boost::optional< CbfPacket > fetch(const Identifier &id)
void remove_timer(typename timer_bimap::left_map::iterator)
bool remove(const Identifier &id)
CbfPacketBuffer(Runtime &rt, TimerCallback cb, std::unique_ptr< CbfCounter > cnt, std::size_t bytes)
void update(const Identifier &id, Clock::duration timeout)
void add(CbfPacket &&packet, Clock::duration timeout)
const CbfPacket * find(const Identifier &id) const
bool reduce_lifetime(const Timer &, CbfPacket &) const
std::size_t length() const
Clock::duration reduce_lifetime(Clock::duration d)
const MacAddress & sender() const
SequenceNumber sequence_number() const
const Address & source() const