Commit 8c8d8e80 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

ucrtbase: Add ilogb* functions.

parent a91c1e05
...@@ -18698,6 +18698,8 @@ for ac_func in \ ...@@ -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(\ ...@@ -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 @@ ...@@ -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 @@ ...@@ -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 @@ ...@@ -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) ...@@ -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 @@ ...@@ -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; ...@@ -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 @@ ...@@ -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 @@ ...@@ -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
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment