mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-06-17 07:37:13 +02:00
Update POCO to 1.11.0
This commit is contained in:
@ -31,35 +31,71 @@ class FPEnvironmentImpl
|
||||
protected:
|
||||
enum RoundingModeImpl
|
||||
{
|
||||
#if defined(FE_DOWNWARD)
|
||||
FP_ROUND_DOWNWARD_IMPL = FE_DOWNWARD,
|
||||
#else
|
||||
FP_ROUND_DOWNWARD_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_UPWARD)
|
||||
FP_ROUND_UPWARD_IMPL = FE_UPWARD,
|
||||
#else
|
||||
FP_ROUND_UPWARD_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_TONEAREST)
|
||||
FP_ROUND_TONEAREST_IMPL = FE_TONEAREST,
|
||||
#else
|
||||
FP_ROUND_TONEAREST_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_TOWARDZERO)
|
||||
FP_ROUND_TOWARDZERO_IMPL = FE_TOWARDZERO
|
||||
#else
|
||||
FP_ROUND_TOWARDZERO_IMPL = 0
|
||||
#endif
|
||||
};
|
||||
enum FlagImpl
|
||||
{
|
||||
#if defined(FE_DIVBYZERO)
|
||||
FP_DIVIDE_BY_ZERO_IMPL = FE_DIVBYZERO,
|
||||
#else
|
||||
FP_DIVIDE_BY_ZERO_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_INEXACT)
|
||||
FP_INEXACT_IMPL = FE_INEXACT,
|
||||
#else
|
||||
FP_INEXACT_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_OVERFLOW)
|
||||
FP_OVERFLOW_IMPL = FE_OVERFLOW,
|
||||
#else
|
||||
FP_OVERFLOW_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_UNDERFLOW)
|
||||
FP_UNDERFLOW_IMPL = FE_UNDERFLOW,
|
||||
#else
|
||||
FP_UNDERFLOW_IMPL = 0,
|
||||
#endif
|
||||
#if defined(FE_INVALID)
|
||||
FP_INVALID_IMPL = FE_INVALID
|
||||
#else
|
||||
FP_INVALID_IMPL = 0
|
||||
#endif
|
||||
};
|
||||
FPEnvironmentImpl();
|
||||
FPEnvironmentImpl(const FPEnvironmentImpl& env);
|
||||
~FPEnvironmentImpl();
|
||||
FPEnvironmentImpl& operator = (const FPEnvironmentImpl& env);
|
||||
void keepCurrentImpl();
|
||||
void keepCurrentImpl();
|
||||
static void clearFlagsImpl();
|
||||
static bool isFlagImpl(FlagImpl flag);
|
||||
static bool isFlagImpl(FlagImpl flag);
|
||||
static void setRoundingModeImpl(RoundingModeImpl mode);
|
||||
static RoundingModeImpl getRoundingModeImpl();
|
||||
static bool isInfiniteImpl(float value);
|
||||
static bool isInfiniteImpl(float value);
|
||||
static bool isInfiniteImpl(double value);
|
||||
static bool isInfiniteImpl(long double value);
|
||||
static bool isNaNImpl(float value);
|
||||
static bool isNaNImpl(float value);
|
||||
static bool isNaNImpl(double value);
|
||||
static bool isNaNImpl(long double value);
|
||||
static float copySignImpl(float target, float source);
|
||||
static float copySignImpl(float target, float source);
|
||||
static double copySignImpl(double target, double source);
|
||||
static long double copySignImpl(long double target, long double source);
|
||||
|
||||
@ -73,37 +109,61 @@ private:
|
||||
//
|
||||
inline bool FPEnvironmentImpl::isInfiniteImpl(float value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isinf(value) != 0;
|
||||
#else
|
||||
return std::isinf(value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
inline bool FPEnvironmentImpl::isInfiniteImpl(double value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isinf(value) != 0;
|
||||
#else
|
||||
return std::isinf(value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
inline bool FPEnvironmentImpl::isInfiniteImpl(long double value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isinf((double) value) != 0;
|
||||
#else
|
||||
return std::isinf((double) value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
inline bool FPEnvironmentImpl::isNaNImpl(float value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isnan(value) != 0;
|
||||
#else
|
||||
return std::isnan(value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
inline bool FPEnvironmentImpl::isNaNImpl(double value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isnan(value) != 0;
|
||||
#else
|
||||
return std::isnan(value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
inline bool FPEnvironmentImpl::isNaNImpl(long double value)
|
||||
{
|
||||
#if POCO_OS == POCO_OS_AIX
|
||||
return ::isnan((double) value) != 0;
|
||||
#else
|
||||
return std::isnan((double) value) != 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user