2022-12-06 14:40:18 +00:00
|
|
|
#pragma once
|
|
|
|
#include <luna/Result.h>
|
|
|
|
|
|
|
|
template <typename T> Result<T> safe_add(T a, T b)
|
|
|
|
{
|
2022-12-06 14:47:59 +00:00
|
|
|
T result;
|
2022-12-06 14:40:18 +00:00
|
|
|
|
2022-12-06 14:47:59 +00:00
|
|
|
if (__builtin_add_overflow(a, b, &result)) return err(EOVERFLOW);
|
|
|
|
|
|
|
|
return result;
|
2022-12-06 14:40:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> Result<T> safe_sub(T a, T b)
|
|
|
|
{
|
2022-12-06 14:47:59 +00:00
|
|
|
T result;
|
|
|
|
|
|
|
|
if (__builtin_sub_overflow(a, b, &result)) return err(EOVERFLOW);
|
2022-12-06 14:40:18 +00:00
|
|
|
|
2022-12-06 14:47:59 +00:00
|
|
|
return result;
|
2022-12-06 14:40:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> Result<T> safe_mul(T a, T b)
|
|
|
|
{
|
2022-12-06 14:47:59 +00:00
|
|
|
T result;
|
|
|
|
|
|
|
|
if (__builtin_mul_overflow(a, b, &result)) return err(EOVERFLOW);
|
2022-12-06 14:40:18 +00:00
|
|
|
|
2022-12-06 14:47:59 +00:00
|
|
|
return result;
|
2022-12-06 14:53:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> bool add_will_overflow(T a, T b)
|
|
|
|
{
|
|
|
|
#ifdef __GNUC__
|
|
|
|
return __builtin_add_overflow_p(a, b, (T)0);
|
|
|
|
#else
|
|
|
|
return safe_add(a, b).has_error();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> bool sub_will_overflow(T a, T b)
|
|
|
|
{
|
|
|
|
#ifdef __GNUC__
|
|
|
|
return __builtin_sub_overflow_p(a, b, (T)0);
|
|
|
|
#else
|
|
|
|
return safe_sub(a, b).has_error();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T> bool mul_will_overflow(T a, T b)
|
|
|
|
{
|
|
|
|
#ifdef __GNUC__
|
|
|
|
return __builtin_mul_overflow_p(a, b, (T)0);
|
|
|
|
#else
|
|
|
|
return safe_mul(a, b).has_error();
|
|
|
|
#endif
|
2023-01-02 12:07:29 +00:00
|
|
|
}
|