diff options
author | Richard Stallman <rms@gnu.org> | 1992-11-30 23:10:14 +0000 |
---|---|---|
committer | Richard Stallman <rms@gnu.org> | 1992-11-30 23:10:14 +0000 |
commit | fc5c2df84b591e28497656e3abfab28da1501933 (patch) | |
tree | 6197405d2be8daf64bf321d1ce047f995afbe7e5 /gcc/fixinc.svr4 | |
parent | 30c08fcc6b8b6823b156b1b4b23420b8b2715152 (diff) | |
download | gcc-fc5c2df84b591e28497656e3abfab28da1501933.zip gcc-fc5c2df84b591e28497656e3abfab28da1501933.tar.gz gcc-fc5c2df84b591e28497656e3abfab28da1501933.tar.bz2 |
(regexp.h): Don't add a getrnge declaration if a conflicting
declaration is already present.
From-SVN: r2823
Diffstat (limited to 'gcc/fixinc.svr4')
-rwxr-xr-x | gcc/fixinc.svr4 | 30 |
1 files changed, 19 insertions, 11 deletions
diff --git a/gcc/fixinc.svr4 b/gcc/fixinc.svr4 index cae39fc..b96b3de 100755 --- a/gcc/fixinc.svr4 +++ b/gcc/fixinc.svr4 @@ -467,6 +467,10 @@ fi # Add a `static' declaration of `getrnge' into <regexp.h>. +# Don't do this if there is already a `static void getrnge' declaration +# present, since this would cause a redeclaration error. Solaris 2.x has +# such a declaration. + file=regexp.h base=`basename $file` if [ -r ${LIB}/$file ]; then @@ -480,22 +484,26 @@ else fi if [ \! -z "$file_to_fix" ]; then echo Checking $file_to_fix - cp $file_to_fix /tmp/$base - chmod +w /tmp/$base - ex /tmp/$base <<EOF - /^static int[ ]*size;/c + if grep "static void getrnge" $file_to_fix > /dev/null; then + true + else + cp $file_to_fix /tmp/$base + chmod +w /tmp/$base + ex /tmp/$base <<EOF + /^static int[ ]*size;/c static int size ; static int getrnge (); . - wq + wq EOF - if cmp $file_to_fix /tmp/$base >/dev/null 2>&1; then \ - echo No change needed in $file_to_fix - else - echo Fixed $file_to_fix - rm -f ${LIB}/$file - cp /tmp/$base ${LIB}/$file + if cmp $file_to_fix /tmp/$base >/dev/null 2>&1; then \ + No change needed in $file_to_fix + else + echo Fixed $file_to_fix + rm -f ${LIB}/$file + cp /tmp/$base ${LIB}/$file + fi fi rm -f /tmp/$base fi |