2007-03-14 20:24:57 +00:00
|
|
|
/*
|
|
|
|
* COPYRIGHT: See COPYING in the top level directory
|
|
|
|
* PROJECT: ReactOS system libraries
|
2011-11-17 22:38:15 +00:00
|
|
|
* FILE: lib/sdk/crt/float/fpclass.c
|
|
|
|
* PURPOSE: Floating-point classes
|
2011-11-19 13:03:17 +00:00
|
|
|
* PROGRAMER: Pierre Schweitzer (pierre@reactos.org)
|
|
|
|
* REFERENCE: http://babbage.cs.qc.cuny.edu/IEEE-754/References.xhtml
|
2007-03-14 20:24:57 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <precomp.h>
|
2011-11-19 10:39:58 +00:00
|
|
|
#include <float.h>
|
2007-03-14 20:24:57 +00:00
|
|
|
#include <internal/ieee.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @implemented
|
|
|
|
*/
|
2011-11-19 10:39:58 +00:00
|
|
|
int _fpclass(double __d)
|
2007-03-14 20:24:57 +00:00
|
|
|
{
|
|
|
|
union
|
|
|
|
{
|
|
|
|
double* __d;
|
2010-03-26 23:41:53 +00:00
|
|
|
double_s* d;
|
2007-03-14 20:24:57 +00:00
|
|
|
} d;
|
|
|
|
d.__d = &__d;
|
|
|
|
|
2011-11-19 13:03:17 +00:00
|
|
|
|
|
|
|
/* With 0x7ff, it can only be infinity or NaN */
|
|
|
|
if (d.d->exponent == 0x7ff)
|
|
|
|
{
|
|
|
|
if (d.d->mantissah == 0 && d.d->mantissal == 0)
|
|
|
|
{
|
|
|
|
return (d.d->sign == 0) ? _FPCLASS_PINF : _FPCLASS_NINF;
|
|
|
|
}
|
|
|
|
/* Windows will never return Signaling NaN */
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return _FPCLASS_QNAN;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* With 0, it can only be zero or denormalized number */
|
|
|
|
if (d.d->exponent == 0)
|
|
|
|
{
|
|
|
|
if (d.d->mantissah == 0 && d.d->mantissal == 0)
|
|
|
|
{
|
|
|
|
return (d.d->sign == 0) ? _FPCLASS_PZ : _FPCLASS_NZ;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return (d.d->sign == 0) ? _FPCLASS_PD : _FPCLASS_ND;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* Only remain normalized numbers */
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return (d.d->sign == 0) ? _FPCLASS_PN : _FPCLASS_NN;
|
|
|
|
}
|
2007-03-14 20:24:57 +00:00
|
|
|
}
|