1#include "packet_buffer.hpp"
2#include "basic_header.hpp"
11Expiry::Expiry(Clock::time_point now, Clock::duration lifetime) :
12 m_buffered_since(now), m_expires_at(now)
14 m_expires_at += lifetime;
17bool Expiry::is_expired(Clock::time_point now)
const
19 return (m_expires_at < now);
25PacketBuffer::PacketBuffer(std::size_t capacity) :
26 m_capacity(capacity), m_stored(0)
35 if (
drop(data->length())) {
36 m_stored += data->length();
37 m_nodes.push_back(std::make_tuple(
38 expiry_type(now, data->reduce_lifetime(Clock::duration::zero())),
48 decltype(m_nodes) nodes;
49 std::swap(m_nodes, nodes);
52 for (
auto& node : nodes) {
53 const auto& expiry = std::get<0>(node);
54 if (!expiry.is_expired(now)) {
55 auto& data = std::get<1>(node);
56 const auto queuing_time = now - expiry.buffered_since();
57 data->reduce_lifetime(queuing_time);
65 bool dropped = !m_nodes.empty();
67 m_stored -= std::get<1>(m_nodes.front())->length();
75 std::list<
decltype(m_nodes)::iterator> expired;
76 for (
auto it = m_nodes.begin(), end = m_nodes.end(); it != end;) {
77 if (std::get<0>(*it).is_expired(now)) {
78 m_stored -= std::get<1>(*it)->length();
79 it = m_nodes.erase(it);
89 return free() >= bytes;
bool drop(std::size_t bytes)
void flush(Clock::time_point t)
void drop_expired(Clock::time_point t)
bool push(data_ptr packet, Clock::time_point t)