v8
V8 is Google’s open source high-performance JavaScript and WebAssembly engine, written in C++.
Loading...
Searching...
No Matches
clamped_math_impl.h File Reference
#include <concepts>
#include <limits>
#include <type_traits>
#include "src/base/numerics/checked_math.h"
#include "src/base/numerics/safe_conversions.h"
#include "src/base/numerics/safe_math_shared_impl.h"
Include dependency graph for clamped_math_impl.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  v8::base::internal::ClampedAddOp< T, U >
 
struct  v8::base::internal::ClampedAddOp< T, U >
 
struct  v8::base::internal::ClampedSubOp< T, U >
 
struct  v8::base::internal::ClampedSubOp< T, U >
 
struct  v8::base::internal::ClampedMulOp< T, U >
 
struct  v8::base::internal::ClampedMulOp< T, U >
 
struct  v8::base::internal::ClampedDivOp< T, U >
 
struct  v8::base::internal::ClampedDivOp< T, U >
 
struct  v8::base::internal::ClampedModOp< T, U >
 
struct  v8::base::internal::ClampedModOp< T, U >
 
struct  v8::base::internal::ClampedLshOp< T, U >
 
struct  v8::base::internal::ClampedLshOp< T, U >
 
struct  v8::base::internal::ClampedRshOp< T, U >
 
struct  v8::base::internal::ClampedRshOp< T, U >
 
struct  v8::base::internal::ClampedAndOp< T, U >
 
struct  v8::base::internal::ClampedAndOp< T, U >
 
struct  v8::base::internal::ClampedOrOp< T, U >
 
struct  v8::base::internal::ClampedOrOp< T, U >
 
struct  v8::base::internal::ClampedXorOp< T, U >
 
struct  v8::base::internal::ClampedXorOp< T, U >
 
struct  v8::base::internal::ClampedMaxOp< T, U >
 
struct  v8::base::internal::ClampedMaxOp< T, U >
 
struct  v8::base::internal::ClampedMinOp< T, U >
 
struct  v8::base::internal::ClampedMinOp< T, U >
 

Namespaces

namespace  v8
 
namespace  v8::base
 
namespace  v8::base::internal
 

Macros

#define BASE_FLOAT_ARITHMETIC_OPS(NAME, OP)
 

Functions

template<typename T >
requires (std::signed_integral<T>)
constexpr T v8::base::internal::SaturatedNegWrapper (T value)
 
template<typename T >
requires (std::unsigned_integral<T>)
constexpr T v8::base::internal::SaturatedNegWrapper (T value)
 
template<typename T >
requires (std::floating_point<T>)
constexpr T v8::base::internal::SaturatedNegWrapper (T value)
 
template<typename T >
requires (std::integral<T>)
constexpr T v8::base::internal::SaturatedAbsWrapper (T value)
 
template<typename T >
requires (std::floating_point<T>)
constexpr T v8::base::internal::SaturatedAbsWrapper (T value)
 

Macro Definition Documentation

◆ BASE_FLOAT_ARITHMETIC_OPS

#define BASE_FLOAT_ARITHMETIC_OPS ( NAME,
OP )
Value:
template <typename T, typename U> \
requires(std::floating_point<T> || std::floating_point<U>) \
struct Clamped##NAME##Op<T, U> { \
using result_type = MaxExponentPromotion<T, U>; \
template <typename V = result_type> \
static constexpr V Do(T x, U y) { \
return saturated_cast<V>(x OP y); \
} \
};
#define V(Name)
int y
int x
#define OP(kType)
#define NAME(feat,...)

Definition at line 283 of file clamped_math_impl.h.