summaryrefslogtreecommitdiff
path: root/gcc/fixinc/inclhack.sh
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/fixinc/inclhack.sh')
-rwxr-xr-xgcc/fixinc/inclhack.sh3086
1 files changed, 3086 insertions, 0 deletions
diff --git a/gcc/fixinc/inclhack.sh b/gcc/fixinc/inclhack.sh
new file mode 100755
index 0000000..9e993ea
--- /dev/null
+++ b/gcc/fixinc/inclhack.sh
@@ -0,0 +1,3086 @@
+#!/bin/sh
+#
+# DO NOT EDIT THIS FILE (inclhack.sh)
+#
+# It has been autogen-ed Friday October 16, 1998 at 07:29:49 AM PDT
+# From the definitions inclhack.def
+# and the template file inclhack.tpl
+#
+# Install modified versions of certain ANSI-incompatible system header
+# files which are fixed to work correctly with ANSI C and placed in a
+# directory that GNU C will search.
+#
+# This script contains 104 fixup scripts.
+#
+# See README-fixinc for more information.
+#
+# fixincludes is free software.
+#
+# You may redistribute it and/or modify it under the terms of the
+# GNU General Public License, as published by the Free Software
+# Foundation; either version 2, or (at your option) any later version.
+#
+# fixincludes is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+# See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with fixincludes. See the file "COPYING". If not,
+# write to: The Free Software Foundation, Inc.,
+# 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+#
+# # # # # # # # # # # # # # # # # # # # #
+#
+# Directory in which to store the results.
+# Fail if no arg to specify a directory for the output.
+if [ "x$1" = "x" ]
+then echo fixincludes: no output directory specified
+exit 1
+fi
+
+LIB=${1}
+shift
+
+# Make sure it exists.
+if [ ! -d $LIB ]; then
+ mkdir $LIB || {
+ echo fixincludes: output dir '`'$LIB"' cannot be created"
+ exit 1
+ }
+else
+ ( \cd $LIB && touch DONE && rm DONE ) || {
+ echo fixincludes: output dir '`'$LIB"' is an invalid directory"
+ exit 1
+ }
+fi
+
+# Define what target system we're fixing.
+#
+if test -r ./Makefile; then
+ target_canonical="`sed -n -e 's,^target[ ]*=[ ]*\(.*\)$,\1,p' < Makefile`"
+fi
+
+# If not from the Makefile, then try config.guess
+#
+if test -z "${target_canonical}" ; then
+ if test -x ./config.guess ; then
+ target_canonical="`config.guess`" ; fi
+ test -z "${target_canonical}" && target_canonical=unknown
+fi
+export target_canonical
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+# Define PWDCMD as a command to use to get the working dir
+# in the form that we want.
+PWDCMD=pwd
+
+case "`$PWDCMD`" in
+//*)
+ # On an Apollo, discard everything before `/usr'.
+ PWDCMD="eval pwd | sed -e 's,.*/usr/,/usr/,'"
+ ;;
+esac
+
+# Original directory.
+ORIGDIR=`${PWDCMD}`
+
+# Make LIB absolute only if needed to avoid problems with the amd.
+case $LIB in
+/*)
+ ;;
+*)
+ cd $LIB; LIB=`${PWDCMD}`
+ ;;
+esac
+
+echo Fixing headers into ${LIB} for ${target_canonical} target
+
+# Determine whether this system has symbolic links.
+if ln -s X $LIB/ShouldNotExist 2>/dev/null; then
+ rm -f $LIB/ShouldNotExist
+ LINKS=true
+elif ln -s X /tmp/ShouldNotExist 2>/dev/null; then
+ rm -f /tmp/ShouldNotExist
+ LINKS=true
+else
+ LINKS=false
+fi
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+# Search each input directory for broken header files.
+# This loop ends near the end of the file.
+#
+if test $# -eq 0
+then
+ INPUTLIST="/usr/include"
+else
+ INPUTLIST="$@"
+fi
+
+for INPUT in ${INPUTLIST} ; do
+
+cd ${ORIGDIR}
+
+cd ${INPUT} || {
+ echo 'fixincludes: input dir `'$INPUT"' is an invalid directory"
+ exit 1
+}
+
+#
+# # # # # # # # # # # # # # # # # # # # #
+#
+echo Finding directories and links to directories
+
+# Find all directories and all symlinks that point to directories.
+# Put the list in $files.
+# Each time we find a symlink, add it to newdirs
+# so that we do another find within the dir the link points to.
+# Note that $files may have duplicates in it;
+# later parts of this file are supposed to ignore them.
+dirs="."
+levels=2
+while [ -n "$dirs" ] && [ $levels -gt 0 ]
+do
+ levels=`expr $levels - 1`
+ newdirs=
+ for d in $dirs
+ do
+ echo " Searching $INPUT/$d"
+
+ # Find all directories under $d, relative to $d, excluding $d itself.
+ # (The /. is needed after $d in case $d is a symlink.)
+ files="$files `find $d/. -type d -print | \
+ sed -e '/\/\.$/d' -e 's@/./@/@g'`"
+ # Find all links to directories.
+ # Using `-exec test -d' in find fails on some systems,
+ # and trying to run test via sh fails on others,
+ # so this is the simplest alternative left.
+ # First find all the links, then test each one.
+ theselinks=
+ $LINKS && \
+ theselinks=`find $d/. -type l -print | sed -e 's@/./@/@g'`
+ for d1 in $theselinks --dummy--
+ do
+ # If the link points to a directory,
+ # add that dir to $newdirs
+ if [ -d $d1 ]
+ then
+ files="$files $d1"
+ if [ "`ls -ld $d1 | sed -n 's/.*-> //p'`" != "." ]
+ then
+ newdirs="$newdirs $d1"
+ fi
+ fi
+ done
+ done
+
+ dirs="$newdirs"
+done
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+dirs=
+echo "All directories (including links to directories):"
+echo $files
+
+for file in $files; do
+ rm -rf $LIB/$file
+ if [ ! -d $LIB/$file ]
+ then mkdir $LIB/$file
+ fi
+done
+mkdir $LIB/root
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+# treetops gets an alternating list
+# of old directories to copy
+# and the new directories to copy to.
+treetops="${INPUT} ${LIB}"
+
+if $LINKS; then
+ echo 'Making symbolic directory links'
+ for file in $files; do
+ dest=`ls -ld $file | sed -n 's/.*-> //p'`
+ if [ "$dest" ]; then
+ cwd=`${PWDCMD}`
+ # In case $dest is relative, get to $file's dir first.
+ cd ${INPUT}
+ cd `echo ./$file | sed -n 's&[^/]*$&&p'`
+ # Check that the target directory exists.
+ # Redirections changed to avoid bug in sh on Ultrix.
+ (cd $dest) > /dev/null 2>&1
+ if [ $? = 0 ]; then
+ cd $dest
+ # X gets the dir that the link actually leads to.
+ x=`${PWDCMD}`
+ # Canonicalize ${INPUT} now to minimize the time an
+ # automounter has to change the result of ${PWDCMD}.
+ cinput=`cd ${INPUT}; ${PWDCMD}`
+ # If a link points to ., make a similar link to .
+ if [ $x = ${cinput} ]; then
+ echo $file '->' . ': Making link'
+ rm -fr ${LIB}/$file > /dev/null 2>&1
+ ln -s . ${LIB}/$file > /dev/null 2>&1
+ # If link leads back into ${INPUT},
+ # make a similar link here.
+ elif expr $x : "${cinput}/.*" > /dev/null; then
+ # Y gets the actual target dir name, relative to ${INPUT}.
+ y=`echo $x | sed -n "s&${cinput}/&&p"`
+ # DOTS is the relative path from ${LIB}/$file's dir back to ${LIB}.
+ dots=`echo "$file" |
+ sed -e 's@^./@@' -e 's@/./@/@g' -e 's@[^/][^/]*@..@g' -e 's@..$@@'`
+ echo $file '->' $dots$y ': Making link'
+ rm -fr ${LIB}/$file > /dev/null 2>&1
+ ln -s $dots$y ${LIB}/$file > /dev/null 2>&1
+ else
+ # If the link is to a dir $target outside ${INPUT},
+ # repoint the link at ${INPUT}/root$target
+ # and process $target into ${INPUT}/root$target
+ # treat this directory as if it actually contained the files.
+ echo $file '->' root$x ': Making link'
+ if [ -d $LIB/root$x ]
+ then true
+ else
+ dirname=root$x/
+ dirmade=.
+ cd $LIB
+ while [ x$dirname != x ]; do
+ component=`echo $dirname | sed -e 's|/.*$||'`
+ mkdir $component >/dev/null 2>&1
+ cd $component
+ dirmade=$dirmade/$component
+ dirname=`echo $dirname | sed -e 's|[^/]*/||'`
+ done
+ fi
+ # Duplicate directory structure created in ${LIB}/$file in new
+ # root area.
+ for file2 in $files; do
+ case $file2 in
+ $file/*)
+ dupdir=${LIB}/root$x/`echo $file2 | sed -n "s|^${file}/||p"`
+ echo "Duplicating ${file}'s ${dupdir}"
+ if [ -d ${dupdir} ]
+ then true
+ else
+ mkdir ${dupdir}
+ fi
+ ;;
+ *)
+ ;;
+ esac
+ done
+ # Get the path from ${LIB} to $file, accounting for symlinks.
+ parent=`echo "$file" | sed -e 's@/[^/]*$@@'`
+ libabs=`cd ${LIB}; ${PWDCMD}`
+ file2=`cd ${LIB}; cd $parent; ${PWDCMD} | sed -e "s@^${libabs}@@"`
+ # DOTS is the relative path from ${LIB}/$file's dir back to ${LIB}.
+ dots=`echo "$file2" | sed -e 's@/[^/]*@../@g'`
+ rm -fr ${LIB}/$file > /dev/null 2>&1
+ ln -s ${dots}root$x ${LIB}/$file > /dev/null 2>&1
+ treetops="$treetops $x ${LIB}/root$x"
+ fi
+ fi
+ cd $cwd
+ fi
+ done
+fi
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+required=
+set x $treetops
+shift
+while [ $# != 0 ]; do
+ # $1 is an old directory to copy, and $2 is the new directory to copy to.
+ #
+ SRCDIR=`cd ${INPUT} ; cd $1 ; ${PWDCMD}`
+ export SRCDIR
+ shift
+
+ DESTDIR=`cd $1;${PWDCMD}`
+ export DESTDIR
+ shift
+
+ # The same dir can appear more than once in treetops.
+ # There's no need to scan it more than once.
+ #
+ if [ -f ${DESTDIR}/DONE ]
+ then continue ; fi
+
+ touch ${DESTDIR}/DONE
+ echo Fixing directory ${SRCDIR} into ${DESTDIR}
+
+ # Check .h files which are symlinks as well as those which are files.
+ # A link to a header file will not be processed by anything but this.
+ #
+ cd ${SRCDIR}
+
+ if $LINKS; then
+ files=`find . -name '*.h' \( -type f -o -type l \) -print`
+ else
+ files=`find . -name '*.h' -type f -print`
+ fi
+ echo Checking header files
+ for file in $files; do
+
+ if ( test ! -r $file -o \
+ -n "`fgrep 'This file is part of the GNU C Library' $file`" )
+ then continue ; fi
+
+ fixlist=""
+
+ #
+ # Fix 1: Aix_Syswait
+ #
+ case "$file" in ./sys/wait.h )
+ if ( test -n "`egrep 'bos325,' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ aix_syswait"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^extern pid_t wait3();$/i\
+struct rusage;
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 2: Aix_Volatile
+ #
+ case "$file" in ./sys/signal.h )
+ if ( test -n "`egrep 'typedef volatile int sig_atomic_t' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ aix_volatile"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/typedef volatile int sig_atomic_t/typedef int sig_atomic_t/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 3: Alpha_Getopt
+ #
+ case "$file" in ./stdio.h | \
+ ./stdlib.h )
+ if ( test -n "`egrep 'getopt\\(int, char \\*\\[' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ alpha_getopt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/getopt(int, char \*\[\],[ ]*char \*)/getopt(int, char *const[], const char *)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 4: Alpha_Parens
+ #
+ case "$file" in ./sym.h )
+ if ( test -n "`egrep '#ifndef\\(__mips64\\)' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ alpha_parens"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/#ifndef(__mips64)/#ifndef __mips64/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 5: Alpha_Sbrk
+ #
+ case "$file" in ./unistd.h )
+ if ( test -n "`egrep 'char[ ]*\\*[ ]*sbrk[ ]*\\(' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ alpha_sbrk"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/char\([ ]*\*[ ]*sbrk[ ]*(\)/void\1/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 6: Arm_Norcroft_Hint
+ #
+ case "$file" in ./X11/Intrinsic.h )
+ fixlist="${fixlist}
+ arm_norcroft_hint"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/___type p_type/p_type/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 7: Arm_Wchar
+ #
+ case "$file" in ./stdlib.h )
+ if ( test -n "`egrep '#[ ]*define[ ]*__wchar_t' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ arm_wchar"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/\(#[ ]*ifndef[ ]*\)__wchar_t/\1_GCC_WCHAR_T/' \
+ -e 's/\(#[ ]*define[ ]*\)__wchar_t/\1_GCC_WCHAR_T/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 8: Aux_Asm
+ #
+ case "$file" in ./sys/param.h )
+ if ( test -n "`egrep '#ifndef NOINLINE' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ aux_asm"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's|#ifndef NOINLINE|#if !defined(NOINLINE) \&\& !defined(__GNUC__)|' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 9: Avoid_Bool
+ #
+ case "$file" in ./curses.h | \
+ ./term.h | \
+ ./tinfo.h )
+ fixlist="${fixlist}
+ avoid_bool"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^#[ ]*define[ ][ ]*bool[ ][ ]*char[ ]*$/i\
+#ifndef __cplusplus
+' \
+ -e '/^#[ ]*define[ ][ ]*bool[ ][ ]*char[ ]*$/a\
+#endif
+' \
+ -e '/^typedef[ ][ ]*char[ ][ ]*bool[ ]*;/i\
+#ifndef __cplusplus
+' \
+ -e '/^typedef[ ][ ]*char[ ][ ]*bool[ ]*;/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 10: Bad_Malloc_Decl
+ #
+ case "$file" in ./rpc/types.h )
+ if ( test -z "`egrep '\"C\"' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ bad_malloc_decl"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+#ifdef __cplusplus\
+extern "C" {\
+#endif\
+
+' \
+ -e '$a\
+#ifdef __cplusplus\
+}\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 11: Bad_Struct_Term
+ #
+ case "$file" in ./curses.h )
+ if ( test -n "`egrep '^[ ]*typedef[ ]+struct[ ]+term[ ]*;' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ bad_struct_term"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^[ ]*typedef[ ][ ]*\(struct[ ][ ]*term[ ]*;[ ]*\)$/\1/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 12: Badquote
+ #
+ case "$file" in ./sundev/vuid_event.h )
+ fixlist="${fixlist}
+ badquote"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/doesn'\''t/does not/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 13: Bad_Lval
+ #
+ case "$file" in ./libgen.h | \
+ ./dirent.h | \
+ ./ftw.h | \
+ ./grp.h | \
+ ./ndbm.h | \
+ ./pthread.h | \
+ ./pwd.h | \
+ ./signal.h | \
+ ./standards.h | \
+ ./stdlib.h | \
+ ./string.h | \
+ ./stropts.h | \
+ ./time.h | \
+ ./unistd.h )
+ if ( test -n "`egrep '^[ ]*#[ ]*pragma[ ]extern_prefix' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ bad_lval"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^[ ]*#[ ]*define[ ]*\([^(]*\)\(([^)]*)\)[ ]*\(_.\)\1\2[ ]*$/#define \1 \3\1/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 14: Broken_Assert_Stdio
+ #
+ case "$file" in ./assert.h )
+ if ( test -n "`egrep 'stderr' $file`" -a \
+ -z "`egrep 'include.*stdio.h' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ broken_assert_stdio"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+#include <stdio.h>
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 15: Broken_Assert_Stdlib
+ #
+ case "$file" in ./assert.h )
+ if ( test -n "`egrep 'exit *\\(|abort *\\(' $file`" -a \
+ -z "`egrep 'include.*stdlib.h' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ broken_assert_stdlib"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+#ifdef __cplusplus\
+#include <stdlib.h>\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 16: Bsd43_Io_Macros
+ #
+ if ( test -n "`egrep 'BSD43__IO' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ bsd43_io_macros"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/[ ]BSD43__IO[A-Z]*[ ]*(/s/(\(.\),/('\''\1'\'',/' \
+ -e '/#[ ]*define[ ]*[ ]BSD43__IO/s/'\''\([cgx]\)'\''/\1/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 17: No_Double_Slash
+ #
+ if ( test -n "`egrep '//[^*]' $file`" -a \
+ '(' -z "`echo ${file}|egrep '++$|\.hh$|\.H$'`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ no_double_slash"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/\/\/[^*]/s|//.*$||g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 18: Irix_Bogus_Cxx_Cmnt
+ #
+ case "$file" in ./elf_abi.h | \
+ ./elf.h )
+ fixlist="${fixlist}
+ irix_bogus_cxx_cmnt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@"/\*"\*/@"//"@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 19: Ecd_Cursor
+ #
+ case "$file" in ./sunwindow/win_lock.h | \
+ ./sunwindow/win_cursor.h )
+ fixlist="${fixlist}
+ ecd_cursor"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/ecd.cursor/ecd_cursor/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 20: Else_Label
+ #
+ if ( test -n "`egrep '^[ ]*#[ ]*else[ ]+[!-.0-~]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ else_label"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e ':loop
+/\\$/N
+s/\\$/\\+++fixinc_eol+++/
+/\\$/b loop
+s/\\+++fixinc_eol+++/\\/g
+s%^\([ ]*#[ ]*else\)[ ]*/[^*].*%\1%
+s%^\([ ]*#[ ]*else\)[ ]*[^/ ].*%\1%' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 21: Endif_Label
+ #
+ if ( test -n "`egrep '^[ ]*#[ ]*endif[ ]+[!-.0-z{|}~]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ endif_label"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e ':loop
+/\\$/N
+s/\\$/\\+++fixinc_eol+++/
+/\\$/b loop
+s/\\+++fixinc_eol+++/\\/g
+s%^\([ ]*#[ ]*endif\)[ ]*/[^*].*%\1%
+s%^\([ ]*#[ ]*endif\)[ ]*\*[^/].*%\1%
+s%^\([ ]*#[ ]*endif\)[ ]*[^/* ].*%\1%' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 22: Hp_Inline
+ #
+ case "$file" in ./sys/spinlock.h )
+ if ( test -n "`egrep 'include.*\"\\.\\./machine/' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ hp_inline"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's,"../machine/inline.h",<machine/inline.h>,' \
+ -e 's,"../machine/psl.h",<machine/psl.h>,' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 23: Hp_Sysfile
+ #
+ case "$file" in ./sys/file.h )
+ if ( test -n "`egrep 'HPUX_SOURCE' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ hp_sysfile"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/(\.\.\.)/(struct file * ...)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 24: Hpux_Cxx_Unready
+ #
+ case "$file" in ./sys/mman.h )
+ if ( test -z "`egrep '\"C\"|__BEGIN_DECLS' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ hpux_cxx_unready"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+#ifdef __cplusplus\
+extern "C" {\
+#endif\
+
+' \
+ -e '$a\
+#ifdef __cplusplus\
+}\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 25: Hpux_Maxint
+ #
+ case "$file" in ./sys/param.h )
+ fixlist="${fixlist}
+ hpux_maxint"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^#[ ]*define[ ]*MAXINT[ ]/i\
+#ifndef MAXINT
+' \
+ -e '/^#[ ]*define[ ]*MAXINT[ ]/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 26: Hpux_Systime
+ #
+ case "$file" in ./sys/time.h )
+ if ( test -n "`egrep '^extern struct sigevent;' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ hpux_systime"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^extern struct sigevent;/struct sigevent;/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 27: Interactv_Add1
+ #
+ case "$file" in ./stdio.h | \
+ ./math.h | \
+ ./ctype.h | \
+ ./sys/limits.h | \
+ ./sys/fcntl.h | \
+ ./sys/dirent.h )
+ if ( test '(' -d /etc/conf/kconfig.d ')' -a \
+ '(' -n "`grep _POSIX_VERSION /usr/include/sys/unistd.h`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ interactv_add1"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/!defined(__STDC__) && !defined(_POSIX_SOURCE)/!defined(_POSIX_SOURCE)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 28: Interactv_Add2
+ #
+ case "$file" in ./math.h )
+ if ( test '(' -d /etc/conf/kconfig.d ')' -a \
+ '(' -n "`grep _POSIX_VERSION /usr/include/sys/unistd.h`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ interactv_add2"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/fmod(double)/fmod(double, double)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 29: Interactv_Add3
+ #
+ case "$file" in ./sys/limits.h )
+ if ( test '(' -d /etc/conf/kconfig.d ')' -a \
+ '(' -n "`grep _POSIX_VERSION /usr/include/sys/unistd.h`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ interactv_add3"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/CHILD_MAX/s,/\* Max, Max,' \
+ -e '/OPEN_MAX/s,/\* Max, Max,' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 30: Io_Def_Quotes
+ #
+ if ( test -n "`egrep '[ ]_IO[A-Z]*[ ]*\\([A-Za-z]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ io_def_quotes"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/\([ ]_IO[A-Z]*[ ]*(\)\([A-Za-z]\),/\1'\''\2'\'',/' \
+ -e '/#[ ]*define[ ]*[ ]_IO/s/'\''\([cgxtf]\)'\''/\1/g' \
+ -e '/#[ ]*define[ ]*[ ]DESIOC/s/'\''\([cdgx]\)'\''/\1/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 31: Ioctl_Fix_Ctrl
+ #
+ if ( test -n "`egrep 'CTRL[ ]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ ioctl_fix_ctrl"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/[^A-Z0-9_]CTRL[ ]*(/s/\([^'\'']\))/'\''\1'\'')/' \
+ -e '/[^A-Z0-9]_CTRL[ ]*(/s/\([^'\'']\))/'\''\1'\'')/' \
+ -e '/#[ ]*define[ ]*[ ]CTRL/s/'\''\([cgx]\)'\''/\1/g' \
+ -e '/#[ ]*define[ ]*[ ]_CTRL/s/'\''\([cgx]\)'\''/\1/g' \
+ -e '/#[ ]*define[ ]*[ ]BSD43_CTRL/s/'\''\([cgx]\)'\''/\1/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 32: Ip_Missing_Semi
+ #
+ case "$file" in ./netinet/ip.h )
+ fixlist="${fixlist}
+ ip_missing_semi"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^struct/,/^};/s/}$/};/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 33: Irix_Multiline_Cmnt
+ #
+ case "$file" in ./sys/types.h )
+ fixlist="${fixlist}
+ irix_multiline_cmnt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@type of the result@type of the result */@' \
+ -e 's@of the sizeof@/* of the sizeof@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 34: Irix_Sockaddr
+ #
+ case "$file" in ./rpc/auth.h )
+ if ( test -n "`egrep 'authdes_create.*struct sockaddr' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ irix_sockaddr"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/authdes_create.*struct sockaddr/i\
+struct sockaddr;
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 35: Irix_Struct__File
+ #
+ case "$file" in ./rpc/xdr.h )
+ fixlist="${fixlist}
+ irix_struct__file"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/xdrstdio_create.*struct __file_s/i\
+struct __file_s;
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 36: Isc_Fmod
+ #
+ case "$file" in ./math.h )
+ if ( test -n "`egrep 'fmod\\(double\\)' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ isc_fmod"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/fmod(double)/fmod(double, double)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 37: Motorola_Nested
+ #
+ case "$file" in ./limits.h | \
+ ./sys/limits.h )
+ fixlist="${fixlist}
+ motorola_nested"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@^\(#undef[ ][ ]*PIPE_BUF[ ]*/\* max # bytes atomic in write to a\)$@\1 */@' \
+ -e 's@\(/\*#define HUGE_VAL 3.40282346638528860e+38 \)\(/\*error value returned by Math lib\*/\)$@\1*/ \2@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 38: Isc_Sys_Limits
+ #
+ case "$file" in ./sys/limits.h )
+ if ( test -n "`egrep 'CHILD_MAX' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ isc_sys_limits"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/CHILD_MAX/s,/\* Max, Max,' \
+ -e '/OPEN_MAX/s,/\* Max, Max,' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 39: Kandr_Concat
+ #
+ case "$file" in ./sparc/asm_linkage.h | \
+ ./sun3/asm_linkage.h | \
+ ./sun3x/asm_linkage.h | \
+ ./sun4/asm_linkage.h | \
+ ./sun4c/asm_linkage.h | \
+ ./sun4m/asm_linkage.h | \
+ ./sun4c/debug/asm_linkage.h | \
+ ./sun4m/debug/asm_linkage.h | \
+ ./arm/as_support.h | \
+ ./arm/mc_type.h | \
+ ./arm/xcb.h | \
+ ./dev/chardefmac.h | \
+ ./dev/ps_irq.h | \
+ ./dev/screen.h | \
+ ./dev/scsi.h | \
+ ./sys/tty.h | \
+ ./Xm.acorn/XmP.h | \
+ ./bsd43/bsd43_.h )
+ if ( test -n "`egrep '/\\*\\*/' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ kandr_concat"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's|/\*\*/| ## |g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 40: Limits_Ifndefs
+ #
+ case "$file" in ./limits.h )
+ if ( test -z "`egrep 'ifndef[ ]+FLT_MIN' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ limits_ifndefs"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/[ ]FLT_MIN[ ]/i\
+#ifndef FLT_MIN
+' \
+ -e '/[ ]FLT_MIN[ ]/a\
+#endif
+' \
+ -e '/[ ]FLT_MAX[ ]/i\
+#ifndef FLT_MAX
+' \
+ -e '/[ ]FLT_MAX[ ]/a\
+#endif
+' \
+ -e '/[ ]FLT_DIG[ ]/i\
+#ifndef FLT_DIG
+' \
+ -e '/[ ]FLT_DIG[ ]/a\
+#endif
+' \
+ -e '/[ ]DBL_MIN[ ]/i\
+#ifndef DBL_MIN
+' \
+ -e '/[ ]DBL_MIN[ ]/a\
+#endif
+' \
+ -e '/[ ]DBL_MAX[ ]/i\
+#ifndef DBL_MAX
+' \
+ -e '/[ ]DBL_MAX[ ]/a\
+#endif
+' \
+ -e '/[ ]DBL_DIG[ ]/i\
+#ifndef DBL_DIG
+' \
+ -e '/[ ]DBL_DIG[ ]/a\
+#endif
+' \
+ -e '/^\(\/\*#define HUGE_VAL 3\.[0-9e+]* *\)\/\*/s//\1/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 41: Lynx_Void_Int
+ #
+ case "$file" in ./curses.h )
+ if ( test -n "`egrep '#[ ]*define[ ]+void[ ]+int' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ lynx_void_int"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/#[ ]*define[ ][ ]*void[ ]int/d' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 42: Lynxos_Fcntl_Proto
+ #
+ case "$file" in ./fcntl.h )
+ fixlist="${fixlist}
+ lynxos_fcntl_proto"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/\(fcntl.*(int, int, \)int)/\1...)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 43: M88k_Bad_Hypot_Opt
+ #
+ case "$file" in ./math.h )
+ case "$target_canonical" in m88k-motorola-sysv3* )
+ fixlist="${fixlist}
+ m88k_bad_hypot_opt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/extern double floor(), ceil(), fmod(), fabs();/extern double floor(), ceil(), fmod(), fabs _PARAMS((double));/' \
+ -e '/^extern double hypot();$/a\
+\/* Workaround a stupid Motorola optimization if one\
+ of x or y is 0.0 and the other is negative! *\/\
+#ifdef __STDC__\
+static __inline__ double fake_hypot (double x, double y)\
+#else\
+static __inline__ double fake_hypot (x, y)\
+ double x, y;\
+#endif\
+{\
+ return fabs (hypot (x, y));\
+}\
+#define hypot fake_hypot
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 44: M88k_Bad_S_If
+ #
+ case "$file" in ./sys/stat.h )
+ case "$target_canonical" in m88k-*-sysv3* )
+ if ( test -n "`egrep '#define[ ]+S_IS[A-Z]*(m)[ ]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ m88k_bad_s_if"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^\(#define[ ]*S_IS[A-Z]*(m)\)[ ]*(m[ ]*&[ ]*\(S_IF[A-Z][A-Z][A-Z][A-Z]*\)[ ]*)/\1 (((m)\&S_IFMT)==\2)/' \
+ -e 's/^\(#define[ ]*S_IS[A-Z]*(m)\)[ ]*(m[ ]*&[ ]*\(0[0-9]*\)[ ]*)/\1 (((m)\&S_IFMT)==\2)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 45: M88k_Multi_Incl
+ #
+ case "$file" in ./time.h )
+ case "$target_canonical" in m88k-tektronix-sysv3* )
+ if ( test -z "`egrep '#ifndef' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ m88k_multi_incl"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo Fixing $file, to protect against multiple inclusion. >&2
+ cpp_wrapper=`echo $file | sed -e 's,\.,_,g' -e 's,/,_,g'`
+ sed -e "1i\
+#ifndef __GCC_GOT_${cpp_wrapper}_\
+#define __GCC_GOT_${cpp_wrapper}_\
+" \
+ -e "$a\
+#endif /* ! __GCC_GOT_${cpp_wrapper}_ */
+" ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 46: Machine_Name
+ #
+ if ( test -n "`egrep '^#[ ]*(if|elif).*[^a-zA-Z0-9_](_*[MSRrhim]|[Mbimnpstuv])[a-zA-Z0-9_]' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ machine_name"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e ':loop
+/\\$/N
+s/\\$/\\+++fixinc_eol+++/
+/\\$/b loop
+s/\\+++fixinc_eol+++/\\/g
+/#[ ]*[el]*if/ {
+ s/[a-zA-Z0-9_][a-zA-Z0-9_]*/ & /g
+ s/ M32 / __M32__ /g
+ s/ _*MIPSE\([LB]\) / __MIPSE\1__ /g
+ s/ _*SYSTYPE_\([A-Z0-9]*\) / __SYSTYPE_\1__ /g
+ s/ _*\([Rr][34]\)000 / __\1000__ /g
+ s/ _*host_mips / __host_mips__ /g
+ s/ _*i386 / __i386__ /g
+ s/ _*mips / __mips__ /g
+ s/ bsd4\([0-9]\) / __bsd4\1__ /g
+ s/ is68k / __is68k__ /g
+ s/ m68k / __m68k__ /g
+ s/ m88k / __m88k__ /g
+ s/ mc680\([0-9]\)0 / __mc680\10__ /g
+ s/ news\([0-9]*\) / __news\1__ /g
+ s/ ns32000 / __ns32000__ /g
+ s/ pdp11 / __pdp11__ /g
+ s/ pyr / __pyr__ /g
+ s/ sel / __sel__ /g
+ s/ sony_news / __sony_news__ /g
+ s/ sparc / __sparc__ /g
+ s/ sun\([a-z0-9]*\) / __sun\1__ /g
+ s/ tahoe / __tahoe__ /g
+ s/ tower\([_0-9]*\) / __tower\1__ /g
+ s/ u370 / __u370__ /g
+ s/ u3b\([0-9]*\) / __u3b\1__ /g
+ s/ unix / __unix__ /g
+ s/ vax / __vax__ /g
+ s/ \([a-zA-Z0-9_][a-zA-Z0-9_]*\) /\1/g
+ }' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 47: Math_Exception
+ #
+ case "$file" in ./math.h )
+ if ( test -n "`egrep 'struct exception' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ math_exception"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/struct exception/i\
+#ifdef __cplusplus\
+#define exception __math_exception\
+#endif
+' \
+ -e '/struct exception/a\
+#ifdef __cplusplus\
+#undef exception\
+#endif
+' \
+ -e '/matherr/i\
+#ifdef __cplusplus\
+#define exception __math_exception\
+#endif
+' \
+ -e '/matherr/a\
+#ifdef __cplusplus\
+#undef exception\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 48: Math_Gcc_Ifndefs
+ #
+ case "$file" in ./math.h )
+ fixlist="${fixlist}
+ math_gcc_ifndefs"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( dbl_max_def="`egrep 'define[ ]+DBL_MAX[ ]+.*' ${SRCDIR}/float.h 2>/dev/null`"
+
+ if ( test -n "${dbl_max_def}" \
+ -a -n "`egrep '#define[ ]*HUGE_VAL[ ]+DBL_MAX' $file`" \
+ -a -z "`egrep '#define[ ]+DBL_MAX[ ]+' $file`"
+ ) > /dev/null 2>&1
+ then sed -e '/define[ ]HUGE_VAL[ ]/i\
+#ifndef HUGE_VAL
+' \
+ -e '/define[ ]HUGE_VAL[ ]/a\
+#endif
+'\
+ -e "/define[ ]HUGE_VAL[ ]DBL_MAX/s/DBL_MAX/$dbl_max_def/"
+ else sed -e '/define[ ]HUGE_VAL[ ]/i\
+#ifndef HUGE_VAL
+' \
+ -e '/define[ ]HUGE_VAL[ ]/a\
+#endif
+'
+ fi ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 49: Motorola_Stupid_Opt
+ #
+ case "$file" in ./math.h )
+ case "$target_canonical" in m88k-motorola-sysv3* )
+ if ( test -n "`egrep '^extern double hypot();$' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ motorola_stupid_opt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^extern double hypot();$/a\
+\/* Workaround a stupid Motorola optimization if one\
+ of x or y is 0.0 and the other is negative! *\/\
+#ifdef __STDC__\
+static __inline__ double fake_hypot (double x, double y)\
+#else\
+static __inline__ double fake_hypot (x, y)\
+ double x, y;\
+#endif\
+{\
+ return fabs (hypot (x, y));\
+}\
+#define hypot fake_hypot
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 50: Nested_Comment
+ #
+ case "$file" in ./rpc/rpc.h )
+ fixlist="${fixlist}
+ nested_comment"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@^\(/\*.*rpc/auth_des.h>.*\)/\*@\1*/ /*@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 51: News_Os_Recursion
+ #
+ case "$file" in ./stdlib.h )
+ if ( test -n "`egrep '#include <stdlib.h>' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ news_os_recursion"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^#include <stdlib.h>/i\
+#ifdef BOGUS_RECURSION
+' \
+ -e '/^#include <stdlib.h>/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 52: Next_Math_Prefix
+ #
+ case "$file" in ./ansi/math.h )
+ if ( test -n "`egrep '^extern.*double.*__const__.*' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ next_math_prefix"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^extern.*double.*__const__.*sqrt(/s/__const__//' \
+ -e '/^extern.*double.*__const__.*fabs(/s/__const__//' \
+ -e '/^extern.*double.*__const__.*cos(/s/__const__//' \
+ -e '/^extern.*double.*__const__.*hypot(/s/__const__//' \
+ -e '/^extern.*double.*__const__.*sin(/s/__const__//' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 53: Next_Template
+ #
+ case "$file" in ./bsd/libc.h )
+ if ( test -n "`egrep 'template' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ next_template"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/\(.*template\)/s/template//' \
+ -e '/extern.*volatile.*void.*abort/s/volatile//' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 54: Next_Volitile
+ #
+ case "$file" in ./ansi/stdlib.h )
+ if ( test -n "`egrep 'volatile' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ next_volitile"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/extern.*volatile.*void.*exit/s/volatile//' \
+ -e '/extern.*volatile.*void.*abort/s/volatile//' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 55: Next_Wait_Union
+ #
+ case "$file" in ./sys/wait.h )
+ if ( test -n "`egrep 'wait\\(union wait' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ next_wait_union"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@wait(union wait@wait(void@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 56: Nodeent_Syntax
+ #
+ case "$file" in ./netdnet/dnetdb.h )
+ fixlist="${fixlist}
+ nodeent_syntax"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/char.*na_addr *$/char *na_addr;/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 57: Osf_Namespace_A
+ #
+ case "$file" in ./reg_types.h | \
+ ./sys/lc_core.h )
+ if ( test '(' -r reg_types.h-a -r sys/lc_core.h-a -n "`grep '} regex_t;' reg_types.h`"-a -z "`grep __regex_t regex.h`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ osf_namespace_a"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/regex_t/__regex_t/g' \
+ -e 's/regoff_t/__regoff_t/g' \
+ -e 's/regmatch_t/__regmatch_t/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 58: Osf_Namespace_B
+ #
+ case "$file" in ./regex.h )
+ if ( test '(' -r reg_types.h-a -r sys/lc_core.h-a -n "`grep '} regex_t;' reg_types.h`"-a -z "`grep __regex_t regex.h`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ osf_namespace_b"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/#include <reg_types.h>/a\
+typedef __regex_t regex_t;\
+typedef __regoff_t regoff_t;\
+typedef __regmatch_t regmatch_t;
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 59: Pthread_Page_Size
+ #
+ case "$file" in ./pthread.h )
+ if ( test -n "`egrep '^int __page_size' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ pthread_page_size"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^int __page_size/extern int __page_size/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 60: Rs6000_Double
+ #
+ case "$file" in ./math.h )
+ if ( test -n "`egrep '[^a-zA-Z_]class\\(' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ rs6000_double"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/class[(]/i\
+#ifndef __cplusplus
+' \
+ -e '/class[(]/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 61: Rs6000_Fchmod
+ #
+ case "$file" in ./sys/stat.h )
+ if ( test -n "`egrep 'fchmod\\(char' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ rs6000_fchmod"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/fchmod(char \*/fchmod(int/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 62: Rs6000_Param
+ #
+ case "$file" in ./stdio.h | \
+ ./unistd.h )
+ fixlist="${fixlist}
+ rs6000_param"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@rename(const char \*old, const char \*new)@rename(const char *_old, const char *_new)@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 63: Sony_Include
+ #
+ case "$file" in ./machine/machparam.h )
+ if ( test -n "`egrep '\"\\.\\./machine/endian.h\"' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sony_include"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@"../machine/endian.h"@<machine/endian.h>@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 64: Statsswtch
+ #
+ case "$file" in ./rpcsvc/rstat.h )
+ if ( test -n "`egrep 'boottime$' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ statsswtch"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/boottime$/boottime;/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 65: Stdio_Va_List
+ #
+ case "$file" in ./stdio.h )
+ fixlist="${fixlist}
+ stdio_va_list"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( if ( egrep "__need___va_list" $file ) > /dev/null 2>&1 ; then
+ :
+ else
+ echo "#define __need___va_list"
+ echo "#include <stdarg.h>"
+ fi
+
+ sed -e 's@ va_list @ __gnuc_va_list @' \
+ -e 's@ va_list)@ __gnuc_va_list)@' \
+ -e 's@ _BSD_VA_LIST_));@ __gnuc_va_list));@' \
+ -e 's@ _VA_LIST_));@ __gnuc_va_list));@' \
+ -e 's@ va_list@ __va_list__@' \
+ -e 's@\*va_list@*__va_list__@' \
+ -e 's@ __va_list)@ __gnuc_va_list)@' \
+ -e 's@GNUC_VA_LIST@GNUC_Va_LIST@' \
+ -e 's@_NEED___VA_LIST@_NEED___Va_LIST@' \
+ -e 's@VA_LIST@DUMMY_VA_LIST@' \
+ -e 's@_Va_LIST@_VA_LIST@' ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 66: Sun_Bogus_Ifdef
+ #
+ case "$file" in ./hsfs/hsfs_spec.h | \
+ ./hsfs/iso_spec.h )
+ if ( test -n "`egrep '#ifdef __i386__ || __vax__' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_bogus_ifdef"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/\#ifdef __i386__ || __vax__/\#if __i386__ || __vax__/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 67: Sun_Bogus_Ifdef_Sun4c
+ #
+ case "$file" in ./hsfs/hsnode.h )
+ if ( test -n "`egrep '#ifdef __i386__ || __sun4c__' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_bogus_ifdef_sun4c"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/\#ifdef __i386__ || __sun4c__/\#if __i386__ || __sun4c__/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 68: Sun_Catmacro
+ #
+ case "$file" in ./pixrect/memvar.h )
+ if ( test -n "`egrep '^#define[ ]+CAT(a,b)' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_catmacro"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^#define[ ]CAT(a,b)/ i\
+#ifdef __STDC__ \
+#define CAT(a,b) a##b\
+#else
+' \
+ -e '/^#define[ ]CAT(a,b)/ a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 69: Sun_Malloc
+ #
+ case "$file" in ./malloc.h )
+ fixlist="${fixlist}
+ sun_malloc"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/typedef[ ]char \* malloc_t/typedef void \* malloc_t/g' \
+ -e 's/int[ ][ ]*free/void free/g' \
+ -e 's/char\([ ]*\*[ ]*malloc\)/void\1/g' \
+ -e 's/char\([ ]*\*[ ]*realloc\)/void\1/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 70: Sun_Memcpy
+ #
+ case "$file" in ./memory.h )
+ if ( test -n "`egrep '/\\* @\\(#\\)(head/memory.h 50.1 |memory\\.h 1\\.[2-4] 8./../.. SMI; from S5R2 1\\.2 )\\*/' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_memcpy"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+/* This file was generated by fixincludes */\
+#ifndef __memory_h__\
+#define __memory_h__\
+\
+#ifdef __STDC__\
+extern void *memccpy();\
+extern void *memchr();\
+extern void *memcpy();\
+extern void *memset();\
+#else\
+extern char *memccpy();\
+extern char *memchr();\
+extern char *memcpy();\
+extern char *memset();\
+#endif /* __STDC__ */\
+\
+extern int memcmp();\
+\
+#endif /* __memory_h__ */
+' \
+ -e '1,$d' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 71: Sun_Rusers_Semi
+ #
+ case "$file" in ./rpcsvc/rusers.h )
+ if ( test -n "`egrep '_cnt$' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_rusers_semi"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^struct/,/^};/s/_cnt$/_cnt;/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 72: Sun_Signal
+ #
+ case "$file" in ./sys/signal.h | \
+ ./signal.h )
+ if ( test -n "`egrep '^void \\(\\*signal\\(\\)\\)\\(\\);' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_signal"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^void (\*signal())();$/i\
+#ifdef __cplusplus\
+void (*signal(...))(...);\
+#else
+' \
+ -e '/^void (\*signal())();$/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 73: Sun_Auth_Proto
+ #
+ case "$file" in ./rpc/auth.h | \
+ ./rpc/clnt.h | \
+ ./rpc/svc.h | \
+ ./rpc/xdr.h )
+ case "$target_canonical" in *-sun-* )
+ if ( test -n "`egrep '\\(\\*[a-z][a-z_]*\\)\\(\\)' $file`" -a \
+ -z "`egrep '\\(\\*[a-z][a-z_]*\\)\\([ ]*[a-zA-Z.].*\\)' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sun_auth_proto"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^\(.*(\*[a-z][a-z_]*)(\)\();.*\)/\
+#ifdef __cplusplus\
+\1...\2\
+#else\
+\1\2\
+#endif/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 74: Sunos_Large_Macro
+ #
+ case "$file" in ./sundev/ipi_error.h )
+ fixlist="${fixlist}
+ sunos_large_macro"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to SunOS <sundev/ipi_error.h>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 75: Sunos_Matherr_Decl
+ #
+ case "$file" in ./math.h )
+ if ( test '(' "`fgrep 'struct exception' $file | line`" != 'struct exception {' ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ sunos_matherr_decl"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/matherr/i\
+struct exception;
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 76: Sunos_Strlen
+ #
+ case "$file" in ./strings.h )
+ fixlist="${fixlist}
+ sunos_strlen"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/int[ ]*strlen();/__SIZE_TYPE__ strlen();/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 77: Systypes
+ #
+ case "$file" in ./sys/types.h | \
+ ./stdlib.h | \
+ ./sys/stdtypes.h | \
+ ./stddef.h | \
+ ./memory.h | \
+ ./unistd.h )
+ if ( test -n "`egrep 'typedef[ ]+[a-z_][ a-z_]*[ ](size|ptrdiff|wchar)_t' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ systypes"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^[ ]*\*[ ]*typedef unsigned int size_t;/N' \
+ -e 's/^\([ ]*\*[ ]*typedef unsigned int size_t;\n[ ]*\*\/\)/\1\
+#ifndef __SIZE_TYPE__\
+#define __SIZE_TYPE__ long unsigned int\
+#endif\
+typedef __SIZE_TYPE__ size_t;\
+/' \
+ -e '/typedef[ ][ ]*[a-z_][ a-z_]*[ ]size_t/i\
+#ifndef __SIZE_TYPE__\
+#define __SIZE_TYPE__ long unsigned int\
+#endif
+' \
+ -e 's/typedef[ ][ ]*[a-z_][ a-z_]*[ ]size_t/typedef __SIZE_TYPE__ size_t/' \
+ -e '/typedef[ ][ ]*[a-z_][ a-z_]*[ ]ptrdiff_t/i\
+#ifndef __PTRDIFF_TYPE__\
+#define __PTRDIFF_TYPE__ long int\
+#endif
+' \
+ -e 's/typedef[ ][ ]*[a-z_][ a-z_]*[ ]ptrdiff_t/typedef __PTRDIFF_TYPE__ ptrdiff_t/' \
+ -e '/typedef[ ][ ]*[a-z_][ a-z_]*[ ]wchar_t/i\
+#ifndef __WCHAR_TYPE__\
+#define __WCHAR_TYPE__ int\
+#endif\
+#ifndef __cplusplus
+' \
+ -e '/typedef[ ][ ]*[a-z_][ a-z_]*[ ]wchar_t/a\
+#endif
+' \
+ -e 's/typedef[ ][ ]*[a-z_][ a-z_]*[ ]wchar_t/typedef __WCHAR_TYPE__ wchar_t/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 78: Systypes_For_Aix
+ #
+ case "$file" in ./sys/types.h )
+ if ( test -n "`egrep 'typedef[ ][ ]*[A-Za-z_][ A-Za-z_]*[ ]size_t' $file`" -a \
+ -z "`egrep '_GCC_SIZE_T' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ systypes_for_aix"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/typedef[ ][ ]*[A-Za-z_][ A-Za-z_]*[ ]size_t/i\
+#ifndef _GCC_SIZE_T\
+#define _GCC_SIZE_T
+' \
+ -e '/typedef[ ][ ]*[A-Za-z_][ A-Za-z_]*[ ]size_t/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 79: Sysv68_String
+ #
+ case "$file" in ./string.h )
+ fixlist="${fixlist}
+ sysv68_string"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/extern[ ]*int[ ]*strlen();/extern unsigned int strlen();/' \
+ -e 's/extern[ ]*int[ ]*ffs[ ]*(long);/extern int ffs(int);/' \
+ -e 's/strdup(char \*s1);/strdup(const char *s1);/' \
+ -e '/^extern char$/N' \
+ -e 's/^extern char\(\n \*memccpy(),\)$/extern void\1/' \
+ -e '/^ strncmp(),$/N' \
+ -e 's/^\( strncmp()\),\n\( strlen(),\)$/\1;\
+extern unsigned int\
+\2/' \
+ -e '/^extern int$/N' \
+ -e 's/^extern int\(\n strlen(),\)/extern size_t\1/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 80: Sysz_Stdlib_For_Sun
+ #
+ case "$file" in ./stdlib.h )
+ case "$target_canonical" in *-sun-* | \
+ m88k-*-sysv3* )
+ fixlist="${fixlist}
+ sysz_stdlib_for_sun"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/int abort/void abort/g' \
+ -e 's/int free/void free/g' \
+ -e 's/char[ ]*\*[ ]*calloc/void \* calloc/g' \
+ -e 's/char[ ]*\*[ ]*malloc/void \* malloc/g' \
+ -e 's/char[ ]*\*[ ]*realloc/void \* realloc/g' \
+ -e 's/int[ ][ ]*exit/void exit/g' \
+ -e '/typedef[ a-zA-Z_]*[ ]size_t[ ]*;/i\
+#ifndef _GCC_SIZE_T\
+#define _GCC_SIZE_T
+' \
+ -e '/typedef[ a-zA-Z_]*[ ]size_t[ ]*;/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for machine type test
+ esac
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 81: Sysz_Stdtypes_For_Sun
+ #
+ case "$file" in ./sys/stdtypes.h )
+ fixlist="${fixlist}
+ sysz_stdtypes_for_sun"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/[ ]size_t.*;/i\
+#ifndef _GCC_SIZE_T\
+#define _GCC_SIZE_T
+' \
+ -e '/[ ]size_t.*;/a\
+#endif
+' \
+ -e '/[ ]ptrdiff_t.*;/i\
+#ifndef _GCC_PTRDIFF_T\
+#define _GCC_PTRDIFF_T
+' \
+ -e '/[ ]ptrdiff_t.*;/a\
+#endif
+' \
+ -e '/[ ]wchar_t.*;/i\
+#ifndef _GCC_WCHAR_T\
+#define _GCC_WCHAR_T
+' \
+ -e '/[ ]wchar_t.*;/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 82: Tinfo_Cplusplus
+ #
+ case "$file" in ./tinfo.h )
+ fixlist="${fixlist}
+ tinfo_cplusplus"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/[ ]_cplusplus/ __cplusplus/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 83: Ultrix_Ansi_Compat
+ #
+ case "$file" in ./ansi_compat.h )
+ if ( test -n "`egrep 'ULTRIX' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ ultrix_ansi_compat"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '1i\
+/* This file intentionally left blank. */
+' \
+ -e '1,$d' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 84: Ultrix_Atof_Param
+ #
+ case "$file" in ./math.h )
+ fixlist="${fixlist}
+ ultrix_atof_param"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@atof(\([ ]*char[ ]*\*[^)]*\))@atof(const \1)@' \
+ -e 's@inline int abs(int [a-z][a-z]*) {.*}@extern "C" int abs(int);@' \
+ -e 's@inline double abs(double [a-z][a-z]*) {.*}@@' \
+ -e 's@inline int sqr(int [a-z][a-z]*) {.*}@@' \
+ -e 's@inline double sqr(double [a-z][a-z]*) {.*}@@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 85: Ultrix_Const
+ #
+ case "$file" in ./stdio.h )
+ fixlist="${fixlist}
+ ultrix_const"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@perror( char \*__s );@perror( const char *__s );@' \
+ -e 's@fputs( char \*__s,@fputs( const char *__s,@' \
+ -e 's@fopen( char \*__filename, char \*__type );@fopen( const char *__filename, const char *__type );@' \
+ -e 's@fwrite( void \*__ptr,@fwrite( const void *__ptr,@' \
+ -e 's@fscanf( FILE \*__stream, char \*__format,@fscanf( FILE *__stream, const char *__format,@' \
+ -e 's@scanf( char \*__format,@scanf( const char *__format,@' \
+ -e 's@sscanf( char \*__s, char \*__format,@sscanf( const char *__s, const char *__format,@' \
+ -e 's@popen(char \*, char \*);@popen(const char *, const char *);@' \
+ -e 's@tempnam(char\*,char\*);@tempnam(const char*,const char*);@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 86: Ultrix_Ifdef
+ #
+ case "$file" in ./sys/file.h )
+ if ( test -n "`egrep '#ifdef KERNEL' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ ultrix_ifdef"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/#ifdef KERNEL/#if defined(KERNEL)/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 87: Ultrix_Nested_Cmnt
+ #
+ case "$file" in ./rpc/svc.h )
+ fixlist="${fixlist}
+ ultrix_nested_cmnt"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's@^\( \* int protocol; \)/\*@\1*/ /*@' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 88: Ultrix_Static
+ #
+ case "$file" in ./machine/cpu.h )
+ if ( test -n "`egrep '#include \"r[34]_cpu' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ ultrix_static"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^static struct tlb_pid_state/struct tlb_pid_state/' \
+ -e 's/^#include "r3_cpu\.h"$/#include <machine\/r3_cpu\.h>/' \
+ -e 's/^#include "r4_cpu\.h"$/#include <machine\/r4_cpu\.h>/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 89: Undefine_Null
+ #
+ if ( test -n "`egrep '^#[ ]*define[ ]*[ ]NULL[ ]' $file`" -a \
+ -z "`egrep '#[ ]*(ifn|un)def[ ]*[ ]NULL($|[ ])' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ undefine_null"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/^#[ ]*define[ ][ ]*NULL[ ]/i\
+#undef NULL
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+
+
+ #
+ # Fix 90: Va_I960_Macro
+ #
+ case "$file" in ./arch/i960/archI960.h )
+ if ( test -n "`egrep '__(vsiz|vali|vpad|alignof__)' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ va_i960_macro"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/__vsiz/__vxvsiz/' \
+ -e 's/__vali/__vxvali/' \
+ -e 's/__vpad/__vxvpad/' \
+ -e 's/__alignof__/__vxalignof__/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 91: Void_Null
+ #
+ case "$file" in ./curses.h | \
+ ./dbm.h | \
+ ./locale.h | \
+ ./stdio.h | \
+ ./stdlib.h | \
+ ./string.h | \
+ ./time.h | \
+ ./unistd.h | \
+ ./sys/dir.h | \
+ ./sys/param.h | \
+ ./sys/types.h )
+ if ( test -n "`egrep '#[ ]*define[ ][ ]*NULL[ ].*void' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ void_null"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/^#[ ]*define[ ]*NULL[ ]*((void[ ]*\*)0)/#define NULL 0/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 92: Vxworks_Gcc_Problem
+ #
+ case "$file" in ./types/vxTypesBase.h )
+ if ( test -n "`egrep '__GNUC_TYPEOF_FEATURE_BROKEN_USE_DEFAULT_UNTIL_FIXED__' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ vxworks_gcc_problem"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/#ifdef __GNUC_TYPEOF_FEATURE_BROKEN_USE_DEFAULT_UNTIL_FIXED__/#if 1/' \
+ -e '/[ ]size_t/i\
+#ifndef _GCC_SIZE_T\
+#define _GCC_SIZE_T
+' \
+ -e '/[ ]size_t/a\
+#endif
+' \
+ -e '/[ ]ptrdiff_t/i\
+#ifndef _GCC_PTRDIFF_T\
+#define _GCC_PTRDIFF_T
+' \
+ -e '/[ ]ptrdiff_t/a\
+#endif
+' \
+ -e '/[ ]wchar_t/i\
+#ifndef _GCC_WCHAR_T\
+#define _GCC_WCHAR_T
+' \
+ -e '/[ ]wchar_t/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 93: Vxworks_Needs_Vxtypes
+ #
+ case "$file" in ./time.h )
+ if ( test -n "`egrep 'uint_t[ ][ ]*_clocks_per_sec' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ vxworks_needs_vxtypes"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/uint_t/unsigned int/' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 94: Vxworks_Needs_Vxworks
+ #
+ case "$file" in ./sys/stat.h )
+ if ( test -n "`egrep '#[ ]define[ ][ ]*__INCstath' $file`" -a \
+ '(' -r types/vxTypesOld.h ')' -a \
+ '(' -n "`fgrep '#include' $file`" ')' -a \
+ '(' -n "`fgrep ULONG $file`" ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ vxworks_needs_vxworks"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/#[ ]define[ ][ ]*__INCstath/a\
+#include <types/vxTypesOld.h>
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 95: Vxworks_Time
+ #
+ case "$file" in ./time.h )
+ if ( test -n "`egrep 'VOIDFUNCPTR' $file`" -a \
+ '(' -r vxWorks.h ')'
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ vxworks_time"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/VOIDFUNCPTR/i\
+#ifndef __gcc_VOIDFUNCPTR_defined\
+#ifdef __cplusplus\
+typedef void (*__gcc_VOIDFUNCPTR) (...);\
+#else\
+typedef void (*__gcc_VOIDFUNCPTR) ();\
+#endif\
+#define __gcc_VOIDFUNCPTR_defined\
+#endif
+' \
+ -e 's/VOIDFUNCPTR/__gcc_VOIDFUNCPTR/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 96: X11_Class
+ #
+ case "$file" in ./X11/ShellP.h )
+ if ( test -z "`egrep '__cplusplus' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ x11_class"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/char \*class;/i\
+#ifdef __cplusplus\
+ char *c_class;\
+#else
+' \
+ -e '/char \*class;/a\
+#endif
+' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 97: X11_Class_Usage
+ #
+ case "$file" in ./Xm/BaseClassI.h )
+ if ( test -z "`egrep '__cplusplus' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ x11_class_usage"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's/ class[)]/ c_class)/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 98: X11_New
+ #
+ case "$file" in ./Xm/Traversal.h )
+ if ( test -z "`egrep '__cplusplus' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ x11_new"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e '/Widget old, new;/i\
+#ifdef __cplusplus\
+ Widget old, c_new;\
+#else
+' \
+ -e '/Widget old, new;/a\
+#endif
+' \
+ -e 's/Widget new,/Widget c_new,/g' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 99: X11_Sprintf
+ #
+ case "$file" in ./X11*/Xmu.h )
+ fixlist="${fixlist}
+ x11_sprintf"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+
+ sed -e 's,^extern char \* sprintf();$,#ifndef __STDC__\
+extern char * sprintf();\
+#endif /* !defined __STDC__ */,' \
+ < $infile > ${DESTDIR}/$file.
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 100: Zzz_Ki_Iface
+ #
+ case "$file" in ./sys/ki_iface.h )
+ if ( test -n "`egrep 'These definitions are for HP Internal developers' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ zzz_ki_iface"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to HP-UX <$file>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 101: Zzz_Ki
+ #
+ case "$file" in ./sys/ki.h )
+ if ( test -n "`egrep '11.00 HP-UX LP64' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ zzz_ki"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to HP-UX <$file>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 102: Zzz_Ki_Calls
+ #
+ case "$file" in ./sys/ki_calls.h )
+ if ( test -n "`egrep 'KI_MAX_PROCS is an arbitrary number' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ zzz_ki_calls"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to HP-UX <$file>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 103: Zzz_Ki_Defs
+ #
+ case "$file" in ./sys/ki_defs.h )
+ if ( test -n "`egrep 'Kernel Instrumentation Definitions' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ zzz_ki_defs"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to HP-UX <$file>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+
+
+ #
+ # Fix 104: Zzz_Time
+ #
+ case "$file" in ./sys/time.h )
+ if ( test -n "`egrep 'For CASPEC, look in' $file`"
+ ) > /dev/null 2>&1 ; then
+ fixlist="${fixlist}
+ zzz_time"
+ if [ ! -r ${DESTDIR}/$file ]
+ then infile=$file
+ else infile=${DESTDIR}/$file ; fi
+ ( echo "Removing incorrect fix to HP-UX <$file>" >&2
+rm -f ${DESTDIR}/$file ${DESTDIR}/$file.
+cat > /dev/null ) < $infile > ${DESTDIR}/$file.
+
+ # Shell scripts have the potential of removing the output
+ # We interpret that to mean the file is not to be altered
+ #
+ if test ! -f ${DESTDIR}/$file.
+ then continue ; fi
+
+ mv -f ${DESTDIR}/$file. ${DESTDIR}/$file
+ fi # end of selection 'if'
+ ;; # case end for file name test
+ esac
+ # IF the output has been removed OR it is unchanged,
+ # THEN ensure the output is gone
+ # ELSE look for local directory include syntax
+ #
+ if ( test ! -f ${DESTDIR}/$file || \
+ cmp $file ${DESTDIR}/$file ) > /dev/null 2>&1
+ then
+ rm -f ${DESTDIR}/$file
+ else
+ echo "Fixed $file:${fixlist}"
+
+ # Find any include directives that use "file".
+ #
+ for include in `
+ egrep '^[ ]*#[ ]*include[ ]*"[^/]' ${DESTDIR}/$file |
+ sed -e 's/^[ ]*#[ ]*include[ ]*"\([^"]*\)".*$/\1/'`
+ do
+ dir=`echo $file | sed -e s'|/[^/]*$||'`
+ required="$required ${SRCDIR} $dir/$include ${DESTDIR}/$dir/$include"
+ done
+ fi
+ done # for file in $files
+
+done
+
+## Make sure that any include files referenced using double quotes
+## exist in the fixed directory. This comes last since otherwise
+## we might end up deleting some of these files "because they don't
+## need any change."
+set x `echo $required`
+shift
+while [ $# != 0 ]; do
+ newreq=
+ while [ $# != 0 ]; do
+ # $1 is the directory to copy from,
+ # $2 is the unfixed file,
+ # $3 is the fixed file name.
+ #
+ cd ${INPUT}
+ cd $1
+ if [ -r $2 ] && [ ! -r $3 ]; then
+ cp $2 $3 >/dev/null 2>&1 || echo "Can't copy $2" >&2
+ chmod +w $3 2>/dev/null
+ chmod a+r $3 2>/dev/null
+ echo Copied $2
+ for include in `egrep '^[ ]*#[ ]*include[ ]*"[^/]' $3 |
+ sed -e 's/^[ ]*#[ ]*include[ ]*"\([^"]*\)".*$/\1/'`
+ do
+ dir=`echo $2 | sed -e s'|/[^/]*$||'`
+ dir2=`echo $3 | sed -e s'|/[^/]*$||'`
+ newreq="$newreq $1 $dir/$include $dir2/$include"
+ done
+ fi
+ shift; shift; shift
+ done
+ set x $newreq
+ shift
+done
+
+echo 'Cleaning up DONE files.'
+cd $LIB
+find . -name DONE -exec rm -f '{}' ';'
+
+echo 'Removing unneeded directories:'
+cd $LIB
+files=`find . -type d -print | sort -r`
+for file in $files; do
+ rmdir $LIB/$file > /dev/null 2>&1 | :
+done
+
+# # # # # # # # # # # # # # # # # # # # #
+#
+# End of for INPUT directories
+#
+done
+#
+# # # # # # # # # # # # # # # # # # # # #
+
+cd $ORIGDIR
+rm -f include/assert.h
+cp ${EGCS_SRCDIR}/assert.h include/assert.h
+chmod a+r include/assert.h
+