don't use shell functions

This commit is contained in:
Bodo Möller
2001-04-04 16:27:44 +00:00
parent 75c3c831db
commit b9a96c0134
2 changed files with 25 additions and 26 deletions

View File

@@ -19,6 +19,8 @@
*) Change bctest to avoid here-documents inside command substitution *) Change bctest to avoid here-documents inside command substitution
(workaround for FreeBSD /bin/sh bug). (workaround for FreeBSD /bin/sh bug).
For compatibility with Ultrix, avoid shell functions (introduced
in the bctest version that searches along $PATH).
[Bodo Moeller] [Bodo Moeller]
*) Rename 'des_encrypt' to 'des_encrypt1'. This avoids the clashes *) Rename 'des_encrypt' to 'des_encrypt1'. This avoids the clashes

View File

@@ -11,9 +11,16 @@
# running) bc. # running) bc.
# Test for SunOS 5.[78] bc bug IFS=:
SunOStest() { for dir in $PATH; do
${1} >tmp.bctest <<\EOF bc="$dir/bc"
if [ -x "$bc" -a ! -d "$bc" ]; then
failure=none
# Test for SunOS 5.[78] bc bug
"$bc" >tmp.bctest <<\EOF
obase=16 obase=16
ibase=16 ibase=16
a=AD88C418F31B3FC712D0425001D522B3AE9134FF3A98C13C1FCC1682211195406C1A6C66C6A\ a=AD88C418F31B3FC712D0425001D522B3AE9134FF3A98C13C1FCC1682211195406C1A6C66C6A\
@@ -28,17 +35,14 @@ b=DCE91E7D120B983EA9A104B5A96D634DD644C37657B1C7860B45E6838999B3DCE5A555583C6\
3ED0E2017D60A68775B75481449 3ED0E2017D60A68775B75481449
(a/b)*b + (a%b) - a (a/b)*b + (a%b) - a
EOF EOF
if [ 0 != "`cat tmp.bctest`" ] if [ 0 != "`cat tmp.bctest`" ]; then
then failure=SunOStest
# failure fi
return 1
fi
}
# Test for SCO bc bug. if [ "$failure" = none ]; then
SCOtest() { # Test for SCO bc bug.
${1} >tmp.bctest <<\EOF "$bc" >tmp.bctest <<\EOF
obase=16 obase=16
ibase=16 ibase=16
-FFDD63BA1A4648F0D804F8A1C66C53F0D2110590E8A3907EC73B4AEC6F15AC177F176F2274D2\ -FFDD63BA1A4648F0D804F8A1C66C53F0D2110590E8A3907EC73B4AEC6F15AC177F176F2274D2\
@@ -65,21 +69,14 @@ F617E3145BBFBE9AFD0D6E437EA4FF6F04BC67C4F1458B4F0F47B64 - 1C2BBBB19B74E86FD32\
D97935A7E1A14AD209D6CF811F55C6DB83AA9E6DFECFCD6669DED7171EE22A40C6181615CAF3F\ D97935A7E1A14AD209D6CF811F55C6DB83AA9E6DFECFCD6669DED7171EE22A40C6181615CAF3F\
5296964 5296964
EOF EOF
if [ "0 if [ "0
0" != "`cat tmp.bctest`" ] 0" != "`cat tmp.bctest`" ]; then
then failure=SCOtest
# failure fi
return 1 fi
fi
}
IFS=: if [ "$failure" = none ]; then
for dir in $PATH; do
bc="$dir/bc"
if [ -x "$bc" -a ! -d "$bc" ]; then
if SunOStest "$bc" && SCOtest "$bc"; then
# bc works; now check if it knows the 'print' command. # bc works; now check if it knows the 'print' command.
if [ "OK" = "`echo 'print \"OK\"' | $bc 2>/dev/null`" ] if [ "OK" = "`echo 'print \"OK\"' | $bc 2>/dev/null`" ]
then then
@@ -90,7 +87,7 @@ for dir in $PATH; do
exit 0 exit 0
fi fi
echo "$bc does not work properly. Looking for another bc ..." >&2 echo "$bc does not work properly ('$failure' failed). Looking for another bc ..." >&2
fi fi
done done