diff options
author | bothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4> | 1993-07-24 22:03:22 +0000 |
---|---|---|
committer | bothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4> | 1993-07-24 22:03:22 +0000 |
commit | dd19a1f4cf9a9d573e1c08a5b3936a7523c3ceb8 (patch) | |
tree | 389ccbd093746ef799486cce661e65e0e524c601 /gcc/fixincludes | |
parent | 779c10dbd3618f9ddb7a8bdad4c386fcec216dfb (diff) | |
download | ppe42-gcc-dd19a1f4cf9a9d573e1c08a5b3936a7523c3ceb8.tar.gz ppe42-gcc-dd19a1f4cf9a9d573e1c08a5b3936a7523c3ceb8.zip |
Fix some AIX and NeXT problems.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@4982 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fixincludes')
-rwxr-xr-x | gcc/fixincludes | 48 |
1 files changed, 44 insertions, 4 deletions
diff --git a/gcc/fixincludes b/gcc/fixincludes index 4ede9ff7d6f..1a2bdd39174 100755 --- a/gcc/fixincludes +++ b/gcc/fixincludes @@ -888,16 +888,56 @@ if [ -r ${LIB}/$file ]; then fi # parameters conflict with C++ new on rs/6000 -file=stdio.h +for file in stdio.h unistd.h ; do + if [ -r $file ] && [ ! -r ${LIB}/$file ]; then + cp $file ${LIB}/$file >/dev/null 2>&1 || echo "Can't copy $file" + chmod +w ${LIB}/$file 2>/dev/null + fi + + if [ -r ${LIB}/$file ]; then + echo Fixing $file, parameter name conflicts + sed -e 's@rename(const char \*old, const char \*new)@rename(const char *_old, const char *_new)@' \ + ${LIB}/$file > ${LIB}/${file}.sed + rm -f ${LIB}/$file; mv ${LIB}/${file}.sed ${LIB}/$file + if cmp $file ${LIB}/$file >/dev/null 2>&1; then + rm -f ${LIB}/$file + fi + fi +done + +# function class(double x) conflicts with C++ keyword on rs/6000 +file=math.h if [ -r $file ] && [ ! -r ${LIB}/$file ]; then cp $file ${LIB}/$file >/dev/null 2>&1 || echo "Can't copy $file" chmod +w ${LIB}/$file 2>/dev/null + chmod a+r ${LIB}/$file 2>/dev/null fi if [ -r ${LIB}/$file ]; then - echo Fixing $file, parameter name conflicts - sed -e 's@rename(const char \*old, const char \*new)@rename(const char *_old, const char *_new)@' \ - ${LIB}/$file > ${LIB}/${file}.sed + if grep 'class[(]' ${LIB}/$file >/dev/null; then + echo Fixing $file + sed -e '/class[(]/i\ +#ifndef __cplusplus' \ + -e '/class[(]/a\ +#endif' ${LIB}/$file > ${LIB}/${file}.sed + rm -f ${LIB}/$file; mv ${LIB}/${file}.sed ${LIB}/$file + if cmp $file ${LIB}/$file >/dev/null 2>&1; then + rm ${LIB}/$file + fi + fi +fi + +# NeXT defines 'int wait(union wait*)', which conflicts with Posix.1. +file=sys/wait.h +if [ -r $file ] && [ ! -r ${LIB}/$file ]; then + cp $file ${LIB}/$file >/dev/null 2>&1 || echo "Can't copy $file" + chmod +w ${LIB}/$file 2>/dev/null +fi + +if [ -r ${LIB}/$file ] \ + && grep 'wait[(]union wait' ${LIB}/$file >/dev/null; then + echo Fixing $file, bad wait formal + sed -e 's@wait(union wait@wait(void@' ${LIB}/$file > ${LIB}/${file}.sed rm -f ${LIB}/$file; mv ${LIB}/${file}.sed ${LIB}/$file if cmp $file ${LIB}/$file >/dev/null 2>&1; then rm -f ${LIB}/$file |