#ifndef PARTITION_ALLOC_PARTITION_ALLOC_BASE_NUMERICS_CHECKED_MATH_IMPL_H_
#define PARTITION_ALLOC_PARTITION_ALLOC_BASE_NUMERICS_CHECKED_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/safe_conversions.h"
#include "partition_alloc/partition_alloc_base/numerics/safe_math_shared_impl.h"
namespace partition_alloc::internal::base::internal {
template <typename T>
constexpr bool CheckedAddImpl(T x, T y, T* result) { … }
template <typename T, typename U, class Enable = void>
struct CheckedAddOp { … };
CheckedAddOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T>
constexpr bool CheckedSubImpl(T x, T y, T* result) { … }
template <typename T, typename U, class Enable = void>
struct CheckedSubOp { … };
CheckedSubOp<T, U, typename std::enable_if<std::is_integral_v<T> && std::is_integral_v<U>>::type>;
template <typename T>
constexpr bool CheckedMulImpl(T x, T y, T* result) { … }
template <typename T, typename U, class Enable = void>
struct CheckedMulOp { … };
CheckedMulOp<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 CheckedDivOp { … };
CheckedDivOp<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 CheckedModOp { … };
CheckedModOp<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 CheckedLshOp { … };
CheckedLshOp<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 CheckedRshOp { … };
CheckedRshOp<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 CheckedAndOp { … };
CheckedAndOp<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 CheckedOrOp { … };
CheckedOrOp<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 CheckedXorOp { … };
CheckedXorOp<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 CheckedMaxOp { … };
CheckedMaxOp<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 CheckedMinOp { … };
CheckedMinOp<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
enum NumericRepresentation { … };
template <typename NumericType>
struct GetNumericRepresentation { … };
template <typename T,
NumericRepresentation type = GetNumericRepresentation<T>::value>
class CheckedNumericState { … };
CheckedNumericState<T, NUMERIC_INTEGER>;
CheckedNumericState<T, NUMERIC_FLOATING>;
}
#endif