| Index: webrtc/modules/video_coding/sequence_number_util.h
|
| diff --git a/webrtc/modules/video_coding/sequence_number_util.h b/webrtc/modules/video_coding/sequence_number_util.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..828e68a76842bfcf02b7f0fa1b2a2850ac1b6982
|
| --- /dev/null
|
| +++ b/webrtc/modules/video_coding/sequence_number_util.h
|
| @@ -0,0 +1,110 @@
|
| +/*
|
| + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license
|
| + * that can be found in the LICENSE file in the root of the source
|
| + * tree. An additional intellectual property rights grant can be found
|
| + * in the file PATENTS. All contributing project authors may
|
| + * be found in the AUTHORS file in the root of the source tree.
|
| + */
|
| +
|
| +#ifndef WEBRTC_MODULES_VIDEO_CODING_SEQUENCE_NUMBER_UTIL_H_
|
| +#define WEBRTC_MODULES_VIDEO_CODING_SEQUENCE_NUMBER_UTIL_H_
|
| +
|
| +#include <limits>
|
| +#include <type_traits>
|
| +
|
| +#include "webrtc/base/mod_ops.h"
|
| +
|
| +namespace webrtc {
|
| +
|
| +// Test if the sequence number |a| is ahead or at sequence number |b|.
|
| +//
|
| +// If |M| is an even number and the two sequence numbers are at max distance
|
| +// from each other, then the sequence number with the highest value is
|
| +// considered to be ahead.
|
| +template <typename T, T M>
|
| +inline bool AheadOrAt(T a, T b) {
|
| + static_assert(std::is_unsigned<T>::value,
|
| + "Type must be an unsigned integer.");
|
| + const T maxDist = M / 2;
|
| + if (!(M & 1) && MinDiff<T, M>(a, b) == maxDist)
|
| + return b < a;
|
| + return ForwardDiff<T, M>(b, a) <= maxDist;
|
| +}
|
| +
|
| +template <typename T>
|
| +inline bool AheadOrAt(T a, T b) {
|
| + static_assert(std::is_unsigned<T>::value,
|
| + "Type must be an unsigned integer.");
|
| + const T maxDist = std::numeric_limits<T>::max() / 2 + T(1);
|
| + if (a - b == maxDist)
|
| + return b < a;
|
| + return ForwardDiff(b, a) < maxDist;
|
| +}
|
| +
|
| +// Test if the sequence number |a| is ahead of sequence number |b|.
|
| +//
|
| +// If |M| is an even number and the two sequence numbers are at max distance
|
| +// from each other, then the sequence number with the highest value is
|
| +// considered to be ahead.
|
| +template <typename T, T M>
|
| +inline bool AheadOf(T a, T b) {
|
| + static_assert(std::is_unsigned<T>::value,
|
| + "Type must be an unsigned integer.");
|
| + return a != b && AheadOrAt<T, M>(a, b);
|
| +}
|
| +
|
| +template <typename T>
|
| +inline bool AheadOf(T a, T b) {
|
| + static_assert(std::is_unsigned<T>::value,
|
| + "Type must be an unsigned integer.");
|
| + return a != b && AheadOrAt(a, b);
|
| +}
|
| +
|
| +namespace internal {
|
| +
|
| +template <typename T, typename M>
|
| +struct SeqNumComp;
|
| +
|
| +template <typename T, T M>
|
| +struct SeqNumComp<T, std::integral_constant<T, M>> {
|
| + bool operator()(T a, T b) const { return AheadOf<T, M>(a, b); }
|
| +};
|
| +
|
| +template <typename T>
|
| +struct SeqNumComp<T, std::integral_constant<T, T(0)>> {
|
| + bool operator()(T a, T b) const { return AheadOf<T>(a, b); }
|
| +};
|
| +
|
| +} // namespace internal
|
| +
|
| +// Comparator used to compare sequence numbers in a continuous fashion.
|
| +//
|
| +// WARNING! If used to sort sequence numbers of length M then the interval
|
| +// covered by the sequence numbers may not be larger than floor(M/2).
|
| +template <typename T, T M = 0>
|
| +struct AscendingSeqNumComp
|
| + : private internal::SeqNumComp<T, std::integral_constant<T, M>> {
|
| + bool operator()(T a, T b) const {
|
| + return internal::SeqNumComp<T, std::integral_constant<T, M>>::operator()(a,
|
| + b);
|
| + }
|
| +};
|
| +
|
| +// Comparator used to compare sequence numbers in a continuous fashion.
|
| +//
|
| +// WARNING! If used to sort sequence numbers of length M then the interval
|
| +// covered by the sequence numbers may not be larger than floor(M/2).
|
| +template <typename T, T M = 0>
|
| +struct DescendingSeqNumComp
|
| + : private internal::SeqNumComp<T, std::integral_constant<T, M>> {
|
| + bool operator()(T a, T b) const {
|
| + return internal::SeqNumComp<T, std::integral_constant<T, M>>::operator()(b,
|
| + a);
|
| + }
|
| +};
|
| +
|
| +} // namespace webrtc
|
| +
|
| +#endif // WEBRTC_MODULES_VIDEO_CODING_SEQUENCE_NUMBER_UTIL_H_
|
|
|