Use bc's "print" feature whenever it is available,
authorBodo Möller <bodo@openssl.org>
Wed, 6 Dec 2000 10:32:55 +0000 (10:32 +0000)
committerBodo Möller <bodo@openssl.org>
Wed, 6 Dec 2000 10:32:55 +0000 (10:32 +0000)
not just on certain platforms.

crypto/bn/bntest.c
test/Makefile.ssl
test/bctest

index 12d68fc526c665178070199437a99e3adefdc921..f27087d59c3dccc62e41e94793ece0524c1414f2 100644 (file)
@@ -109,11 +109,9 @@ static const char rnd_seed[] = "string to make the random number generator think
 static void message(BIO *out, char *m)
        {
        fprintf(stderr, "test %s\n", m);
-#if defined(linux) || defined(__FreeBSD__) /* can we use GNU bc features? */
        BIO_puts(out, "print \"test ");
        BIO_puts(out, m);
        BIO_puts(out, "\\n\"\n");
-#endif
        }
 
 int main(int argc, char *argv[])
index 867789847ca01f82ec3a7c59f848c32717a15bf4..9b96f6406238964431f118d03228521747122e38 100644 (file)
@@ -195,12 +195,8 @@ test_bn:
        @echo starting big number library test, could take a while...
        @./$(BNTEST) >tmp.bntest
        @echo quit >>tmp.bntest
-       @if sh ./bctest; then \
-           echo "running bc"; \
-           bc tmp.bntest 2>&1 | $(PERL) -e 'while (<STDIN>) {if (/^test (.*)/) {print STDERR "\nverify $$1";} elsif (!/^0$$/) {die "\nFailed! bc: $$_";} print STDERR "."; $$i++;} print STDERR "\n$$i tests passed\n"'; \
-       else \
-           echo "skipping bc-based verification"; \
-       fi
+       @echo "running bc"
+       @<tmp.bntest sh -c "`sh ./bctest`" 2>&1 | $(PERL) -e '$$i=0; while (<STDIN>) {if (/^test (.*)/) {print STDERR "\nverify $$1";} elsif (!/^0$$/) {die "\nFailed! bc: $$_";} print STDERR "."; $$i++;} print STDERR "\n$$i tests passed\n"'
        @echo 'test a^b%c implementations'
        ./$(EXPTEST)
 
index 38e43efecc2a816b79f81451f138dc39e62d263e..33fa79d7cfc4aff674bc6320cde084119093c9b1 100755 (executable)
@@ -4,6 +4,11 @@
 # is installed.
 # ('make test_bn' should not try to run 'bc' if it does not exist or if
 # it is the broken SunOS 5.[78] bc, which fails the following test.)
+#
+# If 'bc' works, we also test if it knows the 'print' command.
+#
+# In any case, output an appropriate command line for running (or not
+# running) bc.
 
 if [ 0 != "`bc <<\EOF
 obase=16
@@ -22,7 +27,18 @@ b=DCE91E7D120B983EA9A104B5A96D634DD644C37657B1C7860B45E6838999B3DCE5A555583C6\
 EOF`" ]
 then
   echo "bc does not work.  Consider installing GNU bc." >&2
+  echo "cat >/dev/null"
   exit 1
 else
+  # bc works, good.
+  # Now check if it knows the 'print' command.
+  if [ "OK" = "`bc 2>/dev/null <<\EOF
+print \"OK\"
+EOF`" ]
+  then
+    echo "bc"
+  else
+    echo "sed 's/print.*//' | bc"
+  fi
   exit 0
 fi