summaryrefslogtreecommitdiff
path: root/gcc/fixinc
diff options
context:
space:
mode:
authorkorbb <korbb@138bc75d-0d04-0410-961f-82ee72b054a4>2000-05-20 21:32:42 +0000
committerkorbb <korbb@138bc75d-0d04-0410-961f-82ee72b054a4>2000-05-20 21:32:42 +0000
commit038a3e7a475cf0af637cf0a65a554511dee4aaf8 (patch)
treeec9ed8f6cb6cdae81ec97a3f4a41bbffb408fa9b /gcc/fixinc
parent24ed871edc9788786cc4c83b7b9b730fcd0c7886 (diff)
downloadgcc-038a3e7a475cf0af637cf0a65a554511dee4aaf8.tar.gz
many applications of c_fix=format + tests
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@34059 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fixinc')
-rw-r--r--gcc/fixinc/check.diff451
-rw-r--r--gcc/fixinc/fixincl.x604
-rw-r--r--gcc/fixinc/inclhack.def359
3 files changed, 1007 insertions, 407 deletions
diff --git a/gcc/fixinc/check.diff b/gcc/fixinc/check.diff
index c2d3b6c8a5d..373da30c5e0 100644
--- a/gcc/fixinc/check.diff
+++ b/gcc/fixinc/check.diff
@@ -236,6 +236,21 @@
#if defined( LYNXOS_FCNTL_PROTO_CHECK )
! extern int fcntl(int, int, ...);
#endif /* LYNXOS_FCNTL_PROTO_CHECK */
+*** inc/hsfs/hsfs_spec.h
+--- res/hsfs/hsfs_spec.h
+***************
+*** 1,5 ****
+
+
+ #if defined( SUN_BOGUS_IFDEF_CHECK )
+! #ifdef __i386__ || __vax__ || __sun4c__
+ #endif /* SUN_BOGUS_IFDEF_CHECK */
+--- 1,5 ----
+
+
+ #if defined( SUN_BOGUS_IFDEF_CHECK )
+! #if __i386__ || __vax__ || __sun4c__
+ #endif /* SUN_BOGUS_IFDEF_CHECK */
*** inc/inttypes.h
--- res/inttypes.h
***************
@@ -295,6 +310,27 @@
#if defined( MACHINE_ANSI_H_VA_LIST_CHECK )
! # define _BSD_VA_LIST_ __builtin_va_list
#endif /* MACHINE_ANSI_H_VA_LIST_CHECK */
+*** inc/malloc.h
+--- res/malloc.h
+***************
+*** 1,8 ****
+
+
+ #if defined( SUN_MALLOC_CHECK )
+! typedef char * malloc_t;
+! int free();
+! char* malloc();
+! char* realloc();
+ #endif /* SUN_MALLOC_CHECK */
+--- 1,8 ----
+
+
+ #if defined( SUN_MALLOC_CHECK )
+! typedef void * malloc_t;
+! void free();
+! void* malloc();
+! void* realloc();
+ #endif /* SUN_MALLOC_CHECK */
*** inc/math.h
--- res/math.h
***************
@@ -340,7 +376,11 @@
#endif /* M88K_BAD_HYPOT_OPT_CHECK */
---- 1,61 ----
+--- 1,65 ----
++ #ifndef FIXINC_SUNOS_MATHERR_DECL_CHECK
++ #define FIXINC_SUNOS_MATHERR_DECL_CHECK 1
++
++ struct exception;
+ #ifndef FIXINC_MATH_EXCEPTION_CHECK
+ #define FIXINC_MATH_EXCEPTION_CHECK 1
+
@@ -403,8 +443,8 @@
***************
-*** 45,49 ****
---- 65,76 ----
+*** 45,56 ****
+--- 69,84 ----
#if defined( MATH_HUGE_VAL_IFNDEF_CHECK )
@@ -412,11 +452,47 @@
# define HUGE_VAL 3.4e+40
+ #endif
#endif /* MATH_HUGE_VAL_IFNDEF_CHECK */
+
+
+ #if defined( RS6000_DOUBLE_CHECK )
++ #ifndef __cplusplus
+ extern int class();
++ #endif
+ #endif /* RS6000_DOUBLE_CHECK */
+
+
+***************
+*** 60,64 ****
+--- 88,101 ----
+
+
+ #if defined( SVR4__P_CHECK )
++ #ifndef __P
+ #define __P(a) a
++ #endif
+ #endif /* SVR4__P_CHECK */
+ #ifdef __cplusplus
+ #undef exception
+ #endif
+
+ #endif /* FIXINC_MATH_EXCEPTION_CHECK */
++
++ #endif /* FIXINC_SUNOS_MATHERR_DECL_CHECK */
+*** inc/netdnet/dnetdb.h
+--- res/netdnet/dnetdb.h
+***************
+*** 1,5 ****
+
+
+ #if defined( NODEENT_SYNTAX_CHECK )
+! char *na_addr
+ #endif /* NODEENT_SYNTAX_CHECK */
+--- 1,5 ----
+
+
+ #if defined( NODEENT_SYNTAX_CHECK )
+! char *na_addr ;
+ #endif /* NODEENT_SYNTAX_CHECK */
*** inc/netinet/ip.h
--- res/netinet/ip.h
***************
@@ -436,17 +512,90 @@
}; /* mumbled struct */
#endif /* IP_MISSING_SEMI_CHECK */
+*** inc/pixrect/memvar.h
+--- res/pixrect/memvar.h
+***************
+*** 1,5 ****
+--- 1,9 ----
+
+
+ #if defined( SUN_CATMACRO_CHECK )
++ #ifdef __STDC__
++ # define CAT(a,b) a##b
++ #else
+ #define CAT(a,b) a/**/b
++ #endif
+ #endif /* SUN_CATMACRO_CHECK */
+*** inc/pthread.h
+--- res/pthread.h
+***************
+*** 1,5 ****
+
+
+ #if defined( PTHREAD_PAGE_SIZE_CHECK )
+! int __page_size;
+ #endif /* PTHREAD_PAGE_SIZE_CHECK */
+--- 1,5 ----
+
+
+ #if defined( PTHREAD_PAGE_SIZE_CHECK )
+! extern int __page_size;
+ #endif /* PTHREAD_PAGE_SIZE_CHECK */
+*** inc/reg_types.h
+--- res/reg_types.h
+***************
+*** 4,11 ****
+ typedef struct {
+ int stuff, mo_suff;
+ } regex_t;
+! extern regex_t re;
+! extern regoff_t ro;
+! extern regmatch_t rm;
+
+ #endif /* OSF_NAMESPACE_A_CHECK */
+--- 4,11 ----
+ typedef struct {
+ int stuff, mo_suff;
+ } regex_t;
+! extern __regex_t re;
+! extern __regoff_t ro;
+! extern __regmatch_t rm;
+
+ #endif /* OSF_NAMESPACE_A_CHECK */
+*** inc/regex.h
+--- res/regex.h
+***************
+*** 2,5 ****
+--- 2,8 ----
+
+ #if defined( OSF_NAMESPACE_C_CHECK )
+ #include <reg_types.h>
++ typedef __regex_t regex_t;
++ typedef __regoff_t regoff_t;
++ typedef __regmatch_t regmatch_t;
+ #endif /* OSF_NAMESPACE_C_CHECK */
*** inc/rpc/auth.h
--- res/rpc/auth.h
***************
-*** 1,5 ****
---- 1,6 ----
+*** 1,12 ****
+--- 1,17 ----
#if defined( STRUCT_SOCKADDR_CHECK )
+ struct sockaddr;
extern AUTH* authdes_create( struct sockaddr* );
#endif /* STRUCT_SOCKADDR_CHECK */
+
+
+ #if defined( SUN_AUTH_PROTO_CHECK )
+ struct auth_t {
++ #ifdef __cplusplus
++ int (*name)(...); /* C++ bad */
++ #else
+ int (*name)(); /* C++ bad */
++ #endif
+ };
+ #endif /* SUN_AUTH_PROTO_CHECK */
*** inc/rpc/rpc.h
--- res/rpc/rpc.h
***************
@@ -473,6 +622,40 @@
+ struct __file_s;
extern void xdrstdio_create( struct __file_s* );
#endif /* STRUCT_FILE_CHECK */
+*** inc/rpcsvc/rstat.h
+--- res/rpcsvc/rstat.h
+***************
+*** 2,7 ****
+
+ #if defined( STATSSWTCH_CHECK )
+ struct statswtch {
+! int boottime
+ };
+ #endif /* STATSSWTCH_CHECK */
+--- 2,7 ----
+
+ #if defined( STATSSWTCH_CHECK )
+ struct statswtch {
+! int boottime;
+ };
+ #endif /* STATSSWTCH_CHECK */
+*** inc/rpcsvc/rusers.h
+--- res/rpcsvc/rusers.h
+***************
+*** 2,7 ****
+
+ #if defined( SUN_RUSERS_SEMI_CHECK )
+ struct mumble
+! int _cnt
+ };
+ #endif /* SUN_RUSERS_SEMI_CHECK */
+--- 2,7 ----
+
+ #if defined( SUN_RUSERS_SEMI_CHECK )
+ struct mumble
+! int _cnt;
+ };
+ #endif /* SUN_RUSERS_SEMI_CHECK */
*** inc/sparc/asm_linkage.h
--- res/sparc/asm_linkage.h
***************
@@ -491,7 +674,7 @@
*** inc/stdio.h
--- res/stdio.h
***************
-*** 1,12 ****
+*** 1,27 ****
#if defined( ALPHA_GETOPT_CHECK )
@@ -504,7 +687,22 @@
int foo;
#endif
#endif /* ISC_OMITS_WITH_STDC_CHECK */
---- 1,17 ----
+
+
+ #if defined( READ_RET_TYPE_CHECK )
+! extern int fclose(), fflush(), fread(), fwrite(), foo();
+ #endif /* READ_RET_TYPE_CHECK */
+
+
+ #if defined( RS6000_PARAM_CHECK )
+! extern int rename(const char *old, const char *new);
+ #endif /* RS6000_PARAM_CHECK */
+
+
+ #if defined( STDIO_STDARG_H_CHECK )
+
+ #endif /* STDIO_STDARG_H_CHECK */
+--- 1,35 ----
+ #ifndef FIXINC_STDIO_STDARG_H_CHECK
+ #define FIXINC_STDIO_STDARG_H_CHECK 1
+
@@ -522,9 +720,19 @@
int foo;
#endif
#endif /* ISC_OMITS_WITH_STDC_CHECK */
-***************
-*** 15,17 ****
---- 20,24 ----
+
+
+ #if defined( READ_RET_TYPE_CHECK )
+! extern unsigned int fread(), fwrite();
+! extern int fclose(), fflush(), foo();
+ #endif /* READ_RET_TYPE_CHECK */
+
+
+ #if defined( RS6000_PARAM_CHECK )
+! extern int rename(const char *_old, const char *_new);
+ #endif /* RS6000_PARAM_CHECK */
+
+
#if defined( STDIO_STDARG_H_CHECK )
#endif /* STDIO_STDARG_H_CHECK */
@@ -533,7 +741,7 @@
*** inc/stdlib.h
--- res/stdlib.h
***************
-*** 1,12 ****
+*** 1,38 ****
#if defined( ARM_WCHAR_CHECK )
@@ -543,10 +751,36 @@
#endif /* ARM_WCHAR_CHECK */
+ #if defined( INT_ABORT_FREE_AND_EXIT_CHECK )
+! extern int abort(int);
+! extern int free(void*);
+! extern int exit(void*);
+ #endif /* INT_ABORT_FREE_AND_EXIT_CHECK */
+
+
#if defined( NEWS_OS_RECURSION_CHECK )
#include <stdlib.h>
#endif /* NEWS_OS_RECURSION_CHECK */
---- 1,14 ----
+
+
+ #if defined( SVR4_GETCWD_CHECK )
+! extern char* getcwd(char *, int);
+ #endif /* SVR4_GETCWD_CHECK */
+
+
+ #if defined( SVR4_PROFIL_CHECK )
+! profil(unsigned short *, unsigned int, unsigned int, unsigned int);
+ #endif /* SVR4_PROFIL_CHECK */
+
+
+ #if defined( SYSZ_STDLIB_FOR_SUN_CHECK )
+! extern char* calloc(size_t);
+! extern char* malloc(size_t);
+! extern char* realloc(void*,size_t);
+! extern char* bsearch(void*,size_t,size_t);
+
+ #endif /* SYSZ_STDLIB_FOR_SUN_CHECK */
+--- 1,40 ----
#if defined( ARM_WCHAR_CHECK )
@@ -556,11 +790,52 @@
#endif /* ARM_WCHAR_CHECK */
+ #if defined( INT_ABORT_FREE_AND_EXIT_CHECK )
+! extern void abort(int);
+! extern void free(void*);
+! extern void exit(void*);
+ #endif /* INT_ABORT_FREE_AND_EXIT_CHECK */
+
+
#if defined( NEWS_OS_RECURSION_CHECK )
+ #ifdef BOGUS_RECURSION
#include <stdlib.h>
+ #endif
#endif /* NEWS_OS_RECURSION_CHECK */
+
+
+ #if defined( SVR4_GETCWD_CHECK )
+! extern char* getcwd(char *, size_t);
+ #endif /* SVR4_GETCWD_CHECK */
+
+
+ #if defined( SVR4_PROFIL_CHECK )
+! profil(unsigned short *, size_t, int, unsigned int);
+ #endif /* SVR4_PROFIL_CHECK */
+
+
+ #if defined( SYSZ_STDLIB_FOR_SUN_CHECK )
+! extern void * calloc(size_t);
+! extern void * malloc(size_t);
+! extern void * realloc(void*,size_t);
+! extern void * bsearch(void*,size_t,size_t);
+
+ #endif /* SYSZ_STDLIB_FOR_SUN_CHECK */
+*** inc/strings.h
+--- res/strings.h
+***************
+*** 1,5 ****
+
+
+ #if defined( SUNOS_STRLEN_CHECK )
+! int strlen(); /* string length */
+ #endif /* SUNOS_STRLEN_CHECK */
+--- 1,5 ----
+
+
+ #if defined( SUNOS_STRLEN_CHECK )
+! __SIZE_TYPE__ strlen(); /* string length */
+ #endif /* SUNOS_STRLEN_CHECK */
*** inc/sundev/vuid_event.h
--- res/sundev/vuid_event.h
***************
@@ -644,6 +919,7 @@
#if defined( HP_SYSFILE_CHECK )
! extern void foo(struct file *, ...); /* HPUX_SOURCE - bad varargs */
#endif /* HP_SYSFILE_CHECK */
+Only in inc: inc/sys/lc_core.h
*** inc/sys/limits.h
--- res/sys/limits.h
***************
@@ -716,18 +992,32 @@
*** inc/sys/signal.h
--- res/sys/signal.h
***************
-*** 1,5 ****
+*** 1,10 ****
#if defined( AIX_VOLATILE_CHECK )
! typedef volatile int sig_atomic_t;
#endif /* AIX_VOLATILE_CHECK */
---- 1,5 ----
+
+
+ #if defined( SUN_SIGNAL_CHECK )
+ void (*signal())();
+ #endif /* SUN_SIGNAL_CHECK */
+--- 1,14 ----
#if defined( AIX_VOLATILE_CHECK )
! typedef int sig_atomic_t;
#endif /* AIX_VOLATILE_CHECK */
+
+
+ #if defined( SUN_SIGNAL_CHECK )
++ #ifdef __cplusplus
++ void (*signal(...))(...);
++ #else
+ void (*signal())();
++ #endif
+ #endif /* SUN_SIGNAL_CHECK */
*** inc/sys/spinlock.h
--- res/sys/spinlock.h
***************
@@ -746,18 +1036,74 @@
*** inc/sys/stat.h
--- res/sys/stat.h
***************
-*** 1,5 ****
+*** 1,27 ****
#if defined( M88K_BAD_S_IF_CHECK )
! #define S_ISREG(m) (m & S_IFREG) /* is regular? */
#endif /* M88K_BAD_S_IF_CHECK */
---- 1,5 ----
+
+
+ #if defined( RS6000_FCHMOD_CHECK )
+! extern int fchmod(char *, mode_t);
+ #endif /* RS6000_FCHMOD_CHECK */
+
+
+ #if defined( SCO_STATIC_FUNC_CHECK )
+ #ifdef __STDC__
+ static int stat(const char *__f, struct stat *__p) {
+ return __stat32(__f, __p);
+ }
+
+ # else /* !__STDC__ */
+ static int stat(__f, __p)
+ char *__f;
+ struct stat *__p;
+ {
+ return __stat32(__f, __p);
+ }
+ #endif
+ #endif /* SCO_STATIC_FUNC_CHECK */
+--- 1,39 ----
#if defined( M88K_BAD_S_IF_CHECK )
! #define S_ISREG(m) (((m) & S_IFMT) == S_IFREG) /* is regular? */
#endif /* M88K_BAD_S_IF_CHECK */
+
+
+ #if defined( RS6000_FCHMOD_CHECK )
+! extern int fchmod(int, mode_t);
+ #endif /* RS6000_FCHMOD_CHECK */
+
+
+ #if defined( SCO_STATIC_FUNC_CHECK )
+ #ifdef __STDC__
++ #if __cplusplus
++ extern "C" {
++ #endif /* __cplusplus */
+ static int stat(const char *__f, struct stat *__p) {
+ return __stat32(__f, __p);
+ }
++ #if __cplusplus
++ }
++ #endif /* __cplusplus */
+
+ # else /* !__STDC__ */
++ #if __cplusplus
++ extern "C" {
++ #endif /* __cplusplus */
+ static int stat(__f, __p)
+ char *__f;
+ struct stat *__p;
+ {
+ return __stat32(__f, __p);
+ }
++ #if __cplusplus
++ }
++ #endif /* __cplusplus */
+ #endif
+ #endif /* SCO_STATIC_FUNC_CHECK */
*** inc/sys/time.h
--- res/sys/time.h
***************
@@ -773,28 +1119,70 @@
#if defined( HPUX_SYSTIME_CHECK )
! struct sigevent;
#endif /* HPUX_SYSTIME_CHECK */
+*** inc/sys/times.h
+--- res/sys/times.h
+***************
+*** 1,5 ****
+
+
+ #if defined( SCO_UTIME_CHECK )
+! extern int utime(const char *, struct utimbuf *);
+ #endif /* SCO_UTIME_CHECK */
+--- 1,5 ----
+
+
+ #if defined( SCO_UTIME_CHECK )
+! extern int utime(const char *, const struct utimbuf *);
+ #endif /* SCO_UTIME_CHECK */
*** inc/sys/types.h
--- res/sys/types.h
***************
-*** 1,6 ****
+*** 1,11 ****
#if defined( IRIX_MULTILINE_CMNT_CHECK )
! /* we check the type of the result
! // of the sizeof something. This is a bad test :-( */
#endif /* IRIX_MULTILINE_CMNT_CHECK */
---- 1,6 ----
+
+
+ #if defined( SYSTYPES_STDLIB_SIZE_T_CHECK )
+! typedef unsigned int size_t; /* size of something */
+ #endif /* SYSTYPES_STDLIB_SIZE_T_CHECK */
+--- 1,17 ----
#if defined( IRIX_MULTILINE_CMNT_CHECK )
! /* we check the type of the result */
! // /* of the sizeof something. This is a bad test :-( */
#endif /* IRIX_MULTILINE_CMNT_CHECK */
+
+
+ #if defined( SYSTYPES_STDLIB_SIZE_T_CHECK )
+! #ifndef __SIZE_TYPE__
+! #define __SIZE_TYPE__ long unsigned int
+! #endif
+! #ifndef _GCC_SIZE_T
+! #define _GCC_SIZE_T
+! typedef __SIZE_TYPE__ size_t; /* size of something */
+! #endif
+ #endif /* SYSTYPES_STDLIB_SIZE_T_CHECK */
*** inc/sys/wait.h
--- res/sys/wait.h
***************
-*** 2,7 ****
---- 2,8 ----
+*** 2,12 ****
+
+ #if defined( AIX_SYSWAIT_CHECK )
+ /* bos325, */
+ extern pid_t wait3();
+ /* pid_t wait3(int *, int, struct rusage *); */
+ #endif /* AIX_SYSWAIT_CHECK */
+
+
+ #if defined( NEXT_WAIT_UNION_CHECK )
+! extern pid_d wait(union wait*);
+ #endif /* NEXT_WAIT_UNION_CHECK */
+--- 2,13 ----
#if defined( AIX_SYSWAIT_CHECK )
/* bos325, */
@@ -802,10 +1190,15 @@
extern pid_t wait3();
/* pid_t wait3(int *, int, struct rusage *); */
#endif /* AIX_SYSWAIT_CHECK */
+
+
+ #if defined( NEXT_WAIT_UNION_CHECK )
+! extern pid_d wait(void*);
+ #endif /* NEXT_WAIT_UNION_CHECK */
*** inc/testing.h
--- res/testing.h
***************
-*** 1,36 ****
+*** 1,43 ****
#if defined( CTRL_QUOTES_DEF_CHECK )
@@ -834,12 +1227,19 @@
#endif /* MACHINE_NAME_CHECK */
+ #if defined( SCO_STRICT_ANSI_CHECK )
+! #if !__STDC__ /* not standard C */
+ int foo;
+ #endif
+ #endif /* SCO_STRICT_ANSI_CHECK */
+
+
#if defined( UNDEFINE_NULL_CHECK )
#define NULL 0UL
#define NULL ((void*)0)
#endif /* UNDEFINE_NULL_CHECK */
---- 1,40 ----
+--- 1,47 ----
#if defined( CTRL_QUOTES_DEF_CHECK )
@@ -868,6 +1268,13 @@
#endif /* MACHINE_NAME_CHECK */
+ #if defined( SCO_STRICT_ANSI_CHECK )
+! #if !defined(__STRICT_ANSI__) /* not standard C */
+ int foo;
+ #endif
+ #endif /* SCO_STRICT_ANSI_CHECK */
+
+
#if defined( UNDEFINE_NULL_CHECK )
+ #ifndef NULL
#define NULL 0UL
diff --git a/gcc/fixinc/fixincl.x b/gcc/fixinc/fixincl.x
index f5918407897..912a159112a 100644
--- a/gcc/fixinc/fixincl.x
+++ b/gcc/fixinc/fixincl.x
@@ -5,7 +5,7 @@
* files which are fixed to work correctly with ANSI C and placed in a
* directory that GNU C will search.
*
- * This file contains 121 fixup descriptions.
+ * This file contains 122 fixup descriptions.
*
* See README-fixinc for more information.
*
@@ -1766,9 +1766,45 @@ const char* apzHpux8_Bogus_InlinesPatch[] = { "sed",
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
+ * Description of Int_Abort_Free_And_Exit fix
+ */
+#define INT_ABORT_FREE_AND_EXIT_FIXIDX 40
+tSCC zInt_Abort_Free_And_ExitName[] =
+ "int_abort_free_and_exit";
+
+/*
+ * File name selection pattern
+ */
+tSCC zInt_Abort_Free_And_ExitList[] =
+ "|stdlib.h|";
+/*
+ * Machine/OS name selection pattern
+ */
+#define apzInt_Abort_Free_And_ExitMachs (const char**)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zInt_Abort_Free_And_ExitSelect0[] =
+ "int[ \t]+(abort|free|exit)[ \t]*\\(";
+
+#define INT_ABORT_FREE_AND_EXIT_TEST_CT 1
+tTestDesc aInt_Abort_Free_And_ExitTests[] = {
+ { TT_EGREP, zInt_Abort_Free_And_ExitSelect0, (regex_t*)NULL }, };
+
+/*
+ * Fix Command Arguments for Int_Abort_Free_And_Exit
+ */
+const char* apzInt_Abort_Free_And_ExitPatch[] = {
+ "format",
+ "void\t%1(",
+ (char*)NULL };
+
+/* * * * * * * * * * * * * * * * * * * * * * * * * *
+ *
* Description of Isc_Omits_With_Stdc fix
*/
-#define ISC_OMITS_WITH_STDC_FIXIDX 40
+#define ISC_OMITS_WITH_STDC_FIXIDX 41
tSCC zIsc_Omits_With_StdcName[] =
"isc_omits_with_stdc";
@@ -1804,7 +1840,7 @@ const char* apzIsc_Omits_With_StdcPatch[] = {
*
* Description of Io_Quotes_Def fix
*/
-#define IO_QUOTES_DEF_FIXIDX 41
+#define IO_QUOTES_DEF_FIXIDX 42
tSCC zIo_Quotes_DefName[] =
"io_quotes_def";
@@ -1839,7 +1875,7 @@ const char* apzIo_Quotes_DefPatch[] = {
*
* Description of Io_Quotes_Use fix
*/
-#define IO_QUOTES_USE_FIXIDX 42
+#define IO_QUOTES_USE_FIXIDX 43
tSCC zIo_Quotes_UseName[] =
"io_quotes_use";
@@ -1874,7 +1910,7 @@ const char* apzIo_Quotes_UsePatch[] = {
*
* Description of Hpux_Maxint fix
*/
-#define HPUX_MAXINT_FIXIDX 43
+#define HPUX_MAXINT_FIXIDX 44
tSCC zHpux_MaxintName[] =
"hpux_maxint";
@@ -1913,7 +1949,7 @@ const char* apzHpux_MaxintPatch[] = {
*
* Description of Hpux_Systime fix
*/
-#define HPUX_SYSTIME_FIXIDX 44
+#define HPUX_SYSTIME_FIXIDX 45
tSCC zHpux_SystimeName[] =
"hpux_systime";
@@ -1949,7 +1985,7 @@ const char* apzHpux_SystimePatch[] = {
*
* Description of Ip_Missing_Semi fix
*/
-#define IP_MISSING_SEMI_FIXIDX 45
+#define IP_MISSING_SEMI_FIXIDX 46
tSCC zIp_Missing_SemiName[] =
"ip_missing_semi";
@@ -1984,7 +2020,7 @@ const char* apzIp_Missing_SemiPatch[] = { "sed",
*
* Description of Irix_Asm_Apostrophe fix
*/
-#define IRIX_ASM_APOSTROPHE_FIXIDX 46
+#define IRIX_ASM_APOSTROPHE_FIXIDX 47
tSCC zIrix_Asm_ApostropheName[] =
"irix_asm_apostrophe";
@@ -2021,7 +2057,7 @@ const char* apzIrix_Asm_ApostrophePatch[] = {
*
* Description of Irix_Multiline_Cmnt fix
*/
-#define IRIX_MULTILINE_CMNT_FIXIDX 47
+#define IRIX_MULTILINE_CMNT_FIXIDX 48
tSCC zIrix_Multiline_CmntName[] =
"irix_multiline_cmnt";
@@ -2049,7 +2085,7 @@ const char* apzIrix_Multiline_CmntPatch[] = { "sed",
*
* Description of Isc_Fmod fix
*/
-#define ISC_FMOD_FIXIDX 48
+#define ISC_FMOD_FIXIDX 49
tSCC zIsc_FmodName[] =
"isc_fmod";
@@ -2085,7 +2121,7 @@ const char* apzIsc_FmodPatch[] = {
*
* Description of Kandr_Concat fix
*/
-#define KANDR_CONCAT_FIXIDX 49
+#define KANDR_CONCAT_FIXIDX 50
tSCC zKandr_ConcatName[] =
"kandr_concat";
@@ -2121,7 +2157,7 @@ const char* apzKandr_ConcatPatch[] = {
*
* Description of Limits_Ifndefs fix
*/
-#define LIMITS_IFNDEFS_FIXIDX 50
+#define LIMITS_IFNDEFS_FIXIDX 51
tSCC zLimits_IfndefsName[] =
"limits_ifndefs";
@@ -2160,7 +2196,7 @@ const char* apzLimits_IfndefsPatch[] = {
*
* Description of Lynx_Void_Int fix
*/
-#define LYNX_VOID_INT_FIXIDX 51
+#define LYNX_VOID_INT_FIXIDX 52
tSCC zLynx_Void_IntName[] =
"lynx_void_int";
@@ -2196,7 +2232,7 @@ const char* apzLynx_Void_IntPatch[] = {
*
* Description of Lynxos_Fcntl_Proto fix
*/
-#define LYNXOS_FCNTL_PROTO_FIXIDX 52
+#define LYNXOS_FCNTL_PROTO_FIXIDX 53
tSCC zLynxos_Fcntl_ProtoName[] =
"lynxos_fcntl_proto";
@@ -2233,7 +2269,7 @@ const char* apzLynxos_Fcntl_ProtoPatch[] = {
*
* Description of M88k_Bad_Hypot_Opt fix
*/
-#define M88K_BAD_HYPOT_OPT_FIXIDX 53
+#define M88K_BAD_HYPOT_OPT_FIXIDX 54
tSCC zM88k_Bad_Hypot_OptName[] =
"m88k_bad_hypot_opt";
@@ -2282,7 +2318,7 @@ static __inline__ double fake_hypot (x, y)\n\
*
* Description of M88k_Bad_S_If fix
*/
-#define M88K_BAD_S_IF_FIXIDX 54
+#define M88K_BAD_S_IF_FIXIDX 55
tSCC zM88k_Bad_S_IfName[] =
"m88k_bad_s_if";
@@ -2321,7 +2357,7 @@ const char* apzM88k_Bad_S_IfPatch[] = {
*
* Description of M88k_Multi_Incl fix
*/
-#define M88K_MULTI_INCL_FIXIDX 55
+#define M88K_MULTI_INCL_FIXIDX 56
tSCC zM88k_Multi_InclName[] =
"m88k_multi_incl";
@@ -2358,7 +2394,7 @@ const char* apzM88k_Multi_InclPatch[] = {
*
* Description of Machine_Ansi_H_Va_List fix
*/
-#define MACHINE_ANSI_H_VA_LIST_FIXIDX 56
+#define MACHINE_ANSI_H_VA_LIST_FIXIDX 57
tSCC zMachine_Ansi_H_Va_ListName[] =
"machine_ansi_h_va_list";
@@ -2402,7 +2438,7 @@ const char* apzMachine_Ansi_H_Va_ListPatch[] = {
*
* Description of Machine_Name fix
*/
-#define MACHINE_NAME_FIXIDX 57
+#define MACHINE_NAME_FIXIDX 58
tSCC zMachine_NameName[] =
"machine_name";
@@ -2435,7 +2471,7 @@ const char* apzMachine_NamePatch[] = {
*
* Description of Math_Exception fix
*/
-#define MATH_EXCEPTION_FIXIDX 58
+#define MATH_EXCEPTION_FIXIDX 59
tSCC zMath_ExceptionName[] =
"math_exception";
@@ -2483,7 +2519,7 @@ const char* apzMath_ExceptionPatch[] = {
*
* Description of Math_Huge_Val_From_Dbl_Max fix
*/
-#define MATH_HUGE_VAL_FROM_DBL_MAX_FIXIDX 59
+#define MATH_HUGE_VAL_FROM_DBL_MAX_FIXIDX 60
tSCC zMath_Huge_Val_From_Dbl_MaxName[] =
"math_huge_val_from_dbl_max";
@@ -2530,7 +2566,7 @@ const char* apzMath_Huge_Val_From_Dbl_MaxPatch[] = { "sh", "-c",
*
* Description of Math_Huge_Val_Ifndef fix
*/
-#define MATH_HUGE_VAL_IFNDEF_FIXIDX 60
+#define MATH_HUGE_VAL_IFNDEF_FIXIDX 61
tSCC zMath_Huge_Val_IfndefName[] =
"math_huge_val_ifndef";
@@ -2569,7 +2605,7 @@ const char* apzMath_Huge_Val_IfndefPatch[] = {
*
* Description of Nested_Motorola fix
*/
-#define NESTED_MOTOROLA_FIXIDX 61
+#define NESTED_MOTOROLA_FIXIDX 62
tSCC zNested_MotorolaName[] =
"nested_motorola";
@@ -2599,7 +2635,7 @@ const char* apzNested_MotorolaPatch[] = { "sed",
*
* Description of Nested_Sys_Limits fix
*/
-#define NESTED_SYS_LIMITS_FIXIDX 62
+#define NESTED_SYS_LIMITS_FIXIDX 63
tSCC zNested_Sys_LimitsName[] =
"nested_sys_limits";
@@ -2635,7 +2671,7 @@ const char* apzNested_Sys_LimitsPatch[] = { "sed",
*
* Description of Nested_Auth_Des fix
*/
-#define NESTED_AUTH_DES_FIXIDX 63
+#define NESTED_AUTH_DES_FIXIDX 64
tSCC zNested_Auth_DesName[] =
"nested_auth_des";
@@ -2671,7 +2707,7 @@ const char* apzNested_Auth_DesPatch[] = {
*
* Description of Nested_Ultrix fix
*/
-#define NESTED_ULTRIX_FIXIDX 64
+#define NESTED_ULTRIX_FIXIDX 65
tSCC zNested_UltrixName[] =
"nested_ultrix";
@@ -2698,7 +2734,7 @@ const char* apzNested_UltrixPatch[] = { "sed",
*
* Description of News_Os_Recursion fix
*/
-#define NEWS_OS_RECURSION_FIXIDX 65
+#define NEWS_OS_RECURSION_FIXIDX 66
tSCC zNews_Os_RecursionName[] =
"news_os_recursion";
@@ -2716,7 +2752,7 @@ tSCC zNews_Os_RecursionList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zNews_Os_RecursionSelect0[] =
- "#include <stdlib\\.h>";
+ "[ \t]*#include <stdlib\\.h>.*";
#define NEWS_OS_RECURSION_TEST_CT 1
tTestDesc aNews_Os_RecursionTests[] = {
@@ -2736,7 +2772,7 @@ const char* apzNews_Os_RecursionPatch[] = {
*
* Description of Next_Math_Prefix fix
*/
-#define NEXT_MATH_PREFIX_FIXIDX 66
+#define NEXT_MATH_PREFIX_FIXIDX 67
tSCC zNext_Math_PrefixName[] =
"next_math_prefix";
@@ -2773,7 +2809,7 @@ const char* apzNext_Math_PrefixPatch[] = {
*
* Description of Next_Template fix
*/
-#define NEXT_TEMPLATE_FIXIDX 67
+#define NEXT_TEMPLATE_FIXIDX 68
tSCC zNext_TemplateName[] =
"next_template";
@@ -2810,7 +2846,7 @@ const char* apzNext_TemplatePatch[] = {
*
* Description of Next_Volitile fix
*/
-#define NEXT_VOLITILE_FIXIDX 68
+#define NEXT_VOLITILE_FIXIDX 69
tSCC zNext_VolitileName[] =
"next_volitile";
@@ -2847,7 +2883,7 @@ const char* apzNext_VolitilePatch[] = {
*
* Description of Next_Wait_Union fix
*/
-#define NEXT_WAIT_UNION_FIXIDX 69
+#define NEXT_WAIT_UNION_FIXIDX 70
tSCC zNext_Wait_UnionName[] =
"next_wait_union";
@@ -2874,15 +2910,16 @@ tTestDesc aNext_Wait_UnionTests[] = {
/*
* Fix Command Arguments for Next_Wait_Union
*/
-const char* apzNext_Wait_UnionPatch[] = { "sed",
- "-e", "s@wait(union wait@wait(void@",
+const char* apzNext_Wait_UnionPatch[] = {
+ "format",
+ "wait(void",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Nodeent_Syntax fix
*/
-#define NODEENT_SYNTAX_FIXIDX 70
+#define NODEENT_SYNTAX_FIXIDX 71
tSCC zNodeent_SyntaxName[] =
"nodeent_syntax";
@@ -2895,21 +2932,30 @@ tSCC zNodeent_SyntaxList[] =
* Machine/OS name selection pattern
*/
#define apzNodeent_SyntaxMachs (const char**)NULL
-#define NODEENT_SYNTAX_TEST_CT 0
-#define aNodeent_SyntaxTests (tTestDesc*)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zNodeent_SyntaxSelect0[] =
+ "char[ \t]*\\*na_addr[ \t]*$";
+
+#define NODEENT_SYNTAX_TEST_CT 1
+tTestDesc aNodeent_SyntaxTests[] = {
+ { TT_EGREP, zNodeent_SyntaxSelect0, (regex_t*)NULL }, };
/*
* Fix Command Arguments for Nodeent_Syntax
*/
-const char* apzNodeent_SyntaxPatch[] = { "sed",
- "-e", "s/char.*na_addr *$/char *na_addr;/",
+const char* apzNodeent_SyntaxPatch[] = {
+ "format",
+ "%0;",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Osf_Namespace_A fix
*/
-#define OSF_NAMESPACE_A_FIXIDX 71
+#define OSF_NAMESPACE_A_FIXIDX 72
tSCC zOsf_Namespace_AName[] =
"osf_namespace_a";
@@ -2945,64 +2991,72 @@ tTestDesc aOsf_Namespace_ATests[] = {
/*
* Fix Command Arguments for Osf_Namespace_A
*/
-const char* apzOsf_Namespace_APatch[] = { "sed",
- "-e", "s/regex_t/__regex_t/g",
- "-e", "s/regoff_t/__regoff_t/g",
- "-e", "s/regmatch_t/__regmatch_t/g",
+const char* apzOsf_Namespace_APatch[] = {
+ "format",
+ "__%0",
+ "reg(ex|off|match)_t[^;]",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
- * Description of Osf_Namespace_B fix
+ * Description of Osf_Namespace_C fix
*/
-#define OSF_NAMESPACE_B_FIXIDX 72
-tSCC zOsf_Namespace_BName[] =
- "osf_namespace_b";
+#define OSF_NAMESPACE_C_FIXIDX 73
+tSCC zOsf_Namespace_CName[] =
+ "osf_namespace_c";
/*
* File name selection pattern
*/
-tSCC zOsf_Namespace_BList[] =
+tSCC zOsf_Namespace_CList[] =
"|regex.h|";
/*
* Machine/OS name selection pattern
*/
-#define apzOsf_Namespace_BMachs (const char**)NULL
+#define apzOsf_Namespace_CMachs (const char**)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zOsf_Namespace_CSelect0[] =
+ "#include <reg_types.h>.*";
/*
* perform the 'test' shell command - do fix on success
*/
-tSCC zOsf_Namespace_BTest0[] =
+tSCC zOsf_Namespace_CTest0[] =
" -r reg_types.h";
-tSCC zOsf_Namespace_BTest1[] =
+tSCC zOsf_Namespace_CTest1[] =
" -r sys/lc_core.h";
-tSCC zOsf_Namespace_BTest2[] =
+tSCC zOsf_Namespace_CTest2[] =
" -n \"`grep '} regex_t;' reg_types.h`\"";
-tSCC zOsf_Namespace_BTest3[] =
+tSCC zOsf_Namespace_CTest3[] =
" -z \"`grep __regex_t regex.h`\"";
-#define OSF_NAMESPACE_B_TEST_CT 4
-tTestDesc aOsf_Namespace_BTests[] = {
- { TT_TEST, zOsf_Namespace_BTest0, 0 /* unused */ },
- { TT_TEST, zOsf_Namespace_BTest1, 0 /* unused */ },
- { TT_TEST, zOsf_Namespace_BTest2, 0 /* unused */ },
- { TT_TEST, zOsf_Namespace_BTest3, 0 /* unused */ }, };
+#define OSF_NAMESPACE_C_TEST_CT 5
+tTestDesc aOsf_Namespace_CTests[] = {
+ { TT_TEST, zOsf_Namespace_CTest0, 0 /* unused */ },
+ { TT_TEST, zOsf_Namespace_CTest1, 0 /* unused */ },
+ { TT_TEST, zOsf_Namespace_CTest2, 0 /* unused */ },
+ { TT_TEST, zOsf_Namespace_CTest3, 0 /* unused */ },
+ { TT_EGREP, zOsf_Namespace_CSelect0, (regex_t*)NULL }, };
/*
- * Fix Command Arguments for Osf_Namespace_B
+ * Fix Command Arguments for Osf_Namespace_C
*/
-const char* apzOsf_Namespace_BPatch[] = { "sed",
- "-e", "/#include <reg_types.h>/a\\\n\
-typedef __regex_t\tregex_t;\\\n\
-typedef __regoff_t\tregoff_t;\\\n\
-typedef __regmatch_t\tregmatch_t;\n",
+const char* apzOsf_Namespace_CPatch[] = {
+ "format",
+ "%0\n\
+typedef __regex_t\tregex_t;\n\
+typedef __regoff_t\tregoff_t;\n\
+typedef __regmatch_t\tregmatch_t;",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Pthread_Page_Size fix
*/
-#define PTHREAD_PAGE_SIZE_FIXIDX 73
+#define PTHREAD_PAGE_SIZE_FIXIDX 74
tSCC zPthread_Page_SizeName[] =
"pthread_page_size";
@@ -3029,15 +3083,16 @@ tTestDesc aPthread_Page_SizeTests[] = {
/*
* Fix Command Arguments for Pthread_Page_Size
*/
-const char* apzPthread_Page_SizePatch[] = { "sed",
- "-e", "s/^int __page_size/extern int __page_size/",
+const char* apzPthread_Page_SizePatch[] = {
+ "format",
+ "extern %0",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Read_Ret_Type fix
*/
-#define READ_RET_TYPE_FIXIDX 74
+#define READ_RET_TYPE_FIXIDX 75
tSCC zRead_Ret_TypeName[] =
"read_ret_type";
@@ -3064,16 +3119,18 @@ tTestDesc aRead_Ret_TypeTests[] = {
/*
* Fix Command Arguments for Read_Ret_Type
*/
-const char* apzRead_Ret_TypePatch[] = { "sed",
- "-e", "s/^\\(extern int\tfclose(), fflush()\\), \\(fread(), fwrite()\\)\\(.*\\)$/extern unsigned int\t\\2;\\\n\
-\\1\\3/",
+const char* apzRead_Ret_TypePatch[] = {
+ "format",
+ "extern unsigned int fread(), fwrite();\n\
+%1%2",
+ "(extern int\t.*), fread\\(\\), fwrite\\(\\)(.*)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Rs6000_Double fix
*/
-#define RS6000_DOUBLE_FIXIDX 75
+#define RS6000_DOUBLE_FIXIDX 76
tSCC zRs6000_DoubleName[] =
"rs6000_double";
@@ -3100,18 +3157,19 @@ tTestDesc aRs6000_DoubleTests[] = {
/*
* Fix Command Arguments for Rs6000_Double
*/
-const char* apzRs6000_DoublePatch[] = { "sed",
- "-e", "/class[(]/i\\\n\
-#ifndef __cplusplus\n",
- "-e", "/class[(]/a\\\n\
-#endif\n",
+const char* apzRs6000_DoublePatch[] = {
+ "format",
+ "#ifndef __cplusplus\n\
+%0\n\
+#endif",
+ "^.*[^a-zA-Z_]class\\(.*",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Rs6000_Fchmod fix
*/
-#define RS6000_FCHMOD_FIXIDX 76
+#define RS6000_FCHMOD_FIXIDX 77
tSCC zRs6000_FchmodName[] =
"rs6000_fchmod";
@@ -3129,7 +3187,7 @@ tSCC zRs6000_FchmodList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zRs6000_FchmodSelect0[] =
- "fchmod\\(char";
+ "fchmod\\(char \\*";
#define RS6000_FCHMOD_TEST_CT 1
tTestDesc aRs6000_FchmodTests[] = {
@@ -3138,15 +3196,16 @@ tTestDesc aRs6000_FchmodTests[] = {
/*
* Fix Command Arguments for Rs6000_Fchmod
*/
-const char* apzRs6000_FchmodPatch[] = { "sed",
- "-e", "s/fchmod(char \\*/fchmod(int/",
+const char* apzRs6000_FchmodPatch[] = {
+ "format",
+ "fchmod(int",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Rs6000_Param fix
*/
-#define RS6000_PARAM_FIXIDX 77
+#define RS6000_PARAM_FIXIDX 78
tSCC zRs6000_ParamName[] =
"rs6000_param";
@@ -3164,7 +3223,7 @@ tSCC zRs6000_ParamList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zRs6000_ParamSelect0[] =
- "const char new";
+ "rename\\(const char \\*old, const char \\*new\\)";
#define RS6000_PARAM_TEST_CT 1
tTestDesc aRs6000_ParamTests[] = {
@@ -3173,15 +3232,16 @@ tTestDesc aRs6000_ParamTests[] = {
/*
* Fix Command Arguments for Rs6000_Param
*/
-const char* apzRs6000_ParamPatch[] = { "sed",
- "-e", "s@rename(const char \\*old, const char \\*new)@rename(const char *_old, const char *_new)@",
+const char* apzRs6000_ParamPatch[] = {
+ "format",
+ "rename(const char *_old, const char *_new)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sco_Static_Func fix
*/
-#define SCO_STATIC_FUNC_FIXIDX 78
+#define SCO_STATIC_FUNC_FIXIDX 79
tSCC zSco_Static_FuncName[] =
"sco_static_func";
@@ -3225,7 +3285,7 @@ extern \"C\" {\\\n\
*
* Description of Sco_Strict_Ansi fix
*/
-#define SCO_STRICT_ANSI_FIXIDX 79
+#define SCO_STRICT_ANSI_FIXIDX 80
tSCC zSco_Strict_AnsiName[] =
"sco_strict_ansi";
@@ -3253,15 +3313,17 @@ tTestDesc aSco_Strict_AnsiTests[] = {
/*
* Fix Command Arguments for Sco_Strict_Ansi
*/
-const char* apzSco_Strict_AnsiPatch[] = { "sed",
- "-e", "s/!__STDC__/!defined(__STRICT_ANSI__)/g",
+const char* apzSco_Strict_AnsiPatch[] = {
+ "format",
+ "%1defined(__STRICT_ANSI__)%2",
+ "^([ \t]*#[ \t]*if[ \t].*!)__STDC__(.*)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sco_Utime fix
*/
-#define SCO_UTIME_FIXIDX 80
+#define SCO_UTIME_FIXIDX 81
tSCC zSco_UtimeName[] =
"sco_utime";
@@ -3281,7 +3343,7 @@ tSCC* apzSco_UtimeMachs[] = {
* content selection pattern - do fix if pattern found
*/
tSCC zSco_UtimeSelect0[] =
- "(const char *, struct utimbuf *);";
+ "\\(const char \\*, struct utimbuf \\*\\);";
#define SCO_UTIME_TEST_CT 1
tTestDesc aSco_UtimeTests[] = {
@@ -3290,15 +3352,16 @@ tTestDesc aSco_UtimeTests[] = {
/*
* Fix Command Arguments for Sco_Utime
*/
-const char* apzSco_UtimePatch[] = { "sed",
- "-e", "s/(const char \\*, struct utimbuf \\*);/(const char *, const struct utimbuf *);/",
+const char* apzSco_UtimePatch[] = {
+ "format",
+ "(const char *, const struct utimbuf *);",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sony_Include fix
*/
-#define SONY_INCLUDE_FIXIDX 81
+#define SONY_INCLUDE_FIXIDX 82
tSCC zSony_IncludeName[] =
"sony_include";
@@ -3333,7 +3396,7 @@ const char* apzSony_IncludePatch[] = { "sed",
*
* Description of Statsswtch fix
*/
-#define STATSSWTCH_FIXIDX 82
+#define STATSSWTCH_FIXIDX 83
tSCC zStatsswtchName[] =
"statsswtch";
@@ -3360,15 +3423,16 @@ tTestDesc aStatsswtchTests[] = {
/*
* Fix Command Arguments for Statsswtch
*/
-const char* apzStatsswtchPatch[] = { "sed",
- "-e", "s/boottime$/boottime;/",
+const char* apzStatsswtchPatch[] = {
+ "format",
+ "boottime;",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Stdio_Stdarg_H fix
*/
-#define STDIO_STDARG_H_FIXIDX 83
+#define STDIO_STDARG_H_FIXIDX 84
tSCC zStdio_Stdarg_HName[] =
"stdio_stdarg_h";
@@ -3405,7 +3469,7 @@ const char* apzStdio_Stdarg_HPatch[] = {
*
* Description of Stdio_Va_List fix
*/
-#define STDIO_VA_LIST_FIXIDX 84
+#define STDIO_VA_LIST_FIXIDX 85
tSCC zStdio_Va_ListName[] =
"stdio_va_list";
@@ -3450,7 +3514,7 @@ s@_Va_LIST@_VA_LIST@",
*
* Description of Struct_File fix
*/
-#define STRUCT_FILE_FIXIDX 85
+#define STRUCT_FILE_FIXIDX 86
tSCC zStruct_FileName[] =
"struct_file";
@@ -3487,7 +3551,7 @@ const char* apzStruct_FilePatch[] = {
*
* Description of Struct_Sockaddr fix
*/
-#define STRUCT_SOCKADDR_FIXIDX 86
+#define STRUCT_SOCKADDR_FIXIDX 87
tSCC zStruct_SockaddrName[] =
"struct_sockaddr";
@@ -3531,7 +3595,7 @@ const char* apzStruct_SockaddrPatch[] = {
*
* Description of Sun_Auth_Proto fix
*/
-#define SUN_AUTH_PROTO_FIXIDX 87
+#define SUN_AUTH_PROTO_FIXIDX 88
tSCC zSun_Auth_ProtoName[] =
"sun_auth_proto";
@@ -3558,20 +3622,21 @@ tTestDesc aSun_Auth_ProtoTests[] = {
/*
* Fix Command Arguments for Sun_Auth_Proto
*/
-const char* apzSun_Auth_ProtoPatch[] = { "sed",
- "-e", "s/^\\(.*(\\*[a-z][a-z_]*)(\\)\\();.*\\)/\\\n\
-#ifdef __cplusplus\\\n\
-\\1...\\2\\\n\
-#else\\\n\
-\\1\\2\\\n\
-#endif/",
+const char* apzSun_Auth_ProtoPatch[] = {
+ "format",
+ "#ifdef __cplusplus\n\
+%1(...);%2\n\
+#else\n\
+%1();%2\n\
+#endif",
+ "(.*\\(\\*[a-z][a-z_]*\\))\\(\\);(.*)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sun_Bogus_Ifdef fix
*/
-#define SUN_BOGUS_IFDEF_FIXIDX 88
+#define SUN_BOGUS_IFDEF_FIXIDX 89
tSCC zSun_Bogus_IfdefName[] =
"sun_bogus_ifdef";
@@ -3589,7 +3654,7 @@ tSCC zSun_Bogus_IfdefList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zSun_Bogus_IfdefSelect0[] =
- "#ifdef __i386__ || __vax__";
+ "#ifdef(.*\\|\\|.*)";
#define SUN_BOGUS_IFDEF_TEST_CT 1
tTestDesc aSun_Bogus_IfdefTests[] = {
@@ -3598,43 +3663,9 @@ tTestDesc aSun_Bogus_IfdefTests[] = {
/*
* Fix Command Arguments for Sun_Bogus_Ifdef
*/
-const char* apzSun_Bogus_IfdefPatch[] = { "sed",
- "-e", "s/\\#ifdef __i386__ || __vax__/\\#if __i386__ || __vax__/g",
- (char*)NULL };
-
-/* * * * * * * * * * * * * * * * * * * * * * * * * *
- *
- * Description of Sun_Bogus_Ifdef_Sun4c fix
- */
-#define SUN_BOGUS_IFDEF_SUN4C_FIXIDX 89
-tSCC zSun_Bogus_Ifdef_Sun4cName[] =
- "sun_bogus_ifdef_sun4c";
-
-/*
- * File name selection pattern
- */
-tSCC zSun_Bogus_Ifdef_Sun4cList[] =
- "|hsfs/hsnode.h|";
-/*
- * Machine/OS name selection pattern
- */
-#define apzSun_Bogus_Ifdef_Sun4cMachs (const char**)NULL
-
-/*
- * content selection pattern - do fix if pattern found
- */
-tSCC zSun_Bogus_Ifdef_Sun4cSelect0[] =
- "#ifdef __i386__ || __sun4c__";
-
-#define SUN_BOGUS_IFDEF_SUN4C_TEST_CT 1
-tTestDesc aSun_Bogus_Ifdef_Sun4cTests[] = {
- { TT_EGREP, zSun_Bogus_Ifdef_Sun4cSelect0, (regex_t*)NULL }, };
-
-/*
- * Fix Command Arguments for Sun_Bogus_Ifdef_Sun4c
- */
-const char* apzSun_Bogus_Ifdef_Sun4cPatch[] = { "sed",
- "-e", "s/\\#ifdef __i386__ || __sun4c__/\\#if __i386__ || __sun4c__/g",
+const char* apzSun_Bogus_IfdefPatch[] = {
+ "format",
+ "#if%1",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
@@ -3659,7 +3690,7 @@ tSCC zSun_CatmacroList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zSun_CatmacroSelect0[] =
- "^#define[ \t]+CAT\\(a,b\\)";
+ "^#define[ \t]+CAT\\(a,b\\).*";
#define SUN_CATMACRO_TEST_CT 1
tTestDesc aSun_CatmacroTests[] = {
@@ -3668,13 +3699,13 @@ tTestDesc aSun_CatmacroTests[] = {
/*
* Fix Command Arguments for Sun_Catmacro
*/
-const char* apzSun_CatmacroPatch[] = { "sed",
- "-e", "/^#define[ \t]CAT(a,b)/ i\\\n\
-#ifdef __STDC__ \\\n\
-#define CAT(a,b) a##b\\\n\
-#else\n",
- "-e", "/^#define[ \t]CAT(a,b)/ a\\\n\
-#endif\n",
+const char* apzSun_CatmacroPatch[] = {
+ "format",
+ "#ifdef __STDC__\n\
+# define CAT(a,b) a##b\n\
+#else\n\
+%0\n\
+#endif",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
@@ -3764,7 +3795,7 @@ tSCC zSun_SignalList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zSun_SignalSelect0[] =
- "^void\t\\(\\*signal\\(\\)\\)\\(\\);";
+ "^void\t\\(\\*signal\\(\\)\\)\\(\\);.*";
#define SUN_SIGNAL_TEST_CT 1
tTestDesc aSun_SignalTests[] = {
@@ -3773,13 +3804,13 @@ tTestDesc aSun_SignalTests[] = {
/*
* Fix Command Arguments for Sun_Signal
*/
-const char* apzSun_SignalPatch[] = { "sed",
- "-e", "/^void\t(\\*signal())();$/i\\\n\
-#ifdef __cplusplus\\\n\
-void\t(*signal(...))(...);\\\n\
-#else\n",
- "-e", "/^void\t(\\*signal())();$/a\\\n\
-#endif\n",
+const char* apzSun_SignalPatch[] = {
+ "format",
+ "#ifdef __cplusplus\n\
+void\t(*signal(...))(...);\n\
+#else\n\
+%0\n\
+#endif",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
@@ -3801,22 +3832,28 @@ tSCC zSunos_Matherr_DeclList[] =
#define apzSunos_Matherr_DeclMachs (const char**)NULL
/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zSunos_Matherr_DeclSelect0[] =
+ "matherr";
+
+/*
* content bypass pattern - skip fix if pattern found
*/
tSCC zSunos_Matherr_DeclBypass0[] =
"matherr.*struct exception";
-#define SUNOS_MATHERR_DECL_TEST_CT 1
+#define SUNOS_MATHERR_DECL_TEST_CT 2
tTestDesc aSunos_Matherr_DeclTests[] = {
- { TT_NEGREP, zSunos_Matherr_DeclBypass0, (regex_t*)NULL }, };
+ { TT_NEGREP, zSunos_Matherr_DeclBypass0, (regex_t*)NULL },
+ { TT_EGREP, zSunos_Matherr_DeclSelect0, (regex_t*)NULL }, };
/*
* Fix Command Arguments for Sunos_Matherr_Decl
*/
-const char* apzSunos_Matherr_DeclPatch[] = { "sed",
- "-e", "/^struct exception/,$b",
- "-e", "/matherr/i\\\n\
-struct exception;\n",
+const char* apzSunos_Matherr_DeclPatch[] = {
+ "wrap",
+ "struct exception;\n",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
@@ -3841,7 +3878,7 @@ tSCC zSunos_StrlenList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zSunos_StrlenSelect0[] =
- "int[ \t]*strlen";
+ "int[ \t]*strlen\\(\\);(.*)";
#define SUNOS_STRLEN_TEST_CT 1
tTestDesc aSunos_StrlenTests[] = {
@@ -3850,15 +3887,54 @@ tTestDesc aSunos_StrlenTests[] = {
/*
* Fix Command Arguments for Sunos_Strlen
*/
-const char* apzSunos_StrlenPatch[] = { "sed",
- "-e", "s/int[ \t]*strlen();/__SIZE_TYPE__ strlen();/",
+const char* apzSunos_StrlenPatch[] = {
+ "format",
+ "__SIZE_TYPE__ strlen();%1",
+ (char*)NULL };
+
+/* * * * * * * * * * * * * * * * * * * * * * * * * *
+ *
+ * Description of Svr4__P fix
+ */
+#define SVR4__P_FIXIDX 96
+tSCC zSvr4__PName[] =
+ "svr4__p";
+
+/*
+ * File name selection pattern
+ */
+tSCC zSvr4__PList[] =
+ "|math.h|floatingpoint.h|";
+/*
+ * Machine/OS name selection pattern
+ */
+#define apzSvr4__PMachs (const char**)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zSvr4__PSelect0[] =
+ "^#define[ \t]+__P.*";
+
+#define SVR4__P_TEST_CT 1
+tTestDesc aSvr4__PTests[] = {
+ { TT_EGREP, zSvr4__PSelect0, (regex_t*)NULL }, };
+
+/*
+ * Fix Command Arguments for Svr4__P
+ */
+const char* apzSvr4__PPatch[] = {
+ "format",
+ "#ifndef __P\n\
+%0\n\
+#endif",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Svr4_Getcwd fix
*/
-#define SVR4_GETCWD_FIXIDX 96
+#define SVR4_GETCWD_FIXIDX 97
tSCC zSvr4_GetcwdName[] =
"svr4_getcwd";
@@ -3885,15 +3961,16 @@ tTestDesc aSvr4_GetcwdTests[] = {
/*
* Fix Command Arguments for Svr4_Getcwd
*/
-const char* apzSvr4_GetcwdPatch[] = { "sed",
- "-e", "s/getcwd(char \\*, int)/getcwd(char *, size_t)/",
+const char* apzSvr4_GetcwdPatch[] = {
+ "format",
+ "getcwd(char *, size_t)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Svr4_Profil fix
*/
-#define SVR4_PROFIL_FIXIDX 97
+#define SVR4_PROFIL_FIXIDX 98
tSCC zSvr4_ProfilName[] =
"svr4_profil";
@@ -3906,21 +3983,30 @@ tSCC zSvr4_ProfilList[] =
* Machine/OS name selection pattern
*/
#define apzSvr4_ProfilMachs (const char**)NULL
-#define SVR4_PROFIL_TEST_CT 0
-#define aSvr4_ProfilTests (tTestDesc*)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zSvr4_ProfilSelect0[] =
+ "profil\\(unsigned short \\*, unsigned int, unsigned int, unsigned int\\)";
+
+#define SVR4_PROFIL_TEST_CT 1
+tTestDesc aSvr4_ProfilTests[] = {
+ { TT_EGREP, zSvr4_ProfilSelect0, (regex_t*)NULL }, };
/*
* Fix Command Arguments for Svr4_Profil
*/
-const char* apzSvr4_ProfilPatch[] = { "sed",
- "-e", "s/profil(unsigned short \\*, unsigned int, unsigned int, unsigned int)/profil(unsigned short *, size_t, int, unsigned)/",
+const char* apzSvr4_ProfilPatch[] = {
+ "format",
+ "profil(unsigned short *, size_t, int, unsigned int)",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Systypes fix
*/
-#define SYSTYPES_FIXIDX 98
+#define SYSTYPES_FIXIDX 99
tSCC zSystypesName[] =
"systypes";
@@ -3979,7 +4065,7 @@ typedef __SIZE_TYPE__ size_t;\\\n\
*
* Description of Systypes_Stdlib_Size_T fix
*/
-#define SYSTYPES_STDLIB_SIZE_T_FIXIDX 99
+#define SYSTYPES_STDLIB_SIZE_T_FIXIDX 100
tSCC zSystypes_Stdlib_Size_TName[] =
"systypes_stdlib_size_t";
@@ -3997,7 +4083,7 @@ tSCC zSystypes_Stdlib_Size_TList[] =
* content selection pattern - do fix if pattern found
*/
tSCC zSystypes_Stdlib_Size_TSelect0[] =
- "typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t";
+ "typedef[ \t]+[A-Za-z_][ \tA-Za-z_]*[ \t]size_t.*";
/*
* content bypass pattern - skip fix if pattern found
@@ -4013,19 +4099,19 @@ tTestDesc aSystypes_Stdlib_Size_TTests[] = {
/*
* Fix Command Arguments for Systypes_Stdlib_Size_T
*/
-const char* apzSystypes_Stdlib_Size_TPatch[] = { "sed",
- "-e", "/typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t/i\\\n\
-#ifndef _GCC_SIZE_T\\\n\
-#define _GCC_SIZE_T\n",
- "-e", "/typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t/a\\\n\
-#endif\n",
+const char* apzSystypes_Stdlib_Size_TPatch[] = {
+ "format",
+ "#ifndef _GCC_SIZE_T\n\
+#define _GCC_SIZE_T\n\
+%0\n\
+#endif",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sysv68_String fix
*/
-#define SYSV68_STRING_FIXIDX 100
+#define SYSV68_STRING_FIXIDX 101
tSCC zSysv68_StringName[] =
"sysv68_string";
@@ -4062,7 +4148,7 @@ extern unsigned int\\\n\
*
* Description of Sysz_Stdlib_For_Sun fix
*/
-#define SYSZ_STDLIB_FOR_SUN_FIXIDX 101
+#define SYSZ_STDLIB_FOR_SUN_FIXIDX 102
tSCC zSysz_Stdlib_For_SunName[] =
"sysz_stdlib_for_sun";
@@ -4075,27 +4161,30 @@ tSCC zSysz_Stdlib_For_SunList[] =
* Machine/OS name selection pattern
*/
#define apzSysz_Stdlib_For_SunMachs (const char**)NULL
-#define SYSZ_STDLIB_FOR_SUN_TEST_CT 0
-#define aSysz_Stdlib_For_SunTests (tTestDesc*)NULL
+
+/*
+ * content selection pattern - do fix if pattern found
+ */
+tSCC zSysz_Stdlib_For_SunSelect0[] =
+ "char[ \t]*\\*[ \t]*(calloc|malloc|realloc|bsearch)[ \t]*\\(";
+
+#define SYSZ_STDLIB_FOR_SUN_TEST_CT 1
+tTestDesc aSysz_Stdlib_For_SunTests[] = {
+ { TT_EGREP, zSysz_Stdlib_For_SunSelect0, (regex_t*)NULL }, };
/*
* Fix Command Arguments for Sysz_Stdlib_For_Sun
*/
-const char* apzSysz_Stdlib_For_SunPatch[] = { "sed",
- "-e", "s/int\tabort/void\tabort/g",
- "-e", "s/int\tfree/void\tfree/g",
- "-e", "s/char[ \t]*\\*[ \t]*calloc/void \\*\tcalloc/g",
- "-e", "s/char[ \t]*\\*[ \t]*malloc/void \\*\tmalloc/g",
- "-e", "s/char[ \t]*\\*[ \t]*realloc/void \\*\trealloc/g",
- "-e", "s/char[ \t]*\\*[ \t]*bsearch/void \\*\tbsearch/g",
- "-e", "s/int[ \t][ \t]*exit/void\texit/g",
+const char* apzSysz_Stdlib_For_SunPatch[] = {
+ "format",
+ "void *\t%1(",
(char*)NULL };
/* * * * * * * * * * * * * * * * * * * * * * * * * *
*
* Description of Sysz_Stdtypes_For_Sun fix
*/
-#define SYSZ_STDTYPES_FOR_SUN_FIXIDX 102
+#define SYSZ_STDTYPES_FOR_SUN_FIXIDX 103
tSCC zSysz_Stdtypes_For_SunName[] =
"sysz_stdtypes_for_sun";
@@ -4136,7 +4225,7 @@ const char* apzSysz_Stdtypes_For_SunPatch[] = { "sed",
*
* Description of Tinfo_Cplusplus fix
*/
-#define TINFO_CPLUSPLUS_FIXIDX 103
+#define TINFO_CPLUSPLUS_FIXIDX 104
tSCC zTinfo_CplusplusName[] =
"tinfo_cplusplus";
@@ -4171,7 +4260,7 @@ const char* apzTinfo_CplusplusPatch[] = { "sed",
*
* Description of Ultrix_Atof_Param fix
*/
-#define ULTRIX_ATOF_PARAM_FIXIDX 104
+#define ULTRIX_ATOF_PARAM_FIXIDX 105
tSCC zUltrix_Atof_ParamName[] =
"ultrix_atof_param";
@@ -4206,7 +4295,7 @@ const char* apzUltrix_Atof_ParamPatch[] = { "sed",
*
* Description of Ultrix_Const fix
*/
-#define ULTRIX_CONST_FIXIDX 105
+#define ULTRIX_CONST_FIXIDX 106
tSCC zUltrix_ConstName[] =
"ultrix_const";
@@ -4241,7 +4330,7 @@ const char* apzUltrix_ConstPatch[] = { "sed",
*
* Description of Ultrix_Fix_Fixproto fix
*/
-#define ULTRIX_FIX_FIXPROTO_FIXIDX 106
+#define ULTRIX_FIX_FIXPROTO_FIXIDX 107
tSCC zUltrix_Fix_FixprotoName[] =
"ultrix_fix_fixproto";
@@ -4277,7 +4366,7 @@ struct utsname;\n",
*
* Description of Ultrix_Ifdef fix
*/
-#define ULTRIX_IFDEF_FIXIDX 107
+#define ULTRIX_IFDEF_FIXIDX 108
tSCC zUltrix_IfdefName[] =
"ultrix_ifdef";
@@ -4312,7 +4401,7 @@ const char* apzUltrix_IfdefPatch[] = { "sed",
*
* Description of Ultrix_Static fix
*/
-#define ULTRIX_STATIC_FIXIDX 108
+#define ULTRIX_STATIC_FIXIDX 109
tSCC zUltrix_StaticName[] =
"ultrix_static";
@@ -4349,7 +4438,7 @@ const char* apzUltrix_StaticPatch[] = { "sed",
*
* Description of Undefine_Null fix
*/
-#define UNDEFINE_NULL_FIXIDX 109
+#define UNDEFINE_NULL_FIXIDX 110
tSCC zUndefine_NullName[] =
"undefine_null";
@@ -4395,7 +4484,7 @@ const char* apzUndefine_NullPatch[] = {
*
* Description of Unixware7_Byteorder_Fix fix
*/
-#define UNIXWARE7_BYTEORDER_FIX_FIXIDX 110
+#define UNIXWARE7_BYTEORDER_FIX_FIXIDX 111
tSCC zUnixware7_Byteorder_FixName[] =
"unixware7_byteorder_fix";
@@ -4438,7 +4527,7 @@ const char* apzUnixware7_Byteorder_FixPatch[] = { "sed",
*
* Description of Va_I960_Macro fix
*/
-#define VA_I960_MACRO_FIXIDX 111
+#define VA_I960_MACRO_FIXIDX 112
tSCC zVa_I960_MacroName[] =
"va_i960_macro";
@@ -4476,7 +4565,7 @@ const char* apzVa_I960_MacroPatch[] = { "sed",
*
* Description of Void_Null fix
*/
-#define VOID_NULL_FIXIDX 112
+#define VOID_NULL_FIXIDX 113
tSCC zVoid_NullName[] =
"void_null";
@@ -4511,7 +4600,7 @@ const char* apzVoid_NullPatch[] = { "sed",
*
* Description of Vxworks_Gcc_Problem fix
*/
-#define VXWORKS_GCC_PROBLEM_FIXIDX 113
+#define VXWORKS_GCC_PROBLEM_FIXIDX 114
tSCC zVxworks_Gcc_ProblemName[] =
"vxworks_gcc_problem";
@@ -4561,7 +4650,7 @@ const char* apzVxworks_Gcc_ProblemPatch[] = { "sed",
*
* Description of Vxworks_Needs_Vxtypes fix
*/
-#define VXWORKS_NEEDS_VXTYPES_FIXIDX 114
+#define VXWORKS_NEEDS_VXTYPES_FIXIDX 115
tSCC zVxworks_Needs_VxtypesName[] =
"vxworks_needs_vxtypes";
@@ -4596,7 +4685,7 @@ const char* apzVxworks_Needs_VxtypesPatch[] = { "sed",
*
* Description of Vxworks_Needs_Vxworks fix
*/
-#define VXWORKS_NEEDS_VXWORKS_FIXIDX 115
+#define VXWORKS_NEEDS_VXWORKS_FIXIDX 116
tSCC zVxworks_Needs_VxworksName[] =
"vxworks_needs_vxworks";
@@ -4645,7 +4734,7 @@ const char* apzVxworks_Needs_VxworksPatch[] = { "sed",
*
* Description of Vxworks_Time fix
*/
-#define VXWORKS_TIME_FIXIDX 116
+#define VXWORKS_TIME_FIXIDX 117
tSCC zVxworks_TimeName[] =
"vxworks_time";
@@ -4696,7 +4785,7 @@ typedef void (*__gcc_VOIDFUNCPTR) ();\\\n\
*
* Description of X11_Class fix
*/
-#define X11_CLASS_FIXIDX 117
+#define X11_CLASS_FIXIDX 118
tSCC zX11_ClassName[] =
"x11_class";
@@ -4736,7 +4825,7 @@ const char* apzX11_ClassPatch[] = { "sed",
*
* Description of X11_Class_Usage fix
*/
-#define X11_CLASS_USAGE_FIXIDX 118
+#define X11_CLASS_USAGE_FIXIDX 119
tSCC zX11_Class_UsageName[] =
"x11_class_usage";
@@ -4771,7 +4860,7 @@ const char* apzX11_Class_UsagePatch[] = { "sed",
*
* Description of X11_New fix
*/
-#define X11_NEW_FIXIDX 119
+#define X11_NEW_FIXIDX 120
tSCC zX11_NewName[] =
"x11_new";
@@ -4812,7 +4901,7 @@ const char* apzX11_NewPatch[] = { "sed",
*
* Description of X11_Sprintf fix
*/
-#define X11_SPRINTF_FIXIDX 120
+#define X11_SPRINTF_FIXIDX 121
tSCC zX11_SprintfName[] =
"x11_sprintf";
@@ -4850,9 +4939,9 @@ extern char *\tsprintf();\\\n\
*
* List of all fixes
*/
-#define REGEX_COUNT 115
+#define REGEX_COUNT 121
#define MACH_LIST_SIZE_LIMIT 279
-#define FIX_COUNT 121
+#define FIX_COUNT 122
tFixDesc fixDescList[ FIX_COUNT ] = {
{ zAaa_Ki_IfaceName, zAaa_Ki_IfaceList,
@@ -5055,6 +5144,11 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
HPUX8_BOGUS_INLINES_TEST_CT, FD_MACH_ONLY,
aHpux8_Bogus_InlinesTests, apzHpux8_Bogus_InlinesPatch },
+ { zInt_Abort_Free_And_ExitName, zInt_Abort_Free_And_ExitList,
+ apzInt_Abort_Free_And_ExitMachs,
+ INT_ABORT_FREE_AND_EXIT_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
+ aInt_Abort_Free_And_ExitTests, apzInt_Abort_Free_And_ExitPatch },
+
{ zIsc_Omits_With_StdcName, zIsc_Omits_With_StdcList,
apzIsc_Omits_With_StdcMachs,
ISC_OMITS_WITH_STDC_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
@@ -5202,47 +5296,47 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zNext_Wait_UnionName, zNext_Wait_UnionList,
apzNext_Wait_UnionMachs,
- NEXT_WAIT_UNION_TEST_CT, FD_MACH_ONLY,
+ NEXT_WAIT_UNION_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aNext_Wait_UnionTests, apzNext_Wait_UnionPatch },
{ zNodeent_SyntaxName, zNodeent_SyntaxList,
apzNodeent_SyntaxMachs,
- NODEENT_SYNTAX_TEST_CT, FD_MACH_ONLY,
+ NODEENT_SYNTAX_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aNodeent_SyntaxTests, apzNodeent_SyntaxPatch },
{ zOsf_Namespace_AName, zOsf_Namespace_AList,
apzOsf_Namespace_AMachs,
- OSF_NAMESPACE_A_TEST_CT, FD_MACH_ONLY,
+ OSF_NAMESPACE_A_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aOsf_Namespace_ATests, apzOsf_Namespace_APatch },
- { zOsf_Namespace_BName, zOsf_Namespace_BList,
- apzOsf_Namespace_BMachs,
- OSF_NAMESPACE_B_TEST_CT, FD_MACH_ONLY,
- aOsf_Namespace_BTests, apzOsf_Namespace_BPatch },
+ { zOsf_Namespace_CName, zOsf_Namespace_CList,
+ apzOsf_Namespace_CMachs,
+ OSF_NAMESPACE_C_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
+ aOsf_Namespace_CTests, apzOsf_Namespace_CPatch },
{ zPthread_Page_SizeName, zPthread_Page_SizeList,
apzPthread_Page_SizeMachs,
- PTHREAD_PAGE_SIZE_TEST_CT, FD_MACH_ONLY,
+ PTHREAD_PAGE_SIZE_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aPthread_Page_SizeTests, apzPthread_Page_SizePatch },
{ zRead_Ret_TypeName, zRead_Ret_TypeList,
apzRead_Ret_TypeMachs,
- READ_RET_TYPE_TEST_CT, FD_MACH_ONLY,
+ READ_RET_TYPE_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aRead_Ret_TypeTests, apzRead_Ret_TypePatch },
{ zRs6000_DoubleName, zRs6000_DoubleList,
apzRs6000_DoubleMachs,
- RS6000_DOUBLE_TEST_CT, FD_MACH_ONLY,
+ RS6000_DOUBLE_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aRs6000_DoubleTests, apzRs6000_DoublePatch },
{ zRs6000_FchmodName, zRs6000_FchmodList,
apzRs6000_FchmodMachs,
- RS6000_FCHMOD_TEST_CT, FD_MACH_ONLY,
+ RS6000_FCHMOD_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aRs6000_FchmodTests, apzRs6000_FchmodPatch },
{ zRs6000_ParamName, zRs6000_ParamList,
apzRs6000_ParamMachs,
- RS6000_PARAM_TEST_CT, FD_MACH_ONLY,
+ RS6000_PARAM_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aRs6000_ParamTests, apzRs6000_ParamPatch },
{ zSco_Static_FuncName, zSco_Static_FuncList,
@@ -5252,12 +5346,12 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zSco_Strict_AnsiName, zSco_Strict_AnsiList,
apzSco_Strict_AnsiMachs,
- SCO_STRICT_ANSI_TEST_CT, FD_MACH_ONLY,
+ SCO_STRICT_ANSI_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSco_Strict_AnsiTests, apzSco_Strict_AnsiPatch },
{ zSco_UtimeName, zSco_UtimeList,
apzSco_UtimeMachs,
- SCO_UTIME_TEST_CT, FD_MACH_ONLY,
+ SCO_UTIME_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSco_UtimeTests, apzSco_UtimePatch },
{ zSony_IncludeName, zSony_IncludeList,
@@ -5267,7 +5361,7 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zStatsswtchName, zStatsswtchList,
apzStatsswtchMachs,
- STATSSWTCH_TEST_CT, FD_MACH_ONLY,
+ STATSSWTCH_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aStatsswtchTests, apzStatsswtchPatch },
{ zStdio_Stdarg_HName, zStdio_Stdarg_HList,
@@ -5292,22 +5386,17 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zSun_Auth_ProtoName, zSun_Auth_ProtoList,
apzSun_Auth_ProtoMachs,
- SUN_AUTH_PROTO_TEST_CT, FD_MACH_ONLY,
+ SUN_AUTH_PROTO_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSun_Auth_ProtoTests, apzSun_Auth_ProtoPatch },
{ zSun_Bogus_IfdefName, zSun_Bogus_IfdefList,
apzSun_Bogus_IfdefMachs,
- SUN_BOGUS_IFDEF_TEST_CT, FD_MACH_ONLY,
+ SUN_BOGUS_IFDEF_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSun_Bogus_IfdefTests, apzSun_Bogus_IfdefPatch },
- { zSun_Bogus_Ifdef_Sun4cName, zSun_Bogus_Ifdef_Sun4cList,
- apzSun_Bogus_Ifdef_Sun4cMachs,
- SUN_BOGUS_IFDEF_SUN4C_TEST_CT, FD_MACH_ONLY,
- aSun_Bogus_Ifdef_Sun4cTests, apzSun_Bogus_Ifdef_Sun4cPatch },
-
{ zSun_CatmacroName, zSun_CatmacroList,
apzSun_CatmacroMachs,
- SUN_CATMACRO_TEST_CT, FD_MACH_ONLY,
+ SUN_CATMACRO_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSun_CatmacroTests, apzSun_CatmacroPatch },
{ zSun_MallocName, zSun_MallocList,
@@ -5322,27 +5411,32 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zSun_SignalName, zSun_SignalList,
apzSun_SignalMachs,
- SUN_SIGNAL_TEST_CT, FD_MACH_ONLY,
+ SUN_SIGNAL_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSun_SignalTests, apzSun_SignalPatch },
{ zSunos_Matherr_DeclName, zSunos_Matherr_DeclList,
apzSunos_Matherr_DeclMachs,
- SUNOS_MATHERR_DECL_TEST_CT, FD_MACH_ONLY,
+ SUNOS_MATHERR_DECL_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSunos_Matherr_DeclTests, apzSunos_Matherr_DeclPatch },
{ zSunos_StrlenName, zSunos_StrlenList,
apzSunos_StrlenMachs,
- SUNOS_STRLEN_TEST_CT, FD_MACH_ONLY,
+ SUNOS_STRLEN_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSunos_StrlenTests, apzSunos_StrlenPatch },
+ { zSvr4__PName, zSvr4__PList,
+ apzSvr4__PMachs,
+ SVR4__P_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
+ aSvr4__PTests, apzSvr4__PPatch },
+
{ zSvr4_GetcwdName, zSvr4_GetcwdList,
apzSvr4_GetcwdMachs,
- SVR4_GETCWD_TEST_CT, FD_MACH_ONLY,
+ SVR4_GETCWD_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSvr4_GetcwdTests, apzSvr4_GetcwdPatch },
{ zSvr4_ProfilName, zSvr4_ProfilList,
apzSvr4_ProfilMachs,
- SVR4_PROFIL_TEST_CT, FD_MACH_ONLY,
+ SVR4_PROFIL_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSvr4_ProfilTests, apzSvr4_ProfilPatch },
{ zSystypesName, zSystypesList,
@@ -5352,7 +5446,7 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zSystypes_Stdlib_Size_TName, zSystypes_Stdlib_Size_TList,
apzSystypes_Stdlib_Size_TMachs,
- SYSTYPES_STDLIB_SIZE_T_TEST_CT, FD_MACH_ONLY,
+ SYSTYPES_STDLIB_SIZE_T_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSystypes_Stdlib_Size_TTests, apzSystypes_Stdlib_Size_TPatch },
{ zSysv68_StringName, zSysv68_StringList,
@@ -5362,7 +5456,7 @@ tFixDesc fixDescList[ FIX_COUNT ] = {
{ zSysz_Stdlib_For_SunName, zSysz_Stdlib_For_SunList,
apzSysz_Stdlib_For_SunMachs,
- SYSZ_STDLIB_FOR_SUN_TEST_CT, FD_MACH_ONLY,
+ SYSZ_STDLIB_FOR_SUN_TEST_CT, FD_MACH_ONLY | FD_SUBROUTINE,
aSysz_Stdlib_For_SunTests, apzSysz_Stdlib_For_SunPatch },
{ zSysz_Stdtypes_For_SunName, zSysz_Stdtypes_For_SunList,
diff --git a/gcc/fixinc/inclhack.def b/gcc/fixinc/inclhack.def
index 2d90f5cfd1a..f8d71910a1a 100644
--- a/gcc/fixinc/inclhack.def
+++ b/gcc/fixinc/inclhack.def
@@ -1023,6 +1023,23 @@ fix = {
/*
+ * Fix return type of abort and free
+ */
+fix = {
+ hackname = int_abort_free_and_exit;
+ files = stdlib.h;
+ select = "int[ \t]+(abort|free|exit)[ \t]*\\(";
+
+ c_fix = format;
+ c_fix_arg = "void\t%1(";
+
+ test_text = "extern int abort(int);\n"
+ "extern int free(void*);\n"
+ "extern int exit(void*);";
+};
+
+
+/*
* On Interactive Unix 2.2, certain traditional Unix definitions
* (notably getc and putc in stdio.h) are omitted if __STDC__ is
* defined, not just if _POSIX_SOURCE is defined. This makes it
@@ -1343,9 +1360,9 @@ fix = {
hackname = machine_name;
c_test = machine_name;
c_fix = machine_name;
+
test_text = "/* MACH_DIFF: */\n"
- "#if defined( i386 )"
- " || defined( sparc )"
+ "#if defined( i386 ) || defined( sparc ) || defined( vax )"
"\n/* no uniform test, so be careful :-) */";
};
@@ -1485,7 +1502,7 @@ fix = {
fix = {
hackname = news_os_recursion;
files = stdlib.h;
- select = '#include <stdlib\.h>';
+ select = "[ \t]*#include <stdlib\\.h>.*";
c_fix = format;
c_fix_arg = "#ifdef BOGUS_RECURSION\n%0\n#endif";
@@ -1551,12 +1568,13 @@ fix = {
* conditional, so it doesn't need this fix. So everything is okay.
*/
fix = {
- hackname = next_wait_union;
- files = sys/wait.h;
-
- select = 'wait\(union wait';
+ hackname = next_wait_union;
+ files = sys/wait.h;
- sed = "s@wait(union wait@wait(void@";
+ select = 'wait\(union wait';
+ c_fix = format;
+ c_fix_arg = "wait(void";
+ test_text = "extern pid_d wait(union wait*);";
};
@@ -1564,9 +1582,12 @@ fix = {
* a missing semi-colon at the end of the nodeent structure definition.
*/
fix = {
- hackname = nodeent_syntax;
- files = netdnet/dnetdb.h;
- sed = "s/char.*na_addr *$/char *na_addr;/";
+ hackname = nodeent_syntax;
+ files = netdnet/dnetdb.h;
+ select = "char[ \t]*\\*na_addr[ \t]*$";
+ c_fix = format;
+ c_fix_arg = "%0;";
+ test_text = "char *na_addr\t";
};
@@ -1584,23 +1605,33 @@ fix = {
test = " -n \"`grep '} regex_t;' reg_types.h`\"";
test = " -z \"`grep __regex_t regex.h`\"";
- sed = "s/regex_t/__regex_t/g";
- sed = "s/regoff_t/__regoff_t/g";
- sed = "s/regmatch_t/__regmatch_t/g";
+ c_fix = format;
+ c_fix_arg = "__%0";
+ c_fix_arg = "reg(ex|off|match)_t[^;]";
+
+ test_text = "`touch inc/sys/lc_core.h`"
+ "typedef struct {\n int stuff, mo_suff;\n} regex_t;\n"
+ "extern regex_t re;\n"
+ "extern regoff_t ro;\n"
+ "extern regmatch_t rm;\n";
};
fix = {
- hackname = osf_namespace_b;
+ hackname = osf_namespace_c;
files = regex.h;
test = " -r reg_types.h";
test = " -r sys/lc_core.h";
test = " -n \"`grep '} regex_t;' reg_types.h`\"";
test = " -z \"`grep __regex_t regex.h`\"";
- sed = "/#include <reg_types.h>/a\\\n"
- "typedef __regex_t\tregex_t;\\\n"
- "typedef __regoff_t\tregoff_t;\\\n"
- "typedef __regmatch_t\tregmatch_t;\n";
+ select = "#include <reg_types\.h>.*";
+ c_fix = format;
+ c_fix_arg = "%0\n"
+ "typedef __regex_t\tregex_t;\n"
+ "typedef __regoff_t\tregoff_t;\n"
+ "typedef __regmatch_t\tregmatch_t;";
+
+ test_text = "#include <reg_types.h>";
};
@@ -1610,10 +1641,12 @@ fix = {
* This is the default for all ANSI standard C++ compilers.
*/
fix = {
- hackname = pthread_page_size;
- files = pthread.h;
- select = "^int __page_size";
- sed = "s/^int __page_size/extern int __page_size/";
+ hackname = pthread_page_size;
+ files = pthread.h;
+ select = "^int __page_size";
+ c_fix = format;
+ c_fix_arg = "extern %0";
+ test_text = "int __page_size;";
};
@@ -1624,9 +1657,11 @@ fix = {
hackname = read_ret_type;
files = stdio.h;
select = "extern int\t.*, fread\\(\\), fwrite\\(\\)";
- sed = "s/^\\(extern int\tfclose(), fflush()\\), "
- "\\(fread(), fwrite()\\)\\(.*\\)$"
- "/extern unsigned int\t\\2;\\\n\\1\\3/";
+ c_fix = format;
+ c_fix_arg = "extern unsigned int fread(), fwrite();\n%1%2";
+ c_fix_arg = "(extern int\t.*), fread\\(\\), fwrite\\(\\)(.*)";
+
+ test_text = "extern int\tfclose(), fflush(), fread(), fwrite(), foo();";
};
@@ -1634,12 +1669,15 @@ fix = {
* function class(double x) conflicts with C++ keyword on rs/6000
*/
fix = {
- hackname = rs6000_double;
- files = math.h;
- select = '[^a-zA-Z_]class\(';
-
- sed = "/class[(]/i\\\n#ifndef __cplusplus\n";
- sed = "/class[(]/a\\\n#endif\n";
+ hackname = rs6000_double;
+ files = math.h;
+ select = '[^a-zA-Z_]class\(';
+
+ c_fix = format;
+ c_fix_arg = "#ifndef __cplusplus\n%0\n#endif";
+ c_fix_arg = '^.*[^a-zA-Z_]class\(.*';
+
+ test_text = "extern int class();";
};
@@ -1647,10 +1685,12 @@ fix = {
* Wrong fchmod prototype on RS/6000.
*/
fix = {
- hackname = rs6000_fchmod;
- files = sys/stat.h;
- select = 'fchmod\(char';
- sed = 's/fchmod(char \*/fchmod(int/';
+ hackname = rs6000_fchmod;
+ files = sys/stat.h;
+ select = 'fchmod\(char \*';
+ c_fix = format;
+ c_fix_arg = "fchmod(int";
+ test_text = "extern int fchmod(char *, mode_t);";
};
@@ -1658,13 +1698,15 @@ fix = {
* parameters conflict with C++ new on rs/6000
*/
fix = {
- hackname = rs6000_param;
- files = "stdio.h";
- files = "unistd.h";
- select = 'const char new';
+ hackname = rs6000_param;
+ files = "stdio.h";
+ files = "unistd.h";
- sed = 's@rename(const char \*old, const char \*new)@'
- 'rename(const char *_old, const char *_new)@';
+ select = 'rename\(const char \*old, const char \*new\)';
+ c_fix = format;
+ c_fix_arg = 'rename(const char *_old, const char *_new)';
+
+ test_text = 'extern int rename(const char *old, const char *new);';
};
@@ -1690,6 +1732,20 @@ fix = {
"#if __cplusplus\\\n"
" }\\\n"
"#endif /* __cplusplus */";
+
+ test_text =
+ "#ifdef __STDC__\n"
+ "static int\tstat(const char *__f, struct stat *__p) {\n"
+ "\treturn __stat32(__f, __p);\n"
+ "}\n\n# else /* !__STDC__ */\n"
+
+ "static int\tstat(__f, __p)\n"
+ "\tchar *__f;\n"
+ "\tstruct stat *__p;\n"
+ "{\n"
+ "\treturn __stat32(__f, __p);\n"
+ "}\n"
+ "#endif";
};
@@ -1700,7 +1756,12 @@ fix = {
hackname = sco_strict_ansi;
mach = "i?86-*-sco3.2*";
select = "^[ \t]*#[ \t]*if.*!__STDC__";
- sed = 's/!__STDC__/!defined(__STRICT_ANSI__)/g';
+
+ c_fix = format;
+ c_fix_arg = "%1defined(__STRICT_ANSI__)%2";
+ c_fix_arg = "^([ \t]*#[ \t]*if[ \t].*!)__STDC__(.*)";
+
+ test_text = "#if !__STDC__ /* not standard C */\nint foo;\n#endif";
};
@@ -1709,12 +1770,15 @@ fix = {
* In 3.2v4.0 the const is missing.
*/
fix = {
- hackname = sco_utime;
- files = sys/times.h;
- mach = "i?86-*-sco3.2v4*";
- select = "\(const char \*, struct utimbuf \*\);";
- sed = 's/(const char \*, struct utimbuf \*);/'
- '(const char *, const struct utimbuf *);/';
+ hackname = sco_utime;
+ files = sys/times.h;
+ mach = "i?86-*-sco3.2v4*";
+
+ select = '\(const char \*, struct utimbuf \*\);';
+ c_fix = format;
+ c_fix_arg = '(const char *, const struct utimbuf *);';
+
+ test_text = "extern int utime(const char *, struct utimbuf *);";
};
@@ -1731,6 +1795,23 @@ fix = {
};
#endif
+
+/*
+ * Sony NEWSOS 5.0 does not support the complete ANSI C standard.
+ */
+#ifdef SONY
+fix = {
+ hackname = sony_stdio;
+ files = stdio.h;
+ test = " -x /bin/sony";
+ test = " ! -z \"`if /bin/sony ; then echo true ; fi`\"";
+ sed = "s/__filbuf/_filbuf/g\n"
+ "s/__flsbuf/_flsbuf/g\n"
+ "s/__iob/_iob/g";
+};
+#endif
+
+
/*
* Incorrect #include in Sony News-OS 3.2.
*/
@@ -1757,6 +1838,7 @@ fix = {
};
#endif
+
/*
* Add a `static' declaration of `getrnge' into <regexp.h>.
*
@@ -1780,10 +1862,12 @@ fix = {
* a missing semi-colon at the end of the statsswtch structure definition.
*/
fix = {
- hackname = statsswtch;
- files = rpcsvc/rstat.h;
- select = "boottime$";
- sed = "s/boottime$/boottime;/";
+ hackname = statsswtch;
+ files = rpcsvc/rstat.h;
+ select = "boottime$";
+ c_fix = format;
+ c_fix_arg = "boottime;";
+ test_text = "struct statswtch {\n int boottime\n};";
};
@@ -1895,28 +1979,17 @@ fix = {
/*
* Select those files containing '(*name)()'.
*/
- select = '\(\*[a-z][a-z_]*\)\(\)';
- sed = 's'
- '/^\(.*(\*[a-z][a-z_]*)(\)' '\();.*\)'
- "/\\\n"
- "#ifdef __cplusplus\\\n"
- '\1...\2' "\\\n"
- "#else\\\n"
- '\1\2' "\\\n"
- "#endif"
- "/";
-};
+ select = '\(\*[a-z][a-z_]*\)\(\)';
+ c_fix = format;
+ c_fix_arg = "#ifdef __cplusplus\n%1(...);%2\n"
+ "#else\n%1();%2\n#endif";
+ c_fix_arg = '(.*\(\*[a-z][a-z_]*\))\(\);(.*)';
-/*
- * Fix bogus #ifdef on SunOS 4.1.
- */
-fix = {
- hackname = sun_bogus_ifdef;
- files = "hsfs/hsfs_spec.h";
- files = "hsfs/iso_spec.h";
- select = '#ifdef __i386__ || __vax__';
- sed = "s/\\#ifdef __i386__ || __vax__/\\#if __i386__ || __vax__/g";
+ test_text =
+ "struct auth_t {\n"
+ " int (*name)(); /* C++ bad */\n"
+ "};";
};
@@ -1924,10 +1997,14 @@ fix = {
* Fix bogus #ifdef on SunOS 4.1.
*/
fix = {
- hackname = sun_bogus_ifdef_sun4c;
- files = "hsfs/hsnode.h";
- select = '#ifdef __i386__ || __sun4c__';
- sed = "s/\\#ifdef __i386__ || __sun4c__/\\#if __i386__ || __sun4c__/g";
+ hackname = sun_bogus_ifdef;
+ files = "hsfs/hsfs_spec.h";
+ files = "hsfs/iso_spec.h";
+ select = '#ifdef(.*\|\|.*)';
+ c_fix = format;
+ c_fix_arg = "#if%1";
+
+ test_text = "#ifdef __i386__ || __vax__ || __sun4c__";
};
@@ -1935,16 +2012,18 @@ fix = {
* Fix the CAT macro in SunOS memvar.h.
*/
fix = {
- hackname = sun_catmacro;
- files = pixrect/memvar.h;
- select = "^#define[ \t]+CAT\\(a,b\\)";
- sed = "/^#define[ \t]CAT(a,b)/ i\\\n"
- "#ifdef __STDC__ \\\n"
- "#define CAT(a,b) a##b\\\n"
- "#else\n";
+ hackname = sun_catmacro;
+ files = pixrect/memvar.h;
+ select = "^#define[ \t]+CAT\\(a,b\\).*";
+ c_fix = format;
- sed = "/^#define[ \t]CAT(a,b)/ a\\\n"
- "#endif\n";
+ c_fix_arg =
+ "#ifdef __STDC__\n"
+ "# define CAT(a,b) a##b\n"
+ "#else\n%0\n#endif";
+
+ test_text =
+ "#define CAT(a,b)\ta/**/b";
};
@@ -1960,6 +2039,12 @@ fix = {
sed = "s/int[ \t][ \t]*free/void\tfree/g";
sed = "s/char\\([ \t]*\\*[ \t]*malloc\\)/void\\1/g";
sed = "s/char\\([ \t]*\\*[ \t]*realloc\\)/void\\1/g";
+
+ test_text =
+ "typedef char *\tmalloc_t;\n"
+ "int \tfree();\n"
+ "char*\tmalloc();\n"
+ "char*\trealloc();";
};
@@ -1971,6 +2056,7 @@ fix = {
files = rpcsvc/rusers.h;
select = "_cnt$";
sed = "/^struct/,/^};/s/_cnt$/_cnt;/";
+ test_text = "struct mumble\n int _cnt\n};";
};
@@ -1982,15 +2068,15 @@ fix = {
hackname = sun_signal;
files = sys/signal.h;
files = signal.h;
- select = "^void\t" '\(\*signal\(\)\)\(\);';
+ select = "^void\t" '\(\*signal\(\)\)\(\);.*';
- sed = "/^void\t" '(\*signal())();$/i' "\\\n"
- "#ifdef __cplusplus" "\\\n"
- "void\t(*signal(...))(...);" "\\\n"
- "#else" "\n";
+ c_fix = format;
+ c_fix_arg =
+ "#ifdef __cplusplus\n"
+ "void\t(*signal(...))(...);\n"
+ "#else\n%0\n#endif";
- sed = "/^void\t" '(\*signal())();$/a' "\\\n"
- '#endif' "\n";
+ test_text = "void\t(*signal())();";
};
@@ -1999,16 +2085,17 @@ fix = {
* of struct exception, so the prototype (added by fixproto) causes havoc.
*/
fix = {
- hackname = sunos_matherr_decl;
- files = math.h;
+ hackname = sunos_matherr_decl;
+ files = math.h;
+
/* If matherr has a prototype already, the header needs no fix. */
- bypass = 'matherr.*struct exception';
- /*
- * Once a declaration for 'struct exception' is found,
- * stop trying to insert a forward reference for it.
- */
- sed = "/^struct exception/,$b";
- sed = "/matherr/i\\\nstruct exception;\n";
+ bypass = 'matherr.*struct exception';
+ select = matherr;
+
+ c_fix = wrap;
+ c_fix_arg = "struct exception;\n";
+
+ test_text = "extern int matherr();";
};
@@ -2018,8 +2105,10 @@ fix = {
fix = {
hackname = sunos_strlen;
files = strings.h;
- select = "int[ \t]*strlen";
- sed = "s/int[ \t]*strlen();/__SIZE_TYPE__ strlen();/";
+ select = "int[ \t]*strlen\\(\\);(.*)";
+ c_fix = format;
+ c_fix_arg = "__SIZE_TYPE__ strlen();%1";
+ test_text = " int\tstrlen(); /* string length */";
};
@@ -2028,16 +2117,17 @@ fix = {
* which conflicts with the fixproto definition. The fixproto
* definition and the Solaris definition are used the same way.
*/
-#ifdef SVR4
fix = {
hackname = svr4__p;
files = math.h;
files = floatingpoint.h;
- select = "^#define[ \t]*__P";
- sed = "/^#define[ \t]*__P/i\\\n#ifndef __P\n";
- sed = "/^#define[ \t]*__P/a\\\n#endif\n";
+ select = "^#define[ \t]+__P.*";
+ c_fix = format;
+ c_fix_arg = "#ifndef __P\n%0\n#endif";
+
+ test_text = "#define __P(a) a";
};
-#endif
+
/*
* Disable apparent native compiler optimization cruft in SVR4.2 <string.h>
@@ -2158,7 +2248,10 @@ fix = {
files = prototypes.h;
select = 'getcwd\(char \*, int\)';
- sed = 's/getcwd(char \*, int)/getcwd(char *, size_t)/';
+ c_fix = format;
+ c_fix_arg = "getcwd(char *, size_t)";
+
+ test_text = "extern char* getcwd(char *, int);";
};
@@ -2212,9 +2305,9 @@ fix = {
files = sys/mkdev.h;
select = '^static';
- sed = "/^dev_t makedev(/s/^/static /";
- sed = "/^major_t major(/s/^/static /";
- sed = "/^minor_t minor(/s/^/static /";
+ sed = "/^dev_t makedev(/s/^/static /";
+ sed = "/^major_t major(/s/^/static /";
+ sed = "/^minor_t minor(/s/^/static /";
};
#endif /* SVR5 */
@@ -2254,9 +2347,13 @@ fix = {
files = stdlib.h;
files = unistd.h;
- sed = 's/profil(unsigned short \*, unsigned int, '
- 'unsigned int, unsigned int)'
- '/profil(unsigned short *, size_t, int, unsigned)/';
+ select =
+ 'profil\(unsigned short \*, unsigned int, unsigned int, unsigned int\)';
+ c_fix = format;
+ c_fix_arg = 'profil(unsigned short *, size_t, int, unsigned int)';
+
+ test_text =
+ 'profil(unsigned short *, unsigned int, unsigned int, unsigned int);';
};
@@ -2417,15 +2514,15 @@ fix = {
hackname = systypes_stdlib_size_t;
files = sys/types.h;
files = stdlib.h;
- select = "typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t";
+ select = "typedef[ \t]+[A-Za-z_][ \tA-Za-z_]*[ \t]size_t.*";
bypass = "_(GCC|BSD)_SIZE_T";
- sed = "/typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t/i\\\n"
- "#ifndef _GCC_SIZE_T\\\n"
- "#define _GCC_SIZE_T\n";
+ c_fix = format;
+ c_fix_arg =
+ "#ifndef _GCC_SIZE_T\n"
+ "#define _GCC_SIZE_T\n%0\n#endif";
- sed = "/typedef[ \t][ \t]*[A-Za-z_][ \tA-Za-z_]*[ \t]size_t/a\\\n"
- "#endif\n";
+ test_text = "typedef unsigned int size_t; /* size of something */";
};
@@ -2455,19 +2552,21 @@ fix = {
/*
- * Fix return type of exit and abort in <stdlib.h>
+ * Fix return type of calloc, malloc, realloc, bsearch and exit
*/
fix = {
hackname = sysz_stdlib_for_sun;
files = stdlib.h;
- sed = "s/int\tabort/void\tabort/g";
- sed = "s/int\tfree/void\tfree/g";
- sed = "s/char[ \t]*\\*[ \t]*calloc/void \\*\tcalloc/g";
- sed = "s/char[ \t]*\\*[ \t]*malloc/void \\*\tmalloc/g";
- sed = "s/char[ \t]*\\*[ \t]*realloc/void \\*\trealloc/g";
- sed = "s/char[ \t]*\\*[ \t]*bsearch/void \\*\tbsearch/g";
- sed = "s/int[ \t][ \t]*exit/void\texit/g";
+ select = "char[ \t]*\\*[ \t]*(calloc|malloc|realloc|bsearch)[ \t]*\\(";
+ c_fix = format;
+ c_fix_arg = "void *\t%1(";
+
+ test_text =
+ "extern char*\tcalloc(size_t);\n"
+ "extern char*\tmalloc(size_t);\n"
+ "extern char*\trealloc(void*,size_t);\n"
+ "extern char*\tbsearch(void*,size_t,size_t);\n";
};