mirror of
https://github.com/pocoproject/poco.git
synced 2025-01-09 11:17:31 +01:00
Merge pull request #1646 from andred/nofpu-fix
fp: support environments without hardware floating point
This commit is contained in:
commit
63b6be6481
@ -33,18 +33,54 @@ class FPEnvironmentImpl
|
|||||||
protected:
|
protected:
|
||||||
enum RoundingModeImpl
|
enum RoundingModeImpl
|
||||||
{
|
{
|
||||||
|
#if defined(FE_DOWNWARD)
|
||||||
FP_ROUND_DOWNWARD_IMPL = 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,
|
FP_ROUND_UPWARD_IMPL = FE_UPWARD,
|
||||||
|
#else
|
||||||
|
FP_ROUND_UPWARD_IMPL = 0,
|
||||||
|
#endif
|
||||||
|
#if defined(FE_TONEAREST)
|
||||||
FP_ROUND_TONEAREST_IMPL = 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
|
FP_ROUND_TOWARDZERO_IMPL = FE_TOWARDZERO
|
||||||
|
#else
|
||||||
|
FP_ROUND_TOWARDZERO_IMPL = 0
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
enum FlagImpl
|
enum FlagImpl
|
||||||
{
|
{
|
||||||
|
#if defined(FE_DIVBYZERO)
|
||||||
FP_DIVIDE_BY_ZERO_IMPL = 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,
|
FP_INEXACT_IMPL = FE_INEXACT,
|
||||||
|
#else
|
||||||
|
FP_INEXACT_IMPL = 0,
|
||||||
|
#endif
|
||||||
|
#if defined(FE_OVERFLOW)
|
||||||
FP_OVERFLOW_IMPL = FE_OVERFLOW,
|
FP_OVERFLOW_IMPL = FE_OVERFLOW,
|
||||||
|
#else
|
||||||
|
FP_OVERFLOW_IMPL = 0,
|
||||||
|
#endif
|
||||||
|
#if defined(FE_UNDERFLOW)
|
||||||
FP_UNDERFLOW_IMPL = FE_UNDERFLOW,
|
FP_UNDERFLOW_IMPL = FE_UNDERFLOW,
|
||||||
|
#else
|
||||||
|
FP_UNDERFLOW_IMPL = 0,
|
||||||
|
#endif
|
||||||
|
#if defined(FE_INVALID)
|
||||||
FP_INVALID_IMPL = FE_INVALID
|
FP_INVALID_IMPL = FE_INVALID
|
||||||
|
#else
|
||||||
|
FP_INVALID_IMPL = 0
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
FPEnvironmentImpl();
|
FPEnvironmentImpl();
|
||||||
FPEnvironmentImpl(const FPEnvironmentImpl& env);
|
FPEnvironmentImpl(const FPEnvironmentImpl& env);
|
||||||
|
Loading…
Reference in New Issue
Block a user