Commit 83c4e75b authored by Bodo Möller's avatar Bodo Möller
Browse files

Use enhanced bctest (as in main trunk), and add a workaround that

should solve the problems with FreeBSD's /bin/sh.
parent e5f3be2b
Loading
Loading
Loading
Loading
+8 −0
Original line number Diff line number Diff line
@@ -4,6 +4,10 @@

 Changes between 0.9.6 and 0.9.6a  [xx XXX 2001]

  *) Change bctest to avoid here-documents inside command substitution
     (workaround for FreeBSD /bin/sh bug).
     [Bodo Moeller]

  *) Rename 'des_encrypt' to 'des_encrypt1'.  This avoids the clashes
     with des_encrypt() defined on some operating systems, like Solaris
     and UnixWare.
@@ -29,6 +33,10 @@
     (but broken) behaviour.
     [Steve Henson]

  *) Enhance bctest to search for a working bc along $PATH and print
     it when found.
     [Tim Rice <tim@multitalents.net> via Richard Levitte]

  *) Fix memory leaks in err.c: free err_data string if necessary;
     don't write to the wrong index in ERR_set_error_data.
     [Bodo Moeller]
+1 −1
Original line number Diff line number Diff line
@@ -240,7 +240,7 @@ dclean:
	mv -f Makefile.new $(MAKEFILE)

clean:
	rm -f .rnd tmp.bntest *.o *.obj lib tags core .pure .nfs* *.old *.bak fluff $(EXE) *.ss log
	rm -f .rnd tmp.bntest tmp.bctest *.o *.obj lib tags core .pure .nfs* *.old *.bak fluff $(EXE) *.ss log

$(DLIBSSL):
	(cd ../ssl; $(MAKE))
+38 −23
Original line number Diff line number Diff line
@@ -11,8 +11,9 @@
# running) bc.


# Test for SunOS 5.[78] bc bug (or missing bc)
if [ 0 != "`bc <<\EOF
# Test for SunOS 5.[78] bc bug
SunOStest() {
${1} >tmp.bctest <<\EOF
obase=16
ibase=16
a=AD88C418F31B3FC712D0425001D522B3AE9134FF3A98C13C1FCC1682211195406C1A6C66C6A\
@@ -26,17 +27,18 @@ b=DCE91E7D120B983EA9A104B5A96D634DD644C37657B1C7860B45E6838999B3DCE5A555583C6\
8B3CD64126E1A82E190228020C05B91C8B141F1110086FC2A4C6ED631EBA129D04BB9A19FC53D\
3ED0E2017D60A68775B75481449
(a/b)*b + (a%b) - a
EOF`" ]
EOF
if [ 0 != "`cat tmp.bctest`" ]
then
  echo "bc does not work.  Consider installing GNU bc." >&2
  echo "cat >/dev/null"
  exit 1
  # failure
  return 1
fi
}


# Test for SCO bc bug.
if [ "0
0" != "`bc <<\EOF
SCOtest() {
${1} >tmp.bctest <<\EOF
obase=16
ibase=16
-FFDD63BA1A4648F0D804F8A1C66C53F0D2110590E8A3907EC73B4AEC6F15AC177F176F2274D2\
@@ -62,23 +64,36 @@ F617E3145BBFBE9AFD0D6E437EA4FF6F04BC67C4F1458B4F0F47B64 - 1C2BBBB19B74E86FD32\
9E8DB6A8C3B1B9986D57ED5419C2E855F7D5469E35E76334BB42F4C43E3F3A31B9697C171DAC4\
D97935A7E1A14AD209D6CF811F55C6DB83AA9E6DFECFCD6669DED7171EE22A40C6181615CAF3F\
5296964
EOF`" ]
EOF
if [ "0
0" != "`cat tmp.bctest`" ]
then
  echo "bc does not work.  Consider installing GNU bc." >&2
  echo "cat >/dev/null"
  exit 1
  # failure
  return 1
fi
}


IFS=:
for dir in $PATH; do
    bc="$dir/bc"

# bc works, good.
# Now check if it knows the 'print' command.
if [ "OK" = "`bc 2>/dev/null <<\EOF
print \"OK\"
EOF`" ]
    if [ -x "$bc" -a ! -d "$bc" ]; then
        if SunOStest "$bc" && SCOtest "$bc"; then
            # bc works; now check if it knows the 'print' command.
            if [ "OK" = "`echo 'print \"OK\"' | $bc 2>/dev/null`" ]
            then
    echo "bc"
                echo "$bc"
            else
    echo "sed 's/print.*//' | bc"
                echo "sed 's/print.*//' | $bc"
            fi

            exit 0
        fi

        echo "$bc does not work properly.  Looking for another bc ..." >&2
    fi
done

echo "No working bc found.  Consider installing GNU bc." >&2
echo "cat >/dev/null"
exit 1