OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [gdb-5.0/] [include/] [ansidecl.h] - Diff between revs 107 and 1765

Only display areas with differences | Details | Blame | View Log

Rev 107 Rev 1765
/* ANSI and traditional C compatability macros
/* ANSI and traditional C compatability macros
   Copyright 1991, 1992, 1996, 1999 Free Software Foundation, Inc.
   Copyright 1991, 1992, 1996, 1999 Free Software Foundation, Inc.
   This file is part of the GNU C Library.
   This file is part of the GNU C Library.
 
 
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 General Public License as published by
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
(at your option) any later version.
 
 
This program is distributed in the hope that it will be useful,
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
GNU General Public License for more details.
 
 
You should have received a copy of the GNU General Public License
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 
 
/* ANSI and traditional C compatibility macros
/* ANSI and traditional C compatibility macros
 
 
   ANSI C is assumed if __STDC__ is #defined.
   ANSI C is assumed if __STDC__ is #defined.
 
 
   Macro        ANSI C definition       Traditional C definition
   Macro        ANSI C definition       Traditional C definition
   -----        ---- - ----------       ----------- - ----------
   -----        ---- - ----------       ----------- - ----------
   PTR          `void *'                `char *'
   PTR          `void *'                `char *'
   LONG_DOUBLE  `long double'           `double'
   LONG_DOUBLE  `long double'           `double'
   VOLATILE     `volatile'              `'
   VOLATILE     `volatile'              `'
   SIGNED       `signed'                `'
   SIGNED       `signed'                `'
   PTRCONST     `void *const'           `char *'
   PTRCONST     `void *const'           `char *'
   ANSI_PROTOTYPES  1                   not defined
   ANSI_PROTOTYPES  1                   not defined
 
 
   CONST is also defined, but is obsolete.  Just use const.
   CONST is also defined, but is obsolete.  Just use const.
 
 
   obsolete --     DEFUN (name, arglist, args)
   obsolete --     DEFUN (name, arglist, args)
 
 
        Defines function NAME.
        Defines function NAME.
 
 
        ARGLIST lists the arguments, separated by commas and enclosed in
        ARGLIST lists the arguments, separated by commas and enclosed in
        parentheses.  ARGLIST becomes the argument list in traditional C.
        parentheses.  ARGLIST becomes the argument list in traditional C.
 
 
        ARGS list the arguments with their types.  It becomes a prototype in
        ARGS list the arguments with their types.  It becomes a prototype in
        ANSI C, and the type declarations in traditional C.  Arguments should
        ANSI C, and the type declarations in traditional C.  Arguments should
        be separated with `AND'.  For functions with a variable number of
        be separated with `AND'.  For functions with a variable number of
        arguments, the last thing listed should be `DOTS'.
        arguments, the last thing listed should be `DOTS'.
 
 
   obsolete --     DEFUN_VOID (name)
   obsolete --     DEFUN_VOID (name)
 
 
        Defines a function NAME, which takes no arguments.
        Defines a function NAME, which takes no arguments.
 
 
   obsolete --     EXFUN (name, (prototype))    -- obsolete.
   obsolete --     EXFUN (name, (prototype))    -- obsolete.
 
 
        Replaced by PARAMS.  Do not use; will disappear someday soon.
        Replaced by PARAMS.  Do not use; will disappear someday soon.
        Was used in external function declarations.
        Was used in external function declarations.
        In ANSI C it is `NAME PROTOTYPE' (so PROTOTYPE should be enclosed in
        In ANSI C it is `NAME PROTOTYPE' (so PROTOTYPE should be enclosed in
        parentheses).  In traditional C it is `NAME()'.
        parentheses).  In traditional C it is `NAME()'.
        For a function that takes no arguments, PROTOTYPE should be `(void)'.
        For a function that takes no arguments, PROTOTYPE should be `(void)'.
 
 
   obsolete --     PROTO (type, name, (prototype)    -- obsolete.
   obsolete --     PROTO (type, name, (prototype)    -- obsolete.
 
 
        This one has also been replaced by PARAMS.  Do not use.
        This one has also been replaced by PARAMS.  Do not use.
 
 
   PARAMS ((args))
   PARAMS ((args))
 
 
        We could use the EXFUN macro to handle prototype declarations, but
        We could use the EXFUN macro to handle prototype declarations, but
        the name is misleading and the result is ugly.  So we just define a
        the name is misleading and the result is ugly.  So we just define a
        simple macro to handle the parameter lists, as in:
        simple macro to handle the parameter lists, as in:
 
 
              static int foo PARAMS ((int, char));
              static int foo PARAMS ((int, char));
 
 
        This produces:  `static int foo();' or `static int foo (int, char);'
        This produces:  `static int foo();' or `static int foo (int, char);'
 
 
        EXFUN would have done it like this:
        EXFUN would have done it like this:
 
 
              static int EXFUN (foo, (int, char));
              static int EXFUN (foo, (int, char));
 
 
        but the function is not external...and it's hard to visually parse
        but the function is not external...and it's hard to visually parse
        the function name out of the mess.   EXFUN should be considered
        the function name out of the mess.   EXFUN should be considered
        obsolete; new code should be written to use PARAMS.
        obsolete; new code should be written to use PARAMS.
 
 
   DOTS is also obsolete.
   DOTS is also obsolete.
 
 
   Examples:
   Examples:
 
 
        extern int printf PARAMS ((const char *format, ...));
        extern int printf PARAMS ((const char *format, ...));
*/
*/
 
 
#ifndef _ANSIDECL_H
#ifndef _ANSIDECL_H
 
 
#define _ANSIDECL_H     1
#define _ANSIDECL_H     1
 
 
 
 
/* Every source file includes this file,
/* Every source file includes this file,
   so they will all get the switch for lint.  */
   so they will all get the switch for lint.  */
/* LINTLIBRARY */
/* LINTLIBRARY */
 
 
 
 
#if defined (__STDC__) || defined (_AIX) || (defined (__mips) && defined (_SYSTYPE_SVR4)) || defined(_WIN32)
#if defined (__STDC__) || defined (_AIX) || (defined (__mips) && defined (_SYSTYPE_SVR4)) || defined(_WIN32)
/* All known AIX compilers implement these things (but don't always
/* All known AIX compilers implement these things (but don't always
   define __STDC__).  The RISC/OS MIPS compiler defines these things
   define __STDC__).  The RISC/OS MIPS compiler defines these things
   in SVR4 mode, but does not define __STDC__.  */
   in SVR4 mode, but does not define __STDC__.  */
 
 
#define PTR             void *
#define PTR             void *
#define PTRCONST        void *CONST
#define PTRCONST        void *CONST
#define LONG_DOUBLE     long double
#define LONG_DOUBLE     long double
 
 
#ifndef IN_GCC
#ifndef IN_GCC
#define AND             ,
#define AND             ,
#define NOARGS          void
#define NOARGS          void
#define VOLATILE        volatile
#define VOLATILE        volatile
#define SIGNED          signed
#define SIGNED          signed
#endif /* ! IN_GCC */
#endif /* ! IN_GCC */
 
 
#define PARAMS(paramlist)               paramlist
#define PARAMS(paramlist)               paramlist
#define ANSI_PROTOTYPES                 1
#define ANSI_PROTOTYPES                 1
 
 
#define VPARAMS(ARGS)                   ARGS
#define VPARAMS(ARGS)                   ARGS
#define VA_START(va_list,var)           va_start(va_list,var)
#define VA_START(va_list,var)           va_start(va_list,var)
 
 
/* These are obsolete.  Do not use.  */
/* These are obsolete.  Do not use.  */
#ifndef IN_GCC
#ifndef IN_GCC
#define CONST                           const
#define CONST                           const
#define DOTS                            , ...
#define DOTS                            , ...
#define PROTO(type, name, arglist)      type name arglist
#define PROTO(type, name, arglist)      type name arglist
#define EXFUN(name, proto)              name proto
#define EXFUN(name, proto)              name proto
#define DEFUN(name, arglist, args)      name(args)
#define DEFUN(name, arglist, args)      name(args)
#define DEFUN_VOID(name)                name(void)
#define DEFUN_VOID(name)                name(void)
#endif /* ! IN_GCC */
#endif /* ! IN_GCC */
 
 
#else   /* Not ANSI C.  */
#else   /* Not ANSI C.  */
 
 
#define PTR             char *
#define PTR             char *
#define PTRCONST        PTR
#define PTRCONST        PTR
#define LONG_DOUBLE     double
#define LONG_DOUBLE     double
 
 
#ifndef IN_GCC
#ifndef IN_GCC
#define AND             ;
#define AND             ;
#define NOARGS
#define NOARGS
#define VOLATILE
#define VOLATILE
#define SIGNED
#define SIGNED
#endif /* !IN_GCC */
#endif /* !IN_GCC */
 
 
#ifndef const /* some systems define it in header files for non-ansi mode */
#ifndef const /* some systems define it in header files for non-ansi mode */
#define const
#define const
#endif
#endif
 
 
#define PARAMS(paramlist)               ()
#define PARAMS(paramlist)               ()
 
 
#define VPARAMS(ARGS)                   (va_alist) va_dcl
#define VPARAMS(ARGS)                   (va_alist) va_dcl
#define VA_START(va_list,var)           va_start(va_list)
#define VA_START(va_list,var)           va_start(va_list)
 
 
/* These are obsolete.  Do not use.  */
/* These are obsolete.  Do not use.  */
#ifndef IN_GCC
#ifndef IN_GCC
#define CONST
#define CONST
#define DOTS
#define DOTS
#define PROTO(type, name, arglist)      type name ()
#define PROTO(type, name, arglist)      type name ()
#define EXFUN(name, proto)              name()
#define EXFUN(name, proto)              name()
#define DEFUN(name, arglist, args)      name arglist args;
#define DEFUN(name, arglist, args)      name arglist args;
#define DEFUN_VOID(name)                name()
#define DEFUN_VOID(name)                name()
#endif /* ! IN_GCC */
#endif /* ! IN_GCC */
 
 
#endif  /* ANSI C.  */
#endif  /* ANSI C.  */
 
 
/* Using MACRO(x,y) in cpp #if conditionals does not work with some
/* Using MACRO(x,y) in cpp #if conditionals does not work with some
   older preprocessors.  Thus we can't define something like this:
   older preprocessors.  Thus we can't define something like this:
 
 
#define HAVE_GCC_VERSION(MAJOR, MINOR) \
#define HAVE_GCC_VERSION(MAJOR, MINOR) \
  (__GNUC__ > (MAJOR) || (__GNUC__ == (MAJOR) && __GNUC_MINOR__ >= (MINOR)))
  (__GNUC__ > (MAJOR) || (__GNUC__ == (MAJOR) && __GNUC_MINOR__ >= (MINOR)))
 
 
and then test "#if HAVE_GCC_VERSION(2,7)".
and then test "#if HAVE_GCC_VERSION(2,7)".
 
 
So instead we use the macro below and test it against specific values.  */
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
/* This macro simplifies testing whether we are using gcc, and if it
   is of a particular minimum version. (Both major & minor numbers are
   is of a particular minimum version. (Both major & minor numbers are
   significant.)  This macro will evaluate to 0 if we are not using
   significant.)  This macro will evaluate to 0 if we are not using
   gcc at all.  */
   gcc at all.  */
#ifndef GCC_VERSION
#ifndef GCC_VERSION
#define GCC_VERSION (__GNUC__ * 1000 + __GNUC_MINOR__)
#define GCC_VERSION (__GNUC__ * 1000 + __GNUC_MINOR__)
#endif /* GCC_VERSION */
#endif /* GCC_VERSION */
 
 
/* Define macros for some gcc attributes.  This permits us to use the
/* Define macros for some gcc attributes.  This permits us to use the
   macros freely, and know that they will come into play for the
   macros freely, and know that they will come into play for the
   version of gcc in which they are supported.  */
   version of gcc in which they are supported.  */
 
 
#if (GCC_VERSION < 2007)
#if (GCC_VERSION < 2007)
# define __attribute__(x)
# define __attribute__(x)
#endif
#endif
 
 
/* Attribute __malloc__ on functions was valid as of gcc 2.96. */
/* Attribute __malloc__ on functions was valid as of gcc 2.96. */
#ifndef ATTRIBUTE_MALLOC
#ifndef ATTRIBUTE_MALLOC
# if (GCC_VERSION >= 2096)
# if (GCC_VERSION >= 2096)
#  define ATTRIBUTE_MALLOC __attribute__ ((__malloc__))
#  define ATTRIBUTE_MALLOC __attribute__ ((__malloc__))
# else
# else
#  define ATTRIBUTE_MALLOC
#  define ATTRIBUTE_MALLOC
# endif /* GNUC >= 2.96 */
# endif /* GNUC >= 2.96 */
#endif /* ATTRIBUTE_MALLOC */
#endif /* ATTRIBUTE_MALLOC */
 
 
/* Attributes on labels were valid as of gcc 2.93. */
/* Attributes on labels were valid as of gcc 2.93. */
#ifndef ATTRIBUTE_UNUSED_LABEL
#ifndef ATTRIBUTE_UNUSED_LABEL
# if (GCC_VERSION >= 2093)
# if (GCC_VERSION >= 2093)
#  define ATTRIBUTE_UNUSED_LABEL ATTRIBUTE_UNUSED
#  define ATTRIBUTE_UNUSED_LABEL ATTRIBUTE_UNUSED
# else
# else
#  define ATTRIBUTE_UNUSED_LABEL
#  define ATTRIBUTE_UNUSED_LABEL
# endif /* GNUC >= 2.93 */
# endif /* GNUC >= 2.93 */
#endif /* ATTRIBUTE_UNUSED_LABEL */
#endif /* ATTRIBUTE_UNUSED_LABEL */
 
 
#ifndef ATTRIBUTE_UNUSED
#ifndef ATTRIBUTE_UNUSED
#define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
#define ATTRIBUTE_UNUSED __attribute__ ((__unused__))
#endif /* ATTRIBUTE_UNUSED */
#endif /* ATTRIBUTE_UNUSED */
 
 
#ifndef ATTRIBUTE_NORETURN
#ifndef ATTRIBUTE_NORETURN
#define ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
#define ATTRIBUTE_NORETURN __attribute__ ((__noreturn__))
#endif /* ATTRIBUTE_NORETURN */
#endif /* ATTRIBUTE_NORETURN */
 
 
#ifndef ATTRIBUTE_PRINTF
#ifndef ATTRIBUTE_PRINTF
#define ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
#define ATTRIBUTE_PRINTF(m, n) __attribute__ ((__format__ (__printf__, m, n)))
#define ATTRIBUTE_PRINTF_1 ATTRIBUTE_PRINTF(1, 2)
#define ATTRIBUTE_PRINTF_1 ATTRIBUTE_PRINTF(1, 2)
#define ATTRIBUTE_PRINTF_2 ATTRIBUTE_PRINTF(2, 3)
#define ATTRIBUTE_PRINTF_2 ATTRIBUTE_PRINTF(2, 3)
#define ATTRIBUTE_PRINTF_3 ATTRIBUTE_PRINTF(3, 4)
#define ATTRIBUTE_PRINTF_3 ATTRIBUTE_PRINTF(3, 4)
#define ATTRIBUTE_PRINTF_4 ATTRIBUTE_PRINTF(4, 5)
#define ATTRIBUTE_PRINTF_4 ATTRIBUTE_PRINTF(4, 5)
#define ATTRIBUTE_PRINTF_5 ATTRIBUTE_PRINTF(5, 6)
#define ATTRIBUTE_PRINTF_5 ATTRIBUTE_PRINTF(5, 6)
#endif /* ATTRIBUTE_PRINTF */
#endif /* ATTRIBUTE_PRINTF */
 
 
#endif  /* ansidecl.h   */
#endif  /* ansidecl.h   */
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.