From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 120305 invoked by alias); 15 Dec 2015 09:30:33 -0000 Mailing-List: contact cygwin-help@cygwin.com; run by ezmlm Precedence: bulk List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner@cygwin.com Mail-Followup-To: cygwin@cygwin.com Received: (qmail 119931 invoked by uid 89); 15 Dec 2015 09:30:28 -0000 Authentication-Results: sourceware.org; auth=none X-Virus-Found: No X-Spam-SWARE-Status: No, score=3.8 required=5.0 tests=AWL,BAYES_00,KAM_LAZY_DOMAIN_SECURITY,RCVD_IN_PBL,RDNS_DYNAMIC autolearn=no version=3.3.2 X-HELO: calimero.vinschen.de Received: from ipbcc02fe8.dynamic.kabel-deutschland.de (HELO calimero.vinschen.de) (188.192.47.232) by sourceware.org (qpsmtpd/0.93/v0.84-503-g423c35a) with ESMTP; Tue, 15 Dec 2015 09:30:22 +0000 Received: by calimero.vinschen.de (Postfix, from userid 500) id 57AD7A80637; Tue, 15 Dec 2015 10:30:20 +0100 (CET) Date: Tue, 15 Dec 2015 09:30:00 -0000 From: Corinna Vinschen To: cygwin@cygwin.com Subject: Re: __STRICT_ANSI__ and stdio.h Message-ID: <20151215093020.GA12827@calimero.vinschen.de> Reply-To: cygwin@cygwin.com Mail-Followup-To: cygwin@cygwin.com References: <20151214140649.GB29983@calimero.vinschen.de> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="zhXaljGHf11kAtnf" Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23 (2014-03-12) X-SW-Source: 2015-12/txt/msg00167.txt.bz2 --zhXaljGHf11kAtnf Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Content-length: 4122 On Dec 15 02:17, KIMURA Masaru wrote: > Hi, >=20 > >> is cygwin's __STRICT_ANSI__ and stdio.h behavior not so compatible to = glibc's? > > > > Cygwin is using newlib, newlib is BSD based. We introduced the > > compatibility checking macros from FreeBSD lately. >=20 > i roughly checked FreeBSD include/stdio.h and sys/sys/cdefs.h. > https://github.com/freebsd/freebsd/blob/master/include/stdio.h > https://github.com/freebsd/freebsd/blob/master/sys/sys/cdefs.h >=20 > it looks very different to newlib's. Yes, it does. Newlib has a long history diverging from the BSDs to support embedded systems in the first place, and compatibility checking macros other than __STRICT_ANSI__ and __POSIX_SOURCE weren't much of a concern for a long time. > FreeBSD has visibility for popen()/pclose() if __POSIX_VISIBLE >=3D 19920= 9, > it looks no checking about __STRICT_ANSI__ in their cdefs.h. Yeah, that's history as described above. popen gets declared in newlib if __STRICT_ANSI__ is not defined right now. > only one thing i worried about is _ANSI_SOURCE in their cdefs.h, > (b/c i don't understand where _ANSI_SOURCE comes from...) > but it looks _POSIX_C_SOURCE wins anyway. > for ease to see, i'd attach simplified their cdefs.h for their > visibility handling. I don't see the difference, see below. The big differences in newlib are the additional handling of _GNU_SOURCE and the old usage of __STRICT_ANSI__ in some circumstances which haven't been replaced by another usage of compatibility macros yet. But here's the deal: Newlib is a volunteer-driven project. If the compatiblity checking macros are not correct or not correctly used in all circumstances, newlib is happily open to patches. Just send them to the newlib AT sourceware DOT org mailing list. > #if defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE =3D=3D 1 > #undef _POSIX_C_SOURCE > #define _POSIX_C_SOURCE 199009 > #endif Same in Newlib's sys/cdefs.h. > #if defined(_POSIX_C_SOURCE) && _POSIX_C_SOURCE =3D=3D 2 > #undef _POSIX_C_SOURCE > #define _POSIX_C_SOURCE 199209 > #endif Ditto. > #ifdef _XOPEN_SOURCE > #if _XOPEN_SOURCE - 0 >=3D 700 > #define __XSI_VISIBLE 700 > #undef _POSIX_C_SOURCE > #define _POSIX_C_SOURCE 200809 > #elif _XOPEN_SOURCE - 0 >=3D 600 > #define __XSI_VISIBLE 600 > #undef _POSIX_C_SOURCE > #define _POSIX_C_SOURCE 200112 > #elif _XOPEN_SOURCE - 0 >=3D 500 > #define __XSI_VISIBLE 500 > #undef _POSIX_C_SOURCE > #define _POSIX_C_SOURCE 199506 > #endif > #endif Ditto. > #if defined(_POSIX_SOURCE) && !defined(_POSIX_C_SOURCE) > #define _POSIX_C_SOURCE 198808 > #endif Ditto. > #ifdef _POSIX_C_SOURCE > #if _POSIX_C_SOURCE >=3D 200809 > #define __POSIX_VISIBLE 200809 > #define __ISO_C_VISIBLE 1999 > #elif _POSIX_C_SOURCE >=3D 200112 > #define __POSIX_VISIBLE 200112 > #define __ISO_C_VISIBLE 1999 > #elif _POSIX_C_SOURCE >=3D 199506 > #define __POSIX_VISIBLE 199506 > #define __ISO_C_VISIBLE 1990 > #elif _POSIX_C_SOURCE >=3D 199309 > #define __POSIX_VISIBLE 199309 > #define __ISO_C_VISIBLE 1990 > #elif _POSIX_C_SOURCE >=3D 199209 > #define __POSIX_VISIBLE 199209 > #define __ISO_C_VISIBLE 1990 > #elif _POSIX_C_SOURCE >=3D 199009 > #define __POSIX_VISIBLE 199009 > #define __ISO_C_VISIBLE 1990 > #else > #define __POSIX_VISIBLE 198808 > #define __ISO_C_VISIBLE 0 > #endif > #else > #if defined(_ANSI_SOURCE) > #define __POSIX_VISIBLE 0 > #define __XSI_VISIBLE 0 > #define __BSD_VISIBLE 0 > #define __ISO_C_VISIBLE 1990 > #elif defined(_C99_SOURCE) > #define __POSIX_VISIBLE 0 > #define __XSI_VISIBLE 0 > #define __BSD_VISIBLE 0 > #define __ISO_C_VISIBLE 1999 > #elif defined(_C11_SOURCE) > #define __POSIX_VISIBLE 0 > #define __XSI_VISIBLE 0 > #define __BSD_VISIBLE 0 > #define __ISO_C_VISIBLE 2011 > #else > #define __POSIX_VISIBLE 200809 > #define __XSI_VISIBLE 700 > #define __BSD_VISIBLE 1 > #define __ISO_C_VISIBLE 2011 > #endif > #endif Ditto. Corinna --=20 Corinna Vinschen Please, send mails regarding Cygwin to Cygwin Maintainer cygwin AT cygwin DOT com Red Hat --zhXaljGHf11kAtnf Content-Type: application/pgp-signature Content-length: 819 -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQIcBAEBCAAGBQJWb92sAAoJEPU2Bp2uRE+gLhMQAIppp5eYFt2ZVFF48BUDewdF gRIIVO1/NK8LludSYqhhErchAW3zM9Iq8sT88vAK07ApQfioYksrFBkGm+dzJWcX viY8PH9YzkIsxAaI1iVwkFR0JNLEBdpSdqFPilCek0p0NHAMw46XBXl/+zA9KVVv Hj4SKfTHXJo2RvctNBpUb9FgVKQAb4oXOf/1JNRMFUM6Lq1hUMAlUsz8ux+vnXXO N+2Y1EM3esfMwH751LrU6lSk+a+qNihmb6K+umRPgXh0IbeY5+qe40RRWJEqwTIp iGgqeSJWn5ZYhXTXbD6RG9MhCDFSFEhk+P2Gtfg6CU/wRIZCmcUyXr8hUZWYgGYN uUSW2PNbJzsVhIHtJjyPnspDmVzT4u7L//uOx5ZUpwKQmuOvCjjYl1YSZDp9zOsD GIwMCTOvc+X2+H9Uo2QW/745yEkkrENATLmlH6rciqt6/Tdfr0jJj9tK3zTDyK41 8oiBq/Gh1zrixrS2paeYYGxUa1qTIj3HJghL46Y/lyaKY8+T3rjDRmkYqx66j17z 2k+yUnDkMhegz/GvRVr0TkqXItXOuJpB/+9RI/bSblbES2Qqw9APRDw6sJROrAe8 Ia5uSPTayfZrwgWVfFX6Ss7p3DjhExR8ZBxiPUTfExGLFEmqWpR54RJxDblEjG1p n1evW6NtxIlQxFDHgukT =lDhu -----END PGP SIGNATURE----- --zhXaljGHf11kAtnf--