cvs.gedasymbols.org/archives/browse.cgi   search  
Mail Archives: djgpp-workers/2018/09/14/15:18:06

X-Authentication-Warning: delorie.com: mail set sender to djgpp-workers-bounces using -f
X-Recipient: djgpp-workers AT delorie DOT com
X-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
d=gmail.com; s=20161025;
h=mime-version:in-reply-to:references:from:date:message-id:subject:to;
bh=n/uviXICnSt+Jq7vM8QXjrbY3BJQc6HY3vBou5fdguM=;
b=KUMSxg5TE3lRc3kGCRKmYbZLuyG6UQqX39nSBXMS9Rt2IeLkHnPkNh7eilzYi7c/QS
Pfokr4aNMm0FH6CWq24HNTBrrNJSTtQhGH3yx0QLrwfnxAsvWfbVc5P3P9cv40RVIwJV
RD6cz8ArvtZbdmibSt1B1T3AIU9/qDe2ND231ARePkgvNjOuRFfxt6nJ6xKIxiIUvyxQ
Hso/q3b7qjVae8tLS9Bvsls+3nlF9aPwPj1IY6JsvUqBgR28z+z8U2sBShtrVGfkSZcd
TKDxmzJgPutPO8X2/wITmfzezBRrEfanVEfH/L5XAMC7ObEV0copARyaDe8iX/Gwu8MP
sNkw==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
d=1e100.net; s=20161025;
h=x-gm-message-state:mime-version:in-reply-to:references:from:date
:message-id:subject:to;
bh=n/uviXICnSt+Jq7vM8QXjrbY3BJQc6HY3vBou5fdguM=;
b=lIgjnqVMdVqo2CYL49Rby32R+KbDiimMdmRH6a+3LvEC4FQF81qVqLLib6rdvQD0z3
Nti0xJOumB0V9hADrG2QccwgbuM6L2vdz44AFIbk53ADXP6CYFKBXfk5atcX810G1xFs
3k08wfI+GMUvdGdYlHs98GcMnTr4wwtrdVGbxN9jaVnCIf+6qtU5oMOOCXS/2sEdspPz
GnH87evNndvQF0J/Ee0WIEfEAIrNre0wZ2TKRSGiEa1JyUHUrIP4zyW2IF1ZjGlFBrmf
Oepp+qkDSoNg4cENGkFinRoUA+vGga9QO95GvQl/32wi5lK4GFngxtL4TOQOvnbzoZxN
ft7g==
X-Gm-Message-State: APzg51DKTZgueCU49V/xWgLgkduhQrOynvwVJbK580ug8sy1FydttvMK
qroCgTd6VhisDMzUkD3bvuZ3qJrHvCSoMIlAloBdhqP6
X-Google-Smtp-Source: ANB0VdYja1Yf35yUDJ8pCH0l6T98TtA3zNjHluUHpzTSGGc8pXOnQ8L4LAWsCg5vArZX7cLNTRGD9kb+q5m+EkQ+K7c=
X-Received: by 2002:a6b:8cd6:: with SMTP id o205-v6mr12165463iod.195.1536952683229;
Fri, 14 Sep 2018 12:18:03 -0700 (PDT)
MIME-Version: 1.0
In-Reply-To: <CAA2C=vBs-=vUkC_4Ek96cnEPPg0=Dy_LMVM3ALOBThpe08CsYA@mail.gmail.com>
References: <CAA2C=vBs-=vUkC_4Ek96cnEPPg0=Dy_LMVM3ALOBThpe08CsYA AT mail DOT gmail DOT com>
From: "Ozkan Sezer (sezeroz AT gmail DOT com) [via djgpp-workers AT delorie DOT com]" <djgpp-workers AT delorie DOT com>
Date: Fri, 14 Sep 2018 22:18:02 +0300
Message-ID: <CAA2C=vAD0wRdTjgC1Xgj2LH2AmM7J7hJq=jCXjyhWHH5ou8q-Q@mail.gmail.com>
Subject: Re: stdbool.h
To: djgpp-workers AT delorie DOT com
Reply-To: djgpp-workers AT delorie DOT com
Errors-To: nobody AT delorie DOT com
X-Mailing-List: djgpp-workers AT delorie DOT com
X-Unsubscribes-To: listserv AT delorie DOT com

On 9/14/18, Ozkan Sezer <sezeroz AT gmail DOT com> wrote:
> Why do we need to provide a stdbool.h among djgpp includes? Gcc >= 3.0
> already provides it, and looking at deleted/v2gnu/ our own gcc302b.zip
> and gcc31b.zip do have it. (And the more recent versions gcc packages
> from current/v2gnu/ have it too, of course.)  That makes our stdbool.h
> only useful for gcc2.95, but it is broken for it, because gcc2.95 does
> not define the _Bool type which we rely upon. (I don't know about the
> gcc2.95 C++ bool support, so I don't know whether our stdbool.h works
> with it.)
>
> I suggest we either remove it, or adjust it in a way so it only defines
> stuff for gcc < 3.0.  Maybe (?) something like:
[...]
> Comments?

I obviously inlined a wrong patch.  Saner one below:

diff -U 5 -r1.3 stdbool.h
--- stdbool.h	2 May 2015 07:31:48 -0000	1.3
+++ stdbool.h	14 Sep 2018 18:56:02 -0000
@@ -1,15 +1,21 @@
 /* Copyright (C) 2012 DJ Delorie, see COPYING.DJ for details */
 #ifndef __dj_stdbool__h_
 #define __dj_stdbool__h_

+#if (__GNUC__ < 3)
 #if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) \
   || !defined(__STRICT_ANSI__) || defined(__cplusplus)

+typedef int _Bool;
 #define bool _Bool
 #define true 1
 #define false 0
 #define __bool_true_false_are_defined 1

 #endif /* (__STDC_VERSION__ >= 199901L) || !__STRICT_ANSI__ */

+#else
+#include_next <stdbool.h>
+#endif /* (__GNUC__ < 3) */
+
 #endif /* !__dj_stdbool__h_ */


> I am writing this, because I just attempted building current cvs using
> gcc-2.95 and it failed in src/libc/dos/io/_open.c which added stdbool.h
> dependency in revision 1.13.  The failure is unrecognized type _Bool,of
> course.  For it, I suggest the following (like doprnt.c):
>
> diff -u -r1.13 _open.c
> --- _open.c	19 May 2018 18:01:03 -0000	1.13
> +++ _open.c	14 Sep 2018 18:57:21 -0000
> @@ -7,7 +7,6 @@
>  /* Copyright (C) 1995 DJ Delorie, see COPYING.DJ for details */
>  #include <libc/stubs.h>
>  #include <stdarg.h>
> -#include <stdbool.h>
>  #include <string.h>
>  #include <fcntl.h>
>  #include <errno.h>
> @@ -19,6 +18,10 @@
>  #include <sys/fsext.h>
>  #include <libc/fsexthlp.h>
>
> +typedef enum {
> +  false = 0, true = 1
> +} bool;
> +
>  int
>  _open(const char* filename, int oflag)
>  {
>
> OK to apply?

--
O.S.

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019