msvcrt: Implement lrint using rint function.
Signed-off-by: Piotr Caban <piotr@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
ad2ecc6e06
commit
0838c995ea
|
@ -19642,7 +19642,6 @@ for ac_func in \
|
||||||
log1pf \
|
log1pf \
|
||||||
log2 \
|
log2 \
|
||||||
log2f \
|
log2f \
|
||||||
lrint \
|
|
||||||
lrintf \
|
lrintf \
|
||||||
nearbyint \
|
nearbyint \
|
||||||
nearbyintf \
|
nearbyintf \
|
||||||
|
|
|
@ -2682,7 +2682,6 @@ AC_CHECK_FUNCS(\
|
||||||
log1pf \
|
log1pf \
|
||||||
log2 \
|
log2 \
|
||||||
log2f \
|
log2f \
|
||||||
lrint \
|
|
||||||
lrintf \
|
lrintf \
|
||||||
nearbyint \
|
nearbyint \
|
||||||
nearbyintf \
|
nearbyintf \
|
||||||
|
|
|
@ -4340,7 +4340,15 @@ float CDECL rintf(float x)
|
||||||
*/
|
*/
|
||||||
__msvcrt_long CDECL lrint(double x)
|
__msvcrt_long CDECL lrint(double x)
|
||||||
{
|
{
|
||||||
return unix_funcs->lrint( x );
|
double d;
|
||||||
|
|
||||||
|
d = rint(x);
|
||||||
|
if ((d < 0 && d != (double)(__msvcrt_long)d)
|
||||||
|
|| (d >= 0 && d != (double)(__msvcrt_ulong)d)) {
|
||||||
|
*_errno() = EDOM;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************
|
/*********************************************************************
|
||||||
|
|
|
@ -555,18 +555,6 @@ static float CDECL unix_logbf( float x )
|
||||||
return logbf( x );
|
return logbf( x );
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************
|
|
||||||
* lrint
|
|
||||||
*/
|
|
||||||
static int CDECL unix_lrint(double x)
|
|
||||||
{
|
|
||||||
#ifdef HAVE_LRINT
|
|
||||||
return lrint(x);
|
|
||||||
#else
|
|
||||||
return x >= 0 ? floor(x + 0.5) : ceil(x - 0.5);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************************************************************
|
/*********************************************************************
|
||||||
* lrintf
|
* lrintf
|
||||||
*/
|
*/
|
||||||
|
@ -894,7 +882,6 @@ static const struct unix_funcs funcs =
|
||||||
unix_log2f,
|
unix_log2f,
|
||||||
unix_logb,
|
unix_logb,
|
||||||
unix_logbf,
|
unix_logbf,
|
||||||
unix_lrint,
|
|
||||||
unix_lrintf,
|
unix_lrintf,
|
||||||
unix_modf,
|
unix_modf,
|
||||||
unix_modff,
|
unix_modff,
|
||||||
|
|
|
@ -72,7 +72,6 @@ struct unix_funcs
|
||||||
float (CDECL *log2f)(float x);
|
float (CDECL *log2f)(float x);
|
||||||
double (CDECL *logb)(double x);
|
double (CDECL *logb)(double x);
|
||||||
float (CDECL *logbf)(float x);
|
float (CDECL *logbf)(float x);
|
||||||
int (CDECL *lrint)(double x);
|
|
||||||
int (CDECL *lrintf)(float x);
|
int (CDECL *lrintf)(float x);
|
||||||
double (CDECL *modf)(double x, double *iptr);
|
double (CDECL *modf)(double x, double *iptr);
|
||||||
float (CDECL *modff)(float x, float *iptr);
|
float (CDECL *modff)(float x, float *iptr);
|
||||||
|
|
|
@ -471,9 +471,6 @@
|
||||||
/* Define to 1 if you have the `log2f' function. */
|
/* Define to 1 if you have the `log2f' function. */
|
||||||
#undef HAVE_LOG2F
|
#undef HAVE_LOG2F
|
||||||
|
|
||||||
/* Define to 1 if you have the `lrint' function. */
|
|
||||||
#undef HAVE_LRINT
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `lrintf' function. */
|
/* Define to 1 if you have the `lrintf' function. */
|
||||||
#undef HAVE_LRINTF
|
#undef HAVE_LRINTF
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue