Message-ID: <3A290D90.C424D8F4@softhome.net>
Date: Sat, 02 Dec 2000 15:56:16 +0100
From: Laurynas Biveinis <lauras AT softhome DOT net>
X-Mailer: Mozilla 4.76 [en] (Win98; U)
X-Accept-Language: lt,en
MIME-Version: 1.0
To: DJGPP Workers <djgpp-workers AT delorie DOT com>
Subject: Patch: make GCC & DJGPP headers compatible
Content-Type: text/plain; charset=iso-8859-4
Content-Transfer-Encoding: 7bit
Reply-To: djgpp-workers AT delorie DOT com

I hope this is the last time I have to raise this issue...

The major obstacle about header compatibility has vanished - we
can be sure that GCC headers define size_t etc. in the right way.

So the only thing left to do is to avoid redefinition warnings,
and my patch does that. Tested under DOS with GCC 2.95.2 and with
a GCC 2.97 cross-compiler from Linux.

OK to apply this time?

Laurynas

Index: djgpp/include/glob.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/glob.h,v
retrieving revision 1.1
diff -u -r1.1 glob.h
--- glob.h      1995/03/21 09:01:00     1.1
+++ glob.h      2000/12/02 13:51:37
@@ -12,9 +12,10 @@

 #include <sys/djtypes.h>

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 typedef struct {
   size_t gl_pathc;
Index: djgpp/include/go32.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/go32.h,v
retrieving revision 1.2
diff -u -r1.2 go32.h
--- go32.h      1998/11/15 14:14:42     1.2
+++ go32.h      2000/12/02 13:51:37
@@ -16,9 +16,10 @@
 #include <sys/version.h>
 #include <sys/djtypes.h>

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 typedef struct {
   unsigned long  size_of_this_structure_in_bytes;
Index: djgpp/include/grp.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/grp.h,v
retrieving revision 1.1
diff -u -r1.1 grp.h
--- grp.h       1995/04/01 22:29:54     1.1
+++ grp.h       2000/12/02 13:51:37
@@ -11,9 +11,11 @@
 #ifndef __STRICT_ANSI__

 #include <sys/djtypes.h>
+
+#ifndef _GID_T
 __DJ_gid_t
-#undef __DJ_gid_t
-#define __DJ_gid_t
+#define _GID_T
+#endif

 struct group {
   gid_t                gr_gid;
Index: djgpp/include/pwd.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/pwd.h,v
retrieving revision 1.1
diff -u -r1.1 pwd.h
--- pwd.h       1995/02/27 03:31:44     1.1
+++ pwd.h       2000/12/02 13:51:38
@@ -12,12 +12,14 @@

 #include <sys/djtypes.h>

+#ifndef _GID_T
 __DJ_gid_t
-#undef __DJ_gid_t
-#define __DJ_gid_t
+#define _GID_T
+#endif
+#ifndef _UID_T
 __DJ_uid_t
-#undef __DJ_uid_t
-#define __DJ_uid_t
+#define _UID_T
+#endif

 struct passwd {
   char *       pw_name;
Index: djgpp/include/signal.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/signal.h,v
retrieving revision 1.3
diff -u -r1.3 signal.h
--- signal.h    1998/07/13 08:12:04     1.3
+++ signal.h    2000/12/02 13:51:38
@@ -24,9 +24,10 @@
 #define SIG_ERR        ((void (*)(int))(1))
 #define SIG_IGN        ((void (*)(int))(-1))

+#ifndef _PID_T
 __DJ_pid_t
-#undef __DJ_pid_t
-#define __DJ_pid_t
+#define _PID_T
+#endif

 typedef int sig_atomic_t;

Index: djgpp/include/stdarg.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/stdarg.h,v
retrieving revision 1.5
diff -u -r1.5 stdarg.h
--- stdarg.h    2000/06/20 20:51:38     1.5
+++ stdarg.h    2000/12/02 13:51:38
@@ -16,9 +16,10 @@

 #include <sys/djtypes.h>

+#ifndef _VA_LIST
 __DJ_va_list
-#undef __DJ_va_list
-#define __DJ_va_list
+#define _VA_LIST
+#endif

 /* New va_list builtins from GCC 2.96 or later */
 #if ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 96)) || (__GNUC__ >= 3)
Index: djgpp/include/stddef.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/stddef.h,v
retrieving revision 1.1
diff -u -r1.1 stddef.h
--- stddef.h    1994/12/07 07:02:08     1.1
+++ stddef.h    2000/12/02 13:51:38
@@ -10,14 +10,21 @@

 #define NULL 0
 #define offsetof(s_type, mbr) ((size_t) &((s_type *)0)->mbr)
+
+#ifndef _PTRDIFF_T
 typedef int ptrdiff_t;
+#define _PTRDIFF_T
+#endif

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif
+
+#ifndef _WCHAR_T
 __DJ_wchar_t
-#undef __DJ_wchar_t
-#define __DJ_wchar_t
+#define _WCHAR_T
+#endif

 #ifndef __dj_ENFORCE_ANSI_FREESTANDING

Index: djgpp/include/stdio.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/stdio.h,v
retrieving revision 1.2
diff -u -r1.2 stdio.h
--- stdio.h     1998/11/15 13:37:28     1.2
+++ stdio.h     2000/12/02 13:51:39
@@ -32,12 +32,15 @@
 #define SEEK_CUR       1
 #define SEEK_END       2

+#ifndef _VA_LIST
 __DJ_va_list
-#undef __DJ_va_list
-#define __DJ_va_list
+#define _VA_LIST
+#endif
+
+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 /* Note that the definitions of these fields are NOT guaranteed!  They
    may change with any release without notice!  The fact that they
Index: djgpp/include/stdlib.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/stdlib.h,v
retrieving revision 1.5
diff -u -r1.5 stdlib.h
--- stdlib.h    1999/06/03 17:22:28     1.5
+++ stdlib.h    2000/12/02 13:51:39
@@ -33,12 +33,15 @@
   long rem;
 } ldiv_t;

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif
+
+#ifndef _WCHAR_T
 __DJ_wchar_t
-#undef __DJ_wchar_t
-#define __DJ_wchar_t
+#define _WCHAR_T
+#endif

 void   abort(void) __attribute__((noreturn));
 int    abs(int _i);
Index: djgpp/include/string.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/string.h,v
retrieving revision 1.4
diff -u -r1.4 string.h
--- string.h    2000/07/24 15:52:44     1.4
+++ string.h    2000/12/02 13:51:40
@@ -16,9 +16,11 @@
 #undef NULL

 #define NULL 0
+
+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 void * memchr(const void *_s, int _c, size_t _n);
 int    memcmp(const void *_s1, const void *_s2, size_t _n);
Index: djgpp/include/time.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/time.h,v
retrieving revision 1.4
diff -u -r1.4 time.h
--- time.h      1999/06/03 17:22:28     1.4
+++ time.h      2000/12/02 13:51:40
@@ -21,15 +21,18 @@
 #undef NULL

 #define NULL 0
+#ifndef _CLOCK_T
 __DJ_clock_t
-#undef __DJ_clock_t
-#define __DJ_clock_t
+#define _CLOCK_T
+#endif
+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif
+#ifndef _TIME_T
 __DJ_time_t
-#undef __DJ_time_t
-#define __DJ_time_t
+#define _TIME_T
+#endif

 struct tm {
   int tm_sec;
Index: djgpp/include/unistd.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/unistd.h,v
retrieving revision 1.8
diff -u -r1.8 unistd.h
--- unistd.h    2000/08/11 11:16:16     1.8
+++ unistd.h    2000/12/02 13:51:41
@@ -60,13 +60,15 @@
 #define _SC_STREAM_MAX         8
 #define _SC_TZNAME_MAX         9
 #define _SC_VERSION            10
-
+
+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif
+#ifndef _SSIZE_T
 __DJ_ssize_t
-#undef __DJ_ssize_t
-#define __DJ_ssize_t
+#define _SSIZE_T
+#endif

 extern char *optarg;
 extern int optind, opterr, optopt;
Index: djgpp/include/utime.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/utime.h,v
retrieving revision 1.1
diff -u -r1.1 utime.h
--- utime.h     1995/03/21 09:04:36     1.1
+++ utime.h     2000/12/02 13:51:41
@@ -11,9 +11,11 @@
 #ifndef __STRICT_ANSI__

 #include <sys/djtypes.h>
+
+#ifndef _TIME_T
 __DJ_time_t
-#undef __DJ_time_t
-#define __DJ_time_t
+#define _TIME_T
+#endif

 struct utimbuf {
   time_t actime;
Index: djgpp/include/varargs.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/varargs.h,v
retrieving revision 1.3
diff -u -r1.3 varargs.h
--- varargs.h   2000/06/20 20:51:38     1.3
+++ varargs.h   2000/12/02 13:51:41
@@ -15,9 +15,10 @@

 #include <sys/djtypes.h>

+#ifndef _VA_LIST
 __DJ_va_list
-#undef __DJ_va_list
-#define __DJ_va_list
+#define _VA_LIST
+#endif

 /* For GCC 2.96 or later we use its builtin va_list */
 #if ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 96)) || (__GNUC__ >= 3)
Index: djgpp/include/wchar.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/wchar.h,v
retrieving revision 1.3
diff -u -r1.3 wchar.h
--- wchar.h     1999/06/03 17:22:28     1.3
+++ wchar.h     2000/12/02 13:51:41
@@ -13,9 +13,10 @@

 #include <stddef.h>

+#ifndef _WINT_T
 __DJ_wint_t
-#undef __DJ_wint_t
-#define __DJ_wint_t
+#define _WINT_T
+#endif

 #ifndef WEOF
 #define WEOF ((wint_t)(-1))
Index: djgpp/include/wctype.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/wctype.h,v
retrieving revision 1.4
diff -u -r1.4 wctype.h
--- wctype.h    1999/06/03 17:22:28     1.4
+++ wctype.h    2000/12/02 13:51:41
@@ -13,12 +13,14 @@

 #include <sys/djtypes.h>

+#ifndef _WCHAR_T
 __DJ_wchar_t
-#undef __DJ_wchar_t
-#define __DJ_wchar_t
+#define _WCHAR_T
+#endif
+#ifndef _WINT_T
 __DJ_wint_t
-#undef __DJ_wint_t
-#define __DJ_wint_t
+#define _WINT_T
+#endif

 #ifndef WEOF
 #define WEOF ((wint_t)(-1))
Index: djgpp/include/libc/symlink.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/libc/symlink.h,v
retrieving revision 1.3
diff -u -r1.3 symlink.h
--- symlink.h   2000/08/31 08:18:34     1.3
+++ symlink.h   2000/12/02 13:51:42
@@ -19,15 +19,16 @@

 #include <sys/djtypes.h>

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 /* Semi-internal library function which reads symlink contents given  */
 /* either a file name or its handle.  Used by readlink(), fstat() and */
 /* user supplied (if any) file fstat handler.                         */

-int __internal_readlink(const char * __path, int __fhandle, char * __buf,
+int __internal_readlink(const char * __path, int __fhandle, char * __buf,
                         size_t  __max);

 /* A prototype for internal library function for fully resolving symlink   */
Index: djgpp/include/sys/movedata.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/movedata.h,v
retrieving revision 1.2
diff -u -r1.2 movedata.h
--- movedata.h  1998/01/01 23:38:48     1.2
+++ movedata.h  2000/12/02 13:51:42
@@ -15,9 +15,10 @@

 #include <sys/djtypes.h>

+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif

 /* This header is intended to be included only by other
    headers, like <go32.h> and <string.h>.  You may
Index: djgpp/include/sys/stat.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/stat.h,v
retrieving revision 1.3
diff -u -r1.3 stat.h
--- stat.h      2000/08/15 17:38:40     1.3
+++ stat.h      2000/12/02 13:51:43
@@ -34,9 +34,10 @@

 #include <sys/types.h>
 #include <sys/djtypes.h>
+#ifndef _TIME_T
 __DJ_time_t
-#undef __DJ_time_t
-#define __DJ_time_t
+#define _TIME_T
+#endif

 struct stat {
   time_t       st_atime;
Index: djgpp/include/sys/timeb.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/timeb.h,v
retrieving revision 1.1
diff -u -r1.1 timeb.h
--- timeb.h     1995/04/02 04:05:16     1.1
+++ timeb.h     2000/12/02 13:51:43
@@ -14,9 +14,10 @@

 #include <sys/djtypes.h>

+#ifndef _TIME_T
 __DJ_time_t
-#undef __DJ_time_t
-#define __DJ_time_t
+#define _TIME_T
+#endif

 struct timeb
 {
Index: djgpp/include/sys/times.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/times.h,v
retrieving revision 1.1
diff -u -r1.1 times.h
--- times.h     1995/05/10 03:59:06     1.1
+++ times.h     2000/12/02 13:51:43
@@ -11,9 +11,11 @@
 #ifndef __STRICT_ANSI__

 #include <sys/djtypes.h>
+
+#ifndef _CLOCK_T
 __DJ_clock_t
-#undef __DJ_clock_t
-#define __DJ_clock_t
+#define _CLOCK_T
+#endif

 struct tms {
   clock_t tms_utime;
Index: djgpp/include/sys/types.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/types.h,v
retrieving revision 1.5
diff -u -r1.5 types.h
--- types.h     2000/06/19 18:00:55     1.5
+++ types.h     2000/12/02 13:51:44
@@ -19,27 +19,34 @@
 typedef int            mode_t;
 typedef int            nlink_t;

+#ifndef _GID_T
 __DJ_gid_t
-#undef __DJ_gid_t
-#define __DJ_gid_t
+#define _GID_T
+#endif
+#ifndef _OFF_T
 __DJ_off_t
-#undef __DJ_off_t
-#define __DJ_off_t
+#define _OFF_T
+#endif
+#ifndef _OFFSET_T
 __DJ_offset_t
-#undef __DJ_offset_t
-#define __DJ_offset_t
+#define _OFFSET_T
+#endif
+#ifndef _PID_T
 __DJ_pid_t
-#undef __DJ_pid_t
-#define __DJ_pid_t
+#define _PID_T
+#endif
+#ifndef _SIZE_T
 __DJ_size_t
-#undef __DJ_size_t
-#define __DJ_size_t
+#define _SIZE_T
+#endif
+#ifndef _SSIZE_T
 __DJ_ssize_t
-#undef __DJ_ssize_t
-#define __DJ_ssize_t
+#define _SSIZE_T
+#endif
+#ifndef _UID_T
+#define _UID_T
 __DJ_uid_t
-#undef __DJ_uid_t
-#define __DJ_uid_t
+#endif

 #ifndef _POSIX_SOURCE

@@ -57,9 +64,10 @@
 #define FD_ISSET(n, p) ((p)->fd_bits[(n) / 8] & (1 << ((n) & 7)))
 #define FD_ZERO(p)     memset ((void *)(p), 0, sizeof (*(p)))

+#ifndef _TIME_T
 __DJ_time_t
-#undef __DJ_time_t
-#define __DJ_time_t
+#define _TIME_T
+#endif

 #endif /* !_POSIX_SOURCE */
 #endif /* !__STRICT_ANSI__ */
Index: djgpp/include/sys/wait.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/sys/wait.h,v
retrieving revision 1.3
diff -u -r1.3 wait.h
--- wait.h      1998/07/12 16:55:36     1.3
+++ wait.h      2000/12/02 13:51:44
@@ -22,9 +22,10 @@
 #define WTERMSIG(stat_val)     ( ((stat_val) >> 8 ) & 0x3ff)
 #define WUNTRACED              0

+#ifndef _PID_T
 __DJ_pid_t
-#undef __DJ_pid_t
-#define __DJ_pid_t
+#define _PID_T
+#endif

 pid_t wait(int *stat_loc);
 pid_t waitpid(pid_t pid, int *stat_loc, int options);
Index: djgpp/src/docs/kb/wc204.txi
===================================================================
RCS file: /cvs/djgpp/djgpp/src/docs/kb/wc204.txi,v
retrieving revision 1.28
diff -u -r1.28 wc204.txi
--- wc204.txi   2000/11/25 11:06:02     1.28
+++ wc204.txi   2000/12/02 13:51:46
@@ -137,3 +137,7 @@
 preservation.  Its source can now be compiled on a Unix or GNU/Linux
 system.

+@cindex header files and GCC
+The protection against multiple redefinitions of various
+types like @code{size_t} has been rewriten to make DJGPP
+header files compatible with GCC provided ones.