111 lines
2.6 KiB
C
111 lines
2.6 KiB
C
#ifndef EV_HEADERS_NUMERIC_H
|
|
#define EV_HEADERS_NUMERIC_H
|
|
|
|
#include "ev_internal.h"
|
|
#include "ev_types.h"
|
|
|
|
// Signed integers
|
|
EV_TYPEDEF(i8 , __ev_int8_t); TYPEDATA_GEN(i8);
|
|
#define i8_const(v) (i8){v}
|
|
EV_TYPEDEF(i16, __ev_int16_t); TYPEDATA_GEN(i16);
|
|
#define i16_const(v) (i16){v}
|
|
EV_TYPEDEF(i32, __ev_int32_t); TYPEDATA_GEN(i32);
|
|
#define i32_const(v) (i32){v}
|
|
EV_TYPEDEF(i64, __ev_int64_t); TYPEDATA_GEN(i64);
|
|
#define i64_const(v) (i64){v}
|
|
|
|
// Unsigned integers
|
|
EV_TYPEDEF(u8 , __ev_uint8_t); TYPEDATA_GEN(u8);
|
|
#define u8_const(v) (u8){v}
|
|
EV_TYPEDEF(u16, __ev_uint16_t); TYPEDATA_GEN(u16);
|
|
#define u16_const(v) (u16){v}
|
|
EV_TYPEDEF(u32, __ev_uint32_t); TYPEDATA_GEN(u32);
|
|
#define u32_const(v) (u32){v}
|
|
EV_TYPEDEF(u64, __ev_uint64_t); TYPEDATA_GEN(u64);
|
|
#define u64_const(v) (u64){v}
|
|
|
|
// Floating-Point Numbers
|
|
EV_TYPEDEF(f32, __ev_float32_t); TYPEDATA_GEN(f32);
|
|
#define f32_const(v) (f32){v}
|
|
EV_TYPEDEF(f64, __ev_float64_t); TYPEDATA_GEN(f64);
|
|
#define f64_const(v) (f64){v}
|
|
|
|
struct Int8Data { i8 MIN; i8 MAX; };
|
|
struct Int16Data { i16 MIN; i16 MAX; };
|
|
struct Int32Data { i32 MIN; i32 MAX; };
|
|
struct Int64Data { i64 MIN; i64 MAX; };
|
|
|
|
struct UInt8Data { u8 MIN; u8 MAX; };
|
|
struct UInt16Data { u16 MIN; u16 MAX; };
|
|
struct UInt32Data { u32 MIN; u32 MAX; };
|
|
struct UInt64Data { u64 MIN; u64 MAX; };
|
|
|
|
struct Float32Data { f32 MIN; f32 MAX; f32 MIN_POS; f32 EPS; };
|
|
struct Float64Data { f64 MIN; f64 MAX; f64 MIN_POS; f64 EPS; };
|
|
|
|
static const struct Int8Data Int8 =
|
|
{
|
|
.MIN = -128,
|
|
.MAX = 127
|
|
};
|
|
|
|
static const struct Int16Data Int16 =
|
|
{
|
|
.MIN = -32767-1,
|
|
.MAX = 32767
|
|
};
|
|
|
|
static const struct Int32Data Int32 =
|
|
{
|
|
.MIN = -2147483647-1,
|
|
.MAX = 2147483647
|
|
};
|
|
|
|
static const struct Int64Data Int64 =
|
|
{
|
|
.MIN = -(9223372036854775807LL)-1,
|
|
.MAX = 9223372036854775807LL
|
|
};
|
|
|
|
static const struct UInt8Data UInt8 =
|
|
{
|
|
.MIN = 0,
|
|
.MAX = 255
|
|
};
|
|
|
|
static const struct UInt16Data UInt16 =
|
|
{
|
|
.MIN = 0,
|
|
.MAX = 65535
|
|
};
|
|
|
|
static const struct UInt32Data UInt32 =
|
|
{
|
|
.MIN = 0,
|
|
.MAX = 4294967295U
|
|
};
|
|
|
|
static const struct UInt64Data UInt64 =
|
|
{
|
|
.MIN = 0,
|
|
.MAX = 18446744073709551615ULL
|
|
};
|
|
|
|
static const struct Float32Data Float32 =
|
|
{
|
|
.MIN_POS = 1.175494351e-38,
|
|
.MIN = -3.402823466e+38,
|
|
.MAX = 3.402823466e+38,
|
|
.EPS = 1.192093e-07
|
|
};
|
|
|
|
static const struct Float64Data Float64 =
|
|
{
|
|
.MIN_POS = 2.2250738585072014e-308,
|
|
.MIN = -1.7976931348623158e+308,
|
|
.MAX = 1.7976931348623158e+308,
|
|
.EPS = 2.2204460492503131e-016
|
|
};
|
|
|
|
#endif // EV_HEADERS_NUMERIC_H
|