44 lines
1.3 KiB
C++
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
|