Blame gnulib/stdbool.in.h

Packit Service 392537
/* Copyright (C) 2001-2003, 2006-2016 Free Software Foundation, Inc.
Packit Service 392537
   Written by Bruno Haible <haible@clisp.cons.org>, 2001.
Packit Service 392537
Packit Service 392537
   This program is free software; you can redistribute it and/or modify
Packit Service 392537
   it under the terms of the GNU General Public License as published by
Packit Service 392537
   the Free Software Foundation; either version 3, or (at your option)
Packit Service 392537
   any later version.
Packit Service 392537
Packit Service 392537
   This program is distributed in the hope that it will be useful,
Packit Service 392537
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 392537
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 392537
   GNU General Public License for more details.
Packit Service 392537
Packit Service 392537
   You should have received a copy of the GNU General Public License
Packit Service 392537
   along with this program; if not, see <http://www.gnu.org/licenses/>.  */
Packit Service 392537
Packit Service 392537
#ifndef _GL_STDBOOL_H
Packit Service 392537
#define _GL_STDBOOL_H
Packit Service 392537
Packit Service 392537
/* ISO C 99 <stdbool.h> for platforms that lack it.  */
Packit Service 392537
Packit Service 392537
/* Usage suggestions:
Packit Service 392537
Packit Service 392537
   Programs that use <stdbool.h> should be aware of some limitations
Packit Service 392537
   and standards compliance issues.
Packit Service 392537
Packit Service 392537
   Standards compliance:
Packit Service 392537
Packit Service 392537
       - <stdbool.h> must be #included before 'bool', 'false', 'true'
Packit Service 392537
         can be used.
Packit Service 392537
Packit Service 392537
       - You cannot assume that sizeof (bool) == 1.
Packit Service 392537
Packit Service 392537
       - Programs should not undefine the macros bool, true, and false,
Packit Service 392537
         as C99 lists that as an "obsolescent feature".
Packit Service 392537
Packit Service 392537
   Limitations of this substitute, when used in a C89 environment:
Packit Service 392537
Packit Service 392537
       - <stdbool.h> must be #included before the '_Bool' type can be used.
Packit Service 392537
Packit Service 392537
       - You cannot assume that _Bool is a typedef; it might be a macro.
Packit Service 392537
Packit Service 392537
       - Bit-fields of type 'bool' are not supported.  Portable code
Packit Service 392537
         should use 'unsigned int foo : 1;' rather than 'bool foo : 1;'.
Packit Service 392537
Packit Service 392537
       - In C99, casts and automatic conversions to '_Bool' or 'bool' are
Packit Service 392537
         performed in such a way that every nonzero value gets converted
Packit Service 392537
         to 'true', and zero gets converted to 'false'.  This doesn't work
Packit Service 392537
         with this substitute.  With this substitute, only the values 0 and 1
Packit Service 392537
         give the expected result when converted to _Bool' or 'bool'.
Packit Service 392537
Packit Service 392537
       - C99 allows the use of (_Bool)0.0 in constant expressions, but
Packit Service 392537
         this substitute cannot always provide this property.
Packit Service 392537
Packit Service 392537
   Also, it is suggested that programs use 'bool' rather than '_Bool';
Packit Service 392537
   this isn't required, but 'bool' is more common.  */
Packit Service 392537
Packit Service 392537
Packit Service 392537
/* 7.16. Boolean type and values */
Packit Service 392537
Packit Service 392537
/* BeOS <sys/socket.h> already #defines false 0, true 1.  We use the same
Packit Service 392537
   definitions below, but temporarily we have to #undef them.  */
Packit Service 392537
#if defined __BEOS__ && !defined __HAIKU__
Packit Service 392537
# include <OS.h> /* defines bool but not _Bool */
Packit Service 392537
# undef false
Packit Service 392537
# undef true
Packit Service 392537
#endif
Packit Service 392537
Packit Service 392537
#ifdef __cplusplus
Packit Service 392537
# define _Bool bool
Packit Service 392537
# define bool bool
Packit Service 392537
#else
Packit Service 392537
# if defined __BEOS__ && !defined __HAIKU__
Packit Service 392537
  /* A compiler known to have 'bool'.  */
Packit Service 392537
  /* If the compiler already has both 'bool' and '_Bool', we can assume they
Packit Service 392537
     are the same types.  */
Packit Service 392537
#  if !@HAVE__BOOL@
Packit Service 392537
typedef bool _Bool;
Packit Service 392537
#  endif
Packit Service 392537
# else
Packit Service 392537
#  if !defined __GNUC__
Packit Service 392537
   /* If @HAVE__BOOL@:
Packit Service 392537
        Some HP-UX cc and AIX IBM C compiler versions have compiler bugs when
Packit Service 392537
        the built-in _Bool type is used.  See
Packit Service 392537
          http://gcc.gnu.org/ml/gcc-patches/2003-12/msg02303.html
Packit Service 392537
          http://lists.gnu.org/archive/html/bug-coreutils/2005-11/msg00161.html
Packit Service 392537
          http://lists.gnu.org/archive/html/bug-coreutils/2005-10/msg00086.html
Packit Service 392537
        Similar bugs are likely with other compilers as well; this file
Packit Service 392537
        wouldn't be used if <stdbool.h> was working.
Packit Service 392537
        So we override the _Bool type.
Packit Service 392537
      If !@HAVE__BOOL@:
Packit Service 392537
        Need to define _Bool ourselves. As 'signed char' or as an enum type?
Packit Service 392537
        Use of a typedef, with SunPRO C, leads to a stupid
Packit Service 392537
          "warning: _Bool is a keyword in ISO C99".
Packit Service 392537
        Use of an enum type, with IRIX cc, leads to a stupid
Packit Service 392537
          "warning(1185): enumerated type mixed with another type".
Packit Service 392537
        Even the existence of an enum type, without a typedef,
Packit Service 392537
          "Invalid enumerator. (badenum)" with HP-UX cc on Tru64.
Packit Service 392537
        The only benefit of the enum, debuggability, is not important
Packit Service 392537
        with these compilers.  So use 'signed char' and no enum.  */
Packit Service 392537
#   define _Bool signed char
Packit Service 392537
#  else
Packit Service 392537
   /* With this compiler, trust the _Bool type if the compiler has it.  */
Packit Service 392537
#   if !@HAVE__BOOL@
Packit Service 392537
   /* For the sake of symbolic names in gdb, define true and false as
Packit Service 392537
      enum constants, not only as macros.
Packit Service 392537
      It is tempting to write
Packit Service 392537
         typedef enum { false = 0, true = 1 } _Bool;
Packit Service 392537
      so that gdb prints values of type 'bool' symbolically.  But then
Packit Service 392537
      values of type '_Bool' might promote to 'int' or 'unsigned int'
Packit Service 392537
      (see ISO C 99 6.7.2.2.(4)); however, '_Bool' must promote to 'int'
Packit Service 392537
      (see ISO C 99 6.3.1.1.(2)).  So add a negative value to the
Packit Service 392537
      enum; this ensures that '_Bool' promotes to 'int'.  */
Packit Service 392537
typedef enum { _Bool_must_promote_to_int = -1, false = 0, true = 1 } _Bool;
Packit Service 392537
#   endif
Packit Service 392537
#  endif
Packit Service 392537
# endif
Packit Service 392537
# define bool _Bool
Packit Service 392537
#endif
Packit Service 392537
Packit Service 392537
/* The other macros must be usable in preprocessor directives.  */
Packit Service 392537
#ifdef __cplusplus
Packit Service 392537
# define false false
Packit Service 392537
# define true true
Packit Service 392537
#else
Packit Service 392537
# define false 0
Packit Service 392537
# define true 1
Packit Service 392537
#endif
Packit Service 392537
Packit Service 392537
#define __bool_true_false_are_defined 1
Packit Service 392537
Packit Service 392537
#endif /* _GL_STDBOOL_H */