Made to work under Microsoft Xenix V3.2
This commit is contained in:
parent
a0a265736c
commit
44ce140103
5 changed files with 184 additions and 26 deletions
|
@ -4,3 +4,4 @@ first
|
|||
did_first
|
||||
myecho.c
|
||||
fixlexlib
|
||||
cc.xenix
|
||||
|
|
70
first/cc.xenix.src
Normal file
70
first/cc.xenix.src
Normal file
|
@ -0,0 +1,70 @@
|
|||
trap "rm -f x$$.c" 0 1 2 3 15
|
||||
EMHOME=/usr/em
|
||||
CFLAG=0
|
||||
TARGET=a.out
|
||||
while :
|
||||
do
|
||||
case $# in
|
||||
0) break;;
|
||||
esac
|
||||
case $1 in
|
||||
-I*|-D*|-U*)
|
||||
PREP=$PREP" "$1
|
||||
;;
|
||||
-c) CFLAG=1
|
||||
;;
|
||||
-o) shift
|
||||
TARGET=$1
|
||||
;;
|
||||
-F) shift
|
||||
LFLAG="-F $1"
|
||||
;;
|
||||
-*) FLAGS=$FLAGS" "$1
|
||||
;;
|
||||
*) ARG=$ARG" "$1
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
for i in $ARG
|
||||
do
|
||||
case $i in
|
||||
*.c)
|
||||
nm=`basename $i .c`
|
||||
if [ -x $EMHOME/lib/cpp ]
|
||||
then
|
||||
cpp=$EMHOME/lib/cpp
|
||||
cppf=-P
|
||||
else
|
||||
cpp=/bin/cc
|
||||
cppf=-E
|
||||
fi
|
||||
if $cpp $cppf $PREP $i > x$$.c && /bin/cc $FLAGS -c x$$.c
|
||||
then
|
||||
mv x$$.o $nm.o
|
||||
LDARG=$LDARG" "$nm.o
|
||||
else
|
||||
rm -f x$$.c
|
||||
exit 1
|
||||
fi
|
||||
rm -f x$$.c
|
||||
;;
|
||||
*.s)
|
||||
if /bin/cc $FLAGS -c $i
|
||||
then
|
||||
LDARG=$LDARG" "`basename $i .s`.o
|
||||
else exit 1
|
||||
fi
|
||||
;;
|
||||
*) LDARG=$LDARG" "$i
|
||||
;;
|
||||
esac
|
||||
done
|
||||
case $CFLAG in
|
||||
1) ;;
|
||||
*) if /bin/cc $FLAGS $LFLAG $LDARG -o $TARGET
|
||||
then :
|
||||
else exit 1
|
||||
fi
|
||||
;;
|
||||
esac
|
15
first/ckpath
15
first/ckpath
|
@ -1,4 +1,5 @@
|
|||
rm -f ../bin/x_tpath x_tpath
|
||||
echo 'Checking out your $PATH; . and $ACK/bin should be in front ...'
|
||||
echo "echo $$" >../bin/x_tpath
|
||||
rm -f x_tpath
|
||||
chmod +x ../bin/x_tpath
|
||||
|
@ -49,4 +50,18 @@ x$$)
|
|||
STAT=4 ;;
|
||||
esac
|
||||
rm -f ../bin/x_tpath x_tpath
|
||||
echo "echo 93" > ../bin/cat
|
||||
chmod +x ../bin/cat
|
||||
hash -r
|
||||
case x`cat < /dev/null 2>/dev/null`
|
||||
in
|
||||
x93)
|
||||
rm -f ../bin/cat
|
||||
;;
|
||||
*)
|
||||
rm -f ../bin/cat
|
||||
(cd ../bin ; echo Sorry, `pwd` comes too late in your PATH" ($PATH)" )
|
||||
STAT=13
|
||||
;;
|
||||
esac
|
||||
exit $STAT
|
||||
|
|
112
first/first
112
first/first
|
@ -10,11 +10,12 @@ first)
|
|||
esac
|
||||
: check $PATH first
|
||||
if sh ckpath
|
||||
then :
|
||||
then
|
||||
echo "PATH is ok"
|
||||
else
|
||||
exit 1
|
||||
fi
|
||||
: check write-ability of /tmp and /usr/tmp
|
||||
echo check write-ability of /tmp and /usr/tmp ...
|
||||
if ( >/usr/tmp/aaax.$$ )
|
||||
then
|
||||
rm /usr/tmp/aaax.$$
|
||||
|
@ -29,29 +30,33 @@ else
|
|||
echo /tmp must exist and be writable.
|
||||
exit 2
|
||||
fi
|
||||
: set ACK HOME Directory in ../h/em_path.h
|
||||
echo "/tmp and /usr/tmp ok"
|
||||
echo setting ACK HOME Directory in ../h/em_path.h ...
|
||||
rm -f em_path.h
|
||||
sed -e "/^#define[ ]*EM_DIR/s@\".*\"@\"`cd .. ; pwd`\"@" <../h/em_path.h >em_path.h
|
||||
HM=`cd ..; pwd`
|
||||
sed -e "/^#define[ ]*EM_DIR/s@\".*\"@\"$HM\"@" <../h/em_path.h >em_path.h
|
||||
if cmp ../h/em_path.h em_path.h >/dev/null 2>&1
|
||||
then
|
||||
: Don't touch ../h/em_path.h, it's already correct
|
||||
echo "../h/em_path.h already correct"
|
||||
else
|
||||
rm -f ../h/em_path.h
|
||||
if mv em_path.h ../h >/dev/null 2>&1
|
||||
then : success
|
||||
then echo "../h/em_path.h replaced"
|
||||
else
|
||||
echo "Sorry, can't replace ../h/em_path.h"
|
||||
exit 7
|
||||
fi
|
||||
fi
|
||||
: translate myecho
|
||||
if cc -o myecho myecho.c > /dev/null 2>&1
|
||||
echo compile own echo program, so that we know how it works ...
|
||||
if cc -o echo myecho.c > /dev/null 2>&1
|
||||
then
|
||||
:
|
||||
echo compilation succeeded
|
||||
else
|
||||
echo "Sorry, cc does not seem to work"
|
||||
exit 8
|
||||
fi
|
||||
cp echo ../bin/echo
|
||||
: find cc option for lex library
|
||||
if fixlexlib
|
||||
then
|
||||
|
@ -64,7 +69,7 @@ if (ack_sys) >/dev/null 2>&1
|
|||
then
|
||||
: echo Your system is: `ack_sys`.
|
||||
else
|
||||
myecho -n "Give me the type of your system, the current choice is:
|
||||
echo -n "Give me the type of your system, the current choice is:
|
||||
pdp_v7 PDP11 with sep I/D and version 7 (or BSD 2.8, 2.9)
|
||||
vax_bsd4_1a VAX11 with BSD4.1a
|
||||
vax_bsd4_2 VAX11 with BSD4.2
|
||||
|
@ -93,7 +98,7 @@ system type: "
|
|||
exit 10
|
||||
fi
|
||||
fi
|
||||
myecho -n "Your system is `ack_sys`, are you satisfied with that? (y/n) "
|
||||
echo -n "Your system is `ack_sys`, are you satisfied with that? (y/n) "
|
||||
if read YESNO
|
||||
then
|
||||
case $YESNO in
|
||||
|
@ -113,17 +118,12 @@ fi
|
|||
: "Take action according to the system used"
|
||||
: 'Prevent the use of the system assembler on for certain systems'
|
||||
: 'prevent the use of ranlib on pdp 11s'
|
||||
echo "take some actions according to system used ..."
|
||||
case `ack_sys` in
|
||||
pdp_*) RMD="vax4"
|
||||
echo "disabling use of ranlib; cannot trust its result"
|
||||
echo 'echo "no ranlib on this system"; exit 93' > ../bin/ranlib
|
||||
chmod +x ../bin/ranlib
|
||||
ranlib > /dev/null 2>&1
|
||||
case X$? in
|
||||
X93) ;;
|
||||
*) echo "Sorry, there still is an error in your PATH."
|
||||
echo "It finds the system ranlib before ours, which is in the ACK bin directory."
|
||||
exit 13
|
||||
esac
|
||||
;;
|
||||
vax*) ;;
|
||||
*) RMD="vax4" ;;
|
||||
|
@ -131,6 +131,7 @@ esac
|
|||
for i in $RMD
|
||||
do
|
||||
( cd ../lib/$i
|
||||
echo "disabling use of local assembler and loader for $i"
|
||||
if grep '^name as$' descr >/dev/null 2>&1
|
||||
then
|
||||
cp descr descr.orig
|
||||
|
@ -163,7 +164,7 @@ ABC
|
|||
)
|
||||
;;
|
||||
esac
|
||||
: 'Set the default machine in ../h/local.h'
|
||||
echo 'Setting the default machine in ../h/local.h ...'
|
||||
BM=1
|
||||
case `ack_sys` in
|
||||
pdp_v7) ACM=pdp ; BM=0 ; SYS=V7 ;;
|
||||
|
@ -183,9 +184,11 @@ esac
|
|||
rm -f local.h
|
||||
sed -e /ACKM/s/'".*"'/'"'$ACM'"'/ -e /BIGMACH/s/'[01]'/$BM/ -e /SYSTEM/s/'^#[ ]*define[ ]*[a-zA-Z_][a-zA-Z0-9_]*'/"# define $SYS"/ < ../h/local.h >local.h
|
||||
if cmp -s ../h/local.h local.h
|
||||
then :
|
||||
then
|
||||
echo "../h/local.h already correct"
|
||||
else
|
||||
cp local.h ../h
|
||||
echo "../h/local.h updated"
|
||||
rm -f local.h
|
||||
fi
|
||||
echo "Your default machine to compile for is $ACM"
|
||||
|
@ -214,9 +217,77 @@ vax_sysV_2)
|
|||
cp libsysV_2/* libsys
|
||||
)
|
||||
;;
|
||||
xenix3)
|
||||
echo "Xenix cannot handle our Makefiles; install our own make ..."
|
||||
if ( cd ../util/make; make install )
|
||||
then
|
||||
echo "Done"
|
||||
else
|
||||
echo "Sorry, this seems to have failed."
|
||||
echo "You have to install it by hand later, or use the Xenix"
|
||||
echo "make anyway"
|
||||
fi
|
||||
echo "The Xenix C compiler cannot compile some of our programs."
|
||||
echo "It complains about lack of heap space when many #defines are"
|
||||
echo 'used. This is prevented by installing a "cc" shell script in'
|
||||
echo 'the EM bin directory, which runs a .c file through a preprocessor'
|
||||
echo 'before running it through the C compiler proper. Unfortunately,'
|
||||
echo 'line number and filename information is lost. The compiler does'
|
||||
echo 'not recognize its own line directives.'
|
||||
echo 'You can remove this "cc" script from the EM bin directory'
|
||||
echo 'when installation is done.'
|
||||
cp cc.xenix cc.xenix.orig
|
||||
ed - cc.xenix <<ABC
|
||||
/EMHOME/s/=.*/=$HM/
|
||||
w
|
||||
q
|
||||
ABC
|
||||
cp cc.xenix ../bin/cc
|
||||
chmod +x ../bin/cc
|
||||
echo "code-generators and peephole optimizer need more stack than the default."
|
||||
echo "adapting LDFLAGS in Makefiles"
|
||||
for i in ../mach/*/*cg/Makefile
|
||||
do
|
||||
cp $i $i.orig
|
||||
ed - $i <<ABC
|
||||
/LDFLAGS/s/$/ -F 3000/
|
||||
w
|
||||
q
|
||||
ABC
|
||||
done
|
||||
cp ../util/opt/Makefile ../util/opt/Makefile.orig
|
||||
ed - ../util/opt/Makefile <<ABC
|
||||
/LDFLAGS/s/$/-F 2000/
|
||||
w
|
||||
q
|
||||
ABC
|
||||
echo "target optimizers do not work on Xenix; disabling their use"
|
||||
for i in ../lib/*/descr
|
||||
do
|
||||
if grep -s "name asopt" $i
|
||||
then
|
||||
cp $i $i.top
|
||||
ed - $i <<ABC
|
||||
/name asopt/;/^end/d
|
||||
w
|
||||
q
|
||||
ABC
|
||||
fi
|
||||
done
|
||||
echo "the -l option in cc command puts library in wrong place."
|
||||
echo "this is a problem with the lex library for the occam compiler."
|
||||
echo "changing Makefile for Occam compiler"
|
||||
cp ../lang/occam/comp/Makefile ../lang/occam/comp/Makefile.orig
|
||||
ed - ../lang/occam/comp/Makefile <<ABC
|
||||
/LEXLIB/s.-l[a-z]*./lib/Slibl.a.
|
||||
w
|
||||
q
|
||||
ABC
|
||||
;;
|
||||
esac
|
||||
case X$BM in
|
||||
X0)
|
||||
echo "set some installation pararmeters for small machines"
|
||||
( cd ../lang/cem/cemcom
|
||||
cp SmallPars Parameters
|
||||
cp makefile makefile.orig
|
||||
|
@ -288,7 +359,8 @@ q
|
|||
ABC
|
||||
)
|
||||
;;
|
||||
*) ( cd ../lang/cem/cemcom
|
||||
*) ( echo "set some installation pararmeters for big machines"
|
||||
cd ../lang/cem/cemcom
|
||||
cp BigPars Parameters
|
||||
cd ../../m2/comp
|
||||
cp BigPars Parameters
|
||||
|
|
|
@ -7,14 +7,14 @@ X0)
|
|||
TRY=`.Xlex`
|
||||
else TRY=-lln
|
||||
fi
|
||||
myecho "trying to find your lex library ..."
|
||||
echo "trying to find your lex library ..."
|
||||
cat > x.l <<'EOF'
|
||||
%%
|
||||
[A-Z] putchar(yytext[0]+'a'-'A');
|
||||
EOF
|
||||
if lex x.l > /dev/null 2>&1 && cc -c lex.yy.c > /dev/null 2>&1
|
||||
then :
|
||||
else myecho "Sorry, your lex does not seem to work"
|
||||
else echo "Sorry, your lex does not seem to work"
|
||||
exit 2
|
||||
fi
|
||||
cat > trylib <<'EOF'
|
||||
|
@ -43,12 +43,12 @@ EOF
|
|||
;;
|
||||
esac
|
||||
case X$FL in
|
||||
Xfail) myecho 'What option do I have to give to cc to get the LEX library?'
|
||||
myecho "I tried " $TRIES "but these don't seem to work."
|
||||
myecho -n 'LEX library option: '
|
||||
Xfail) echo 'What option do I have to give to cc to get the LEX library?'
|
||||
echo "I tried " $TRIES "but these don't seem to work."
|
||||
echo -n 'LEX library option: '
|
||||
if read ANSWER
|
||||
then :
|
||||
else myecho "Sorry, got EOF while reading your answer"
|
||||
else echo "Sorry, got EOF while reading your answer"
|
||||
exit 9
|
||||
fi
|
||||
exec $0 $ANSWER "$TRIES"
|
||||
|
|
Loading…
Reference in a new issue