#if RTC_ENABLE_MEDIA
#include "rtppacketizationconfig.hpp"
namespace rtc {
RtpPacketizationConfig::RtpPacketizationConfig(SSRC ssrc, string cname, uint8_t payloadType,
uint32_t clockRate,
std::optional<uint16_t> sequenceNumber,
std::optional<uint32_t> timestamp)
: ssrc(ssrc), cname(cname), payloadType(payloadType), clockRate(clockRate) {
assert(clockRate > 0);
srand((unsigned)time(NULL));
if (sequenceNumber.has_value()) {
this->sequenceNumber = sequenceNumber.value();
} else {
this->sequenceNumber = rand();
}
if (timestamp.has_value()) {
this->timestamp = timestamp.value();
} else {
this->timestamp = rand();
}
this->_startTimestamp = this->timestamp;
}
void RtpPacketizationConfig::setStartTime(double startTime_s, EpochStart epochStart,
std::optional<uint32_t> startTimestamp) {
this->_startTime_s = startTime_s + static_cast<unsigned long long>(epochStart);
if (startTimestamp.has_value()) {
this->_startTimestamp = startTimestamp.value();
timestamp = this->startTimestamp;
} else {
this->_startTimestamp = timestamp;
}
}
double RtpPacketizationConfig::getSecondsFromTimestamp(uint32_t timestamp, uint32_t clockRate) {
return double(timestamp) / double(clockRate);
}
double RtpPacketizationConfig::timestampToSeconds(uint32_t timestamp) {
return RtpPacketizationConfig::getSecondsFromTimestamp(timestamp, clockRate);
}
uint32_t RtpPacketizationConfig::getTimestampFromSeconds(double seconds, uint32_t clockRate) {
return uint32_t(seconds * clockRate);
}
uint32_t RtpPacketizationConfig::secondsToTimestamp(double seconds) {
return RtpPacketizationConfig::getTimestampFromSeconds(seconds, clockRate);
}
}
#endif