Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com Delivered-To: mailing list cygwin AT cygwin DOT com X-Originating-IP: [204.39.229.208] From: "David F" To: cygwin AT cygwin DOT com Subject: Why does declare getopt_long()? Date: Fri, 07 Mar 2003 18:50:22 +0000 Mime-Version: 1.0 Content-Type: text/plain; format=flowed Message-ID: X-OriginalArrivalTime: 07 Mar 2003 18:50:22.0342 (UTC) FILETIME=[68491A60:01C2E4DA] I recently re-ran setup.exe and upgraded the packages I have installed and was surprised to find that many of my projects no longer build with Cygwin. They now fail with an error regarding the redefinition of struct option. These projects use getopt_long() which is of course not portable; so I provide an implementation (copied from NetBSD) along with my other project source files and #include “getopt.h” where necessary. (Yes, ideally I should have a ./configure and use the system’s copy if it provides one, but I still don’t understand why it’s declared in .) The problem occurs when is also #included as it now also provides a definition of struct option. (Cygwin’s getopt.h and the getopt.h in my projects use different guard macros.) For reference, I’ll quote the entire contents of : ---- cut here ---- /* unistd.h for Cygwin. */ #ifndef _UNISTD_H_ #define _UNISTD_H_ # include # define __UNISTD_GETOPT__ # include # undef __UNISTD_GETOPT__ #endif /* _UNISTD_H_ */ ---- cut here ---- It seems that previously provided declarations for getopt() and its associated ints (but *not* for getopt_long() and its associated paraphernalia) and now it just #includes when __CYGWIN__ is defined. Which is weird because also #includes . But when includes it uses some preprocessor magic to avoid declaring getopt_long(); or rather it tries to, as that magic is now rendered useless by the previous inclusion of . I checked glibc 2.3.1’s and it uses a similar preprocessor mechanism to declare getopt() (but not getopt_long()) by including . So my question is why does declare getopt_long()? What precedent is there for declaring getopt_long() in ? Normally, if you want getopt_long() you have to #include . Checking the CVS log I see that the change (to ) was made on Sat Dec 28 23:20:47 2002 UTC by cgf with the following log entry: * libc/include/sys/unistd.h: Under cygwin, just include getopt.h rather than defining getopt directly. newlib’s contains declarations for getopt() and I understand the desire to not duplicate the declarations in Cygwin’s , but is now included twice every time you #include . Given this and the, AFAICT, unprecedented namespace pollution, I propose the following patch: --- sys/unistd.h.orig 2003-02-08 12:11:52.000000000 -0500 +++ sys/unistd.h 2003-03-07 07:22:00.000000000 -0500 @@ -125,9 +125,7 @@ int _EXFUN(vhangup, (void )); _READ_WRITE_RETURN_TYPE _EXFUN(write, (int __fd, const void *__buf, size_t __nbyte )); -#ifdef __CYGWIN__ -# include -#else +#ifndef __CYGWIN__ extern char *optarg; /* getopt(3) external variables */ extern int optind, opterr, optopt; int getopt(int, char * const [], const char *); Cheers _________________________________________________________________ Add photos to your messages with MSN 8. Get 2 months FREE*. http://join.msn.com/?page=features/featuredemail -- Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple Bug reporting: http://cygwin.com/bugs.html Documentation: http://cygwin.com/docs.html FAQ: http://cygwin.com/faq/