mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 08:16:24 +01:00
glib: update internal gnulib from upstream
https://bugzilla.gnome.org/show_bug.cgi?id=795569 Related to issue #1371.
This commit is contained in:
parent
df62731771
commit
8f27aa9965
@ -39,6 +39,43 @@ C99 return value semantics.
|
|||||||
Matthias Clasen
|
Matthias Clasen
|
||||||
November 1, 2003
|
November 1, 2003
|
||||||
|
|
||||||
|
To update:
|
||||||
|
* Create an empty directory, put a configure.ac file into it.
|
||||||
|
* Run gnulib-tool --lgpl=2 --import --lib=libgnu --source-base=lib \
|
||||||
|
--m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=. \
|
||||||
|
--no-conditional-dependencies --no-libtool --macro-prefix=gl \
|
||||||
|
isnand-nolibm isnanl-nolibm printf-frexpl vasnprintf
|
||||||
|
* Then pick out the files that are already in glib/gnulib subdirectory
|
||||||
|
(the rest of the files are not needed):
|
||||||
|
|
||||||
|
asnprintf.c
|
||||||
|
c++defs.h
|
||||||
|
float+.h
|
||||||
|
fpucw.h
|
||||||
|
gnulib_math.h.in (rename from math.in.h)
|
||||||
|
isnan.c
|
||||||
|
isnand.c
|
||||||
|
isnand-nolibm.h
|
||||||
|
isnanl.c
|
||||||
|
isnanl-nolibm.h
|
||||||
|
printf-args.c
|
||||||
|
printf-args.h
|
||||||
|
printf-frexp.c
|
||||||
|
printf-frexp.h
|
||||||
|
printf-frexpl.c
|
||||||
|
printf-frexpl.h
|
||||||
|
printf-parse.c
|
||||||
|
printf-parse.h
|
||||||
|
vasnprintf.c
|
||||||
|
vasnprintf.h
|
||||||
|
verify.h
|
||||||
|
xsize.h
|
||||||
|
|
||||||
|
* Then look at the glib-gnulib.patch and re-introduce custom glib changes
|
||||||
|
contained in that patch.
|
||||||
|
* If gnulib_math.h.in got some new @variables@, these will have to be
|
||||||
|
somehow set in meson.build, otherwise meson would warn about them
|
||||||
|
at configure stage
|
||||||
|
|
||||||
|
LRN
|
||||||
|
June 06, 2018
|
||||||
|
26
glib/gnulib/arg-nonnull.h
Normal file
26
glib/gnulib/arg-nonnull.h
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
/* A C macro for declaring that specific arguments must not be NULL.
|
||||||
|
Copyright (C) 2009-2018 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU Lesser General Public License as published
|
||||||
|
by the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* _GL_ARG_NONNULL((n,...,m)) tells the compiler and static analyzer tools
|
||||||
|
that the values passed as arguments n, ..., m must be non-NULL pointers.
|
||||||
|
n = 1 stands for the first argument, n = 2 for the second argument etc. */
|
||||||
|
#ifndef _GL_ARG_NONNULL
|
||||||
|
# if (__GNUC__ == 3 && __GNUC_MINOR__ >= 3) || __GNUC__ > 3
|
||||||
|
# define _GL_ARG_NONNULL(params) __attribute__ ((__nonnull__ params))
|
||||||
|
# else
|
||||||
|
# define _GL_ARG_NONNULL(params)
|
||||||
|
# endif
|
||||||
|
#endif
|
@ -1,5 +1,5 @@
|
|||||||
/* Formatted output to strings.
|
/* Formatted output to strings.
|
||||||
Copyright (C) 1999, 2002, 2006, 2009-2016 Free Software Foundation, Inc.
|
Copyright (C) 1999, 2002, 2006, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -12,7 +12,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
|
316
glib/gnulib/c++defs.h
Normal file
316
glib/gnulib/c++defs.h
Normal file
@ -0,0 +1,316 @@
|
|||||||
|
/* C++ compatible function declaration macros.
|
||||||
|
Copyright (C) 2010-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU Lesser General Public License as published
|
||||||
|
by the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef _GL_CXXDEFS_H
|
||||||
|
#define _GL_CXXDEFS_H
|
||||||
|
|
||||||
|
/* Begin/end the GNULIB_NAMESPACE namespace. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_BEGIN_NAMESPACE namespace GNULIB_NAMESPACE {
|
||||||
|
# define _GL_END_NAMESPACE }
|
||||||
|
#else
|
||||||
|
# define _GL_BEGIN_NAMESPACE
|
||||||
|
# define _GL_END_NAMESPACE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The three most frequent use cases of these macros are:
|
||||||
|
|
||||||
|
* For providing a substitute for a function that is missing on some
|
||||||
|
platforms, but is declared and works fine on the platforms on which
|
||||||
|
it exists:
|
||||||
|
|
||||||
|
#if @GNULIB_FOO@
|
||||||
|
# if !@HAVE_FOO@
|
||||||
|
_GL_FUNCDECL_SYS (foo, ...);
|
||||||
|
# endif
|
||||||
|
_GL_CXXALIAS_SYS (foo, ...);
|
||||||
|
_GL_CXXALIASWARN (foo);
|
||||||
|
#elif defined GNULIB_POSIXCHECK
|
||||||
|
...
|
||||||
|
#endif
|
||||||
|
|
||||||
|
* For providing a replacement for a function that exists on all platforms,
|
||||||
|
but is broken/insufficient and needs to be replaced on some platforms:
|
||||||
|
|
||||||
|
#if @GNULIB_FOO@
|
||||||
|
# if @REPLACE_FOO@
|
||||||
|
# if !(defined __cplusplus && defined GNULIB_NAMESPACE)
|
||||||
|
# undef foo
|
||||||
|
# define foo rpl_foo
|
||||||
|
# endif
|
||||||
|
_GL_FUNCDECL_RPL (foo, ...);
|
||||||
|
_GL_CXXALIAS_RPL (foo, ...);
|
||||||
|
# else
|
||||||
|
_GL_CXXALIAS_SYS (foo, ...);
|
||||||
|
# endif
|
||||||
|
_GL_CXXALIASWARN (foo);
|
||||||
|
#elif defined GNULIB_POSIXCHECK
|
||||||
|
...
|
||||||
|
#endif
|
||||||
|
|
||||||
|
* For providing a replacement for a function that exists on some platforms
|
||||||
|
but is broken/insufficient and needs to be replaced on some of them and
|
||||||
|
is additionally either missing or undeclared on some other platforms:
|
||||||
|
|
||||||
|
#if @GNULIB_FOO@
|
||||||
|
# if @REPLACE_FOO@
|
||||||
|
# if !(defined __cplusplus && defined GNULIB_NAMESPACE)
|
||||||
|
# undef foo
|
||||||
|
# define foo rpl_foo
|
||||||
|
# endif
|
||||||
|
_GL_FUNCDECL_RPL (foo, ...);
|
||||||
|
_GL_CXXALIAS_RPL (foo, ...);
|
||||||
|
# else
|
||||||
|
# if !@HAVE_FOO@ or if !@HAVE_DECL_FOO@
|
||||||
|
_GL_FUNCDECL_SYS (foo, ...);
|
||||||
|
# endif
|
||||||
|
_GL_CXXALIAS_SYS (foo, ...);
|
||||||
|
# endif
|
||||||
|
_GL_CXXALIASWARN (foo);
|
||||||
|
#elif defined GNULIB_POSIXCHECK
|
||||||
|
...
|
||||||
|
#endif
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* _GL_EXTERN_C declaration;
|
||||||
|
performs the declaration with C linkage. */
|
||||||
|
#if defined __cplusplus
|
||||||
|
# define _GL_EXTERN_C extern "C"
|
||||||
|
#else
|
||||||
|
# define _GL_EXTERN_C extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_FUNCDECL_RPL (func, rettype, parameters_and_attributes);
|
||||||
|
declares a replacement function, named rpl_func, with the given prototype,
|
||||||
|
consisting of return type, parameters, and attributes.
|
||||||
|
Example:
|
||||||
|
_GL_FUNCDECL_RPL (open, int, (const char *filename, int flags, ...)
|
||||||
|
_GL_ARG_NONNULL ((1)));
|
||||||
|
*/
|
||||||
|
#define _GL_FUNCDECL_RPL(func,rettype,parameters_and_attributes) \
|
||||||
|
_GL_FUNCDECL_RPL_1 (rpl_##func, rettype, parameters_and_attributes)
|
||||||
|
#define _GL_FUNCDECL_RPL_1(rpl_func,rettype,parameters_and_attributes) \
|
||||||
|
_GL_EXTERN_C rettype rpl_func parameters_and_attributes
|
||||||
|
|
||||||
|
/* _GL_FUNCDECL_SYS (func, rettype, parameters_and_attributes);
|
||||||
|
declares the system function, named func, with the given prototype,
|
||||||
|
consisting of return type, parameters, and attributes.
|
||||||
|
Example:
|
||||||
|
_GL_FUNCDECL_SYS (open, int, (const char *filename, int flags, ...)
|
||||||
|
_GL_ARG_NONNULL ((1)));
|
||||||
|
*/
|
||||||
|
#define _GL_FUNCDECL_SYS(func,rettype,parameters_and_attributes) \
|
||||||
|
_GL_EXTERN_C rettype func parameters_and_attributes
|
||||||
|
|
||||||
|
/* _GL_CXXALIAS_RPL (func, rettype, parameters);
|
||||||
|
declares a C++ alias called GNULIB_NAMESPACE::func
|
||||||
|
that redirects to rpl_func, if GNULIB_NAMESPACE is defined.
|
||||||
|
Example:
|
||||||
|
_GL_CXXALIAS_RPL (open, int, (const char *filename, int flags, ...));
|
||||||
|
|
||||||
|
Wrapping rpl_func in an object with an inline conversion operator
|
||||||
|
avoids a reference to rpl_func unless GNULIB_NAMESPACE::func is
|
||||||
|
actually used in the program. */
|
||||||
|
#define _GL_CXXALIAS_RPL(func,rettype,parameters) \
|
||||||
|
_GL_CXXALIAS_RPL_1 (func, rpl_##func, rettype, parameters)
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIAS_RPL_1(func,rpl_func,rettype,parameters) \
|
||||||
|
namespace GNULIB_NAMESPACE \
|
||||||
|
{ \
|
||||||
|
static const struct _gl_ ## func ## _wrapper \
|
||||||
|
{ \
|
||||||
|
typedef rettype (*type) parameters; \
|
||||||
|
\
|
||||||
|
inline operator type () const \
|
||||||
|
{ \
|
||||||
|
return ::rpl_func; \
|
||||||
|
} \
|
||||||
|
} func = {}; \
|
||||||
|
} \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIAS_RPL_1(func,rpl_func,rettype,parameters) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIAS_RPL_CAST_1 (func, rpl_func, rettype, parameters);
|
||||||
|
is like _GL_CXXALIAS_RPL_1 (func, rpl_func, rettype, parameters);
|
||||||
|
except that the C function rpl_func may have a slightly different
|
||||||
|
declaration. A cast is used to silence the "invalid conversion" error
|
||||||
|
that would otherwise occur. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIAS_RPL_CAST_1(func,rpl_func,rettype,parameters) \
|
||||||
|
namespace GNULIB_NAMESPACE \
|
||||||
|
{ \
|
||||||
|
static const struct _gl_ ## func ## _wrapper \
|
||||||
|
{ \
|
||||||
|
typedef rettype (*type) parameters; \
|
||||||
|
\
|
||||||
|
inline operator type () const \
|
||||||
|
{ \
|
||||||
|
return reinterpret_cast<type>(::rpl_func); \
|
||||||
|
} \
|
||||||
|
} func = {}; \
|
||||||
|
} \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIAS_RPL_CAST_1(func,rpl_func,rettype,parameters) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIAS_SYS (func, rettype, parameters);
|
||||||
|
declares a C++ alias called GNULIB_NAMESPACE::func
|
||||||
|
that redirects to the system provided function func, if GNULIB_NAMESPACE
|
||||||
|
is defined.
|
||||||
|
Example:
|
||||||
|
_GL_CXXALIAS_SYS (open, int, (const char *filename, int flags, ...));
|
||||||
|
|
||||||
|
Wrapping func in an object with an inline conversion operator
|
||||||
|
avoids a reference to func unless GNULIB_NAMESPACE::func is
|
||||||
|
actually used in the program. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIAS_SYS(func,rettype,parameters) \
|
||||||
|
namespace GNULIB_NAMESPACE \
|
||||||
|
{ \
|
||||||
|
static const struct _gl_ ## func ## _wrapper \
|
||||||
|
{ \
|
||||||
|
typedef rettype (*type) parameters; \
|
||||||
|
\
|
||||||
|
inline operator type () const \
|
||||||
|
{ \
|
||||||
|
return ::func; \
|
||||||
|
} \
|
||||||
|
} func = {}; \
|
||||||
|
} \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIAS_SYS(func,rettype,parameters) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIAS_SYS_CAST (func, rettype, parameters);
|
||||||
|
is like _GL_CXXALIAS_SYS (func, rettype, parameters);
|
||||||
|
except that the C function func may have a slightly different declaration.
|
||||||
|
A cast is used to silence the "invalid conversion" error that would
|
||||||
|
otherwise occur. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIAS_SYS_CAST(func,rettype,parameters) \
|
||||||
|
namespace GNULIB_NAMESPACE \
|
||||||
|
{ \
|
||||||
|
static const struct _gl_ ## func ## _wrapper \
|
||||||
|
{ \
|
||||||
|
typedef rettype (*type) parameters; \
|
||||||
|
\
|
||||||
|
inline operator type () const \
|
||||||
|
{ \
|
||||||
|
return reinterpret_cast<type>(::func); \
|
||||||
|
} \
|
||||||
|
} func = {}; \
|
||||||
|
} \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIAS_SYS_CAST(func,rettype,parameters) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIAS_SYS_CAST2 (func, rettype, parameters, rettype2, parameters2);
|
||||||
|
is like _GL_CXXALIAS_SYS (func, rettype, parameters);
|
||||||
|
except that the C function is picked among a set of overloaded functions,
|
||||||
|
namely the one with rettype2 and parameters2. Two consecutive casts
|
||||||
|
are used to silence the "cannot find a match" and "invalid conversion"
|
||||||
|
errors that would otherwise occur. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
/* The outer cast must be a reinterpret_cast.
|
||||||
|
The inner cast: When the function is defined as a set of overloaded
|
||||||
|
functions, it works as a static_cast<>, choosing the designated variant.
|
||||||
|
When the function is defined as a single variant, it works as a
|
||||||
|
reinterpret_cast<>. The parenthesized cast syntax works both ways. */
|
||||||
|
# define _GL_CXXALIAS_SYS_CAST2(func,rettype,parameters,rettype2,parameters2) \
|
||||||
|
namespace GNULIB_NAMESPACE \
|
||||||
|
{ \
|
||||||
|
static const struct _gl_ ## func ## _wrapper \
|
||||||
|
{ \
|
||||||
|
typedef rettype (*type) parameters; \
|
||||||
|
\
|
||||||
|
inline operator type () const \
|
||||||
|
{ \
|
||||||
|
return reinterpret_cast<type>((rettype2 (*) parameters2)(::func)); \
|
||||||
|
} \
|
||||||
|
} func = {}; \
|
||||||
|
} \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIAS_SYS_CAST2(func,rettype,parameters,rettype2,parameters2) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIASWARN (func);
|
||||||
|
causes a warning to be emitted when ::func is used but not when
|
||||||
|
GNULIB_NAMESPACE::func is used. func must be defined without overloaded
|
||||||
|
variants. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIASWARN(func) \
|
||||||
|
_GL_CXXALIASWARN_1 (func, GNULIB_NAMESPACE)
|
||||||
|
# define _GL_CXXALIASWARN_1(func,namespace) \
|
||||||
|
_GL_CXXALIASWARN_2 (func, namespace)
|
||||||
|
/* To work around GCC bug <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=43881>,
|
||||||
|
we enable the warning only when not optimizing. */
|
||||||
|
# if !__OPTIMIZE__
|
||||||
|
# define _GL_CXXALIASWARN_2(func,namespace) \
|
||||||
|
_GL_WARN_ON_USE (func, \
|
||||||
|
"The symbol ::" #func " refers to the system function. " \
|
||||||
|
"Use " #namespace "::" #func " instead.")
|
||||||
|
# elif __GNUC__ >= 3 && GNULIB_STRICT_CHECKING
|
||||||
|
# define _GL_CXXALIASWARN_2(func,namespace) \
|
||||||
|
extern __typeof__ (func) func
|
||||||
|
# else
|
||||||
|
# define _GL_CXXALIASWARN_2(func,namespace) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIASWARN(func) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* _GL_CXXALIASWARN1 (func, rettype, parameters_and_attributes);
|
||||||
|
causes a warning to be emitted when the given overloaded variant of ::func
|
||||||
|
is used but not when GNULIB_NAMESPACE::func is used. */
|
||||||
|
#if defined __cplusplus && defined GNULIB_NAMESPACE
|
||||||
|
# define _GL_CXXALIASWARN1(func,rettype,parameters_and_attributes) \
|
||||||
|
_GL_CXXALIASWARN1_1 (func, rettype, parameters_and_attributes, \
|
||||||
|
GNULIB_NAMESPACE)
|
||||||
|
# define _GL_CXXALIASWARN1_1(func,rettype,parameters_and_attributes,namespace) \
|
||||||
|
_GL_CXXALIASWARN1_2 (func, rettype, parameters_and_attributes, namespace)
|
||||||
|
/* To work around GCC bug <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=43881>,
|
||||||
|
we enable the warning only when not optimizing. */
|
||||||
|
# if !__OPTIMIZE__
|
||||||
|
# define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \
|
||||||
|
_GL_WARN_ON_USE_CXX (func, rettype, parameters_and_attributes, \
|
||||||
|
"The symbol ::" #func " refers to the system function. " \
|
||||||
|
"Use " #namespace "::" #func " instead.")
|
||||||
|
# elif __GNUC__ >= 3 && GNULIB_STRICT_CHECKING
|
||||||
|
# define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \
|
||||||
|
extern __typeof__ (func) func
|
||||||
|
# else
|
||||||
|
# define _GL_CXXALIASWARN1_2(func,rettype,parameters_and_attributes,namespace) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
# define _GL_CXXALIASWARN1(func,rettype,parameters_and_attributes) \
|
||||||
|
_GL_EXTERN_C int _gl_cxxalias_dummy
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _GL_CXXDEFS_H */
|
147
glib/gnulib/float+.h
Normal file
147
glib/gnulib/float+.h
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
/* Supplemental information about the floating-point formats.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
Written by Bruno Haible <bruno@clisp.org>, 2007.
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef _FLOATPLUS_H
|
||||||
|
#define _FLOATPLUS_H
|
||||||
|
|
||||||
|
#include <float.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
|
/* Number of bits in the mantissa of a floating-point number, including the
|
||||||
|
"hidden bit". */
|
||||||
|
#if FLT_RADIX == 2
|
||||||
|
# define FLT_MANT_BIT FLT_MANT_DIG
|
||||||
|
# define DBL_MANT_BIT DBL_MANT_DIG
|
||||||
|
# define LDBL_MANT_BIT LDBL_MANT_DIG
|
||||||
|
#elif FLT_RADIX == 4
|
||||||
|
# define FLT_MANT_BIT (FLT_MANT_DIG * 2)
|
||||||
|
# define DBL_MANT_BIT (DBL_MANT_DIG * 2)
|
||||||
|
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 2)
|
||||||
|
#elif FLT_RADIX == 16
|
||||||
|
# define FLT_MANT_BIT (FLT_MANT_DIG * 4)
|
||||||
|
# define DBL_MANT_BIT (DBL_MANT_DIG * 4)
|
||||||
|
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 4)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Bit mask that can be used to mask the exponent, as an unsigned number. */
|
||||||
|
#define FLT_EXP_MASK ((FLT_MAX_EXP - FLT_MIN_EXP) | 7)
|
||||||
|
#define DBL_EXP_MASK ((DBL_MAX_EXP - DBL_MIN_EXP) | 7)
|
||||||
|
#define LDBL_EXP_MASK ((LDBL_MAX_EXP - LDBL_MIN_EXP) | 7)
|
||||||
|
|
||||||
|
/* Number of bits used for the exponent of a floating-point number, including
|
||||||
|
the exponent's sign. */
|
||||||
|
#define FLT_EXP_BIT \
|
||||||
|
(FLT_EXP_MASK < 0x100 ? 8 : \
|
||||||
|
FLT_EXP_MASK < 0x200 ? 9 : \
|
||||||
|
FLT_EXP_MASK < 0x400 ? 10 : \
|
||||||
|
FLT_EXP_MASK < 0x800 ? 11 : \
|
||||||
|
FLT_EXP_MASK < 0x1000 ? 12 : \
|
||||||
|
FLT_EXP_MASK < 0x2000 ? 13 : \
|
||||||
|
FLT_EXP_MASK < 0x4000 ? 14 : \
|
||||||
|
FLT_EXP_MASK < 0x8000 ? 15 : \
|
||||||
|
FLT_EXP_MASK < 0x10000 ? 16 : \
|
||||||
|
FLT_EXP_MASK < 0x20000 ? 17 : \
|
||||||
|
FLT_EXP_MASK < 0x40000 ? 18 : \
|
||||||
|
FLT_EXP_MASK < 0x80000 ? 19 : \
|
||||||
|
FLT_EXP_MASK < 0x100000 ? 20 : \
|
||||||
|
FLT_EXP_MASK < 0x200000 ? 21 : \
|
||||||
|
FLT_EXP_MASK < 0x400000 ? 22 : \
|
||||||
|
FLT_EXP_MASK < 0x800000 ? 23 : \
|
||||||
|
FLT_EXP_MASK < 0x1000000 ? 24 : \
|
||||||
|
FLT_EXP_MASK < 0x2000000 ? 25 : \
|
||||||
|
FLT_EXP_MASK < 0x4000000 ? 26 : \
|
||||||
|
FLT_EXP_MASK < 0x8000000 ? 27 : \
|
||||||
|
FLT_EXP_MASK < 0x10000000 ? 28 : \
|
||||||
|
FLT_EXP_MASK < 0x20000000 ? 29 : \
|
||||||
|
FLT_EXP_MASK < 0x40000000 ? 30 : \
|
||||||
|
FLT_EXP_MASK <= 0x7fffffff ? 31 : \
|
||||||
|
32)
|
||||||
|
#define DBL_EXP_BIT \
|
||||||
|
(DBL_EXP_MASK < 0x100 ? 8 : \
|
||||||
|
DBL_EXP_MASK < 0x200 ? 9 : \
|
||||||
|
DBL_EXP_MASK < 0x400 ? 10 : \
|
||||||
|
DBL_EXP_MASK < 0x800 ? 11 : \
|
||||||
|
DBL_EXP_MASK < 0x1000 ? 12 : \
|
||||||
|
DBL_EXP_MASK < 0x2000 ? 13 : \
|
||||||
|
DBL_EXP_MASK < 0x4000 ? 14 : \
|
||||||
|
DBL_EXP_MASK < 0x8000 ? 15 : \
|
||||||
|
DBL_EXP_MASK < 0x10000 ? 16 : \
|
||||||
|
DBL_EXP_MASK < 0x20000 ? 17 : \
|
||||||
|
DBL_EXP_MASK < 0x40000 ? 18 : \
|
||||||
|
DBL_EXP_MASK < 0x80000 ? 19 : \
|
||||||
|
DBL_EXP_MASK < 0x100000 ? 20 : \
|
||||||
|
DBL_EXP_MASK < 0x200000 ? 21 : \
|
||||||
|
DBL_EXP_MASK < 0x400000 ? 22 : \
|
||||||
|
DBL_EXP_MASK < 0x800000 ? 23 : \
|
||||||
|
DBL_EXP_MASK < 0x1000000 ? 24 : \
|
||||||
|
DBL_EXP_MASK < 0x2000000 ? 25 : \
|
||||||
|
DBL_EXP_MASK < 0x4000000 ? 26 : \
|
||||||
|
DBL_EXP_MASK < 0x8000000 ? 27 : \
|
||||||
|
DBL_EXP_MASK < 0x10000000 ? 28 : \
|
||||||
|
DBL_EXP_MASK < 0x20000000 ? 29 : \
|
||||||
|
DBL_EXP_MASK < 0x40000000 ? 30 : \
|
||||||
|
DBL_EXP_MASK <= 0x7fffffff ? 31 : \
|
||||||
|
32)
|
||||||
|
#define LDBL_EXP_BIT \
|
||||||
|
(LDBL_EXP_MASK < 0x100 ? 8 : \
|
||||||
|
LDBL_EXP_MASK < 0x200 ? 9 : \
|
||||||
|
LDBL_EXP_MASK < 0x400 ? 10 : \
|
||||||
|
LDBL_EXP_MASK < 0x800 ? 11 : \
|
||||||
|
LDBL_EXP_MASK < 0x1000 ? 12 : \
|
||||||
|
LDBL_EXP_MASK < 0x2000 ? 13 : \
|
||||||
|
LDBL_EXP_MASK < 0x4000 ? 14 : \
|
||||||
|
LDBL_EXP_MASK < 0x8000 ? 15 : \
|
||||||
|
LDBL_EXP_MASK < 0x10000 ? 16 : \
|
||||||
|
LDBL_EXP_MASK < 0x20000 ? 17 : \
|
||||||
|
LDBL_EXP_MASK < 0x40000 ? 18 : \
|
||||||
|
LDBL_EXP_MASK < 0x80000 ? 19 : \
|
||||||
|
LDBL_EXP_MASK < 0x100000 ? 20 : \
|
||||||
|
LDBL_EXP_MASK < 0x200000 ? 21 : \
|
||||||
|
LDBL_EXP_MASK < 0x400000 ? 22 : \
|
||||||
|
LDBL_EXP_MASK < 0x800000 ? 23 : \
|
||||||
|
LDBL_EXP_MASK < 0x1000000 ? 24 : \
|
||||||
|
LDBL_EXP_MASK < 0x2000000 ? 25 : \
|
||||||
|
LDBL_EXP_MASK < 0x4000000 ? 26 : \
|
||||||
|
LDBL_EXP_MASK < 0x8000000 ? 27 : \
|
||||||
|
LDBL_EXP_MASK < 0x10000000 ? 28 : \
|
||||||
|
LDBL_EXP_MASK < 0x20000000 ? 29 : \
|
||||||
|
LDBL_EXP_MASK < 0x40000000 ? 30 : \
|
||||||
|
LDBL_EXP_MASK <= 0x7fffffff ? 31 : \
|
||||||
|
32)
|
||||||
|
|
||||||
|
/* Number of bits used for a floating-point number: the mantissa (not
|
||||||
|
counting the "hidden bit", since it may or may not be explicit), the
|
||||||
|
exponent, and the sign. */
|
||||||
|
#define FLT_TOTAL_BIT ((FLT_MANT_BIT - 1) + FLT_EXP_BIT + 1)
|
||||||
|
#define DBL_TOTAL_BIT ((DBL_MANT_BIT - 1) + DBL_EXP_BIT + 1)
|
||||||
|
#define LDBL_TOTAL_BIT ((LDBL_MANT_BIT - 1) + LDBL_EXP_BIT + 1)
|
||||||
|
|
||||||
|
/* Number of bytes used for a floating-point number.
|
||||||
|
This can be smaller than the 'sizeof'. For example, on i386 systems,
|
||||||
|
'long double' most often have LDBL_MANT_BIT = 64, LDBL_EXP_BIT = 16, hence
|
||||||
|
LDBL_TOTAL_BIT = 80 bits, i.e. 10 bytes of consecutive memory, but
|
||||||
|
sizeof (long double) = 12 or = 16. */
|
||||||
|
#define SIZEOF_FLT ((FLT_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
|
||||||
|
#define SIZEOF_DBL ((DBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
|
||||||
|
#define SIZEOF_LDBL ((LDBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
|
||||||
|
|
||||||
|
/* Verify that SIZEOF_FLT <= sizeof (float) etc. */
|
||||||
|
typedef int verify_sizeof_flt[SIZEOF_FLT <= sizeof (float) ? 1 : -1];
|
||||||
|
typedef int verify_sizeof_dbl[SIZEOF_DBL <= sizeof (double) ? 1 : - 1];
|
||||||
|
typedef int verify_sizeof_ldbl[SIZEOF_LDBL <= sizeof (long double) ? 1 : - 1];
|
||||||
|
|
||||||
|
#endif /* _FLOATPLUS_H */
|
108
glib/gnulib/fpucw.h
Normal file
108
glib/gnulib/fpucw.h
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
/* Manipulating the FPU control word. -*- coding: utf-8 -*-
|
||||||
|
Copyright (C) 2007-2019 Free Software Foundation, Inc.
|
||||||
|
Written by Bruno Haible <bruno@clisp.org>, 2007.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#ifndef _FPUCW_H
|
||||||
|
#define _FPUCW_H
|
||||||
|
|
||||||
|
/* The i386 floating point hardware (the 387 compatible FPU, not the modern
|
||||||
|
SSE/SSE2 hardware) has a controllable rounding precision. It is specified
|
||||||
|
through the 'PC' bits in the FPU control word ('fctrl' register). (See
|
||||||
|
the GNU libc i386 <fpu_control.h> header for details.)
|
||||||
|
|
||||||
|
On some platforms, such as Linux or Solaris, the default precision setting
|
||||||
|
is set to "extended precision". This means that 'long double' instructions
|
||||||
|
operate correctly, but 'double' computations often produce slightly
|
||||||
|
different results as on strictly IEEE 754 conforming systems.
|
||||||
|
|
||||||
|
On some platforms, such as NetBSD, the default precision is set to
|
||||||
|
"double precision". This means that 'long double' instructions will operate
|
||||||
|
only as 'double', i.e. lead to wrong results. Similarly on FreeBSD 6.4, at
|
||||||
|
least for the division of 'long double' numbers.
|
||||||
|
|
||||||
|
The FPU control word is under control of the application, i.e. it is
|
||||||
|
not required to be set either way by the ABI. (In fact, the i386 ABI
|
||||||
|
https://www.linux-mips.org/pub/linux/mips/doc/ABI/abi386-4.pdf page 3-12 = page 38
|
||||||
|
is not clear about it. But in any case, gcc treats the control word
|
||||||
|
like a "preserved" register: it emits code that assumes that the control
|
||||||
|
word is preserved across calls, and it restores the control word at the
|
||||||
|
end of functions that modify it.)
|
||||||
|
|
||||||
|
See Vincent Lefèvre's page https://www.vinc17.net/research/extended.en.html
|
||||||
|
for a good explanation.
|
||||||
|
See http://www.uwsg.iu.edu/hypermail/linux/kernel/0103.0/0453.html for
|
||||||
|
some argumentation which setting should be the default. */
|
||||||
|
|
||||||
|
/* This header file provides the following facilities:
|
||||||
|
fpucw_t integral type holding the value of 'fctrl'
|
||||||
|
FPU_PC_MASK bit mask denoting the precision control
|
||||||
|
FPU_PC_DOUBLE precision control for 53 bits mantissa
|
||||||
|
FPU_PC_EXTENDED precision control for 64 bits mantissa
|
||||||
|
GET_FPUCW () yields the current FPU control word
|
||||||
|
SET_FPUCW (word) sets the FPU control word
|
||||||
|
DECL_LONG_DOUBLE_ROUNDING variable declaration for
|
||||||
|
BEGIN/END_LONG_DOUBLE_ROUNDING
|
||||||
|
BEGIN_LONG_DOUBLE_ROUNDING () starts a sequence of instructions with
|
||||||
|
'long double' safe operation precision
|
||||||
|
END_LONG_DOUBLE_ROUNDING () ends a sequence of instructions with
|
||||||
|
'long double' safe operation precision
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Inline assembler like this works only with GNU C. */
|
||||||
|
#if (defined __i386__ || defined __x86_64__) && defined __GNUC__
|
||||||
|
|
||||||
|
typedef unsigned short fpucw_t; /* glibc calls this fpu_control_t */
|
||||||
|
|
||||||
|
# define FPU_PC_MASK 0x0300
|
||||||
|
# define FPU_PC_DOUBLE 0x200 /* glibc calls this _FPU_DOUBLE */
|
||||||
|
# define FPU_PC_EXTENDED 0x300 /* glibc calls this _FPU_EXTENDED */
|
||||||
|
|
||||||
|
# define GET_FPUCW() \
|
||||||
|
({ fpucw_t _cw; \
|
||||||
|
__asm__ __volatile__ ("fnstcw %0" : "=m" (*&_cw)); \
|
||||||
|
_cw; \
|
||||||
|
})
|
||||||
|
# define SET_FPUCW(word) \
|
||||||
|
(void)({ fpucw_t _ncw = (word); \
|
||||||
|
__asm__ __volatile__ ("fldcw %0" : : "m" (*&_ncw)); \
|
||||||
|
})
|
||||||
|
|
||||||
|
# define DECL_LONG_DOUBLE_ROUNDING \
|
||||||
|
fpucw_t oldcw;
|
||||||
|
# define BEGIN_LONG_DOUBLE_ROUNDING() \
|
||||||
|
(void)(oldcw = GET_FPUCW (), \
|
||||||
|
SET_FPUCW ((oldcw & ~FPU_PC_MASK) | FPU_PC_EXTENDED))
|
||||||
|
# define END_LONG_DOUBLE_ROUNDING() \
|
||||||
|
SET_FPUCW (oldcw)
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
typedef unsigned int fpucw_t;
|
||||||
|
|
||||||
|
# define FPU_PC_MASK 0
|
||||||
|
# define FPU_PC_DOUBLE 0
|
||||||
|
# define FPU_PC_EXTENDED 0
|
||||||
|
|
||||||
|
# define GET_FPUCW() 0
|
||||||
|
# define SET_FPUCW(word) (void)(word)
|
||||||
|
|
||||||
|
# define DECL_LONG_DOUBLE_ROUNDING
|
||||||
|
# define BEGIN_LONG_DOUBLE_ROUNDING()
|
||||||
|
# define END_LONG_DOUBLE_ROUNDING()
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _FPUCW_H */
|
22
glib/gnulib/frexp.c
Normal file
22
glib/gnulib/frexp.c
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
/* Specification. */
|
||||||
|
#include <gnulib_math.h>
|
||||||
|
|
||||||
|
#include <float.h>
|
||||||
|
#include "isnand-nolibm.h"
|
||||||
|
|
||||||
|
double rpl_frexp (double x, int *expptr)
|
||||||
|
{
|
||||||
|
if (x == 0.0 || x == -0.0)
|
||||||
|
{
|
||||||
|
*expptr = x;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
else if (isnan (x))
|
||||||
|
return x;
|
||||||
|
else if (isinf (x))
|
||||||
|
return x;
|
||||||
|
#undef frexp
|
||||||
|
return frexp (x, expptr);
|
||||||
|
}
|
19
glib/gnulib/frexpl.c
Normal file
19
glib/gnulib/frexpl.c
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
#include <config.h>
|
||||||
|
#include <gnulib_math.h>
|
||||||
|
#include <float.h>
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
long double rpl_frexpl (long double x, int *expptr)
|
||||||
|
{
|
||||||
|
if (x == 0.0L || x == -0.0L)
|
||||||
|
{
|
||||||
|
*expptr = x;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
else if (isnanl (x))
|
||||||
|
return x;
|
||||||
|
else if (isinf (x))
|
||||||
|
return x;
|
||||||
|
#undef frexpl
|
||||||
|
return frexpl (x, expptr);
|
||||||
|
}
|
101
glib/gnulib/gl_cv_cc_double_expbit0/meson.build
Normal file
101
glib/gnulib/gl_cv_cc_double_expbit0/meson.build
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
double_exponent_test = '''
|
||||||
|
#include <float.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#define NWORDS \
|
||||||
|
((sizeof (double) + sizeof (unsigned int) - 1) / sizeof (unsigned int))
|
||||||
|
typedef union { double value; unsigned int word[NWORDS]; } memory_double;
|
||||||
|
static unsigned int ored_words[NWORDS];
|
||||||
|
static unsigned int anded_words[NWORDS];
|
||||||
|
static void add_to_ored_words (double x)
|
||||||
|
{
|
||||||
|
memory_double m;
|
||||||
|
size_t i;
|
||||||
|
/* Clear it first, in case sizeof (double) < sizeof (memory_double). */
|
||||||
|
memset (&m, 0, sizeof (memory_double));
|
||||||
|
m.value = x;
|
||||||
|
for (i = 0; i < NWORDS; i++)
|
||||||
|
{
|
||||||
|
ored_words[i] |= m.word[i];
|
||||||
|
anded_words[i] &= m.word[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
size_t j;
|
||||||
|
FILE *fp = stdout;
|
||||||
|
if (fp == NULL)
|
||||||
|
return 1;
|
||||||
|
for (j = 0; j < NWORDS; j++)
|
||||||
|
anded_words[j] = ~ (unsigned int) 0;
|
||||||
|
add_to_ored_words (0.25);
|
||||||
|
add_to_ored_words (0.5);
|
||||||
|
add_to_ored_words (1.0);
|
||||||
|
add_to_ored_words (2.0);
|
||||||
|
add_to_ored_words (4.0);
|
||||||
|
/* Remove bits that are common (e.g. if representation of the first mantissa
|
||||||
|
bit is explicit). */
|
||||||
|
for (j = 0; j < NWORDS; j++)
|
||||||
|
ored_words[j] &= ~anded_words[j];
|
||||||
|
/* Now find the nonzero word. */
|
||||||
|
for (j = 0; j < NWORDS; j++)
|
||||||
|
if (ored_words[j] != 0)
|
||||||
|
break;
|
||||||
|
if (j < NWORDS)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
for (i = j + 1; i < NWORDS; i++)
|
||||||
|
if (ored_words[i] != 0)
|
||||||
|
{
|
||||||
|
fprintf (fp, "-1/-1");
|
||||||
|
return (fclose (fp) != 0);
|
||||||
|
}
|
||||||
|
for (i = 0; ; i++)
|
||||||
|
if ((ored_words[j] >> i) & 1)
|
||||||
|
{
|
||||||
|
fprintf (fp, "%d/%d", (int) j, (int) i);
|
||||||
|
return (fclose (fp) != 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fprintf (fp, "-1/-1");
|
||||||
|
return (fclose (fp) != 0);
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
gl_cv_cc_double_expbit0_word = -1
|
||||||
|
gl_cv_cc_double_expbit0_bit = -1
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(double_exponent_test,
|
||||||
|
name : 'where to find the exponent in a \'double\'')
|
||||||
|
if run_result.compiled() and run_result.returncode() == 0
|
||||||
|
out = run_result.stdout ().split ('/')
|
||||||
|
if out.length () == 2
|
||||||
|
gl_cv_cc_double_expbit0_word = out[0].to_int ()
|
||||||
|
gl_cv_cc_double_expbit0_bit = out[1].to_int ()
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
# On ARM, there are two 'double' floating-point formats, used by
|
||||||
|
# different sets of instructions: The older FPA instructions assume
|
||||||
|
# that they are stored in big-endian word order, while the words
|
||||||
|
# (like integer types) are stored in little-endian byte order.
|
||||||
|
# The newer VFP instructions assume little-endian order
|
||||||
|
# consistently.
|
||||||
|
if (cc.get_define ('arm') == '' and
|
||||||
|
cc.get_define ('__arm') == '' and
|
||||||
|
cc.get_define ('__arm__') == '')
|
||||||
|
gl_cv_cc_double_expbit0_bit = 20
|
||||||
|
if host_machine.endian () == 'big'
|
||||||
|
gl_cv_cc_double_expbit0_word = 0
|
||||||
|
else
|
||||||
|
gl_cv_cc_double_expbit0_word = 1
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
110
glib/gnulib/gl_cv_func_frexp_works/meson.build
Normal file
110
glib/gnulib/gl_cv_func_frexp_works/meson.build
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
frexp_test = '''
|
||||||
|
#define HAVE_DECL_ALARM 0
|
||||||
|
#include <float.h>
|
||||||
|
#include <math.h>
|
||||||
|
#include <string.h>
|
||||||
|
#if HAVE_DECL_ALARM
|
||||||
|
# include <signal.h>
|
||||||
|
# include <unistd.h>
|
||||||
|
#endif
|
||||||
|
/* HP cc on HP-UX 10.20 has a bug with the constant expression -0.0.
|
||||||
|
ICC 10.0 has a bug when optimizing the expression -zero.
|
||||||
|
The expression -DBL_MIN * DBL_MIN does not work when cross-compiling
|
||||||
|
to PowerPC on Mac OS X 10.5. */
|
||||||
|
#if defined __hpux || defined __sgi || defined __ICC
|
||||||
|
static double
|
||||||
|
compute_minus_zero (void)
|
||||||
|
{
|
||||||
|
return -DBL_MIN * DBL_MIN;
|
||||||
|
}
|
||||||
|
# define minus_zero compute_minus_zero ()
|
||||||
|
#else
|
||||||
|
double minus_zero = -0.0;
|
||||||
|
#endif
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
int i;
|
||||||
|
volatile double x;
|
||||||
|
double zero = 0.0;
|
||||||
|
#if HAVE_DECL_ALARM
|
||||||
|
/* NeXTstep 3.3 frexp() runs into an endless loop when called on an infinite
|
||||||
|
number. Let the test fail in this case. */
|
||||||
|
signal (SIGALRM, SIG_DFL);
|
||||||
|
alarm (5);
|
||||||
|
#endif
|
||||||
|
/* Test on denormalized numbers. */
|
||||||
|
for (i = 1, x = 1.0; i >= DBL_MIN_EXP; i--, x *= 0.5)
|
||||||
|
;
|
||||||
|
if (x > 0.0)
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
double y = frexp (x, &exp);
|
||||||
|
/* On machines with IEEE754 arithmetic: x = 1.11254e-308, exp = -1022.
|
||||||
|
On NetBSD: y = 0.75. Correct: y = 0.5. */
|
||||||
|
if (y != 0.5)
|
||||||
|
result |= 1;
|
||||||
|
}
|
||||||
|
/* Test on infinite numbers. */
|
||||||
|
x = 1.0 / zero;
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
double y = frexp (x, &exp);
|
||||||
|
if (y != x)
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
/* Test on negative zero. */
|
||||||
|
x = minus_zero;
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
double y = frexp (x, &exp);
|
||||||
|
if (memcmp (&y, &x, sizeof x))
|
||||||
|
result |= 4;
|
||||||
|
}
|
||||||
|
x = 0.0;
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
double y = frexp (x, &exp);
|
||||||
|
if (memcmp (&y, &x, sizeof x))
|
||||||
|
result |= 8;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(frexp_test,
|
||||||
|
name : 'frexp works',
|
||||||
|
dependencies : [libm])
|
||||||
|
rc = run_result.returncode()
|
||||||
|
gl_cv_func_frexp_works = run_result.compiled() and rc == 0
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = not gl_cv_func_frexp_works
|
||||||
|
# bit 1 is not set
|
||||||
|
if (rc == 1 or rc == 3 or rc == 5 or rc == 9 or
|
||||||
|
rc == 7 or rc == 11 or rc == 13)
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = true
|
||||||
|
else
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = false
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
if (host_system.startswith ('netbsd') or
|
||||||
|
host_system.startswith ('irix'))
|
||||||
|
gl_cv_func_frexp_works = false
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = true
|
||||||
|
elif host_system == 'windows'
|
||||||
|
if cc.get_id () == 'msvc'
|
||||||
|
gl_cv_func_frexp_works = true
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = false
|
||||||
|
else
|
||||||
|
gl_cv_func_frexp_works = false
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = false
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
gl_cv_func_frexp_works = true
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = false
|
||||||
|
endif
|
||||||
|
endif
|
130
glib/gnulib/gl_cv_func_frexpl_works/meson.build
Normal file
130
glib/gnulib/gl_cv_func_frexpl_works/meson.build
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
# Copyright (C) 2007-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
frexpl_test = '''
|
||||||
|
#include <float.h>
|
||||||
|
#include <math.h>
|
||||||
|
/* Override the values of <float.h>, like done in float.in.h. */
|
||||||
|
#if defined __i386__ && (defined __BEOS__ || defined __OpenBSD__)
|
||||||
|
# undef LDBL_MIN_EXP
|
||||||
|
# define LDBL_MIN_EXP (-16381)
|
||||||
|
#endif
|
||||||
|
#if defined __i386__ && (defined __FreeBSD__ || defined __DragonFly__)
|
||||||
|
# undef LDBL_MIN_EXP
|
||||||
|
# define LDBL_MIN_EXP (-16381)
|
||||||
|
#endif
|
||||||
|
#if (defined _ARCH_PPC || defined _POWER) && defined _AIX && (LDBL_MANT_DIG == 106) && defined __GNUC__
|
||||||
|
# undef LDBL_MIN_EXP
|
||||||
|
# define LDBL_MIN_EXP DBL_MIN_EXP
|
||||||
|
#endif
|
||||||
|
#if defined __sgi && (LDBL_MANT_DIG >= 106)
|
||||||
|
# if defined __GNUC__
|
||||||
|
# undef LDBL_MIN_EXP
|
||||||
|
# define LDBL_MIN_EXP DBL_MIN_EXP
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
extern
|
||||||
|
#ifdef __cplusplus
|
||||||
|
"C"
|
||||||
|
#endif
|
||||||
|
long double frexpl (long double, int *);
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
volatile long double x;
|
||||||
|
/* Test on finite numbers that fails on AIX 5.1. */
|
||||||
|
x = 16.0L;
|
||||||
|
{
|
||||||
|
int exp = -9999;
|
||||||
|
frexpl (x, &exp);
|
||||||
|
if (exp != 5)
|
||||||
|
result |= 1;
|
||||||
|
}
|
||||||
|
/* Test on finite numbers that fails on Mac OS X 10.4, because its frexpl
|
||||||
|
function returns an invalid (incorrectly normalized) value: it returns
|
||||||
|
y = { 0x3fe028f5, 0xc28f5c28, 0x3c9eb851, 0xeb851eb8 }
|
||||||
|
but the correct result is
|
||||||
|
0.505L = { 0x3fe028f5, 0xc28f5c29, 0xbc547ae1, 0x47ae1480 } */
|
||||||
|
x = 1.01L;
|
||||||
|
{
|
||||||
|
int exp = -9999;
|
||||||
|
long double y = frexpl (x, &exp);
|
||||||
|
if (!(exp == 1 && y == 0.505L))
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
/* Test on large finite numbers. This fails on BeOS at i = 16322, while
|
||||||
|
LDBL_MAX_EXP = 16384.
|
||||||
|
In the loop end test, we test x against Infinity, rather than comparing
|
||||||
|
i with LDBL_MAX_EXP, because BeOS <float.h> has a wrong LDBL_MAX_EXP. */
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = 1, x = 1.0L; x != x + x; i++, x *= 2.0L)
|
||||||
|
{
|
||||||
|
int exp = -9999;
|
||||||
|
frexpl (x, &exp);
|
||||||
|
if (exp != i)
|
||||||
|
{
|
||||||
|
result |= 4;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Test on denormalized numbers. */
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for (i = 1, x = 1.0L; i >= LDBL_MIN_EXP; i--, x *= 0.5L)
|
||||||
|
;
|
||||||
|
if (x > 0.0L)
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
long double y = frexpl (x, &exp);
|
||||||
|
/* On machines with IEEE854 arithmetic: x = 1.68105e-4932,
|
||||||
|
exp = -16382, y = 0.5. On Mac OS X 10.5: exp = -16384, y = 0.5. */
|
||||||
|
if (exp != LDBL_MIN_EXP - 1)
|
||||||
|
result |= 8;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Test on infinite numbers. */
|
||||||
|
/* The dance around 0.0L is an attempt to prevent MSVC from erroring out */
|
||||||
|
x = 0.0L;
|
||||||
|
x = 1.0L / x;
|
||||||
|
{
|
||||||
|
int exp;
|
||||||
|
long double y = frexpl (x, &exp);
|
||||||
|
if (y != x)
|
||||||
|
result |= 16;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(frexpl_test,
|
||||||
|
name : 'frexpl works',
|
||||||
|
dependencies : [libm])
|
||||||
|
rc = run_result.returncode()
|
||||||
|
gl_cv_func_frexpl_works = run_result.compiled() and rc == 0
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = not gl_cv_func_frexpl_works
|
||||||
|
# bit 1 is not set
|
||||||
|
if (rc == 16)
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = false
|
||||||
|
else
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = true
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
if (host_system.startswith ('aix') or
|
||||||
|
host_system.startswith ('beos') or
|
||||||
|
host_system.startswith ('darwin') or
|
||||||
|
host_system.startswith ('irix'))
|
||||||
|
gl_cv_func_frexpl_works = false
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = true
|
||||||
|
elif (host_system == 'windows')
|
||||||
|
gl_cv_func_frexpl_works = false
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = false
|
||||||
|
else
|
||||||
|
gl_cv_func_frexpl_works = true
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = false
|
||||||
|
endif
|
||||||
|
endif
|
45
glib/gnulib/gl_cv_func_ldexpl_works/meson.build
Normal file
45
glib/gnulib/gl_cv_func_ldexpl_works/meson.build
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
ldexpl_test = '''
|
||||||
|
#include <math.h>
|
||||||
|
extern
|
||||||
|
#ifdef __cplusplus
|
||||||
|
"C"
|
||||||
|
#endif
|
||||||
|
long double ldexpl (long double, int);
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
{
|
||||||
|
volatile long double x = 1.0;
|
||||||
|
volatile long double y = ldexpl (x, -1);
|
||||||
|
if (y != 0.5L)
|
||||||
|
result |= 1;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
volatile long double x = 1.73205L;
|
||||||
|
volatile long double y = ldexpl (x, 0);
|
||||||
|
if (y != x)
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(ldexpl_test,
|
||||||
|
name : 'ldexpl works',
|
||||||
|
dependencies : [libm])
|
||||||
|
gl_cv_func_ldexpl_works = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system.startswith ('aix')
|
||||||
|
gl_cv_func_ldexpl_works = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_ldexpl_works = true
|
||||||
|
else
|
||||||
|
gl_cv_func_ldexpl_works = true
|
||||||
|
endif
|
||||||
|
endif
|
94
glib/gnulib/gl_cv_func_printf_directive_a/meson.build
Normal file
94
glib/gnulib/gl_cv_func_printf_directive_a/meson.build
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports the 'a' and 'A'
|
||||||
|
# conversion specifier for hexadecimal output of floating-point numbers.
|
||||||
|
# (ISO C99, POSIX:2001)
|
||||||
|
# Result is gl_cv_func_printf_directive_a.
|
||||||
|
|
||||||
|
printf_directive_a_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[100];
|
||||||
|
static double zero = 0.0;
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
if (sprintf (buf, "%a %d", 3.1416015625, 33, 44, 55) < 0
|
||||||
|
|| (strcmp (buf, "0x1.922p+1 33") != 0
|
||||||
|
&& strcmp (buf, "0x3.244p+0 33") != 0
|
||||||
|
&& strcmp (buf, "0x6.488p-1 33") != 0
|
||||||
|
&& strcmp (buf, "0xc.91p-2 33") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%A %d", -3.1416015625, 33, 44, 55) < 0
|
||||||
|
|| (strcmp (buf, "-0X1.922P+1 33") != 0
|
||||||
|
&& strcmp (buf, "-0X3.244P+0 33") != 0
|
||||||
|
&& strcmp (buf, "-0X6.488P-1 33") != 0
|
||||||
|
&& strcmp (buf, "-0XC.91P-2 33") != 0))
|
||||||
|
result |= 2;
|
||||||
|
/* This catches a FreeBSD 6.1 bug: it doesn't round. */
|
||||||
|
if (sprintf (buf, "%.2a %d", 1.51, 33, 44, 55) < 0
|
||||||
|
|| (strcmp (buf, "0x1.83p+0 33") != 0
|
||||||
|
&& strcmp (buf, "0x3.05p-1 33") != 0
|
||||||
|
&& strcmp (buf, "0x6.0ap-2 33") != 0
|
||||||
|
&& strcmp (buf, "0xc.14p-3 33") != 0))
|
||||||
|
result |= 4;
|
||||||
|
/* This catches a Mac OS X 10.12.4 (Darwin 16.5) bug: it doesn't round. */
|
||||||
|
if (sprintf (buf, "%.0a %d", 1.51, 33, 44, 55) < 0
|
||||||
|
|| (strcmp (buf, "0x2p+0 33") != 0
|
||||||
|
&& strcmp (buf, "0x3p-1 33") != 0
|
||||||
|
&& strcmp (buf, "0x6p-2 33") != 0
|
||||||
|
&& strcmp (buf, "0xcp-3 33") != 0))
|
||||||
|
result |= 4;
|
||||||
|
/* This catches a FreeBSD 6.1 bug. See
|
||||||
|
<https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html> */
|
||||||
|
if (sprintf (buf, "%010a %d", 1.0 / zero, 33, 44, 55) < 0
|
||||||
|
|| buf[0] == '0')
|
||||||
|
result |= 8;
|
||||||
|
/* This catches a Mac OS X 10.3.9 (Darwin 7.9) bug. */
|
||||||
|
if (sprintf (buf, "%.1a", 1.999) < 0
|
||||||
|
|| (strcmp (buf, "0x1.0p+1") != 0
|
||||||
|
&& strcmp (buf, "0x2.0p+0") != 0
|
||||||
|
&& strcmp (buf, "0x4.0p-1") != 0
|
||||||
|
&& strcmp (buf, "0x8.0p-2") != 0))
|
||||||
|
result |= 16;
|
||||||
|
/* This catches the same Mac OS X 10.3.9 (Darwin 7.9) bug and also a
|
||||||
|
glibc 2.4 bug <https://sourceware.org/bugzilla/show_bug.cgi?id=2908>. */
|
||||||
|
if (sprintf (buf, "%.1La", 1.999L) < 0
|
||||||
|
|| (strcmp (buf, "0x1.0p+1") != 0
|
||||||
|
&& strcmp (buf, "0x2.0p+0") != 0
|
||||||
|
&& strcmp (buf, "0x4.0p-1") != 0
|
||||||
|
&& strcmp (buf, "0x8.0p-2") != 0))
|
||||||
|
result |= 32;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
glibc_printf_directive_a_test = '''
|
||||||
|
#include <features.h>
|
||||||
|
#ifdef __GNU_LIBRARY__
|
||||||
|
#if ((__GLIBC__ == 2 && __GLIBC_MINOR__ >= 5) || (__GLIBC__ > 2)) && !defined __UCLIBC__
|
||||||
|
#else
|
||||||
|
#error Too old glibc
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#error Not glibc
|
||||||
|
#endif
|
||||||
|
int main () { return 0; }
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_directive_a_test,
|
||||||
|
name : 'printf supports the \'a\' and \'A\' directives')
|
||||||
|
gl_cv_func_printf_directive_a = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system == 'linux'
|
||||||
|
gl_cv_func_printf_directive_a = cc.compiles(glibc_printf_directive_a_test)
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_printf_directive_a = false
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_directive_a = false
|
||||||
|
endif
|
||||||
|
endif
|
81
glib/gnulib/gl_cv_func_printf_directive_f/meson.build
Normal file
81
glib/gnulib/gl_cv_func_printf_directive_f/meson.build
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports the %F format
|
||||||
|
# directive. (ISO C99, POSIX:2001)
|
||||||
|
# Result is gl_cv_func_printf_directive_f.
|
||||||
|
|
||||||
|
printf_directive_f_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[100];
|
||||||
|
static double zero = 0.0;
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
if (sprintf (buf, "%F %d", 1234567.0, 33, 44, 55) < 0
|
||||||
|
|| strcmp (buf, "1234567.000000 33") != 0)
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%F", 1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "INF") != 0 && strcmp (buf, "INFINITY") != 0))
|
||||||
|
result |= 2;
|
||||||
|
/* This catches a Cygwin 1.5.x bug. */
|
||||||
|
if (sprintf (buf, "%.F", 1234.0) < 0
|
||||||
|
|| strcmp (buf, "1234") != 0)
|
||||||
|
result |= 4;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_directive_f_test,
|
||||||
|
name : 'printf supports the \'F\' directive')
|
||||||
|
gl_cv_func_printf_directive_f = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system == 'linux'
|
||||||
|
gl_cv_func_printf_directive_f = true
|
||||||
|
elif (host_system.startswith ('freebsd1') or
|
||||||
|
host_system.startswith ('freebsd2') or
|
||||||
|
host_system.startswith ('freebsd3') or
|
||||||
|
host_system.startswith ('freebsd4') or
|
||||||
|
host_system.startswith ('freebsd5'))
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
elif (host_system.startswith ('freebsd') or
|
||||||
|
host_system.startswith ('kfreebsd'))
|
||||||
|
gl_cv_func_printf_directive_f = true
|
||||||
|
elif (host_system.startswith ('darwin1') or
|
||||||
|
host_system.startswith ('darwin2') or
|
||||||
|
host_system.startswith ('darwin3') or
|
||||||
|
host_system.startswith ('darwin4') or
|
||||||
|
host_system.startswith ('darwin5') or
|
||||||
|
host_system.startswith ('darwin6'))
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
elif host_system.startswith ('darwin')
|
||||||
|
gl_cv_func_printf_directive_f = true
|
||||||
|
# Split the check from the main if statement, ensure that
|
||||||
|
# some meson versions (old ones, presumable) won't try
|
||||||
|
# to evaluate host_system[9] when it's shorter than that
|
||||||
|
elif host_system.startswith ('solaris2.')
|
||||||
|
if (host_system[9] == '1' and
|
||||||
|
'0123456789'.contains (host_system[10])) or
|
||||||
|
('23456789'.contains (host_system[9]) == '1' and
|
||||||
|
'0123456789'.contains (host_system[10]))
|
||||||
|
gl_cv_func_printf_directive_f = true
|
||||||
|
elif host_system.startswith ('solaris')
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
endif
|
||||||
|
elif host_system.startswith ('solaris')
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
# Guess yes on MSVC, no on mingw.
|
||||||
|
if cc.get_id() == 'msvc'
|
||||||
|
gl_cv_func_printf_directive_f = true
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_directive_f = false
|
||||||
|
endif
|
||||||
|
endif
|
82
glib/gnulib/gl_cv_func_printf_directive_ls/meson.build
Normal file
82
glib/gnulib/gl_cv_func_printf_directive_ls/meson.build
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports the %ls format
|
||||||
|
# directive and in particular, when a precision is specified, whether
|
||||||
|
# the functions stop converting the wide string argument when the number
|
||||||
|
# of bytes that have been produced by this conversion equals or exceeds
|
||||||
|
# the precision.
|
||||||
|
# Result is gl_cv_func_printf_directive_ls.
|
||||||
|
|
||||||
|
printf_directive_ls_test = '''
|
||||||
|
/* Tru64 with Desktop Toolkit C has a bug: <stdio.h> must be included before
|
||||||
|
<wchar.h>.
|
||||||
|
BSD/OS 4.0.1 has a bug: <stddef.h>, <stdio.h> and <time.h> must be
|
||||||
|
included before <wchar.h>. */
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <wchar.h>
|
||||||
|
#include <string.h>
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
char buf[100];
|
||||||
|
/* Test whether %ls works at all.
|
||||||
|
This test fails on OpenBSD 4.0, IRIX 6.5, Solaris 2.6, Haiku, but not on
|
||||||
|
Cygwin 1.5. */
|
||||||
|
{
|
||||||
|
static const wchar_t wstring[] = { 'a', 'b', 'c', 0 };
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%ls", wstring) < 0
|
||||||
|
|| strcmp (buf, "abc") != 0)
|
||||||
|
result |= 1;
|
||||||
|
}
|
||||||
|
/* This test fails on IRIX 6.5, Solaris 2.6, Cygwin 1.5, Haiku (with an
|
||||||
|
assertion failure inside libc), but not on OpenBSD 4.0. */
|
||||||
|
{
|
||||||
|
static const wchar_t wstring[] = { 'a', 0 };
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%ls", wstring) < 0
|
||||||
|
|| strcmp (buf, "a") != 0)
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
/* Test whether precisions in %ls are supported as specified in ISO C 99
|
||||||
|
section 7.19.6.1:
|
||||||
|
"If a precision is specified, no more than that many bytes are written
|
||||||
|
(including shift sequences, if any), and the array shall contain a
|
||||||
|
null wide character if, to equal the multibyte character sequence
|
||||||
|
length given by the precision, the function would need to access a
|
||||||
|
wide character one past the end of the array."
|
||||||
|
This test fails on Solaris 10. */
|
||||||
|
{
|
||||||
|
static const wchar_t wstring[] = { 'a', 'b', (wchar_t) 0xfdfdfdfd, 0 };
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%.2ls", wstring) < 0
|
||||||
|
|| strcmp (buf, "ab") != 0)
|
||||||
|
result |= 8;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_directive_ls_test,
|
||||||
|
name : 'printf supports the \'ls\' directive')
|
||||||
|
gl_cv_func_printf_directive_ls = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if (host_system.startswith ('openbsd') or
|
||||||
|
host_system.startswith ('irix') or
|
||||||
|
host_system.startswith ('solaris') or
|
||||||
|
host_system.startswith ('cygwin') or
|
||||||
|
host_system.startswith ('beos') or
|
||||||
|
host_system.startswith ('haiku'))
|
||||||
|
gl_cv_func_printf_directive_ls = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_printf_directive_ls = true
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_directive_ls = true
|
||||||
|
endif
|
||||||
|
endif
|
73
glib/gnulib/gl_cv_func_printf_enomem/meson.build
Normal file
73
glib/gnulib/gl_cv_func_printf_enomem/meson.build
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions recovers gracefully in case
|
||||||
|
# of an out-of-memory condition, or whether it crashes the entire program.
|
||||||
|
# Result is gl_cv_func_printf_enomem.
|
||||||
|
|
||||||
|
printf_enomem_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/resource.h>
|
||||||
|
#include <errno.h>
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
struct rlimit limit;
|
||||||
|
int ret;
|
||||||
|
nocrash_init ();
|
||||||
|
/* Some printf implementations allocate temporary space with malloc. */
|
||||||
|
/* On BSD systems, malloc() is limited by RLIMIT_DATA. */
|
||||||
|
#ifdef RLIMIT_DATA
|
||||||
|
if (getrlimit (RLIMIT_DATA, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
if (limit.rlim_max == RLIM_INFINITY || limit.rlim_max > 5000000)
|
||||||
|
limit.rlim_max = 5000000;
|
||||||
|
limit.rlim_cur = limit.rlim_max;
|
||||||
|
if (setrlimit (RLIMIT_DATA, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
#endif
|
||||||
|
/* On Linux systems, malloc() is limited by RLIMIT_AS. */
|
||||||
|
#ifdef RLIMIT_AS
|
||||||
|
if (getrlimit (RLIMIT_AS, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
if (limit.rlim_max == RLIM_INFINITY || limit.rlim_max > 5000000)
|
||||||
|
limit.rlim_max = 5000000;
|
||||||
|
limit.rlim_cur = limit.rlim_max;
|
||||||
|
if (setrlimit (RLIMIT_AS, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
#endif
|
||||||
|
/* Some printf implementations allocate temporary space on the stack. */
|
||||||
|
#ifdef RLIMIT_STACK
|
||||||
|
if (getrlimit (RLIMIT_STACK, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
if (limit.rlim_max == RLIM_INFINITY || limit.rlim_max > 5000000)
|
||||||
|
limit.rlim_max = 5000000;
|
||||||
|
limit.rlim_cur = limit.rlim_max;
|
||||||
|
if (setrlimit (RLIMIT_STACK, &limit) < 0)
|
||||||
|
return 77;
|
||||||
|
#endif
|
||||||
|
ret = printf ("%.5000000f", 1.0);
|
||||||
|
return !(ret == 5000002 || (ret < 0 && errno == ENOMEM));
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_enomem_test,
|
||||||
|
name : 'printf survives out-of-memory conditions')
|
||||||
|
gl_cv_func_printf_enomem = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
# If we don't know, assume the worst.
|
||||||
|
gl_cv_func_printf_enomem = false
|
||||||
|
if (host_system == 'linux' or
|
||||||
|
host_system == 'solaris' or
|
||||||
|
host_system == 'sunos' or
|
||||||
|
host_system == 'aix' or
|
||||||
|
host_system == 'irix' or
|
||||||
|
host_system == 'beos' or
|
||||||
|
host_system == 'haiku')
|
||||||
|
gl_cv_func_printf_enomem = true
|
||||||
|
endif
|
||||||
|
endif
|
37
glib/gnulib/gl_cv_func_printf_flag_grouping/meson.build
Normal file
37
glib/gnulib/gl_cv_func_printf_flag_grouping/meson.build
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports the - flag correctly.
|
||||||
|
# (ISO C99.) See
|
||||||
|
# <https://lists.gnu.org/r/bug-coreutils/2008-02/msg00035.html>
|
||||||
|
# Result is gl_cv_func_printf_flag_leftadjust.
|
||||||
|
|
||||||
|
printf_flag_grouping_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[100];
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
if (sprintf (buf, "%'d %d", 1234567, 99) < 0
|
||||||
|
|| buf[strlen (buf) - 1] != '9')
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_flag_grouping_test,
|
||||||
|
name : 'printf supports the grouping flag')
|
||||||
|
gl_cv_func_printf_flag_grouping = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system.startswith ('cygwin')
|
||||||
|
gl_cv_func_printf_flag_grouping = false
|
||||||
|
elif host_system.startswith ('netbsd')
|
||||||
|
gl_cv_func_printf_flag_grouping = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_printf_flag_grouping = false
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_flag_grouping = true
|
||||||
|
endif
|
||||||
|
endif
|
39
glib/gnulib/gl_cv_func_printf_flag_leftadjust/meson.build
Normal file
39
glib/gnulib/gl_cv_func_printf_flag_leftadjust/meson.build
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports the - flag correctly.
|
||||||
|
# (ISO C99.) See
|
||||||
|
# <https://lists.gnu.org/r/bug-coreutils/2008-02/msg00035.html>
|
||||||
|
# Result is gl_cv_func_printf_flag_leftadjust.
|
||||||
|
|
||||||
|
printf_flag_leftadjust_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[100];
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
/* Check that a '-' flag is not annihilated by a negative width. */
|
||||||
|
if (sprintf (buf, "a%-*sc", -3, "b") < 0
|
||||||
|
|| strcmp (buf, "ab c") != 0)
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_flag_leftadjust_test,
|
||||||
|
name : 'printf supports the left-adjust flag correctly')
|
||||||
|
gl_cv_func_printf_flag_leftadjust = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system.startswith ('hpux11')
|
||||||
|
gl_cv_func_printf_flag_leftadjust = true
|
||||||
|
elif host_system.startswith ('hpux')
|
||||||
|
gl_cv_func_printf_flag_leftadjust = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_printf_flag_leftadjust = true
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_flag_leftadjust = true
|
||||||
|
endif
|
||||||
|
endif
|
40
glib/gnulib/gl_cv_func_printf_flag_zero/meson.build
Normal file
40
glib/gnulib/gl_cv_func_printf_flag_zero/meson.build
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports padding of non-finite
|
||||||
|
# values with the 0 flag correctly. (ISO C99 + TC1 + TC2.) See
|
||||||
|
# <https://lists.gnu.org/r/bug-gnulib/2007-04/msg00107.html>
|
||||||
|
# Result is gl_cv_func_printf_flag_zero.
|
||||||
|
|
||||||
|
printf_flag_zero_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[100];
|
||||||
|
static double zero = 0.0;
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
if (sprintf (buf, "%010f", 1.0 / zero, 33, 44, 55) < 0
|
||||||
|
|| (strcmp (buf, " inf") != 0
|
||||||
|
&& strcmp (buf, " infinity") != 0))
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_flag_zero_test,
|
||||||
|
name : 'printf supports the zero flag correctly')
|
||||||
|
gl_cv_func_printf_flag_zero = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system == 'linux'
|
||||||
|
gl_cv_func_printf_flag_zero = true
|
||||||
|
elif host_system.startswith ('beos')
|
||||||
|
gl_cv_func_printf_flag_zero = true
|
||||||
|
elif host_system == 'windows'
|
||||||
|
gl_cv_func_printf_flag_zero = false
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_flag_zero = false
|
||||||
|
endif
|
||||||
|
endif
|
135
glib/gnulib/gl_cv_func_printf_infinite/meson.build
Normal file
135
glib/gnulib/gl_cv_func_printf_infinite/meson.build
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports infinite and NaN
|
||||||
|
# 'double' arguments and negative zero arguments in the %f, %e, %g
|
||||||
|
# directives. (ISO C99, POSIX:2001)
|
||||||
|
# Result is gl_cv_func_printf_infinite.
|
||||||
|
|
||||||
|
printf_infinite_double_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static int
|
||||||
|
strisnan (const char *string, size_t start_index, size_t end_index)
|
||||||
|
{
|
||||||
|
if (start_index < end_index)
|
||||||
|
{
|
||||||
|
if (string[start_index] == '-')
|
||||||
|
start_index++;
|
||||||
|
if (start_index + 3 <= end_index
|
||||||
|
&& memcmp (string + start_index, "nan", 3) == 0)
|
||||||
|
{
|
||||||
|
start_index += 3;
|
||||||
|
if (start_index == end_index
|
||||||
|
|| (string[start_index] == '(' && string[end_index - 1] == ')'))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
static int
|
||||||
|
have_minus_zero ()
|
||||||
|
{
|
||||||
|
static double plus_zero = 0.0;
|
||||||
|
double minus_zero = - plus_zero;
|
||||||
|
return memcmp (&plus_zero, &minus_zero, sizeof (double)) != 0;
|
||||||
|
}
|
||||||
|
static char buf[10000];
|
||||||
|
static double zero = 0.0;
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
if (sprintf (buf, "%f", 1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%f", -1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%f", zero / zero) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%e", 1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 4;
|
||||||
|
if (sprintf (buf, "%e", -1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 4;
|
||||||
|
if (sprintf (buf, "%e", zero / zero) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 8;
|
||||||
|
if (sprintf (buf, "%g", 1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 16;
|
||||||
|
if (sprintf (buf, "%g", -1.0 / zero) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 16;
|
||||||
|
if (sprintf (buf, "%g", zero / zero) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 32;
|
||||||
|
/* This test fails on HP-UX 10.20. */
|
||||||
|
if (have_minus_zero ())
|
||||||
|
if (sprintf (buf, "%g", - zero) < 0
|
||||||
|
|| strcmp (buf, "-0") != 0)
|
||||||
|
result |= 64;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_infinite_double_test,
|
||||||
|
name : 'printf supports infinite \'double\' arguments')
|
||||||
|
gl_cv_func_printf_infinite = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system == 'linux'
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif (host_system.startswith ('freebsd1') or
|
||||||
|
host_system.startswith ('freebsd2') or
|
||||||
|
host_system.startswith ('freebsd3') or
|
||||||
|
host_system.startswith ('freebsd4') or
|
||||||
|
host_system.startswith ('freebsd5'))
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
elif (host_system.startswith ('freebsd') or
|
||||||
|
host_system.startswith ('kfreebsd'))
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif (host_system.startswith ('darwin1') or
|
||||||
|
host_system.startswith ('darwin2') or
|
||||||
|
host_system.startswith ('darwin3') or
|
||||||
|
host_system.startswith ('darwin4') or
|
||||||
|
host_system.startswith ('darwin5'))
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
elif host_system.startswith ('darwin')
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif (host_system.startswith ('hpux7') or
|
||||||
|
host_system.startswith ('hpux8') or
|
||||||
|
host_system.startswith ('hpux9') or
|
||||||
|
host_system.startswith ('hpux10'))
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
elif host_system.startswith ('hpux')
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif (host_system.startswith ('netbsd1') or
|
||||||
|
host_system.startswith ('netbsd2') or
|
||||||
|
host_system.startswith ('netbsdelf1') or
|
||||||
|
host_system.startswith ('netbsdelf2') or
|
||||||
|
host_system.startswith ('netbsdaout1') or
|
||||||
|
host_system.startswith ('netbsdaout2') or
|
||||||
|
host_system.startswith ('netbsdcoff1') or
|
||||||
|
host_system.startswith ('netbsdcoff2'))
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
elif host_system.startswith ('netbsd')
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif host_system.startswith ('beos')
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
elif host_system.startswith ('windows')
|
||||||
|
# Guess yes on MSVC, no on mingw.
|
||||||
|
if cc.get_id() == 'msvc'
|
||||||
|
gl_cv_func_printf_infinite = true
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
# If we don't know, assume the worst.
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
endif
|
||||||
|
endif
|
210
glib/gnulib/gl_cv_func_printf_infinite_long_double/meson.build
Normal file
210
glib/gnulib/gl_cv_func_printf_infinite_long_double/meson.build
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports infinite and NaN
|
||||||
|
# 'long double' arguments in the %f, %e, %g directives. (ISO C99, POSIX:2001)
|
||||||
|
# Result is gl_cv_func_printf_infinite_long_double.
|
||||||
|
|
||||||
|
# The user can set or unset the variable gl_printf_safe to indicate
|
||||||
|
# that he wishes a safe handling of non-IEEE-754 'long double' values.
|
||||||
|
check_print_safe = ''
|
||||||
|
if get_variable ('gl_printf_safe', false)
|
||||||
|
check_print_safe = '''
|
||||||
|
#if ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
|
||||||
|
/* Representation of an 80-bit 'long double' as an initializer for a sequence
|
||||||
|
of 'unsigned int' words. */
|
||||||
|
# ifdef WORDS_BIGENDIAN
|
||||||
|
# define LDBL80_WORDS(exponent,manthi,mantlo) \
|
||||||
|
{ ((unsigned int) (exponent) << 16) | ((unsigned int) (manthi) >> 16), \
|
||||||
|
((unsigned int) (manthi) << 16) | ((unsigned int) (mantlo) >> 16), \
|
||||||
|
(unsigned int) (mantlo) << 16 \
|
||||||
|
}
|
||||||
|
# else
|
||||||
|
# define LDBL80_WORDS(exponent,manthi,mantlo) \
|
||||||
|
{ mantlo, manthi, exponent }
|
||||||
|
# endif
|
||||||
|
{ /* Quiet NaN. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0xFFFF, 0xC3333333, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%Le", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
/* Signalling NaN. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0xFFFF, 0x83333333, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%Le", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 2;
|
||||||
|
}
|
||||||
|
{ /* Pseudo-NaN. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0xFFFF, 0x40000001, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) <= 0)
|
||||||
|
result |= 4;
|
||||||
|
if (sprintf (buf, "%Le", x.value) <= 0)
|
||||||
|
result |= 4;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) <= 0)
|
||||||
|
result |= 4;
|
||||||
|
}
|
||||||
|
{ /* Pseudo-Infinity. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0xFFFF, 0x00000000, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) <= 0)
|
||||||
|
result |= 8;
|
||||||
|
if (sprintf (buf, "%Le", x.value) <= 0)
|
||||||
|
result |= 8;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) <= 0)
|
||||||
|
result |= 8;
|
||||||
|
}
|
||||||
|
{ /* Pseudo-Zero. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0x4004, 0x00000000, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) <= 0)
|
||||||
|
result |= 16;
|
||||||
|
if (sprintf (buf, "%Le", x.value) <= 0)
|
||||||
|
result |= 16;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) <= 0)
|
||||||
|
result |= 16;
|
||||||
|
}
|
||||||
|
{ /* Unnormalized number. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0x4000, 0x63333333, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) <= 0)
|
||||||
|
result |= 32;
|
||||||
|
if (sprintf (buf, "%Le", x.value) <= 0)
|
||||||
|
result |= 32;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) <= 0)
|
||||||
|
result |= 32;
|
||||||
|
}
|
||||||
|
{ /* Pseudo-Denormal. */
|
||||||
|
static union { unsigned int word[4]; long double value; } x =
|
||||||
|
{ LDBL80_WORDS (0x0000, 0x83333333, 0x00000000) };
|
||||||
|
if (sprintf (buf, "%Lf", x.value) <= 0)
|
||||||
|
result |= 64;
|
||||||
|
if (sprintf (buf, "%Le", x.value) <= 0)
|
||||||
|
result |= 64;
|
||||||
|
if (sprintf (buf, "%Lg", x.value) <= 0)
|
||||||
|
result |= 64;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
'''
|
||||||
|
endif
|
||||||
|
|
||||||
|
printf_infinite_long_double_test = '''
|
||||||
|
#include <float.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static int
|
||||||
|
strisnan (const char *string, size_t start_index, size_t end_index)
|
||||||
|
{
|
||||||
|
if (start_index < end_index)
|
||||||
|
{
|
||||||
|
if (string[start_index] == '-')
|
||||||
|
start_index++;
|
||||||
|
if (start_index + 3 <= end_index
|
||||||
|
&& memcmp (string + start_index, "nan", 3) == 0)
|
||||||
|
{
|
||||||
|
start_index += 3;
|
||||||
|
if (start_index == end_index
|
||||||
|
|| (string[start_index] == '(' && string[end_index - 1] == ')'))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
static char buf[10000];
|
||||||
|
static long double zeroL = 0.0L;
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
nocrash_init();
|
||||||
|
if (sprintf (buf, "%Lf", 1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Lf", -1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Lf", zeroL / zeroL) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Le", 1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Le", -1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Le", zeroL / zeroL) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Lg", 1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "inf") != 0 && strcmp (buf, "infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Lg", -1.0L / zeroL) < 0
|
||||||
|
|| (strcmp (buf, "-inf") != 0 && strcmp (buf, "-infinity") != 0))
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%Lg", zeroL / zeroL) < 0
|
||||||
|
|| !strisnan (buf, 0, strlen (buf)))
|
||||||
|
result |= 1;
|
||||||
|
''' + check_print_safe + '''
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if gl_cv_func_printf_long_double
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_infinite_long_double_test,
|
||||||
|
name : 'printf supports infinite \'long double\' arguments')
|
||||||
|
gl_cv_func_printf_infinite_long_double = (run_result.compiled() and run_result.returncode() == 0) ? 'true' : 'false'
|
||||||
|
else
|
||||||
|
if host_machine.cpu_family() == 'x86_64'
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'false'
|
||||||
|
else
|
||||||
|
if host_system == 'linux'
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'true'
|
||||||
|
elif (host_system.startswith ('freebsd1') or
|
||||||
|
host_system.startswith ('freebsd2') or
|
||||||
|
host_system.startswith ('freebsd3') or
|
||||||
|
host_system.startswith ('freebsd4') or
|
||||||
|
host_system.startswith ('freebsd5'))
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'false'
|
||||||
|
elif (host_system.startswith ('freebsd') or
|
||||||
|
host_system.startswith ('kfreebsd'))
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'true'
|
||||||
|
elif (host_system.startswith ('hpux7') or
|
||||||
|
host_system.startswith ('hpux8') or
|
||||||
|
host_system.startswith ('hpux9') or
|
||||||
|
host_system.startswith ('hpux10'))
|
||||||
|
gl_cv_func_printf_infinite = false
|
||||||
|
elif host_system.startswith ('hpux')
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'true'
|
||||||
|
elif host_system == 'windows'
|
||||||
|
# Guess yes on MSVC, no on mingw.
|
||||||
|
if cc.get_id() == 'msvc'
|
||||||
|
gl_cv_func_printf_infinite = 'true'
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_infinite = 'false'
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'false'
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_infinite_long_double = 'irrelevant'
|
||||||
|
endif
|
50
glib/gnulib/gl_cv_func_printf_long_double/meson.build
Normal file
50
glib/gnulib/gl_cv_func_printf_long_double/meson.build
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports 'long double'
|
||||||
|
# arguments together with the 'L' size specifier. (ISO C99, POSIX:2001)
|
||||||
|
# Result is gl_cv_func_printf_long_double.
|
||||||
|
|
||||||
|
printf_long_double_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[10000];
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%Lf %d", 1.75L, 33, 44, 55) < 0
|
||||||
|
|| strcmp (buf, "1.750000 33") != 0)
|
||||||
|
result |= 1;
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%Le %d", 1.75L, 33, 44, 55) < 0
|
||||||
|
|| strcmp (buf, "1.750000e+00 33") != 0)
|
||||||
|
result |= 2;
|
||||||
|
buf[0] = '\0';
|
||||||
|
if (sprintf (buf, "%Lg %d", 1.75L, 33, 44, 55) < 0
|
||||||
|
|| strcmp (buf, "1.75 33") != 0)
|
||||||
|
result |= 4;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_long_double_test,
|
||||||
|
name : 'printf supports \'long double\' arguments')
|
||||||
|
gl_cv_func_printf_long_double = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
if host_system.startswith ('beos')
|
||||||
|
gl_cv_func_printf_long_double = false
|
||||||
|
elif host_system == 'windows'
|
||||||
|
# Guess yes on MSVC, no on mingw.
|
||||||
|
if cc.get_id() == 'msvc'
|
||||||
|
gl_cv_func_printf_long_double = true
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_long_double = false
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_long_double = true
|
||||||
|
endif
|
||||||
|
endif
|
54
glib/gnulib/gl_cv_func_printf_precision/meson.build
Normal file
54
glib/gnulib/gl_cv_func_printf_precision/meson.build
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Test whether the *printf family of functions supports large precisions.
|
||||||
|
# On mingw, precisions larger than 512 are treated like 512, in integer,
|
||||||
|
# floating-point or pointer output. On Solaris 10/x86, precisions larger
|
||||||
|
# than 510 in floating-point output crash the program. On Solaris 10/SPARC,
|
||||||
|
# precisions larger than 510 in floating-point output yield wrong results.
|
||||||
|
# On AIX 7.1, precisions larger than 998 in floating-point output yield
|
||||||
|
# wrong results. On BeOS, precisions larger than 1044 crash the program.
|
||||||
|
# Result is gl_cv_func_printf_precision.
|
||||||
|
|
||||||
|
printf_precision_test = '''
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
static char buf[5000];
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
int result = 0;
|
||||||
|
#ifdef __BEOS__
|
||||||
|
/* On BeOS, this would crash and show a dialog box. Avoid the crash. */
|
||||||
|
return 1;
|
||||||
|
#endif
|
||||||
|
if (sprintf (buf, "%.4000d %d", 1, 33, 44) < 4000 + 3)
|
||||||
|
result |= 1;
|
||||||
|
if (sprintf (buf, "%.4000f %d", 1.0, 33, 44) < 4000 + 5)
|
||||||
|
result |= 2;
|
||||||
|
if (sprintf (buf, "%.511f %d", 1.0, 33, 44) < 511 + 5
|
||||||
|
|| buf[0] != '1')
|
||||||
|
result |= 4;
|
||||||
|
if (sprintf (buf, "%.999f %d", 1.0, 33, 44) < 999 + 5
|
||||||
|
|| buf[0] != '1')
|
||||||
|
result |= 4;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
if not meson.is_cross_build() or meson.has_exe_wrapper()
|
||||||
|
run_result = cc.run(printf_precision_test,
|
||||||
|
name : 'printf supports large precisions')
|
||||||
|
gl_cv_func_printf_precision = run_result.compiled() and run_result.returncode() == 0
|
||||||
|
else
|
||||||
|
gl_cv_func_printf_precision = true
|
||||||
|
# Guess no only on Solaris, native Windows, and BeOS systems.
|
||||||
|
if (host_system == 'windows' or
|
||||||
|
host_system == 'beos' or
|
||||||
|
host_system == 'haiku' or
|
||||||
|
host_system == 'sunos' or
|
||||||
|
host_system == 'solaris')
|
||||||
|
gl_cv_func_printf_precision = false
|
||||||
|
endif
|
||||||
|
endif
|
24
glib/gnulib/gl_cv_long_double_equals_double/meson.build
Normal file
24
glib/gnulib/gl_cv_long_double_equals_double/meson.build
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# gl_LONG_DOUBLE_VS_DOUBLE
|
||||||
|
# determines whether 'long double' and 'double' have the same representation.
|
||||||
|
# The currently known platforms where this is the case are:
|
||||||
|
# Linux/HPPA, Minix 3.1.8, AIX 5, AIX 6 and 7 with xlc, MSVC 9.
|
||||||
|
|
||||||
|
long_double_eq_double_test = '''
|
||||||
|
#include <float.h>
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
typedef int check[sizeof (long double) == sizeof (double)
|
||||||
|
&& LDBL_MANT_DIG == DBL_MANT_DIG
|
||||||
|
&& LDBL_MAX_EXP == DBL_MAX_EXP
|
||||||
|
&& LDBL_MIN_EXP == DBL_MIN_EXP
|
||||||
|
? 1 : -1];
|
||||||
|
return check;
|
||||||
|
}
|
||||||
|
'''
|
||||||
|
|
||||||
|
gl_cv_long_double_equals_double = cc.compiles(long_double_eq_double_test)
|
103
glib/gnulib/gl_extern_inline/meson.build
Normal file
103
glib/gnulib/gl_extern_inline/meson.build
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
# Copyright (C) 2002-2004, 2006-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# Copyright 2012-2018 Free Software Foundation, Inc.
|
||||||
|
# This file is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
gl_extern_inline = '''
|
||||||
|
/* Please see the Gnulib manual for how to use these macros.
|
||||||
|
|
||||||
|
Suppress extern inline with HP-UX cc, as it appears to be broken; see
|
||||||
|
<https://lists.gnu.org/r/bug-texinfo/2013-02/msg00030.html>.
|
||||||
|
|
||||||
|
Suppress extern inline with Sun C in standards-conformance mode, as it
|
||||||
|
mishandles inline functions that call each other. E.g., for 'inline void f
|
||||||
|
(void) { } inline void g (void) { f (); }', c99 incorrectly complains
|
||||||
|
'reference to static identifier "f" in extern inline function'.
|
||||||
|
This bug was observed with Sun C 5.12 SunOS_i386 2011/11/16.
|
||||||
|
|
||||||
|
Suppress extern inline (with or without __attribute__ ((__gnu_inline__)))
|
||||||
|
on configurations that mistakenly use 'static inline' to implement
|
||||||
|
functions or macros in standard C headers like <ctype.h>. For example,
|
||||||
|
if isdigit is mistakenly implemented via a static inline function,
|
||||||
|
a program containing an extern inline function that calls isdigit
|
||||||
|
may not work since the C standard prohibits extern inline functions
|
||||||
|
from calling static functions. This bug is known to occur on:
|
||||||
|
|
||||||
|
OS X 10.8 and earlier; see:
|
||||||
|
https://lists.gnu.org/r/bug-gnulib/2012-12/msg00023.html
|
||||||
|
|
||||||
|
DragonFly; see
|
||||||
|
http://muscles.dragonflybsd.org/bulk/bleeding-edge-potential/latest-per-pkg/ah-tty-0.3.12.log
|
||||||
|
|
||||||
|
FreeBSD; see:
|
||||||
|
https://lists.gnu.org/r/bug-gnulib/2014-07/msg00104.html
|
||||||
|
|
||||||
|
OS X 10.9 has a macro __header_inline indicating the bug is fixed for C and
|
||||||
|
for clang but remains for g++; see <https://trac.macports.org/ticket/41033>.
|
||||||
|
Assume DragonFly and FreeBSD will be similar. */
|
||||||
|
#if (((defined __APPLE__ && defined __MACH__) \
|
||||||
|
|| defined __DragonFly__ || defined __FreeBSD__) \
|
||||||
|
&& (defined __header_inline \
|
||||||
|
? (defined __cplusplus && defined __GNUC_STDC_INLINE__ \
|
||||||
|
&& ! defined __clang__) \
|
||||||
|
: ((! defined _DONT_USE_CTYPE_INLINE_ \
|
||||||
|
&& (defined __GNUC__ || defined __cplusplus)) \
|
||||||
|
|| (defined _FORTIFY_SOURCE && 0 < _FORTIFY_SOURCE \
|
||||||
|
&& defined __GNUC__ && ! defined __cplusplus))))
|
||||||
|
# define _GL_EXTERN_INLINE_STDHEADER_BUG
|
||||||
|
#endif
|
||||||
|
#if ((__GNUC__ \
|
||||||
|
? defined __GNUC_STDC_INLINE__ && __GNUC_STDC_INLINE__ \
|
||||||
|
: (199901L <= __STDC_VERSION__ \
|
||||||
|
&& !defined __HP_cc \
|
||||||
|
&& !defined __PGI \
|
||||||
|
&& !(defined __SUNPRO_C && __STDC__))) \
|
||||||
|
&& !defined _GL_EXTERN_INLINE_STDHEADER_BUG)
|
||||||
|
# define _GL_INLINE inline
|
||||||
|
# define _GL_EXTERN_INLINE extern inline
|
||||||
|
# define _GL_EXTERN_INLINE_IN_USE
|
||||||
|
#elif (2 < __GNUC__ + (7 <= __GNUC_MINOR__) && !defined __STRICT_ANSI__ \
|
||||||
|
&& !defined _GL_EXTERN_INLINE_STDHEADER_BUG)
|
||||||
|
# if defined __GNUC_GNU_INLINE__ && __GNUC_GNU_INLINE__
|
||||||
|
/* __gnu_inline__ suppresses a GCC 4.2 diagnostic. */
|
||||||
|
# define _GL_INLINE extern inline __attribute__ ((__gnu_inline__)) __attribute__ ((always_inline))
|
||||||
|
# else
|
||||||
|
# define _GL_INLINE extern inline
|
||||||
|
# endif
|
||||||
|
# define _GL_EXTERN_INLINE extern
|
||||||
|
# define _GL_EXTERN_INLINE_IN_USE
|
||||||
|
#else
|
||||||
|
# define _GL_INLINE static _GL_UNUSED
|
||||||
|
# define _GL_EXTERN_INLINE static _GL_UNUSED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* In GCC 4.6 (inclusive) to 5.1 (exclusive),
|
||||||
|
suppress bogus "no previous prototype for 'FOO'"
|
||||||
|
and "no previous declaration for 'FOO'" diagnostics,
|
||||||
|
when FOO is an inline function in the header; see
|
||||||
|
<https://gcc.gnu.org/bugzilla/show_bug.cgi?id=54113> and
|
||||||
|
<https://gcc.gnu.org/bugzilla/show_bug.cgi?id=63877>. */
|
||||||
|
#if __GNUC__ == 4 && 6 <= __GNUC_MINOR__
|
||||||
|
# if defined __GNUC_STDC_INLINE__ && __GNUC_STDC_INLINE__
|
||||||
|
# define _GL_INLINE_HEADER_CONST_PRAGMA
|
||||||
|
# else
|
||||||
|
# define _GL_INLINE_HEADER_CONST_PRAGMA \
|
||||||
|
_Pragma ("GCC diagnostic ignored \"-Wsuggest-attribute=const\"")
|
||||||
|
# endif
|
||||||
|
# define _GL_INLINE_HEADER_BEGIN \
|
||||||
|
_Pragma ("GCC diagnostic push") \
|
||||||
|
_Pragma ("GCC diagnostic ignored \"-Wmissing-prototypes\"") \
|
||||||
|
_Pragma ("GCC diagnostic ignored \"-Wmissing-declarations\"") \
|
||||||
|
_GL_INLINE_HEADER_CONST_PRAGMA
|
||||||
|
# define _GL_INLINE_HEADER_END \
|
||||||
|
_Pragma ("GCC diagnostic pop")
|
||||||
|
#else
|
||||||
|
# define _GL_INLINE_HEADER_BEGIN
|
||||||
|
# define _GL_INLINE_HEADER_END
|
||||||
|
#endif
|
||||||
|
'''
|
2451
glib/gnulib/gnulib_math.h.in
Normal file
2451
glib/gnulib/gnulib_math.h.in
Normal file
File diff suppressed because it is too large
Load Diff
189
glib/gnulib/isnan.c
Normal file
189
glib/gnulib/isnan.c
Normal file
@ -0,0 +1,189 @@
|
|||||||
|
/* Test for NaN that does not need libm.
|
||||||
|
Copyright (C) 2007-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* Written by Bruno Haible <bruno@clisp.org>, 2007. */
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
/* Specification. */
|
||||||
|
#ifdef USE_LONG_DOUBLE
|
||||||
|
/* Specification found in math.h or isnanl-nolibm.h. */
|
||||||
|
extern int rpl_isnanl (long double x) _GL_ATTRIBUTE_CONST;
|
||||||
|
#elif ! defined USE_FLOAT
|
||||||
|
/* Specification found in math.h or isnand-nolibm.h. */
|
||||||
|
extern int rpl_isnand (double x);
|
||||||
|
#else /* defined USE_FLOAT */
|
||||||
|
/* Specification found in math.h or isnanf-nolibm.h. */
|
||||||
|
extern int rpl_isnanf (float x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <float.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "float+.h"
|
||||||
|
|
||||||
|
#ifdef USE_LONG_DOUBLE
|
||||||
|
# define FUNC rpl_isnanl
|
||||||
|
# define DOUBLE long double
|
||||||
|
# define MAX_EXP LDBL_MAX_EXP
|
||||||
|
# define MIN_EXP LDBL_MIN_EXP
|
||||||
|
# if defined LDBL_EXPBIT0_WORD && defined LDBL_EXPBIT0_BIT
|
||||||
|
# define KNOWN_EXPBIT0_LOCATION
|
||||||
|
# define EXPBIT0_WORD LDBL_EXPBIT0_WORD
|
||||||
|
# define EXPBIT0_BIT LDBL_EXPBIT0_BIT
|
||||||
|
# endif
|
||||||
|
# define SIZE SIZEOF_LDBL
|
||||||
|
# define L_(literal) literal##L
|
||||||
|
#elif ! defined USE_FLOAT
|
||||||
|
# define FUNC rpl_isnand
|
||||||
|
# define DOUBLE double
|
||||||
|
# define MAX_EXP DBL_MAX_EXP
|
||||||
|
# define MIN_EXP DBL_MIN_EXP
|
||||||
|
# if defined DBL_EXPBIT0_WORD && defined DBL_EXPBIT0_BIT
|
||||||
|
# define KNOWN_EXPBIT0_LOCATION
|
||||||
|
# define EXPBIT0_WORD DBL_EXPBIT0_WORD
|
||||||
|
# define EXPBIT0_BIT DBL_EXPBIT0_BIT
|
||||||
|
# endif
|
||||||
|
# define SIZE SIZEOF_DBL
|
||||||
|
# define L_(literal) literal
|
||||||
|
#else /* defined USE_FLOAT */
|
||||||
|
# define FUNC rpl_isnanf
|
||||||
|
# define DOUBLE float
|
||||||
|
# define MAX_EXP FLT_MAX_EXP
|
||||||
|
# define MIN_EXP FLT_MIN_EXP
|
||||||
|
# if defined FLT_EXPBIT0_WORD && defined FLT_EXPBIT0_BIT
|
||||||
|
# define KNOWN_EXPBIT0_LOCATION
|
||||||
|
# define EXPBIT0_WORD FLT_EXPBIT0_WORD
|
||||||
|
# define EXPBIT0_BIT FLT_EXPBIT0_BIT
|
||||||
|
# endif
|
||||||
|
# define SIZE SIZEOF_FLT
|
||||||
|
# define L_(literal) literal##f
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define EXP_MASK ((MAX_EXP - MIN_EXP) | 7)
|
||||||
|
|
||||||
|
#define NWORDS \
|
||||||
|
((sizeof (DOUBLE) + sizeof (unsigned int) - 1) / sizeof (unsigned int))
|
||||||
|
typedef union { DOUBLE value; unsigned int word[NWORDS]; } memory_double;
|
||||||
|
|
||||||
|
/* Most hosts nowadays use IEEE floating point, so they use IEC 60559
|
||||||
|
representations, have infinities and NaNs, and do not trap on
|
||||||
|
exceptions. Define IEEE_FLOATING_POINT if this host is one of the
|
||||||
|
typical ones. The C11 macro __STDC_IEC_559__ is close to what is
|
||||||
|
wanted here, but is not quite right because this file does not require
|
||||||
|
all the features of C11 Annex F (and does not require C11 at all,
|
||||||
|
for that matter). */
|
||||||
|
|
||||||
|
#define IEEE_FLOATING_POINT (FLT_RADIX == 2 && FLT_MANT_DIG == 24 \
|
||||||
|
&& FLT_MIN_EXP == -125 && FLT_MAX_EXP == 128)
|
||||||
|
|
||||||
|
int
|
||||||
|
FUNC (DOUBLE x)
|
||||||
|
{
|
||||||
|
#if defined KNOWN_EXPBIT0_LOCATION && IEEE_FLOATING_POINT
|
||||||
|
# if defined USE_LONG_DOUBLE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
|
||||||
|
/* Special CPU dependent code is needed to treat bit patterns outside the
|
||||||
|
IEEE 754 specification (such as Pseudo-NaNs, Pseudo-Infinities,
|
||||||
|
Pseudo-Zeroes, Unnormalized Numbers, and Pseudo-Denormals) as NaNs.
|
||||||
|
These bit patterns are:
|
||||||
|
- exponent = 0x0001..0x7FFF, mantissa bit 63 = 0,
|
||||||
|
- exponent = 0x0000, mantissa bit 63 = 1.
|
||||||
|
The NaN bit pattern is:
|
||||||
|
- exponent = 0x7FFF, mantissa >= 0x8000000000000001. */
|
||||||
|
memory_double m;
|
||||||
|
unsigned int exponent;
|
||||||
|
|
||||||
|
m.value = x;
|
||||||
|
exponent = (m.word[EXPBIT0_WORD] >> EXPBIT0_BIT) & EXP_MASK;
|
||||||
|
# ifdef WORDS_BIGENDIAN
|
||||||
|
/* Big endian: EXPBIT0_WORD = 0, EXPBIT0_BIT = 16. */
|
||||||
|
if (exponent == 0)
|
||||||
|
return 1 & (m.word[0] >> 15);
|
||||||
|
else if (exponent == EXP_MASK)
|
||||||
|
return (((m.word[0] ^ 0x8000U) << 16) | m.word[1] | (m.word[2] >> 16)) != 0;
|
||||||
|
else
|
||||||
|
return 1 & ~(m.word[0] >> 15);
|
||||||
|
# else
|
||||||
|
/* Little endian: EXPBIT0_WORD = 2, EXPBIT0_BIT = 0. */
|
||||||
|
if (exponent == 0)
|
||||||
|
return (m.word[1] >> 31);
|
||||||
|
else if (exponent == EXP_MASK)
|
||||||
|
return ((m.word[1] ^ 0x80000000U) | m.word[0]) != 0;
|
||||||
|
else
|
||||||
|
return (m.word[1] >> 31) ^ 1;
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
/* Be careful to not do any floating-point operation on x, such as x == x,
|
||||||
|
because x may be a signaling NaN. */
|
||||||
|
# if defined __SUNPRO_C || defined __ICC || defined _MSC_VER \
|
||||||
|
|| defined __DECC || defined __TINYC__ \
|
||||||
|
|| (defined __sgi && !defined __GNUC__)
|
||||||
|
/* The Sun C 5.0, Intel ICC 10.0, Microsoft Visual C/C++ 9.0, Compaq (ex-DEC)
|
||||||
|
6.4, and TinyCC compilers don't recognize the initializers as constant
|
||||||
|
expressions. The Compaq compiler also fails when constant-folding
|
||||||
|
0.0 / 0.0 even when constant-folding is not required. The Microsoft
|
||||||
|
Visual C/C++ compiler also fails when constant-folding 1.0 / 0.0 even
|
||||||
|
when constant-folding is not required. The SGI MIPSpro C compiler
|
||||||
|
complains about "floating-point operation result is out of range". */
|
||||||
|
static DOUBLE zero = L_(0.0);
|
||||||
|
memory_double nan;
|
||||||
|
DOUBLE plus_inf = L_(1.0) / zero;
|
||||||
|
DOUBLE minus_inf = -L_(1.0) / zero;
|
||||||
|
nan.value = zero / zero;
|
||||||
|
# else
|
||||||
|
static memory_double nan = { L_(0.0) / L_(0.0) };
|
||||||
|
static DOUBLE plus_inf = L_(1.0) / L_(0.0);
|
||||||
|
static DOUBLE minus_inf = -L_(1.0) / L_(0.0);
|
||||||
|
# endif
|
||||||
|
{
|
||||||
|
memory_double m;
|
||||||
|
|
||||||
|
/* A NaN can be recognized through its exponent. But exclude +Infinity and
|
||||||
|
-Infinity, which have the same exponent. */
|
||||||
|
m.value = x;
|
||||||
|
if (((m.word[EXPBIT0_WORD] ^ nan.word[EXPBIT0_WORD])
|
||||||
|
& (EXP_MASK << EXPBIT0_BIT))
|
||||||
|
== 0)
|
||||||
|
return (memcmp (&m.value, &plus_inf, SIZE) != 0
|
||||||
|
&& memcmp (&m.value, &minus_inf, SIZE) != 0);
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
/* The configuration did not find sufficient information, or does
|
||||||
|
not use IEEE floating point. Give up about the signaling NaNs;
|
||||||
|
handle only the quiet NaNs. */
|
||||||
|
if (x == x)
|
||||||
|
{
|
||||||
|
# if defined USE_LONG_DOUBLE && ((defined __ia64 && LDBL_MANT_DIG == 64) || (defined __x86_64__ || defined __amd64__) || (defined __i386 || defined __i386__ || defined _I386 || defined _M_IX86 || defined _X86_)) && !HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
|
||||||
|
/* Detect any special bit patterns that pass ==; see comment above. */
|
||||||
|
memory_double m1;
|
||||||
|
memory_double m2;
|
||||||
|
|
||||||
|
memset (&m1.value, 0, SIZE);
|
||||||
|
memset (&m2.value, 0, SIZE);
|
||||||
|
m1.value = x;
|
||||||
|
m2.value = x + (x ? 0.0L : -0.0L);
|
||||||
|
if (memcmp (&m1.value, &m2.value, SIZE) != 0)
|
||||||
|
return 1;
|
||||||
|
# endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return 1;
|
||||||
|
#endif
|
||||||
|
}
|
33
glib/gnulib/isnand-nolibm.h
Normal file
33
glib/gnulib/isnand-nolibm.h
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/* Test for NaN that does not need libm.
|
||||||
|
Copyright (C) 2007-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#if HAVE_ISNAND_IN_LIBC
|
||||||
|
/* Get declaration of isnan macro. */
|
||||||
|
# include <gnulib_math.h>
|
||||||
|
# if __GNUC__ >= 4
|
||||||
|
/* GCC 4.0 and newer provides three built-ins for isnan. */
|
||||||
|
# undef isnand
|
||||||
|
# define isnand(x) __builtin_isnan ((double)(x))
|
||||||
|
# else
|
||||||
|
# undef isnand
|
||||||
|
# define isnand(x) isnan ((double)(x))
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
/* Test whether X is a NaN. */
|
||||||
|
# undef isnand
|
||||||
|
# define isnand rpl_isnand
|
||||||
|
extern int isnand (double x);
|
||||||
|
#endif
|
22
glib/gnulib/isnand.c
Normal file
22
glib/gnulib/isnand.c
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
/* Test for NaN that does not need libm.
|
||||||
|
Copyright (C) 2008-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* Written by Bruno Haible <bruno@clisp.org>, 2008. */
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
#include "gnulib_math.h"
|
||||||
|
#include "isnand-nolibm.h"
|
||||||
|
#include "isnan.c"
|
33
glib/gnulib/isnanl-nolibm.h
Normal file
33
glib/gnulib/isnanl-nolibm.h
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/* Test for NaN that does not need libm.
|
||||||
|
Copyright (C) 2007-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#if HAVE_ISNANL_IN_LIBC
|
||||||
|
/* Get declaration of isnan macro or (older) isnanl function. */
|
||||||
|
# include <gnulib_math.h>
|
||||||
|
# if __GNUC__ >= 4
|
||||||
|
/* GCC 4.0 and newer provides three built-ins for isnan. */
|
||||||
|
# undef isnanl
|
||||||
|
# define isnanl(x) __builtin_isnanl ((long double)(x))
|
||||||
|
# elif defined isnan
|
||||||
|
# undef isnanl
|
||||||
|
# define isnanl(x) isnan ((long double)(x))
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
/* Test whether X is a NaN. */
|
||||||
|
# undef isnanl
|
||||||
|
# define isnanl rpl_isnanl
|
||||||
|
extern int isnanl (long double x);
|
||||||
|
#endif
|
23
glib/gnulib/isnanl.c
Normal file
23
glib/gnulib/isnanl.c
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/* Test for NaN that does not need libm.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* Written by Bruno Haible <bruno@clisp.org>, 2007. */
|
||||||
|
|
||||||
|
#define USE_LONG_DOUBLE
|
||||||
|
#include <config.h>
|
||||||
|
#include "gnulib_math.h"
|
||||||
|
#include "isnanl-nolibm.h"
|
||||||
|
#include "isnan.c"
|
@ -3,7 +3,314 @@
|
|||||||
extra_gnulib_args = cc.get_supported_arguments([
|
extra_gnulib_args = cc.get_supported_arguments([
|
||||||
'-Wno-format-nonliteral', '-Wno-duplicated-branches'])
|
'-Wno-format-nonliteral', '-Wno-duplicated-branches'])
|
||||||
|
|
||||||
gnulib_lib = static_library('gnulib', 'asnprintf.c', 'printf.c', 'printf-args.c', 'printf-parse.c', 'vasnprintf.c',
|
math_h_config = configuration_data ()
|
||||||
include_directories : [configinc, glibinc],
|
|
||||||
|
unneeded_funcs = [
|
||||||
|
'ACOSF',
|
||||||
|
'ACOSL',
|
||||||
|
'ASINF',
|
||||||
|
'ASINL',
|
||||||
|
'ATAN2F',
|
||||||
|
'ATANF',
|
||||||
|
'ATANL',
|
||||||
|
'CBRT',
|
||||||
|
'CBRTF',
|
||||||
|
'CBRTL',
|
||||||
|
'CEIL',
|
||||||
|
'CEILF',
|
||||||
|
'CEILL',
|
||||||
|
'COPYSIGN',
|
||||||
|
'COPYSIGNF',
|
||||||
|
'COPYSIGNL',
|
||||||
|
'COSF',
|
||||||
|
'COSHF',
|
||||||
|
'COSL',
|
||||||
|
'EXP2',
|
||||||
|
'EXP2F',
|
||||||
|
'EXP2L',
|
||||||
|
'EXPF',
|
||||||
|
'EXPL',
|
||||||
|
'EXPM1',
|
||||||
|
'EXPM1F',
|
||||||
|
'EXPM1L',
|
||||||
|
'FABSF',
|
||||||
|
'FABSL',
|
||||||
|
'FLOOR',
|
||||||
|
'FLOORF',
|
||||||
|
'FLOORL',
|
||||||
|
'FMA',
|
||||||
|
'FMAF',
|
||||||
|
'FMAL',
|
||||||
|
'FMOD',
|
||||||
|
'FMODF',
|
||||||
|
'FMODL',
|
||||||
|
'FREXPF',
|
||||||
|
'HYPOT',
|
||||||
|
'HYPOTF',
|
||||||
|
'HYPOTL',
|
||||||
|
'ILOGB',
|
||||||
|
'ILOGBF',
|
||||||
|
'ILOGBL',
|
||||||
|
'ISFINITE',
|
||||||
|
'ISINF',
|
||||||
|
'ISNAN',
|
||||||
|
'ISNANF',
|
||||||
|
'LDEXPF',
|
||||||
|
'LOG',
|
||||||
|
'LOG10',
|
||||||
|
'LOG10F',
|
||||||
|
'LOG10L',
|
||||||
|
'LOG1P',
|
||||||
|
'LOG1PF',
|
||||||
|
'LOG1PL',
|
||||||
|
'LOG2',
|
||||||
|
'LOG2F',
|
||||||
|
'LOG2L',
|
||||||
|
'LOGB',
|
||||||
|
'LOGBF',
|
||||||
|
'LOGBL',
|
||||||
|
'LOGF',
|
||||||
|
'LOGL',
|
||||||
|
'MODF',
|
||||||
|
'MODFF',
|
||||||
|
'MODFL',
|
||||||
|
'POWF',
|
||||||
|
'REMAINDER',
|
||||||
|
'REMAINDERF',
|
||||||
|
'REMAINDERL',
|
||||||
|
'RINT',
|
||||||
|
'RINTF',
|
||||||
|
'RINTL',
|
||||||
|
'ROUND',
|
||||||
|
'ROUNDF',
|
||||||
|
'ROUNDL',
|
||||||
|
'SIGNBIT',
|
||||||
|
'SINF',
|
||||||
|
'SINHF',
|
||||||
|
'SINL',
|
||||||
|
'SQRTF',
|
||||||
|
'SQRTL',
|
||||||
|
'TANF',
|
||||||
|
'TANHF',
|
||||||
|
'TANL',
|
||||||
|
'TRUNC',
|
||||||
|
'TRUNCF',
|
||||||
|
'TRUNCL',
|
||||||
|
]
|
||||||
|
|
||||||
|
foreach f : unneeded_funcs
|
||||||
|
math_h_config.set ('GNULIB_' + f, 0)
|
||||||
|
# These are not used in practice, guarded by
|
||||||
|
# the appropriate GNULIB_*, but meson config
|
||||||
|
# processor doesn't know that
|
||||||
|
math_h_config.set ('HAVE_' + f, 'variable not used')
|
||||||
|
math_h_config.set ('REPLACE_' + f, 'variable not used')
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
needed_funcs = [
|
||||||
|
'FREXP',
|
||||||
|
'FREXPL',
|
||||||
|
'ISNAND',
|
||||||
|
'ISNANL',
|
||||||
|
'LDEXPL',
|
||||||
|
]
|
||||||
|
|
||||||
|
foreach f : needed_funcs
|
||||||
|
math_h_config.set ('GNULIB_' + f, 1)
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
math_h_config.set ('GUARD_PREFIX', 'GL')
|
||||||
|
|
||||||
|
decls_for_unused_funcs = [
|
||||||
|
'ACOSL',
|
||||||
|
'ASINL',
|
||||||
|
'ATANL',
|
||||||
|
'CBRTF',
|
||||||
|
'CBRTL',
|
||||||
|
'CEILF',
|
||||||
|
'CEILL',
|
||||||
|
'COPYSIGNF',
|
||||||
|
'COSL',
|
||||||
|
'EXP2',
|
||||||
|
'EXP2F',
|
||||||
|
'EXP2L',
|
||||||
|
'EXPL',
|
||||||
|
'EXPM1L',
|
||||||
|
'FLOORF',
|
||||||
|
'FLOORL',
|
||||||
|
'LOG10L',
|
||||||
|
'LOG2',
|
||||||
|
'LOG2F',
|
||||||
|
'LOG2L',
|
||||||
|
'LOGB',
|
||||||
|
'LOGL',
|
||||||
|
'REMAINDER',
|
||||||
|
'REMAINDERL',
|
||||||
|
'RINTF',
|
||||||
|
'ROUND',
|
||||||
|
'ROUNDF',
|
||||||
|
'ROUNDL',
|
||||||
|
'SINL',
|
||||||
|
'SQRTL',
|
||||||
|
'TANL',
|
||||||
|
'TRUNC',
|
||||||
|
'TRUNCF',
|
||||||
|
'TRUNCL',
|
||||||
|
]
|
||||||
|
|
||||||
|
foreach f : decls_for_unused_funcs
|
||||||
|
math_h_config.set ('HAVE_DECL_' + f, 0)
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
decls_for_used_funcs = [
|
||||||
|
'frexpl',
|
||||||
|
'ldexpl',
|
||||||
|
]
|
||||||
|
|
||||||
|
foreach f : decls_for_used_funcs
|
||||||
|
compiles = cc.compiles('''#include <math.h>
|
||||||
|
int main ()
|
||||||
|
{
|
||||||
|
(void) @0@;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
'''.format (f))
|
||||||
|
math_h_config.set ('HAVE_DECL_' + f.to_upper (), compiles ? 1 : 0)
|
||||||
|
set_variable ('have_decl_' + f, compiles ? true : false)
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
nan_tmpl = '''#include <math.h>
|
||||||
|
#if __GNUC__ >= 4
|
||||||
|
# undef @0@
|
||||||
|
# define @0@(x) __builtin_isnan ((@1@)(x))
|
||||||
|
#else
|
||||||
|
# undef @0@
|
||||||
|
# define @0@(x) isnan ((@1@)(x))
|
||||||
|
#endif
|
||||||
|
double x;
|
||||||
|
int main () {return @0@ (x);}
|
||||||
|
'''
|
||||||
|
|
||||||
|
links = cc.links (nan_tmpl.format ('isnand', 'double'),
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_ISNAND', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_ISNAND_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_isnand', links)
|
||||||
|
|
||||||
|
links = cc.links (nan_tmpl.format ('isnanl', 'long double'),
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_ISNANL', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_ISNANL_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_isnanl', links)
|
||||||
|
|
||||||
|
links = cc.links ('''#include <math.h>
|
||||||
|
double x;
|
||||||
|
int y;
|
||||||
|
int main () {return ldexp (x, y) < 1;}
|
||||||
|
''',
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_LDEXP', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_LDEXP_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_ldexp', links)
|
||||||
|
|
||||||
|
links = cc.links ('''#include <math.h>
|
||||||
|
long double x;
|
||||||
|
int main () {return ldexpl (x, -1) > 0;}
|
||||||
|
''',
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_LDEXPL', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_LDEXPL_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_ldexpl', links)
|
||||||
|
|
||||||
|
links = cc.links ('''#include <math.h>
|
||||||
|
double x;
|
||||||
|
int main () {int e; return frexp (x, &e) > 0;}
|
||||||
|
''',
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_FREXP', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_FREXP_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_frexp', links)
|
||||||
|
|
||||||
|
links = cc.links ('''#include <math.h>
|
||||||
|
long double x;
|
||||||
|
int main () {int e; return frexpl (x, &e) > 0;}
|
||||||
|
''',
|
||||||
|
dependencies : [libm])
|
||||||
|
math_h_config.set ('HAVE_FREXPL', links ? 1 : 0)
|
||||||
|
math_h_config.set ('HAVE_FREXPL_IN_LIBC', links ? 1 : 0)
|
||||||
|
set_variable ('have_frexpl', links)
|
||||||
|
|
||||||
|
math_h_config.set ('INCLUDE_NEXT_AS_FIRST_DIRECTIVE', 'include')
|
||||||
|
math_h_config.set ('NEXT_AS_FIRST_DIRECTIVE_MATH_H', '<math.h>')
|
||||||
|
math_h_config.set ('PRAGMA_COLUMNS', '')
|
||||||
|
math_h_config.set ('PRAGMA_SYSTEM_HEADER', '')
|
||||||
|
|
||||||
|
compiles = cc.compiles ('''
|
||||||
|
#include <math.h>
|
||||||
|
/* Solaris 10 has a broken definition of NAN. Other platforms
|
||||||
|
fail to provide NAN, or provide it only in C99 mode; this
|
||||||
|
test only needs to fail when NAN is provided but wrong. */
|
||||||
|
int main () {
|
||||||
|
float f = 1.0f;
|
||||||
|
#ifdef NAN
|
||||||
|
f = NAN;
|
||||||
|
#endif
|
||||||
|
return f == 0;
|
||||||
|
}
|
||||||
|
''')
|
||||||
|
math_h_config.set ('REPLACE_NAN', compiles ? 0 : 1)
|
||||||
|
|
||||||
|
if have_frexp
|
||||||
|
subdir ('gl_cv_func_frexp_works')
|
||||||
|
else
|
||||||
|
gl_cv_func_frexp_works = false
|
||||||
|
gl_cv_func_frexp_broken_beyond_repair = true
|
||||||
|
endif
|
||||||
|
if have_frexpl
|
||||||
|
subdir ('gl_cv_func_frexpl_works')
|
||||||
|
else
|
||||||
|
gl_cv_func_frexpl_works = false
|
||||||
|
gl_cv_func_frexpl_broken_beyond_repair = true
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_frexp_works and gl_cv_func_frexp_broken_beyond_repair
|
||||||
|
error ('frexp() is missing or broken beyond repair, and we have nothing to replace it with')
|
||||||
|
endif
|
||||||
|
if not gl_cv_func_frexpl_works and gl_cv_func_frexpl_broken_beyond_repair
|
||||||
|
error ('frexpl() is missing or broken beyond repair, and we have nothing to replace it with')
|
||||||
|
endif
|
||||||
|
|
||||||
|
math_h_config.set ('REPLACE_FREXP', gl_cv_func_frexp_works ? 0 : 1)
|
||||||
|
math_h_config.set ('REPLACE_FREXPL', gl_cv_func_frexpl_works ? 0 : 1)
|
||||||
|
|
||||||
|
math_h_config.set ('REPLACE_ITOLD', 0)
|
||||||
|
math_h_config.set ('REPLACE_HUGE_VAL', 0)
|
||||||
|
math_h_config.set ('REPLACE_SIGNBIT_USING_GCC', 0)
|
||||||
|
|
||||||
|
if have_ldexpl
|
||||||
|
subdir ('gl_cv_func_ldexpl_works')
|
||||||
|
else
|
||||||
|
gl_cv_func_ldexpl_works = false
|
||||||
|
endif
|
||||||
|
math_h_config.set ('REPLACE_LDEXPL', gl_cv_func_ldexpl_works ? 0 : 1)
|
||||||
|
|
||||||
|
math_h = configure_file (input: 'gnulib_math.h.in',
|
||||||
|
output: 'gnulib_math.h',
|
||||||
|
configuration: math_h_config)
|
||||||
|
|
||||||
|
gnulib_sources = ['asnprintf.c', 'printf.c', 'printf-args.c', 'printf-parse.c', 'printf-frexp.c', 'printf-frexpl.c', 'isnand.c', 'isnanl.c', 'vasnprintf.c']
|
||||||
|
|
||||||
|
if not gl_cv_func_frexp_works
|
||||||
|
gnulib_sources += ['frexp.c']
|
||||||
|
endif
|
||||||
|
if not gl_cv_func_frexpl_works
|
||||||
|
gnulib_sources += ['frexpl.c']
|
||||||
|
endif
|
||||||
|
|
||||||
|
gnulib_lib = static_library('gnulib', gnulib_sources,
|
||||||
|
dependencies : [libm],
|
||||||
|
include_directories : [configinc, glibinc, include_directories ('.')],
|
||||||
pic : true,
|
pic : true,
|
||||||
c_args : [ '-DLIBDIR="@0@"'.format(get_option('libdir')), '-DGLIB_COMPILATION', '-DG_LOG_DOMAIN="GLib"' ] + glib_hidden_visibility_args + extra_gnulib_args)
|
c_args : ['-DGCC_LINT=1', '-DLIBDIR="@0@"'.format(get_option('libdir')), '-DGLIB_COMPILATION', '-DG_LOG_DOMAIN="GLib"' ] + glib_hidden_visibility_args + extra_gnulib_args)
|
||||||
|
|
||||||
|
gnulib_libm_dependency = [libm]
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* Decomposed printf argument list.
|
/* Decomposed printf argument list.
|
||||||
Copyright (C) 1999, 2002-2003, 2005-2007, 2009-2016 Free Software
|
Copyright (C) 1999, 2002-2003, 2005-2007, 2009-2019 Free Software
|
||||||
Foundation, Inc.
|
Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
@ -13,7 +13,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* This file can be parametrized with the following macros:
|
/* This file can be parametrized with the following macros:
|
||||||
ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions.
|
ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* Decomposed printf argument list.
|
/* Decomposed printf argument list.
|
||||||
Copyright (C) 1999, 2002-2003, 2006-2007, 2011-2016 Free Software
|
Copyright (C) 1999, 2002-2003, 2006-2007, 2011-2019 Free Software
|
||||||
Foundation, Inc.
|
Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
@ -13,7 +13,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#ifndef _PRINTF_ARGS_H
|
#ifndef _PRINTF_ARGS_H
|
||||||
#define _PRINTF_ARGS_H
|
#define _PRINTF_ARGS_H
|
||||||
|
190
glib/gnulib/printf-frexp.c
Normal file
190
glib/gnulib/printf-frexp.c
Normal file
@ -0,0 +1,190 @@
|
|||||||
|
/* Split a double into fraction and mantissa, for hexadecimal printf.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#if ! defined USE_LONG_DOUBLE
|
||||||
|
# include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Specification. */
|
||||||
|
#ifdef USE_LONG_DOUBLE
|
||||||
|
# include "printf-frexpl.h"
|
||||||
|
#else
|
||||||
|
# include "printf-frexp.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <float.h>
|
||||||
|
#include <gnulib_math.h>
|
||||||
|
#ifdef USE_LONG_DOUBLE
|
||||||
|
# include "fpucw.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This file assumes FLT_RADIX = 2. If FLT_RADIX is a power of 2 greater
|
||||||
|
than 2, or not even a power of 2, some rounding errors can occur, so that
|
||||||
|
then the returned mantissa is only guaranteed to be <= 2.0, not < 2.0. */
|
||||||
|
|
||||||
|
#ifdef USE_LONG_DOUBLE
|
||||||
|
# define FUNC printf_frexpl
|
||||||
|
# define DOUBLE long double
|
||||||
|
# define MIN_EXP LDBL_MIN_EXP
|
||||||
|
# if HAVE_FREXPL_IN_LIBC && HAVE_LDEXPL_IN_LIBC
|
||||||
|
# define USE_FREXP_LDEXP
|
||||||
|
# define FREXP frexpl
|
||||||
|
# define LDEXP ldexpl
|
||||||
|
# endif
|
||||||
|
# define DECL_ROUNDING DECL_LONG_DOUBLE_ROUNDING
|
||||||
|
# define BEGIN_ROUNDING() BEGIN_LONG_DOUBLE_ROUNDING ()
|
||||||
|
# define END_ROUNDING() END_LONG_DOUBLE_ROUNDING ()
|
||||||
|
# define L_(literal) literal##L
|
||||||
|
#else
|
||||||
|
# define FUNC printf_frexp
|
||||||
|
# define DOUBLE double
|
||||||
|
# define MIN_EXP DBL_MIN_EXP
|
||||||
|
# if HAVE_FREXP_IN_LIBC && HAVE_LDEXP_IN_LIBC
|
||||||
|
# define USE_FREXP_LDEXP
|
||||||
|
# define FREXP frexp
|
||||||
|
# define LDEXP ldexp
|
||||||
|
# endif
|
||||||
|
# define DECL_ROUNDING
|
||||||
|
# define BEGIN_ROUNDING()
|
||||||
|
# define END_ROUNDING()
|
||||||
|
# define L_(literal) literal
|
||||||
|
#endif
|
||||||
|
|
||||||
|
DOUBLE
|
||||||
|
FUNC (DOUBLE x, int *expptr)
|
||||||
|
{
|
||||||
|
int exponent;
|
||||||
|
DECL_ROUNDING
|
||||||
|
|
||||||
|
BEGIN_ROUNDING ();
|
||||||
|
|
||||||
|
#ifdef USE_FREXP_LDEXP
|
||||||
|
/* frexp and ldexp are usually faster than the loop below. */
|
||||||
|
x = FREXP (x, &exponent);
|
||||||
|
|
||||||
|
x = x + x;
|
||||||
|
exponent -= 1;
|
||||||
|
|
||||||
|
if (exponent < MIN_EXP - 1)
|
||||||
|
{
|
||||||
|
x = LDEXP (x, exponent - (MIN_EXP - 1));
|
||||||
|
exponent = MIN_EXP - 1;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
/* Since the exponent is an 'int', it fits in 64 bits. Therefore the
|
||||||
|
loops are executed no more than 64 times. */
|
||||||
|
DOUBLE pow2[64]; /* pow2[i] = 2^2^i */
|
||||||
|
DOUBLE powh[64]; /* powh[i] = 2^-2^i */
|
||||||
|
int i;
|
||||||
|
|
||||||
|
exponent = 0;
|
||||||
|
if (x >= L_(1.0))
|
||||||
|
{
|
||||||
|
/* A nonnegative exponent. */
|
||||||
|
{
|
||||||
|
DOUBLE pow2_i; /* = pow2[i] */
|
||||||
|
DOUBLE powh_i; /* = powh[i] */
|
||||||
|
|
||||||
|
/* Invariants: pow2_i = 2^2^i, powh_i = 2^-2^i,
|
||||||
|
x * 2^exponent = argument, x >= 1.0. */
|
||||||
|
for (i = 0, pow2_i = L_(2.0), powh_i = L_(0.5);
|
||||||
|
;
|
||||||
|
i++, pow2_i = pow2_i * pow2_i, powh_i = powh_i * powh_i)
|
||||||
|
{
|
||||||
|
if (x >= pow2_i)
|
||||||
|
{
|
||||||
|
exponent += (1 << i);
|
||||||
|
x *= powh_i;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
|
||||||
|
pow2[i] = pow2_i;
|
||||||
|
powh[i] = powh_i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Here 1.0 <= x < 2^2^i. */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* A negative exponent. */
|
||||||
|
{
|
||||||
|
DOUBLE pow2_i; /* = pow2[i] */
|
||||||
|
DOUBLE powh_i; /* = powh[i] */
|
||||||
|
|
||||||
|
/* Invariants: pow2_i = 2^2^i, powh_i = 2^-2^i,
|
||||||
|
x * 2^exponent = argument, x < 1.0, exponent >= MIN_EXP - 1. */
|
||||||
|
for (i = 0, pow2_i = L_(2.0), powh_i = L_(0.5);
|
||||||
|
;
|
||||||
|
i++, pow2_i = pow2_i * pow2_i, powh_i = powh_i * powh_i)
|
||||||
|
{
|
||||||
|
if (exponent - (1 << i) < MIN_EXP - 1)
|
||||||
|
break;
|
||||||
|
|
||||||
|
exponent -= (1 << i);
|
||||||
|
x *= pow2_i;
|
||||||
|
if (x >= L_(1.0))
|
||||||
|
break;
|
||||||
|
|
||||||
|
pow2[i] = pow2_i;
|
||||||
|
powh[i] = powh_i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Here either x < 1.0 and exponent - 2^i < MIN_EXP - 1 <= exponent,
|
||||||
|
or 1.0 <= x < 2^2^i and exponent >= MIN_EXP - 1. */
|
||||||
|
|
||||||
|
if (x < L_(1.0))
|
||||||
|
/* Invariants: x * 2^exponent = argument, x < 1.0 and
|
||||||
|
exponent - 2^i < MIN_EXP - 1 <= exponent. */
|
||||||
|
while (i > 0)
|
||||||
|
{
|
||||||
|
i--;
|
||||||
|
if (exponent - (1 << i) >= MIN_EXP - 1)
|
||||||
|
{
|
||||||
|
exponent -= (1 << i);
|
||||||
|
x *= pow2[i];
|
||||||
|
if (x >= L_(1.0))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Here either x < 1.0 and exponent = MIN_EXP - 1,
|
||||||
|
or 1.0 <= x < 2^2^i and exponent >= MIN_EXP - 1. */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Invariants: x * 2^exponent = argument, and
|
||||||
|
either x < 1.0 and exponent = MIN_EXP - 1,
|
||||||
|
or 1.0 <= x < 2^2^i and exponent >= MIN_EXP - 1. */
|
||||||
|
while (i > 0)
|
||||||
|
{
|
||||||
|
i--;
|
||||||
|
if (x >= pow2[i])
|
||||||
|
{
|
||||||
|
exponent += (1 << i);
|
||||||
|
x *= powh[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Here either x < 1.0 and exponent = MIN_EXP - 1,
|
||||||
|
or 1.0 <= x < 2.0 and exponent >= MIN_EXP - 1. */
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
END_ROUNDING ();
|
||||||
|
|
||||||
|
*expptr = exponent;
|
||||||
|
return x;
|
||||||
|
}
|
23
glib/gnulib/printf-frexp.h
Normal file
23
glib/gnulib/printf-frexp.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/* Split a double into fraction and mantissa, for hexadecimal printf.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* Write a finite, positive number x as
|
||||||
|
x = mantissa * 2^exp
|
||||||
|
where exp >= DBL_MIN_EXP - 1,
|
||||||
|
mantissa < 2.0,
|
||||||
|
if x is not a denormalized number then mantissa >= 1.0.
|
||||||
|
Store exp in *EXPPTR and return mantissa. */
|
||||||
|
extern double printf_frexp (double x, int *expptr);
|
37
glib/gnulib/printf-frexpl.c
Normal file
37
glib/gnulib/printf-frexpl.c
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
/* Split a 'long double' into fraction and mantissa, for hexadecimal printf.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
#if HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
|
||||||
|
|
||||||
|
/* Specification. */
|
||||||
|
# include "printf-frexpl.h"
|
||||||
|
|
||||||
|
# include "printf-frexp.h"
|
||||||
|
|
||||||
|
long double
|
||||||
|
printf_frexpl (long double x, int *expptr)
|
||||||
|
{
|
||||||
|
return printf_frexp (x, expptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
# define USE_LONG_DOUBLE
|
||||||
|
# include "printf-frexp.c"
|
||||||
|
|
||||||
|
#endif
|
23
glib/gnulib/printf-frexpl.h
Normal file
23
glib/gnulib/printf-frexpl.h
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
/* Split a 'long double' into fraction and mantissa, for hexadecimal printf.
|
||||||
|
Copyright (C) 2007, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* Write a finite, positive number x as
|
||||||
|
x = mantissa * 2^exp
|
||||||
|
where exp >= LDBL_MIN_EXP - 1,
|
||||||
|
mantissa < 2.0,
|
||||||
|
if x is not a denormalized number then mantissa >= 1.0.
|
||||||
|
Store exp in *EXPPTR and return mantissa. */
|
||||||
|
extern long double printf_frexpl (long double x, int *expptr);
|
@ -1,5 +1,5 @@
|
|||||||
/* Formatted output to strings.
|
/* Formatted output to strings.
|
||||||
Copyright (C) 1999-2000, 2002-2003, 2006-2016 Free Software Foundation, Inc.
|
Copyright (C) 1999-2000, 2002-2003, 2006-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -12,7 +12,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* This file can be parametrized with the following macros:
|
/* This file can be parametrized with the following macros:
|
||||||
CHAR_T The element type of the format string.
|
CHAR_T The element type of the format string.
|
||||||
@ -27,7 +27,9 @@
|
|||||||
STATIC Set to 'static' to declare the function static.
|
STATIC Set to 'static' to declare the function static.
|
||||||
ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions. */
|
ENABLE_UNISTDIO Set to 1 to enable the unistdio extensions. */
|
||||||
|
|
||||||
#include <config.h>
|
#ifndef PRINTF_PARSE
|
||||||
|
# include <config.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "g-gnulib.h"
|
#include "g-gnulib.h"
|
||||||
|
|
||||||
@ -36,8 +38,6 @@
|
|||||||
# include "printf-parse.h"
|
# include "printf-parse.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "xsize.h"
|
|
||||||
|
|
||||||
/* Default parameters. */
|
/* Default parameters. */
|
||||||
#ifndef PRINTF_PARSE
|
#ifndef PRINTF_PARSE
|
||||||
# define PRINTF_PARSE printf_parse
|
# define PRINTF_PARSE printf_parse
|
||||||
@ -58,11 +58,7 @@
|
|||||||
# include <inttypes.h>
|
# include <inttypes.h>
|
||||||
# endif
|
# endif
|
||||||
#else
|
#else
|
||||||
# if !defined (_MSC_VER) || (_MSC_VER >= 1600)
|
# include <stdint.h>
|
||||||
# include <stdint.h>
|
|
||||||
# else
|
|
||||||
typedef signed __int64 intmax_t;
|
|
||||||
# endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* malloc(), realloc(), free(). */
|
/* malloc(), realloc(), free(). */
|
||||||
@ -74,6 +70,9 @@ typedef signed __int64 intmax_t;
|
|||||||
/* errno. */
|
/* errno. */
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
|
/* Checked size_t computations. */
|
||||||
|
#include "xsize.h"
|
||||||
|
|
||||||
#if CHAR_T_ONLY_ASCII
|
#if CHAR_T_ONLY_ASCII
|
||||||
/* c_isascii(). */
|
/* c_isascii(). */
|
||||||
# include "c-ctype.h"
|
# include "c-ctype.h"
|
||||||
@ -422,7 +421,7 @@ PRINTF_PARSE (const CHAR_T *format, DIRECTIVES *d, arguments *a)
|
|||||||
cp++;
|
cp++;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
#if defined _WIN32 && ! defined __CYGWIN__
|
||||||
/* On native Windows, PRIdMAX is defined as "I64d".
|
/* On native Windows, PRIdMAX is defined as "I64d".
|
||||||
We cannot change it to "lld" because PRIdMAX must also
|
We cannot change it to "lld" because PRIdMAX must also
|
||||||
be understood by the system's printf routines. */
|
be understood by the system's printf routines. */
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* Parse printf format string.
|
/* Parse printf format string.
|
||||||
Copyright (C) 1999, 2002-2003, 2005, 2007, 2010-2016 Free Software
|
Copyright (C) 1999, 2002-2003, 2005, 2007, 2010-2019 Free Software
|
||||||
Foundation, Inc.
|
Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
@ -13,7 +13,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#ifndef _PRINTF_PARSE_H
|
#ifndef _PRINTF_PARSE_H
|
||||||
#define _PRINTF_PARSE_H
|
#define _PRINTF_PARSE_H
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* vsprintf with automatic memory allocation.
|
/* vsprintf with automatic memory allocation.
|
||||||
Copyright (C) 1999, 2002-2016 Free Software Foundation, Inc.
|
Copyright (C) 1999, 2002-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -12,7 +12,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* This file can be parametrized with the following macros:
|
/* This file can be parametrized with the following macros:
|
||||||
VASNPRINTF The name of the function being defined.
|
VASNPRINTF The name of the function being defined.
|
||||||
@ -55,14 +55,18 @@
|
|||||||
#ifndef VASNPRINTF
|
#ifndef VASNPRINTF
|
||||||
# include <config.h>
|
# include <config.h>
|
||||||
#endif
|
#endif
|
||||||
/* galloca.h also defines alloca and HAVE_ALLOCA makes the code below use it */
|
|
||||||
#include "glib/galloca.h"
|
#include "glib/galloca.h"
|
||||||
#define HAVE_ALLOCA 1
|
|
||||||
|
|
||||||
#include "g-gnulib.h"
|
#include "g-gnulib.h"
|
||||||
|
|
||||||
/* Specification. */
|
/* Specification. */
|
||||||
#include "vasnprintf.h"
|
#ifndef VASNPRINTF
|
||||||
|
# if WIDE_CHAR_VERSION
|
||||||
|
# include "vasnwprintf.h"
|
||||||
|
# else
|
||||||
|
# include "vasnprintf.h"
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <locale.h> /* localeconv() */
|
#include <locale.h> /* localeconv() */
|
||||||
#include <stdio.h> /* snprintf(), sprintf() */
|
#include <stdio.h> /* snprintf(), sprintf() */
|
||||||
@ -71,41 +75,59 @@
|
|||||||
#include <errno.h> /* errno */
|
#include <errno.h> /* errno */
|
||||||
#include <limits.h> /* CHAR_BIT */
|
#include <limits.h> /* CHAR_BIT */
|
||||||
#include <float.h> /* DBL_MAX_EXP, LDBL_MAX_EXP */
|
#include <float.h> /* DBL_MAX_EXP, LDBL_MAX_EXP */
|
||||||
|
#if HAVE_NL_LANGINFO
|
||||||
|
# include <langinfo.h>
|
||||||
|
#endif
|
||||||
|
#ifndef VASNPRINTF
|
||||||
|
# if WIDE_CHAR_VERSION
|
||||||
|
# include "wprintf-parse.h"
|
||||||
|
# else
|
||||||
# include "printf-parse.h"
|
# include "printf-parse.h"
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Checked size_t computations. */
|
||||||
#include "xsize.h"
|
#include "xsize.h"
|
||||||
|
|
||||||
#include "verify.h"
|
#include "verify.h"
|
||||||
|
|
||||||
#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
|
#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
|
||||||
# include <math.h>
|
# include <gnulib_math.h>
|
||||||
# include "float+.h"
|
# include "float+.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE) && !defined IN_LIBINTL
|
#if (NEED_PRINTF_DOUBLE || NEED_PRINTF_INFINITE_DOUBLE) && !defined IN_LIBINTL
|
||||||
# include <math.h>
|
# include <gnulib_math.h>
|
||||||
# include "isnand-nolibm.h"
|
# include "isnand-nolibm.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE) && !defined IN_LIBINTL
|
#if (NEED_PRINTF_LONG_DOUBLE || NEED_PRINTF_INFINITE_LONG_DOUBLE) && !defined IN_LIBINTL
|
||||||
# include <math.h>
|
# include <gnulib_math.h>
|
||||||
# include "isnanl-nolibm.h"
|
# include "isnanl-nolibm.h"
|
||||||
# include "fpucw.h"
|
# include "fpucw.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_DOUBLE) && !defined IN_LIBINTL
|
#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_DOUBLE) && !defined IN_LIBINTL
|
||||||
# include <math.h>
|
# include <gnulib_math.h>
|
||||||
# include "isnand-nolibm.h"
|
# include "isnand-nolibm.h"
|
||||||
# include "printf-frexp.h"
|
# include "printf-frexp.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
|
#if (NEED_PRINTF_DIRECTIVE_A || NEED_PRINTF_LONG_DOUBLE) && !defined IN_LIBINTL
|
||||||
# include <math.h>
|
# include <gnulib_math.h>
|
||||||
# include "isnanl-nolibm.h"
|
# include "isnanl-nolibm.h"
|
||||||
# include "printf-frexpl.h"
|
# include "printf-frexpl.h"
|
||||||
# include "fpucw.h"
|
# include "fpucw.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef FALLTHROUGH
|
||||||
|
# if __GNUC__ < 7
|
||||||
|
# define FALLTHROUGH ((void) 0)
|
||||||
|
# else
|
||||||
|
# define FALLTHROUGH __attribute__ ((__fallthrough__))
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Default parameters. */
|
/* Default parameters. */
|
||||||
#ifndef VASNPRINTF
|
#ifndef VASNPRINTF
|
||||||
# if WIDE_CHAR_VERSION
|
# if WIDE_CHAR_VERSION
|
||||||
@ -144,6 +166,7 @@
|
|||||||
# define SNPRINTF snwprintf
|
# define SNPRINTF snwprintf
|
||||||
# else
|
# else
|
||||||
# define SNPRINTF _snwprintf
|
# define SNPRINTF _snwprintf
|
||||||
|
# define USE_MSVC__SNPRINTF 1
|
||||||
# endif
|
# endif
|
||||||
# else
|
# else
|
||||||
/* Unix. */
|
/* Unix. */
|
||||||
@ -169,7 +192,9 @@
|
|||||||
/* Here we need to call the native snprintf, not rpl_snprintf. */
|
/* Here we need to call the native snprintf, not rpl_snprintf. */
|
||||||
# undef snprintf
|
# undef snprintf
|
||||||
# else
|
# else
|
||||||
|
/* MSVC versions < 14 did not have snprintf, only _snprintf. */
|
||||||
# define SNPRINTF _snprintf
|
# define SNPRINTF _snprintf
|
||||||
|
# define USE_MSVC__SNPRINTF 1
|
||||||
# endif
|
# endif
|
||||||
# else
|
# else
|
||||||
/* Unix. */
|
/* Unix. */
|
||||||
@ -183,7 +208,7 @@
|
|||||||
|
|
||||||
/* GCC >= 4.0 with -Wall emits unjustified "... may be used uninitialized"
|
/* GCC >= 4.0 with -Wall emits unjustified "... may be used uninitialized"
|
||||||
warnings in this file. Use -Dlint to suppress them. */
|
warnings in this file. Use -Dlint to suppress them. */
|
||||||
#ifdef lint
|
#if defined GCC_LINT || defined lint
|
||||||
# define IF_LINT(Code) Code
|
# define IF_LINT(Code) Code
|
||||||
#else
|
#else
|
||||||
# define IF_LINT(Code) /* empty */
|
# define IF_LINT(Code) /* empty */
|
||||||
@ -196,7 +221,7 @@
|
|||||||
#undef remainder
|
#undef remainder
|
||||||
#define remainder rem
|
#define remainder rem
|
||||||
|
|
||||||
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99) && !WIDE_CHAR_VERSION
|
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF) && !WIDE_CHAR_VERSION
|
||||||
# if (HAVE_STRNLEN && !defined _AIX)
|
# if (HAVE_STRNLEN && !defined _AIX)
|
||||||
# define local_strnlen strnlen
|
# define local_strnlen strnlen
|
||||||
# else
|
# else
|
||||||
@ -212,7 +237,7 @@ local_strnlen (const char *string, size_t maxlen)
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (((!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99) && WIDE_CHAR_VERSION) || ((!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || (NEED_PRINTF_DIRECTIVE_LS && !defined IN_LIBINTL)) && !WIDE_CHAR_VERSION && DCHAR_IS_TCHAR)) && HAVE_WCHAR_T
|
#if (((!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF) && WIDE_CHAR_VERSION) || ((!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || (NEED_PRINTF_DIRECTIVE_LS && !defined IN_LIBINTL)) && !WIDE_CHAR_VERSION && DCHAR_IS_TCHAR)) && HAVE_WCHAR_T
|
||||||
# if HAVE_WCSLEN
|
# if HAVE_WCSLEN
|
||||||
# define local_wcslen wcslen
|
# define local_wcslen wcslen
|
||||||
# else
|
# else
|
||||||
@ -235,7 +260,7 @@ local_wcslen (const wchar_t *s)
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99) && HAVE_WCHAR_T && WIDE_CHAR_VERSION
|
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF) && HAVE_WCHAR_T && WIDE_CHAR_VERSION
|
||||||
# if HAVE_WCSNLEN
|
# if HAVE_WCSNLEN
|
||||||
# define local_wcsnlen wcsnlen
|
# define local_wcsnlen wcsnlen
|
||||||
# else
|
# else
|
||||||
@ -837,7 +862,9 @@ convert_to_decimal (mpn_t a, size_t extra_zeroes)
|
|||||||
size_t a_len = a.nlimbs;
|
size_t a_len = a.nlimbs;
|
||||||
/* 0.03345 is slightly larger than log(2)/(9*log(10)). */
|
/* 0.03345 is slightly larger than log(2)/(9*log(10)). */
|
||||||
size_t c_len = 9 * ((size_t)(a_len * (GMP_LIMB_BITS * 0.03345f)) + 1);
|
size_t c_len = 9 * ((size_t)(a_len * (GMP_LIMB_BITS * 0.03345f)) + 1);
|
||||||
char *c_ptr = (char *) malloc (xsum (c_len, extra_zeroes));
|
/* We need extra_zeroes bytes for zeroes, followed by c_len bytes for the
|
||||||
|
digits of a, followed by 1 byte for the terminating NUL. */
|
||||||
|
char *c_ptr = (char *) malloc (xsum (xsum (extra_zeroes, c_len), 1));
|
||||||
if (c_ptr != NULL)
|
if (c_ptr != NULL)
|
||||||
{
|
{
|
||||||
char *d_ptr = c_ptr;
|
char *d_ptr = c_ptr;
|
||||||
@ -1505,7 +1532,7 @@ is_borderline (const char *digits, size_t precision)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99
|
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF
|
||||||
|
|
||||||
/* Use a different function name, to make it possible that the 'wchar_t'
|
/* Use a different function name, to make it possible that the 'wchar_t'
|
||||||
parametrization and the 'char' parametrization get compiled in the same
|
parametrization and the 'char' parametrization get compiled in the same
|
||||||
@ -2380,7 +2407,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || (NEED_PRINTF_DIRECTIVE_LS && !defined IN_LIBINTL)) && HAVE_WCHAR_T
|
#if (!USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || (NEED_PRINTF_DIRECTIVE_LS && !defined IN_LIBINTL)) && HAVE_WCHAR_T
|
||||||
else if (dp->conversion == 's'
|
else if (dp->conversion == 's'
|
||||||
# if WIDE_CHAR_VERSION
|
# if WIDE_CHAR_VERSION
|
||||||
&& a.arg[dp->arg_index].type != TYPE_WIDE_STRING
|
&& a.arg[dp->arg_index].type != TYPE_WIDE_STRING
|
||||||
@ -2671,7 +2698,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
errno = EILSEQ;
|
errno = EILSEQ;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (precision < count)
|
if (precision < (unsigned int) count)
|
||||||
break;
|
break;
|
||||||
arg_end++;
|
arg_end++;
|
||||||
characters += count;
|
characters += count;
|
||||||
@ -4220,7 +4247,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
static const wchar_t decimal_format[] =
|
static const wchar_t decimal_format[] =
|
||||||
/* Produce the same number of exponent digits
|
/* Produce the same number of exponent digits
|
||||||
as the native printf implementation. */
|
as the native printf implementation. */
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
{ '%', '+', '.', '3', 'd', '\0' };
|
{ '%', '+', '.', '3', 'd', '\0' };
|
||||||
# else
|
# else
|
||||||
{ '%', '+', '.', '2', 'd', '\0' };
|
{ '%', '+', '.', '2', 'd', '\0' };
|
||||||
@ -4234,7 +4261,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
static const char decimal_format[] =
|
static const char decimal_format[] =
|
||||||
/* Produce the same number of exponent digits
|
/* Produce the same number of exponent digits
|
||||||
as the native printf implementation. */
|
as the native printf implementation. */
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
"%+.3d";
|
"%+.3d";
|
||||||
# else
|
# else
|
||||||
"%+.2d";
|
"%+.2d";
|
||||||
@ -4413,7 +4440,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
static const wchar_t decimal_format[] =
|
static const wchar_t decimal_format[] =
|
||||||
/* Produce the same number of exponent digits
|
/* Produce the same number of exponent digits
|
||||||
as the native printf implementation. */
|
as the native printf implementation. */
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
{ '%', '+', '.', '3', 'd', '\0' };
|
{ '%', '+', '.', '3', 'd', '\0' };
|
||||||
# else
|
# else
|
||||||
{ '%', '+', '.', '2', 'd', '\0' };
|
{ '%', '+', '.', '2', 'd', '\0' };
|
||||||
@ -4427,7 +4454,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
static const char decimal_format[] =
|
static const char decimal_format[] =
|
||||||
/* Produce the same number of exponent digits
|
/* Produce the same number of exponent digits
|
||||||
as the native printf implementation. */
|
as the native printf implementation. */
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
"%+.3d";
|
"%+.3d";
|
||||||
# else
|
# else
|
||||||
"%+.2d";
|
"%+.2d";
|
||||||
@ -4485,7 +4512,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
*p++ = '+';
|
*p++ = '+';
|
||||||
/* Produce the same number of exponent digits as
|
/* Produce the same number of exponent digits as
|
||||||
the native printf implementation. */
|
the native printf implementation. */
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
*p++ = '0';
|
*p++ = '0';
|
||||||
# endif
|
# endif
|
||||||
*p++ = '0';
|
*p++ = '0';
|
||||||
@ -4579,10 +4606,10 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
int has_width;
|
int has_width;
|
||||||
#endif
|
#endif
|
||||||
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
size_t width;
|
size_t width;
|
||||||
#endif
|
#endif
|
||||||
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
int has_precision;
|
int has_precision;
|
||||||
size_t precision;
|
size_t precision;
|
||||||
#endif
|
#endif
|
||||||
@ -4611,7 +4638,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
has_width = 0;
|
has_width = 0;
|
||||||
#endif
|
#endif
|
||||||
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || !DCHAR_IS_TCHAR || ENABLE_UNISTDIO || NEED_PRINTF_FLAG_LEFTADJUST || NEED_PRINTF_FLAG_ZERO || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
width = 0;
|
width = 0;
|
||||||
if (dp->width_start != dp->width_end)
|
if (dp->width_start != dp->width_end)
|
||||||
{
|
{
|
||||||
@ -4645,7 +4672,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || NEED_PRINTF_UNBOUNDED_PRECISION
|
#if !USE_SNPRINTF || !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF || NEED_PRINTF_UNBOUNDED_PRECISION
|
||||||
has_precision = 0;
|
has_precision = 0;
|
||||||
precision = 6;
|
precision = 6;
|
||||||
if (dp->precision_start != dp->precision_end)
|
if (dp->precision_start != dp->precision_end)
|
||||||
@ -4813,16 +4840,16 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
#if HAVE_LONG_LONG
|
#if HAVE_LONG_LONG
|
||||||
case TYPE_LONGLONGINT:
|
case TYPE_LONGLONGINT:
|
||||||
case TYPE_ULONGLONGINT:
|
case TYPE_ULONGLONGINT:
|
||||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
# if (defined _WIN32 && FALSE) && ! defined __CYGWIN__
|
||||||
*fbp++ = 'I';
|
*fbp++ = 'I';
|
||||||
*fbp++ = '6';
|
*fbp++ = '6';
|
||||||
*fbp++ = '4';
|
*fbp++ = '4';
|
||||||
break;
|
break;
|
||||||
# else
|
# else
|
||||||
*fbp++ = 'l';
|
*fbp++ = 'l';
|
||||||
/*FALLTHROUGH*/
|
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
FALLTHROUGH;
|
||||||
case TYPE_LONGINT:
|
case TYPE_LONGINT:
|
||||||
case TYPE_ULONGINT:
|
case TYPE_ULONGINT:
|
||||||
#if HAVE_WINT_T
|
#if HAVE_WINT_T
|
||||||
@ -4846,7 +4873,11 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
#endif
|
#endif
|
||||||
*fbp = dp->conversion;
|
*fbp = dp->conversion;
|
||||||
#if USE_SNPRINTF
|
#if USE_SNPRINTF
|
||||||
# if !(((__GLIBC__ > 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 3)) && !defined __UCLIBC__) || ((defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__))
|
# if ! (((__GLIBC__ > 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 3)) \
|
||||||
|
&& !defined __UCLIBC__) \
|
||||||
|
|| (defined __APPLE__ && defined __MACH__) \
|
||||||
|
|| defined __ANDROID__ \
|
||||||
|
|| (defined _WIN32 && ! defined __CYGWIN__))
|
||||||
fbp[1] = '%';
|
fbp[1] = '%';
|
||||||
fbp[2] = 'n';
|
fbp[2] = 'n';
|
||||||
fbp[3] = '\0';
|
fbp[3] = '\0';
|
||||||
@ -4860,6 +4891,21 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
in format strings in writable memory may crash the program
|
in format strings in writable memory may crash the program
|
||||||
(if compiled with _FORTIFY_SOURCE=2), so we should avoid it
|
(if compiled with _FORTIFY_SOURCE=2), so we should avoid it
|
||||||
in this situation. */
|
in this situation. */
|
||||||
|
/* On Mac OS X 10.3 or newer, we know that snprintf's return
|
||||||
|
value conforms to ISO C 99: the tests gl_SNPRINTF_RETVAL_C99
|
||||||
|
and gl_SNPRINTF_TRUNCATION_C99 pass.
|
||||||
|
Therefore we can avoid using %n in this situation.
|
||||||
|
On Mac OS X 10.13 or newer, the use of %n in format strings
|
||||||
|
in writable memory by default crashes the program, so we
|
||||||
|
should avoid it in this situation. */
|
||||||
|
/* On Android, we know that snprintf's return value conforms to
|
||||||
|
ISO C 99: the tests gl_SNPRINTF_RETVAL_C99 and
|
||||||
|
gl_SNPRINTF_TRUNCATION_C99 pass.
|
||||||
|
Therefore we can avoid using %n in this situation.
|
||||||
|
Starting on 2018-03-07, the use of %n in format strings
|
||||||
|
produces a fatal error (see
|
||||||
|
<https://android.googlesource.com/platform/bionic/+/41398d03b7e8e0dfb951660ae713e682e9fc0336>),
|
||||||
|
so we should avoid it. */
|
||||||
/* On native Windows systems (such as mingw), we can avoid using
|
/* On native Windows systems (such as mingw), we can avoid using
|
||||||
%n because:
|
%n because:
|
||||||
- Although the gl_SNPRINTF_TRUNCATION_C99 test fails,
|
- Although the gl_SNPRINTF_TRUNCATION_C99 test fails,
|
||||||
@ -4872,8 +4918,8 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
On native Windows systems (such as mingw) where the OS is
|
On native Windows systems (such as mingw) where the OS is
|
||||||
Windows Vista, the use of %n in format strings by default
|
Windows Vista, the use of %n in format strings by default
|
||||||
crashes the program. See
|
crashes the program. See
|
||||||
<http://gcc.gnu.org/ml/gcc/2007-06/msg00122.html> and
|
<https://gcc.gnu.org/ml/gcc/2007-06/msg00122.html> and
|
||||||
<http://msdn2.microsoft.com/en-us/library/ms175782(VS.80).aspx>
|
<https://msdn.microsoft.com/en-us/library/ms175782.aspx>
|
||||||
So we should avoid %n in this situation. */
|
So we should avoid %n in this situation. */
|
||||||
fbp[1] = '\0';
|
fbp[1] = '\0';
|
||||||
# endif
|
# endif
|
||||||
@ -5092,7 +5138,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
{
|
{
|
||||||
/* Verify that snprintf() has NUL-terminated its
|
/* Verify that snprintf() has NUL-terminated its
|
||||||
result. */
|
result. */
|
||||||
if (count < maxlen
|
if ((unsigned int) count < maxlen
|
||||||
&& ((TCHAR_T *) (result + length)) [count] != '\0')
|
&& ((TCHAR_T *) (result + length)) [count] != '\0')
|
||||||
abort ();
|
abort ();
|
||||||
/* Portability hack. */
|
/* Portability hack. */
|
||||||
@ -5115,7 +5161,7 @@ VASNPRINTF (DCHAR_T *resultbuf, size_t *lengthp,
|
|||||||
/* Look at the snprintf() return value. */
|
/* Look at the snprintf() return value. */
|
||||||
if (retcount < 0)
|
if (retcount < 0)
|
||||||
{
|
{
|
||||||
# if !HAVE_SNPRINTF_RETVAL_C99
|
# if !HAVE_SNPRINTF_RETVAL_C99 || USE_MSVC__SNPRINTF
|
||||||
/* HP-UX 10.20 snprintf() is doubly deficient:
|
/* HP-UX 10.20 snprintf() is doubly deficient:
|
||||||
It doesn't understand the '%n' directive,
|
It doesn't understand the '%n' directive,
|
||||||
*and* it returns -1 (rather than the length
|
*and* it returns -1 (rather than the length
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* vsprintf with automatic memory allocation.
|
/* vsprintf with automatic memory allocation.
|
||||||
Copyright (C) 2002-2004, 2007-2016 Free Software Foundation, Inc.
|
Copyright (C) 2002-2004, 2007-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -12,7 +12,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License along
|
You should have received a copy of the GNU Lesser General Public License along
|
||||||
with this program; if not, see <http://www.gnu.org/licenses/>. */
|
with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#ifndef _VASNPRINTF_H
|
#ifndef _VASNPRINTF_H
|
||||||
#define _VASNPRINTF_H
|
#define _VASNPRINTF_H
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* Compile-time assert-like macros.
|
/* Compile-time assert-like macros.
|
||||||
|
|
||||||
Copyright (C) 2005-2006, 2009-2016 Free Software Foundation, Inc.
|
Copyright (C) 2005-2006, 2009-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -13,7 +13,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
along with this program. If not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
/* Written by Paul Eggert, Bruno Haible, and Jim Meyering. */
|
/* Written by Paul Eggert, Bruno Haible, and Jim Meyering. */
|
||||||
|
|
||||||
@ -26,7 +26,7 @@
|
|||||||
here generates easier-to-read diagnostics when verify (R) fails.
|
here generates easier-to-read diagnostics when verify (R) fails.
|
||||||
|
|
||||||
Define _GL_HAVE_STATIC_ASSERT to 1 if static_assert works as per C++11.
|
Define _GL_HAVE_STATIC_ASSERT to 1 if static_assert works as per C++11.
|
||||||
This will likely be supported by future GCC versions, in C++ mode.
|
This is supported by GCC 6.1.0 and later, in C++ mode.
|
||||||
|
|
||||||
Use this only with GCC. If we were willing to slow 'configure'
|
Use this only with GCC. If we were willing to slow 'configure'
|
||||||
down we could also use it with other compilers, but since this
|
down we could also use it with other compilers, but since this
|
||||||
@ -36,9 +36,7 @@
|
|||||||
&& !defined __cplusplus)
|
&& !defined __cplusplus)
|
||||||
# define _GL_HAVE__STATIC_ASSERT 1
|
# define _GL_HAVE__STATIC_ASSERT 1
|
||||||
#endif
|
#endif
|
||||||
/* The condition (99 < __GNUC__) is temporary, until we know about the
|
#if (6 <= __GNUC__) && defined __cplusplus
|
||||||
first G++ release that supports static_assert. */
|
|
||||||
#if (99 < __GNUC__) && defined __cplusplus
|
|
||||||
# define _GL_HAVE_STATIC_ASSERT 1
|
# define _GL_HAVE_STATIC_ASSERT 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -248,32 +246,36 @@ template <int w>
|
|||||||
/* Verify requirement R at compile-time, as a declaration without a
|
/* Verify requirement R at compile-time, as a declaration without a
|
||||||
trailing ';'. */
|
trailing ';'. */
|
||||||
|
|
||||||
#define verify(R) _GL_VERIFY (R, "verify (" #R ")")
|
#ifdef __GNUC__
|
||||||
|
# define verify(R) _GL_VERIFY (R, "verify (" #R ")")
|
||||||
#ifdef __has_builtin
|
|
||||||
# define _GL_MACRO__has_builtin __has_builtin
|
|
||||||
#else
|
#else
|
||||||
# define _GL_MACRO__has_builtin(x) 0
|
/* PGI barfs if R is long. Play it safe. */
|
||||||
|
# define verify(R) _GL_VERIFY (R, "verify (...)")
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __has_builtin
|
||||||
|
# define __has_builtin(x) 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Assume that R always holds. This lets the compiler optimize
|
/* Assume that R always holds. This lets the compiler optimize
|
||||||
accordingly. R should not have side-effects; it may or may not be
|
accordingly. R should not have side-effects; it may or may not be
|
||||||
evaluated. Behavior is undefined if R is false. */
|
evaluated. Behavior is undefined if R is false. */
|
||||||
|
|
||||||
#if (_GL_MACRO__has_builtin (__builtin_unreachable) \
|
#if (__has_builtin (__builtin_unreachable) \
|
||||||
|| 4 < __GNUC__ + (5 <= __GNUC_MINOR__))
|
|| 4 < __GNUC__ + (5 <= __GNUC_MINOR__))
|
||||||
# define assume(R) ((R) ? (void) 0 : __builtin_unreachable ())
|
# define assume(R) ((R) ? (void) 0 : __builtin_unreachable ())
|
||||||
#elif 1200 <= _MSC_VER
|
#elif 1200 <= _MSC_VER
|
||||||
# define assume(R) __assume (R)
|
# define assume(R) __assume (R)
|
||||||
#elif (defined lint \
|
#elif ((defined GCC_LINT || defined lint) \
|
||||||
&& (_GL_MACRO__has_builtin (__builtin_trap) \
|
&& (__has_builtin (__builtin_trap) \
|
||||||
|| 3 < __GNUC__ + (3 < __GNUC_MINOR__ + (4 <= __GNUC_PATCHLEVEL__))))
|
|| 3 < __GNUC__ + (3 < __GNUC_MINOR__ + (4 <= __GNUC_PATCHLEVEL__))))
|
||||||
/* Doing it this way helps various packages when configured with
|
/* Doing it this way helps various packages when configured with
|
||||||
--enable-gcc-warnings, which compiles with -Dlint. It's nicer
|
--enable-gcc-warnings, which compiles with -Dlint. It's nicer
|
||||||
when 'assume' silences warnings even with older GCCs. */
|
when 'assume' silences warnings even with older GCCs. */
|
||||||
# define assume(R) ((R) ? (void) 0 : __builtin_trap ())
|
# define assume(R) ((R) ? (void) 0 : __builtin_trap ())
|
||||||
#else
|
#else
|
||||||
# define assume(R) ((void) (0 && (R)))
|
/* Some tools grok NOTREACHED, e.g., Oracle Studio 12.6. */
|
||||||
|
# define assume(R) ((R) ? (void) 0 : /*NOTREACHED*/ (void) 0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* @assert.h omit end@ */
|
/* @assert.h omit end@ */
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* xsize.h -- Checked size_t computations.
|
/* xsize.h -- Checked size_t computations.
|
||||||
|
|
||||||
Copyright (C) 2003, 2008-2016 Free Software Foundation, Inc.
|
Copyright (C) 2003, 2008-2019 Free Software Foundation, Inc.
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify
|
This program is free software; you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
it under the terms of the GNU Lesser General Public License as published by
|
||||||
@ -13,7 +13,7 @@
|
|||||||
GNU Lesser General Public License for more details.
|
GNU Lesser General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
along with this program; if not, see <http://www.gnu.org/licenses/>. */
|
along with this program; if not, see <https://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#ifndef _XSIZE_H
|
#ifndef _XSIZE_H
|
||||||
#define _XSIZE_H
|
#define _XSIZE_H
|
||||||
@ -29,6 +29,10 @@
|
|||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef _GL_INLINE_HEADER_BEGIN
|
||||||
|
#error "Please include config.h first."
|
||||||
|
#endif
|
||||||
|
_GL_INLINE_HEADER_BEGIN
|
||||||
#ifndef XSIZE_INLINE
|
#ifndef XSIZE_INLINE
|
||||||
# define XSIZE_INLINE _GL_INLINE
|
# define XSIZE_INLINE _GL_INLINE
|
||||||
#endif
|
#endif
|
||||||
@ -54,7 +58,7 @@
|
|||||||
((N) <= G_MAXSIZE ? (size_t) (N) : G_MAXSIZE)
|
((N) <= G_MAXSIZE ? (size_t) (N) : G_MAXSIZE)
|
||||||
|
|
||||||
/* Sum of two sizes, with overflow check. */
|
/* Sum of two sizes, with overflow check. */
|
||||||
static inline size_t
|
XSIZE_INLINE size_t
|
||||||
#if __GNUC__ >= 3
|
#if __GNUC__ >= 3
|
||||||
__attribute__ ((__pure__))
|
__attribute__ ((__pure__))
|
||||||
#endif
|
#endif
|
||||||
@ -65,7 +69,7 @@ xsum (size_t size1, size_t size2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Sum of three sizes, with overflow check. */
|
/* Sum of three sizes, with overflow check. */
|
||||||
static inline size_t
|
XSIZE_INLINE size_t
|
||||||
#if __GNUC__ >= 3
|
#if __GNUC__ >= 3
|
||||||
__attribute__ ((__pure__))
|
__attribute__ ((__pure__))
|
||||||
#endif
|
#endif
|
||||||
@ -75,7 +79,7 @@ xsum3 (size_t size1, size_t size2, size_t size3)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Sum of four sizes, with overflow check. */
|
/* Sum of four sizes, with overflow check. */
|
||||||
static inline size_t
|
XSIZE_INLINE size_t
|
||||||
#if __GNUC__ >= 3
|
#if __GNUC__ >= 3
|
||||||
__attribute__ ((__pure__))
|
__attribute__ ((__pure__))
|
||||||
#endif
|
#endif
|
||||||
@ -85,7 +89,7 @@ xsum4 (size_t size1, size_t size2, size_t size3, size_t size4)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Maximum of two sizes, with overflow check. */
|
/* Maximum of two sizes, with overflow check. */
|
||||||
static inline size_t
|
XSIZE_INLINE size_t
|
||||||
#if __GNUC__ >= 3
|
#if __GNUC__ >= 3
|
||||||
__attribute__ ((__pure__))
|
__attribute__ ((__pure__))
|
||||||
#endif
|
#endif
|
||||||
@ -110,4 +114,6 @@ xmax (size_t size1, size_t size2)
|
|||||||
#define size_in_bounds_p(SIZE) \
|
#define size_in_bounds_p(SIZE) \
|
||||||
((SIZE) != G_MAXSIZE)
|
((SIZE) != G_MAXSIZE)
|
||||||
|
|
||||||
|
_GL_INLINE_HEADER_END
|
||||||
|
|
||||||
#endif /* _XSIZE_H */
|
#endif /* _XSIZE_H */
|
||||||
|
@ -16,7 +16,94 @@ endif
|
|||||||
if have_good_vsnprintf and have_good_snprintf
|
if have_good_vsnprintf and have_good_snprintf
|
||||||
gnulib_lib = []
|
gnulib_lib = []
|
||||||
gnulib_objects = []
|
gnulib_objects = []
|
||||||
|
gnulib_libm_dependency = []
|
||||||
|
glib_conf.set ('gl_unused', '')
|
||||||
|
glib_conf.set ('gl_extern_inline', '')
|
||||||
else
|
else
|
||||||
|
subdir ('gnulib/gl_extern_inline')
|
||||||
|
subdir ('gnulib/gl_cv_long_double_equals_double')
|
||||||
|
subdir ('gnulib/gl_cv_cc_double_expbit0')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_precision')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_enomem')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_flag_zero')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_flag_leftadjust')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_flag_grouping')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_directive_a')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_directive_f')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_directive_ls')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_long_double')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_infinite')
|
||||||
|
subdir ('gnulib/gl_cv_func_printf_infinite_long_double')
|
||||||
|
|
||||||
|
gl_unused = '''
|
||||||
|
/* Define as a marker that can be attached to declarations that might not
|
||||||
|
be used. This helps to reduce warnings, such as from
|
||||||
|
GCC -Wunused-parameter. */
|
||||||
|
#if __GNUC__ >= 3 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7)
|
||||||
|
# define _GL_UNUSED __attribute__ ((__unused__))
|
||||||
|
#else
|
||||||
|
# define _GL_UNUSED
|
||||||
|
#endif
|
||||||
|
'''
|
||||||
|
glib_conf.set ('gl_unused', gl_unused)
|
||||||
|
glib_conf.set ('gl_extern_inline', gl_extern_inline)
|
||||||
|
|
||||||
|
if (gl_cv_long_double_equals_double)
|
||||||
|
glib_conf.set ('HAVE_SAME_LONG_DOUBLE_AS_DOUBLE', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if (gl_cv_cc_double_expbit0_word >= 0 and
|
||||||
|
gl_cv_cc_double_expbit0_bit >= 0)
|
||||||
|
glib_conf.set('DBL_EXPBIT0_WORD', gl_cv_cc_double_expbit0_word)
|
||||||
|
glib_conf.set('DBL_EXPBIT0_BIT', gl_cv_cc_double_expbit0_bit)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_precision
|
||||||
|
glib_conf.set('NEED_PRINTF_UNBOUNDED_PRECISION', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_enomem
|
||||||
|
glib_conf.set('NEED_PRINTF_ENOMEM', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_flag_leftadjust
|
||||||
|
glib_conf.set('NEED_PRINTF_FLAG_LEFTADJUST', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_flag_zero
|
||||||
|
glib_conf.set('NEED_PRINTF_FLAG_ZERO', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_flag_grouping
|
||||||
|
glib_conf.set('NEED_PRINTF_FLAG_GROUPING', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_directive_a
|
||||||
|
glib_conf.set('NEED_PRINTF_DIRECTIVE_A', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_directive_f
|
||||||
|
glib_conf.set('NEED_PRINTF_DIRECTIVE_F', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_directive_ls
|
||||||
|
glib_conf.set('NEED_PRINTF_DIRECTIVE_LS', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if (not gl_cv_func_printf_precision or
|
||||||
|
not gl_cv_func_printf_enomem)
|
||||||
|
glib_conf.set('NEED_PRINTF_DOUBLE', 1)
|
||||||
|
glib_conf.set('NEED_PRINTF_LONG_DOUBLE', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if not gl_cv_func_printf_infinite
|
||||||
|
glib_conf.set('NEED_PRINTF_INFINITE_DOUBLE', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if gl_cv_func_printf_long_double and gl_cv_func_printf_infinite_long_double != 'false'
|
||||||
|
glib_conf.set('NEED_PRINTF_INFINITE_LONG_DOUBLE', 1)
|
||||||
|
endif
|
||||||
|
|
||||||
subdir('gnulib')
|
subdir('gnulib')
|
||||||
gnulib_objects = [gnulib_lib.extract_all_objects()]
|
gnulib_objects = [gnulib_lib.extract_all_objects()]
|
||||||
endif
|
endif
|
||||||
@ -270,7 +357,7 @@ libglib = library('glib-2.0',
|
|||||||
# intl.lib is not compatible with SAFESEH
|
# intl.lib is not compatible with SAFESEH
|
||||||
link_args : [noseh_link_args, glib_link_flags, win32_ldflags],
|
link_args : [noseh_link_args, glib_link_flags, win32_ldflags],
|
||||||
include_directories : configinc,
|
include_directories : configinc,
|
||||||
dependencies : pcre_deps + [thread_dep, libintl, librt] + libiconv + platform_deps,
|
dependencies : pcre_deps + [thread_dep, libintl, librt] + libiconv + platform_deps + gnulib_libm_dependency,
|
||||||
c_args : glib_c_args,
|
c_args : glib_c_args,
|
||||||
objc_args : glib_c_args,
|
objc_args : glib_c_args,
|
||||||
)
|
)
|
||||||
|
@ -1037,15 +1037,7 @@ test_strtod (void)
|
|||||||
check_strtod_number (0.75, "%5.2f", " 0.75");
|
check_strtod_number (0.75, "%5.2f", " 0.75");
|
||||||
check_strtod_number (-0.75, "%0.2f", "-0.75");
|
check_strtod_number (-0.75, "%0.2f", "-0.75");
|
||||||
check_strtod_number (-0.75, "%5.2f", "-0.75");
|
check_strtod_number (-0.75, "%5.2f", "-0.75");
|
||||||
#if defined(_MSC_VER) || defined(__MINGW32__)
|
|
||||||
/* FIXME: The included gnulib and the mingw-w64 implementation
|
|
||||||
* currently don't follow C99 and print 3 digits for the exponent.
|
|
||||||
* In case of mingw-w64 this was fixed but not released yet:
|
|
||||||
* https://sourceforge.net/p/mingw-w64/bugs/732/ */
|
|
||||||
check_strtod_number (1e99, "%0.e", "1e+099");
|
|
||||||
#else
|
|
||||||
check_strtod_number (1e99, "%.0e", "1e+99");
|
check_strtod_number (1e99, "%.0e", "1e+99");
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user