#ifndef PARTITION_ALLOC_PARTITION_ALLOC_BASE_NUMERICS_CLAMPED_MATH_IMPL_H_
#define PARTITION_ALLOC_PARTITION_ALLOC_BASE_NUMERICS_CLAMPED_MATH_IMPL_H_
#include <climits>
#include <cmath>
#include <cstddef>
#include <cstdint>
#include <cstdlib>
#include <limits>
#include <type_traits>
#include "partition_alloc/partition_alloc_base/numerics/checked_math.h"
#include "partition_alloc/partition_alloc_base/numerics/safe_conversions.h"
#include "partition_alloc/partition_alloc_base/numerics/safe_math_shared_impl.h"
namespace partition_alloc::internal::base::internal {
template <typename T,
typename std::enable_if<std::is_integral_v<T> &&
std::is_signed_v<T>>::type* = nullptr>
constexpr T SaturatedNegWrapper(T value) { … }
template <typename T,
typename std::enable_if<std::is_integral_v<T> &&
!std::is_signed_v<T>>::type* = nullptr>
constexpr T SaturatedNegWrapper(T value) { … }
template <typename T,
typename std::enable_if<std::is_floating_point_v<T>>::type* = nullptr>
constexpr T SaturatedNegWrapper(T value) { … }
template <typename T,
typename std::enable_if<std::is_integral_v<T>>::type* = nullptr>
constexpr T SaturatedAbsWrapper(T value) { … }
template <typename T,
typename std::enable_if<std::is_floating_point_v<T>>::type* = nullptr>
constexpr T SaturatedAbsWrapper(T value) { … }
template <typename T, typename U, class Enable = void>
struct ClampedAddOp { … };
ClampedAddOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedSubOp { … };
ClampedSubOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedMulOp { … };
ClampedMulOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedDivOp { … };
ClampedDivOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedModOp { … };
ClampedModOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedLshOp { … };
ClampedLshOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedRshOp { … };
ClampedRshOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedAndOp { … };
ClampedAndOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedOrOp { … };
ClampedOrOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedXorOp { … };
ClampedXorOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedMaxOp { … };
ClampedMaxOp<T, U, typename std::enable_if<std::is_arithmetic_v<T> && std::is_arithmetic_v<U>>::type>;
template <typename T, typename U, class Enable = void>
struct ClampedMinOp { … };
ClampedMinOp<T, U, typename std::enable_if<std::is_arithmetic_v<T> && std::is_arithmetic_v<U>>::type>;
#define PA_BASE_FLOAT_ARITHMETIC_OPS …
PA_BASE_FLOAT_ARITHMETIC_OPS
PA_BASE_FLOAT_ARITHMETIC_OPS
PA_BASE_FLOAT_ARITHMETIC_OPS
PA_BASE_FLOAT_ARITHMETIC_OPS
#undef PA_BASE_FLOAT_ARITHMETIC_OPS
}
#endif