[comp.unix.sysv386] SCO UNIX 3.2v2 header patches for use with GCC/G++

chip@tct.uucp (Chip Salzenberg) (03/04/91)

When SCO UNIX users compile programs with a Real ANSI Compiler like
GCC, or even with the AT&T compiler "rcc", inconsistencies in the
SCO-provided header files often cause spurious warnings that clutter
the output of the compiler.

The patches below are for the headers provided with SCO UNIX 3.2v2 and
the 3.2v2 Development System.  They cut down on those unnecessary
warnings by making all definitions of NULL consistent and fixing other
quirks of the SCO headers.

Shar and enjoy.

Index: curses.h
***************
*** 49,53 ****
  
  #if defined( M_TERMINFO ) && defined( M_TERMCAP )
! #error Only one of "M_TERMCAP" or "M_TERMINFO" should be #define'd.
  #endif
  
--- 49,54 ----
  
  #if defined( M_TERMINFO ) && defined( M_TERMCAP )
! /* Remove bare apostrophe.  --Chip */
! #error Only one of "M_TERMCAP" or "M_TERMINFO" should be #defined.
  #endif
  

Index: limits.h
***************
*** 23,27 ****
  
  /* Not implemented yet: */
! /* #define	MB_LEN_MAX	1 /* max number of bytes in a multibyte char */
  
  #define	CHAR_BIT	8		/* # of bits in a "char" */
--- 23,28 ----
  
  /* Not implemented yet: */
! /* Closed nested comment.  --Chip */
! /* #define  MB_LEN_MAX  1 */	/* max number of bytes in a multibyte char */
  
  #define	CHAR_BIT	8		/* # of bits in a "char" */
***************
*** 29,39 ****
  #define	SCHAR_MAX	127		/* max integer value of a "signed char" */
  #define	UCHAR_MAX	255		/* max integer value of a "unsigned char" */
! #	ifdef	_CHAR_UNSIGNED		/* defined with -J to msc */
  #define	CHAR_MAX	255		/* max integer value of a "char" */
  #define	CHAR_MIN	0		/* min integer value of a "char" */
! #	else
  #define	CHAR_MAX	127		/* max integer value of a "char" */
  #define	CHAR_MIN	-128		/* min integer value of a "char" */
! #	endif	/* _CHAR_UNSIGNED */
  #define	SHRT_MAX	32767		/* max decimal value of a "short" */
  #define	SHRT_MIN	-32768		/* min decimal value of a "short" */
--- 30,41 ----
  #define	SCHAR_MAX	127		/* max integer value of a "signed char" */
  #define	UCHAR_MAX	255		/* max integer value of a "unsigned char" */
! /* Handle unsigned char for cc and gcc. --Chip */
! #	if	defined(_CHAR_UNSIGNED) || defined(__CHAR_UNSIGNED__)
  #define	CHAR_MAX	255		/* max integer value of a "char" */
  #define	CHAR_MIN	0		/* min integer value of a "char" */
! #	else	/* signed */
  #define	CHAR_MAX	127		/* max integer value of a "char" */
  #define	CHAR_MIN	-128		/* min integer value of a "char" */
! #	endif	/* signed */
  #define	SHRT_MAX	32767		/* max decimal value of a "short" */
  #define	SHRT_MIN	-32768		/* min decimal value of a "short" */
***************
*** 84,88 ****
  #define         _POSIX_NGROUPS_MAX 0    /* minimum value ofr NGROUPS_MAX */
  #define         _POSIX_OPEN_MAX 16      /* minimum value for OPEN_MAX */
! #define         _POSIX_PATH_MAX 255     /* minimum value for PATH_MAX */
  #define         _POSIX_PIPE_BUF 512     /* minimum value for PIPE_BUF */
  
--- 86,91 ----
  #define         _POSIX_NGROUPS_MAX 0    /* minimum value ofr NGROUPS_MAX */
  #define         _POSIX_OPEN_MAX 16      /* minimum value for OPEN_MAX */
! /* Increase _POSIX_PATH_MAX as suggested by SCO dev sys v2 doc.  --Chip */
! #define         _POSIX_PATH_MAX 1024    /* minimum value for PATH_MAX */
  #define         _POSIX_PIPE_BUF 512     /* minimum value for PIPE_BUF */
  

Index: signal.h
***************
*** 27,33 ****
--- 27,39 ----
  #endif
  
+ /* Added sigaction(), sigprocmask(), sigpending(), sigsuspend().  --Chip */
+ 
  #	if defined( __STDC__ ) && !defined( NO_PROTOTYPE )
  extern	void ( *signal( int, void(*)() ) )();
  extern  void ( *sigset( int, void(*)() ) )();
+ extern	int sigaction( int, struct sigaction *, struct sigaction * );
+ extern	int sigprocmask( int, const sigset_t *, sigset_t * );
+ extern	int sigpending( sigset_t * );
+ extern	int sigsuspend( const sigset_t * );
  extern  int ( *ssignal( int, int(*)() ) )();
  #	else
***************
*** 34,37 ****
--- 40,47 ----
  extern	void (*signal())();
  extern  void (*sigset())();
+ extern	int sigaction();
+ extern	int sigprocmask();
+ extern	int sigpending();
+ extern	int sigsuspend();
  extern  int ( *ssignal())();
  #	endif

Index: stddef.h
***************
*** 40,50 ****
  
  #	ifndef	NULL
! #		ifdef	__STDC__
! #			define	NULL	(void *)0
! #		else
! #			define	NULL	(char *)0
! #		endif	/* __STDC__ */
  #	endif	/* NULL */
! #	define	offsetof(type, member)	(&(((type *)0)->member))
  #endif	/* _STDDEF_H */
  
--- 40,48 ----
  
  #	ifndef	NULL
! /* Correct definition of NULL.  --Chip */
! #		define	NULL	0
  #	endif	/* NULL */
! /* offsetof() definition must evaluate to an integral type.  --Chip */
! #	define	offsetof(type, member)	(int)(&(((type *)0)->member))
  #endif	/* _STDDEF_H */
  

Index: stdio.h
***************
*** 74,78 ****
  
  #	ifndef NULL
! #		define NULL		((void*)0)
  #	endif
  
--- 74,79 ----
  
  #	ifndef NULL
! /* Correct definition of NULL.  --Chip */
! #		define NULL		0
  #	endif
  
***************
*** 148,154 ****
  extern char	*cuserid(char *s);
  
! extern int	rename(const char *old, const char *new);
  extern int	fsetpos(FILE *, const fpos_t *);
  extern int	fgetpos(FILE *, fpos_t *);
  #	else
  extern FILE	*fopen(), *fdopen(), *freopen(), *popen(), *tmpfile();
--- 149,159 ----
  extern char	*cuserid(char *s);
  
! /* Deconflict rename() prototype and C++ keyword "new".  --Chip */
! extern int	rename(const char *oldname, const char *newname);
  extern int	fsetpos(FILE *, const fpos_t *);
  extern int	fgetpos(FILE *, fpos_t *);
+ /* Prototype _filbuf and _flsbuf.  --Chip */
+ extern int	_filbuf(FILE *);
+ extern int	_flsbuf(int, FILE *);
  #	else
  extern FILE	*fopen(), *fdopen(), *freopen(), *popen(), *tmpfile();
***************
*** 166,170 ****
  extern size_t	fread(), fwrite();
  #endif
! 
  #	endif	/* if expr */
  extern unsigned char *_bufendtab[];
--- 171,176 ----
  extern size_t	fread(), fwrite();
  #endif
! /* Declare _filbuf and _flsbuf.  --Chip */
! extern int	_filbuf(), _flsbuf();
  #	endif	/* if expr */
  extern unsigned char *_bufendtab[];

Index: stdlib.h
***************
*** 36,40 ****
  #	define EXIT_SUCCESS	0
  #	define RAND_MAX	077777
! /* #	define	MB_CUR_MAX ????	/* huh??? */
  
  
--- 36,41 ----
  #	define EXIT_SUCCESS	0
  #	define RAND_MAX	077777
! /* Un-nest nested comments.  --Chip */
! /* #	define	MB_CUR_MAX ???? */ /* huh??? */
  
  
***************
*** 53,57 ****
  extern void 	free( void * );
  extern void	abort(void);
! /* extern int	atexit (void (*)(void)); */
  extern void	exit( int );
  extern char	*getenv( const char * );
--- 54,59 ----
  extern void 	free( void * );
  extern void	abort(void);
! /* Prototype atexit().  --Chip */
! extern int	atexit( void (*)(void) );
  extern void	exit( int );
  extern char	*getenv( const char * );
***************
*** 80,84 ****
  extern void 	free();
  extern void	abort();
! /* extern int	atexit (); */
  extern void	exit();
  extern char	*getenv();
--- 82,87 ----
  extern void 	free();
  extern void	abort();
! /* Declare atexit().  --Chip */
! extern int	atexit();
  extern void	exit();
  extern char	*getenv();

Index: string.h
***************
*** 18,22 ****
  #	include	<memory.h>
  #	ifndef	NULL
! #		define	NULL	(void *)0
  #	endif	/* NULL */
  
--- 18,23 ----
  #	include	<memory.h>
  #	ifndef	NULL
! /* Correct definition of NULL.  --Chip */
! #		define	NULL	0
  #	endif	/* NULL */
  

Index: unistd.h
***************
*** 12,16 ****
  
  #ifndef NULL
! #	define	NULL	((void *)0)
  #endif /* NULL defined */
  
--- 12,17 ----
  
  #ifndef NULL
! /* Correct definition of NULL.  --Chip */
! #	define	NULL	0
  #endif /* NULL defined */
  
-- 
Chip Salzenberg at Teltronics/TCT     <chip@tct.uucp>, <uunet!pdn!tct!chip>
   "All this is conjecture of course, since I *only* post in the nude.
    Nothing comes between me and my t.b.  Nothing."   -- Bill Coderre