rtspTransmit/includes/rtcp/rtc/reliability.hpp
2024-03-21 16:36:26 +08:00

44 lines
1.3 KiB
C++

/**
* Copyright (c) 2019 Paul-Louis Ageneau
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
*/
#ifndef RTC_RELIABILITY_H
#define RTC_RELIABILITY_H
#include "common.hpp"
#include <chrono>
namespace rtc {
struct Reliability {
// It true, the channel does not enforce message ordering and out-of-order delivery is allowed
bool unordered = false;
// If both maxPacketLifeTime or maxRetransmits are unset, the channel is reliable.
// If either maxPacketLifeTime or maxRetransmits is set, the channel is unreliable.
// (The settings are exclusive so both maxPacketLifetime and maxRetransmits must not be set.)
// Time window during which transmissions and retransmissions may occur
optional<std::chrono::milliseconds> maxPacketLifeTime;
// Maximum number of retransmissions that are attempted
optional<unsigned int> maxRetransmits;
// For backward compatibility, do not use
enum class Type { Reliable = 0, Rexmit, Timed };
union {
Type typeDeprecated = Type::Reliable;
[[deprecated("Use maxPacketLifeTime or maxRetransmits")]] Type type;
};
variant<int, std::chrono::milliseconds> rexmit = 0;
};
} // namespace rtc
#endif