ucrtbase: Add ilogb* functions.
Signed-off-by: Piotr Caban <piotr@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
a91c1e054a
commit
8c8d8e80f5
|
@ -18698,6 +18698,8 @@ for ac_func in \
|
||||||
exp2f \
|
exp2f \
|
||||||
expm1 \
|
expm1 \
|
||||||
expm1f \
|
expm1f \
|
||||||
|
ilogb \
|
||||||
|
ilogbf \
|
||||||
j0 \
|
j0 \
|
||||||
j1 \
|
j1 \
|
||||||
jn \
|
jn \
|
||||||
|
|
|
@ -2743,6 +2743,8 @@ AC_CHECK_FUNCS(\
|
||||||
exp2f \
|
exp2f \
|
||||||
expm1 \
|
expm1 \
|
||||||
expm1f \
|
expm1f \
|
||||||
|
ilogb \
|
||||||
|
ilogbf \
|
||||||
j0 \
|
j0 \
|
||||||
j1 \
|
j1 \
|
||||||
jn \
|
jn \
|
||||||
|
|
|
@ -254,9 +254,9 @@
|
||||||
@ cdecl -arch=arm,x86_64,arm64 fmodf(float float) ucrtbase.fmodf
|
@ cdecl -arch=arm,x86_64,arm64 fmodf(float float) ucrtbase.fmodf
|
||||||
@ cdecl frexp(double ptr) ucrtbase.frexp
|
@ cdecl frexp(double ptr) ucrtbase.frexp
|
||||||
@ cdecl hypot(double double) ucrtbase.hypot
|
@ cdecl hypot(double double) ucrtbase.hypot
|
||||||
@ stub ilogb
|
@ cdecl ilogb(double) ucrtbase.ilogb
|
||||||
@ stub ilogbf
|
@ cdecl ilogbf(float) ucrtbase.ilogbf
|
||||||
@ stub ilogbl
|
@ cdecl ilogbl(double) ucrtbase.ilogbl
|
||||||
@ cdecl ldexp(double long) ucrtbase.ldexp
|
@ cdecl ldexp(double long) ucrtbase.ldexp
|
||||||
@ cdecl lgamma(double) ucrtbase.lgamma
|
@ cdecl lgamma(double) ucrtbase.lgamma
|
||||||
@ cdecl lgammaf(float) ucrtbase.lgammaf
|
@ cdecl lgammaf(float) ucrtbase.lgammaf
|
||||||
|
|
|
@ -2207,9 +2207,9 @@
|
||||||
@ cdecl gets_s(ptr long) MSVCRT_gets_s
|
@ cdecl gets_s(ptr long) MSVCRT_gets_s
|
||||||
@ cdecl getwc(ptr) MSVCRT_getwc
|
@ cdecl getwc(ptr) MSVCRT_getwc
|
||||||
@ cdecl getwchar() MSVCRT_getwchar
|
@ cdecl getwchar() MSVCRT_getwchar
|
||||||
@ stub ilogb
|
@ cdecl ilogb(double) MSVCR120_ilogb
|
||||||
@ stub ilogbf
|
@ cdecl ilogbf(float) MSVCR120_ilogbf
|
||||||
@ stub ilogbl
|
@ cdecl ilogbl(double) MSVCR120_ilogbl
|
||||||
@ stub imaxabs
|
@ stub imaxabs
|
||||||
@ stub imaxdiv
|
@ stub imaxdiv
|
||||||
@ cdecl is_wctype(long long) ntdll.iswctype
|
@ cdecl is_wctype(long long) ntdll.iswctype
|
||||||
|
|
|
@ -1871,9 +1871,9 @@
|
||||||
@ cdecl gets_s(ptr long) msvcr120.gets_s
|
@ cdecl gets_s(ptr long) msvcr120.gets_s
|
||||||
@ cdecl getwc(ptr) msvcr120.getwc
|
@ cdecl getwc(ptr) msvcr120.getwc
|
||||||
@ cdecl getwchar() msvcr120.getwchar
|
@ cdecl getwchar() msvcr120.getwchar
|
||||||
@ stub ilogb
|
@ cdecl ilogb(double) msvcr120.ilogb
|
||||||
@ stub ilogbf
|
@ cdecl ilogbf(float) msvcr120.ilogbf
|
||||||
@ stub ilogbl
|
@ cdecl ilogbl(double) msvcr120.ilogbl
|
||||||
@ stub imaxabs
|
@ stub imaxabs
|
||||||
@ stub imaxdiv
|
@ stub imaxdiv
|
||||||
@ cdecl isalnum(long) msvcr120.isalnum
|
@ cdecl isalnum(long) msvcr120.isalnum
|
||||||
|
|
|
@ -3433,4 +3433,35 @@ double CDECL MSVCR120_creal(_Dcomplex z)
|
||||||
return z.x;
|
return z.x;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int CDECL MSVCR120_ilogb(double x)
|
||||||
|
{
|
||||||
|
if (!x) return MSVCRT_FP_ILOGB0;
|
||||||
|
if (isnan(x)) return MSVCRT_FP_ILOGBNAN;
|
||||||
|
if (isinf(x)) return MSVCRT_INT_MAX;
|
||||||
|
|
||||||
|
#ifdef HAVE_ILOGB
|
||||||
|
return ilogb(x);
|
||||||
|
#else
|
||||||
|
return logb(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int CDECL MSVCR120_ilogbf(float x)
|
||||||
|
{
|
||||||
|
if (!x) return MSVCRT_FP_ILOGB0;
|
||||||
|
if (isnan(x)) return MSVCRT_FP_ILOGBNAN;
|
||||||
|
if (isinf(x)) return MSVCRT_INT_MAX;
|
||||||
|
|
||||||
|
#ifdef HAVE_ILOGBF
|
||||||
|
return ilogbf(x);
|
||||||
|
#else
|
||||||
|
return logbf(x);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
int CDECL MSVCR120_ilogbl(LDOUBLE x)
|
||||||
|
{
|
||||||
|
return MSVCR120_ilogb(x);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* _MSVCR_VER>=120 */
|
#endif /* _MSVCR_VER>=120 */
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "windef.h"
|
#include "windef.h"
|
||||||
#include "winbase.h"
|
#include "winbase.h"
|
||||||
|
|
||||||
|
#define MSVCRT_INT_MAX 0x7fffffff
|
||||||
#define MSVCRT_LONG_MAX 0x7fffffff
|
#define MSVCRT_LONG_MAX 0x7fffffff
|
||||||
#define MSVCRT_LONG_MIN (-MSVCRT_LONG_MAX-1)
|
#define MSVCRT_LONG_MIN (-MSVCRT_LONG_MAX-1)
|
||||||
#define MSVCRT_ULONG_MAX 0xffffffff
|
#define MSVCRT_ULONG_MAX 0xffffffff
|
||||||
|
@ -1187,6 +1188,9 @@ printf_arg arg_clbk_positional(void*, int, int, __ms_va_list*) DECLSPEC_HIDDEN;
|
||||||
#define MSVCRT__OVERFLOW 3
|
#define MSVCRT__OVERFLOW 3
|
||||||
#define MSVCRT__UNDERFLOW 4
|
#define MSVCRT__UNDERFLOW 4
|
||||||
|
|
||||||
|
#define MSVCRT_FP_ILOGB0 (-MSVCRT_INT_MAX - 1)
|
||||||
|
#define MSVCRT_FP_ILOGBNAN MSVCRT_INT_MAX
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
float f;
|
float f;
|
||||||
|
|
|
@ -2341,9 +2341,9 @@
|
||||||
@ cdecl getwc(ptr) MSVCRT_getwc
|
@ cdecl getwc(ptr) MSVCRT_getwc
|
||||||
@ cdecl getwchar() MSVCRT_getwchar
|
@ cdecl getwchar() MSVCRT_getwchar
|
||||||
@ cdecl hypot(double double) _hypot
|
@ cdecl hypot(double double) _hypot
|
||||||
@ stub ilogb
|
@ cdecl ilogb(double) MSVCR120_ilogb
|
||||||
@ stub ilogbf
|
@ cdecl ilogbf(float) MSVCR120_ilogbf
|
||||||
@ stub ilogbl
|
@ cdecl ilogbl(double) MSVCR120_ilogbl
|
||||||
@ stub imaxabs
|
@ stub imaxabs
|
||||||
@ stub imaxdiv
|
@ stub imaxdiv
|
||||||
@ cdecl is_wctype(long long) ntdll.iswctype
|
@ cdecl is_wctype(long long) ntdll.iswctype
|
||||||
|
|
|
@ -303,6 +303,12 @@
|
||||||
/* Define to 1 if you have the `if_nameindex' function. */
|
/* Define to 1 if you have the `if_nameindex' function. */
|
||||||
#undef HAVE_IF_NAMEINDEX
|
#undef HAVE_IF_NAMEINDEX
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `ilogb' function. */
|
||||||
|
#undef HAVE_ILOGB
|
||||||
|
|
||||||
|
/* Define to 1 if you have the `ilogbf' function. */
|
||||||
|
#undef HAVE_ILOGBF
|
||||||
|
|
||||||
/* Define to 1 if you have the `inet_addr' function. */
|
/* Define to 1 if you have the `inet_addr' function. */
|
||||||
#undef HAVE_INET_ADDR
|
#undef HAVE_INET_ADDR
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue