314 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			314 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* ANSI and traditional C compatability macros
 | |
|    Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001,
 | |
|    2002, 2003, 2004, 2005, 2006, 2007, 2009, 2010, 2013
 | |
|    Free Software Foundation, Inc.
 | |
|    This file is part of the GNU C Library.
 | |
| 
 | |
| This program is free software; you can redistribute it and/or modify
 | |
| it under the terms of the GNU General Public License as published by
 | |
| the Free Software Foundation; either version 2 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 General Public License for more details.
 | |
| 
 | |
| You should have received a copy of the GNU General Public License
 | |
| along with this program; if not, write to the Free Software
 | |
| Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
 | |
| 
 | |
| /* ANSI and traditional C compatibility macros
 | |
| 
 | |
|    ANSI C is assumed if __STDC__ is #defined.
 | |
| 
 | |
|    Macro		ANSI C definition	Traditional C definition
 | |
|    -----		---- - ----------	----------- - ----------
 | |
|    PTR			`void *'		`char *'
 | |
|    const		not defined		`'
 | |
|    volatile		not defined		`'
 | |
|    signed		not defined		`'
 | |
| 
 | |
|    For ease of writing code which uses GCC extensions but needs to be
 | |
|    portable to other compilers, we provide the GCC_VERSION macro that
 | |
|    simplifies testing __GNUC__ and __GNUC_MINOR__ together, and various
 | |
|    wrappers around __attribute__.  Also, __extension__ will be #defined
 | |
|    to nothing if it doesn't work.  See below.  */
 | |
| 
 | |
| #ifndef	_ANSIDECL_H
 | |
| #define _ANSIDECL_H	1
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /* Every source file includes this file,
 | |
|    so they will all get the switch for lint.  */
 | |
| /* LINTLIBRARY */
 | |
| 
 | |
| /* Using MACRO(x,y) in cpp #if conditionals does not work with some
 | |
|    older preprocessors.  Thus we can't define something like this:
 | |
| 
 | |
| #define HAVE_GCC_VERSION(MAJOR, MINOR) \
 | |
|   (__GNUC__ > (MAJOR) || (__GNUC__ == (MAJOR) && __GNUC_MINOR__ >= (MINOR)))
 | |
| 
 | |
| and then test "#if HAVE_GCC_VERSION(2,7)".
 | |
| 
 | |
| So instead we use the macro below and test it against specific values.  */
 | |
| 
 | |
| /* This macro simplifies testing whether we are using gcc, and if it
 | |
|    is of a particular minimum version. (Both major & minor numbers are
 | |
|    significant.)  This macro will evaluate to 0 if we are not using
 | |
|    gcc at all.  */
 | |
| #ifndef GCC_VERSION
 | |
| #define GCC_VERSION (__GNUC__ * 1000 + __GNUC_MINOR__)
 | |
| #endif /* GCC_VERSION */
 | |
| 
 | |
| #if defined (__STDC__) || defined(__cplusplus) || defined (_AIX) || (defined (__mips) && defined (_SYSTYPE_SVR4)) || defined(_WIN32)
 | |
| /* All known AIX compilers implement these things (but don't always
 | |
|    define __STDC__).  The RISC/OS MIPS compiler defines these things
 | |
|    in SVR4 mode, but does not define __STDC__.  */
 | |
| /* eraxxon@alumni.rice.edu: The Compaq C++ compiler, unlike many other
 | |
|    C++ compilers, does not define __STDC__, though it acts as if this
 | |
|    was so. (Verified versions: 5.7, 6.2, 6.3, 6.5) */
 | |
| 
 | |
| #define PTR		void *
 | |
| 
 | |
| #undef const
 | |
| #undef volatile
 | |
| #undef signed
 | |
| 
 | |
| /* inline requires special treatment; it's in C99, and GCC >=2.7 supports
 | |
|    it too, but it's not in C89.  */
 | |
| #undef inline
 | |
| #if __STDC_VERSION__ >= 199901L || defined(__cplusplus) || (defined(__SUNPRO_C) && defined(__C99FEATURES__))
 | |
| /* it's a keyword */
 | |
| #else
 | |
| # if GCC_VERSION >= 2007
 | |
| #  define inline __inline__   /* __inline__ prevents -pedantic warnings */
 | |
| # else
 | |
| #  define inline  /* nothing */
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| #else	/* Not ANSI C.  */
 | |
| 
 | |
| #define PTR		char *
 | |
| 
 | |
| /* some systems define these in header files for non-ansi mode */
 | |
| #undef const
 | |
| #undef volatile
 | |
| #undef signed
 | |
| #undef inline
 | |
| #define const
 | |
| #define volatile
 | |
| #define signed
 | |
| #define inline
 | |
| 
 | |
| #endif	/* ANSI C.  */
 | |
| 
 | |
| /* Define macros for some gcc attributes.  This permits us to use the
 | |
|    macros freely, and know that they will come into play for the
 | |
|    version of gcc in which they are supported.  */
 | |
| 
 | |
| #if (GCC_VERSION < 2007)
 | |
| # define __attribute__(x)
 | |
| #endif
 | |
| 
 | |
| /* Attribute __malloc__ on functions was valid as of gcc 2.96. */
 | |
| #ifndef ATTRIBUTE_MALLOC
 | |
| # if (GCC_VERSION >= 2096)
 | |
| #  define ATTRIBUTE_MALLOC __attribute__ ((__malloc__))
 | |
| # else
 | |
| #  define ATTRIBUTE_MALLOC
 | |
| # endif /* GNUC >= 2.96 */
 | |
| #endif /* ATTRIBUTE_MALLOC */
 | |
| 
 | |
| /* Attributes on labels were valid as of gcc 2.93 and g++ 4.5.  For
 | |
|    g++ an attribute on a label must be followed by a semicolon.  */
 | |
| #ifndef ATTRIBUTE_UNUSED_LABEL
 | |
| # ifndef __cplusplus
 | |
| #  if GCC_VERSION >= 2093
 | |
| #   define ATTRIBUTE_UNUSED_LABEL ATTRIBUTE_UNUSED
 | |
| #  else
 | |
| #   define ATTRIBUTE_UNUSED_LABEL
 | |
| #  endif
 | |
| # else
 | |
| #  if GCC_VERSION >= 4005
 | |
| #   define ATTRIBUTE_UNUSED_LABEL ATTRIBUTE_UNUSED ;
 | |
| #  else
 | |
| #   define ATTRIBUTE_UNUSED_LABEL
 | |
| #  endif
 | |
| # endif
 | |
| #endif
 | |
| 
 | |
| /* Similarly to ARG_UNUSED below.  Prior to GCC 3.4, the C++ frontend
 | |
|    couldn't parse attributes placed after the identifier name, and now
 | |
|    the entire compiler is built with C++.  */
 | |
| #ifndef ATTRIBUTE_UNUSED
 | |
| #if GCC_VERSION >= 3004
 | |
| #  define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
 | |
| #else
 | |
| #define ATTRIBUTE_UNUSED
 | |
| #endif
 | |
| #endif /* ATTRIBUTE_UNUSED */
 | |
| 
 | |
| /* Before GCC 3.4, the C++ frontend couldn't parse attributes placed after the
 | |
|    identifier name.  */
 | |
| #if ! defined(__cplusplus) || (GCC_VERSION >= 3004)
 | |
| # define ARG_UNUSED(NAME) NAME ATTRIBUTE_UNUSED
 | |
| #else /* !__cplusplus || GNUC >= 3.4 */
 | |
| # define ARG_UNUSED(NAME) NAME
 | |
| #endif /* !__cplusplus || GNUC >= 3.4 */
 | |
| 
 | |
| #ifndef ATTRIBUTE_NORETURN
 | |
| #define ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
 | |
| #endif /* ATTRIBUTE_NORETURN */
 | |
| 
 | |
| /* Attribute `nonnull' was valid as of gcc 3.3.  */
 | |
| #ifndef ATTRIBUTE_NONNULL
 | |
| # if (GCC_VERSION >= 3003)
 | |
| #  define ATTRIBUTE_NONNULL(m) __attribute__ ((__nonnull__ (m)))
 | |
| # else
 | |
| #  define ATTRIBUTE_NONNULL(m)
 | |
| # endif /* GNUC >= 3.3 */
 | |
| #endif /* ATTRIBUTE_NONNULL */
 | |
| 
 | |
| /* Attribute `returns_nonnull' was valid as of gcc 4.9.  */
 | |
| #ifndef ATTRIBUTE_RETURNS_NONNULL
 | |
| # if (GCC_VERSION >= 4009)
 | |
| #  define ATTRIBUTE_RETURNS_NONNULL __attribute__ ((__returns_nonnull__))
 | |
| # else
 | |
| #  define ATTRIBUTE_RETURNS_NONNULL
 | |
| # endif /* GNUC >= 4.9 */
 | |
| #endif /* ATTRIBUTE_RETURNS_NONNULL */
 | |
| 
 | |
| /* Attribute `pure' was valid as of gcc 3.0.  */
 | |
| #ifndef ATTRIBUTE_PURE
 | |
| # if (GCC_VERSION >= 3000)
 | |
| #  define ATTRIBUTE_PURE __attribute__ ((__pure__))
 | |
| # else
 | |
| #  define ATTRIBUTE_PURE
 | |
| # endif /* GNUC >= 3.0 */
 | |
| #endif /* ATTRIBUTE_PURE */
 | |
| 
 | |
| /* Use ATTRIBUTE_PRINTF when the format specifier must not be NULL.
 | |
|    This was the case for the `printf' format attribute by itself
 | |
|    before GCC 3.3, but as of 3.3 we need to add the `nonnull'
 | |
|    attribute to retain this behavior.  */
 | |
| #ifndef ATTRIBUTE_PRINTF
 | |
| #define ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n))) ATTRIBUTE_NONNULL(m)
 | |
| #define ATTRIBUTE_PRINTF_1 ATTRIBUTE_PRINTF(1, 2)
 | |
| #define ATTRIBUTE_PRINTF_2 ATTRIBUTE_PRINTF(2, 3)
 | |
| #define ATTRIBUTE_PRINTF_3 ATTRIBUTE_PRINTF(3, 4)
 | |
| #define ATTRIBUTE_PRINTF_4 ATTRIBUTE_PRINTF(4, 5)
 | |
| #define ATTRIBUTE_PRINTF_5 ATTRIBUTE_PRINTF(5, 6)
 | |
| #endif /* ATTRIBUTE_PRINTF */
 | |
| 
 | |
| /* Use ATTRIBUTE_FPTR_PRINTF when the format attribute is to be set on
 | |
|    a function pointer.  Format attributes were allowed on function
 | |
|    pointers as of gcc 3.1.  */
 | |
| #ifndef ATTRIBUTE_FPTR_PRINTF
 | |
| # if (GCC_VERSION >= 3001)
 | |
| #  define ATTRIBUTE_FPTR_PRINTF(m, n) ATTRIBUTE_PRINTF(m, n)
 | |
| # else
 | |
| #  define ATTRIBUTE_FPTR_PRINTF(m, n)
 | |
| # endif /* GNUC >= 3.1 */
 | |
| # define ATTRIBUTE_FPTR_PRINTF_1 ATTRIBUTE_FPTR_PRINTF(1, 2)
 | |
| # define ATTRIBUTE_FPTR_PRINTF_2 ATTRIBUTE_FPTR_PRINTF(2, 3)
 | |
| # define ATTRIBUTE_FPTR_PRINTF_3 ATTRIBUTE_FPTR_PRINTF(3, 4)
 | |
| # define ATTRIBUTE_FPTR_PRINTF_4 ATTRIBUTE_FPTR_PRINTF(4, 5)
 | |
| # define ATTRIBUTE_FPTR_PRINTF_5 ATTRIBUTE_FPTR_PRINTF(5, 6)
 | |
| #endif /* ATTRIBUTE_FPTR_PRINTF */
 | |
| 
 | |
| /* Use ATTRIBUTE_NULL_PRINTF when the format specifier may be NULL.  A
 | |
|    NULL format specifier was allowed as of gcc 3.3.  */
 | |
| #ifndef ATTRIBUTE_NULL_PRINTF
 | |
| # if (GCC_VERSION >= 3003)
 | |
| #  define ATTRIBUTE_NULL_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
 | |
| # else
 | |
| #  define ATTRIBUTE_NULL_PRINTF(m, n)
 | |
| # endif /* GNUC >= 3.3 */
 | |
| # define ATTRIBUTE_NULL_PRINTF_1 ATTRIBUTE_NULL_PRINTF(1, 2)
 | |
| # define ATTRIBUTE_NULL_PRINTF_2 ATTRIBUTE_NULL_PRINTF(2, 3)
 | |
| # define ATTRIBUTE_NULL_PRINTF_3 ATTRIBUTE_NULL_PRINTF(3, 4)
 | |
| # define ATTRIBUTE_NULL_PRINTF_4 ATTRIBUTE_NULL_PRINTF(4, 5)
 | |
| # define ATTRIBUTE_NULL_PRINTF_5 ATTRIBUTE_NULL_PRINTF(5, 6)
 | |
| #endif /* ATTRIBUTE_NULL_PRINTF */
 | |
| 
 | |
| /* Attribute `sentinel' was valid as of gcc 3.5.  */
 | |
| #ifndef ATTRIBUTE_SENTINEL
 | |
| # if (GCC_VERSION >= 3005)
 | |
| #  define ATTRIBUTE_SENTINEL __attribute__ ((__sentinel__))
 | |
| # else
 | |
| #  define ATTRIBUTE_SENTINEL
 | |
| # endif /* GNUC >= 3.5 */
 | |
| #endif /* ATTRIBUTE_SENTINEL */
 | |
| 
 | |
| 
 | |
| #ifndef ATTRIBUTE_ALIGNED_ALIGNOF
 | |
| # if (GCC_VERSION >= 3000)
 | |
| #  define ATTRIBUTE_ALIGNED_ALIGNOF(m) __attribute__ ((__aligned__ (__alignof__ (m))))
 | |
| # else
 | |
| #  define ATTRIBUTE_ALIGNED_ALIGNOF(m)
 | |
| # endif /* GNUC >= 3.0 */
 | |
| #endif /* ATTRIBUTE_ALIGNED_ALIGNOF */
 | |
| 
 | |
| /* Useful for structures whose layout must much some binary specification
 | |
|    regardless of the alignment and padding qualities of the compiler.  */
 | |
| #ifndef ATTRIBUTE_PACKED
 | |
| # define ATTRIBUTE_PACKED __attribute__ ((packed))
 | |
| #endif
 | |
| 
 | |
| /* Attribute `hot' and `cold' was valid as of gcc 4.3.  */
 | |
| #ifndef ATTRIBUTE_COLD
 | |
| # if (GCC_VERSION >= 4003)
 | |
| #  define ATTRIBUTE_COLD __attribute__ ((__cold__))
 | |
| # else
 | |
| #  define ATTRIBUTE_COLD
 | |
| # endif /* GNUC >= 4.3 */
 | |
| #endif /* ATTRIBUTE_COLD */
 | |
| #ifndef ATTRIBUTE_HOT
 | |
| # if (GCC_VERSION >= 4003)
 | |
| #  define ATTRIBUTE_HOT __attribute__ ((__hot__))
 | |
| # else
 | |
| #  define ATTRIBUTE_HOT
 | |
| # endif /* GNUC >= 4.3 */
 | |
| #endif /* ATTRIBUTE_HOT */
 | |
| 
 | |
| /* We use __extension__ in some places to suppress -pedantic warnings
 | |
|    about GCC extensions.  This feature didn't work properly before
 | |
|    gcc 2.8.  */
 | |
| #if GCC_VERSION < 2008
 | |
| #define __extension__
 | |
| #endif
 | |
| 
 | |
| /* This is used to declare a const variable which should be visible
 | |
|    outside of the current compilation unit.  Use it as
 | |
|      EXPORTED_CONST int i = 1;
 | |
|    This is because the semantics of const are different in C and C++.
 | |
|    "extern const" is permitted in C but it looks strange, and gcc
 | |
|    warns about it when -Wc++-compat is not used.  */
 | |
| #ifdef __cplusplus
 | |
| #define EXPORTED_CONST extern const
 | |
| #else
 | |
| #define EXPORTED_CONST const
 | |
| #endif
 | |
| 
 | |
| /* Be conservative and only use enum bitfields with C++ or GCC.
 | |
|    FIXME: provide a complete autoconf test for buggy enum bitfields.  */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| #define ENUM_BITFIELD(TYPE) enum TYPE
 | |
| #elif (GCC_VERSION > 2000)
 | |
| #define ENUM_BITFIELD(TYPE) __extension__ enum TYPE
 | |
| #else
 | |
| #define ENUM_BITFIELD(TYPE) unsigned int
 | |
| #endif
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif	/* ansidecl.h	*/
 |