Problem is that reading bignums depends on multiplying bignums...

Which doesn't work for the second digit into bignum territory - so it's fine at the boundary...
This commit is contained in:
Simon Brooke 2019-01-18 14:25:32 +00:00
parent d8991e8823
commit b433171fb6
2 changed files with 77 additions and 5 deletions

View file

@ -185,4 +185,3 @@ else
exit 1 exit 1
fi fi
1329227995784915872903807060280344576

View file

@ -3,7 +3,7 @@
##################################################################### #####################################################################
# large number, not actally a bignum # large number, not actally a bignum
expected='576460752303423488' expected='576460752303423488'
output=`echo "(progn (print $expected) nil)" | target/psse` output=`echo "(progn (print $expected) nil)" | target/psse -v 2 2>psse.log`
actual=`echo $output |\ actual=`echo $output |\
sed 's/\,//g' |\ sed 's/\,//g' |\
@ -18,10 +18,22 @@ else
exit 1 exit 1
fi fi
echo -n "checking no bignum was created: "
grep -v 'BIGNUM!' psse.log > /dev/null
if [ $? -eq "0" ]
then
echo "OK"
else
echo "Fail"
exit 1
fi
##################################################################### #####################################################################
# right on the boundary # right on the boundary
expected='1152921504606846976' expected='1152921504606846976'
output=`echo "(progn (print $expected) nil)" | target/psse` output=`echo "(progn (print $expected) nil)" | target/psse -v 2 2>psse.log`
actual=`echo $output |\ actual=`echo $output |\
sed 's/\,//g' |\ sed 's/\,//g' |\
@ -36,10 +48,71 @@ else
exit 1 exit 1
fi fi
echo -n "checking no bignum was created: "
grep -v 'BIGNUM!' psse.log > /dev/null
if [ $? -eq "0" ]
then
echo "OK"
else
echo "Fail"
exit 1
fi
##################################################################### #####################################################################
# definitely a bignum # definitely a bignum
expected='1329227995784915872903807060280344577' expected='1152921504606846977'
output=`echo "(progn (print $expected) nil)" | target/psse` output=`echo "(progn (print $expected) nil)" | target/psse -v 2 2>psse.log`
actual=`echo $output |\
sed 's/\,//g' |\
sed 's/[^0-9]*\([0-9]*\).*/\1/'`
echo -n "printing $expected: "
if [ "${expected}" = "${actual}" ]
then
echo "OK"
else
echo "Fail: expected '${expected}', got '${actual}'"
exit 1
fi
echo -n "checking a bignum was created: "
grep 'BIGNUM!' psse.log > /dev/null
if [ $? -eq "0" ]
then
echo "OK"
else
echo "Fail"
exit 1
fi
#####################################################################
# Just on the three cell boundary
expected='1329227995784915872903807060280344576'
output=`echo "(progn (print $expected) nil)" | target/psse -v 2 2>psse.log`
actual=`echo $output |\
sed 's/\,//g' |\
sed 's/[^0-9]*\([0-9]*\).*/\1/'`
echo -n "printing $expected: "
if [ "${expected}" = "${actual}" ]
then
echo "OK"
else
echo "Fail: expected '${expected}', got '${actual}'"
exit 1
fi
exit 0
#####################################################################
# definitely a three cell bignum
expected='1329227995784915872903807060280344577'
output=`echo "(progn (print $expected) nil)" | target/psse -v 2 2>psse.log`
actual=`echo $output |\ actual=`echo $output |\
sed 's/\,//g' |\ sed 's/\,//g' |\