Files
harbour-core/harbour/tests/mathtest.prg
Viktor Szakats e89c2b43ce 2012-11-16 17:50 UTC+0100 Viktor Szakats (vszakats syenar.net)
* extras/hbvpdf/hbvpdf.hbx
    ! two more corrections

  * contrib/gtwvg/tests/_dyndlgs.prg
  * contrib/hbct/doc/en/finan.txt
  * contrib/hbct/readme.txt
  * contrib/hbct/tests/asciisum.prg
  * contrib/hbct/tests/trig.prg
  * contrib/hbfoxpro/dll.prg
  * contrib/hbhttpd/core.prg
  * contrib/hbhttpd/widgets.prg
  * contrib/hbmisc/fcomma.prg
  * contrib/hbmlzo/tests/test.prg
  * contrib/hbmxml/tests/custom.prg
  * contrib/hbmzip/readme.txt
  * contrib/hbnf/nwuid.prg
  * contrib/hbnf/vidcur.prg
  * contrib/hbtip/client.prg
  * contrib/hbwin/tests/olesrv1.prg
  * contrib/hbwin/tests/testprn.prg
  * contrib/xhb/cstruct.prg
  * contrib/xhb/hjwindow.prg
  * contrib/xhb/hterrsys.prg
  * contrib/xhb/htjlist.prg
  * contrib/xhb/htmutil.prg
  * contrib/xhb/tests/decode.prg
  * contrib/xhb/xhberr.prg
  * doc/cmdline.txt
  * doc/en/objfunc.txt
  * doc/en/set.txt
  * doc/en/string.txt
  * doc/pragma.txt
  * extras/gfspell/spell.prg
  * extras/gtwvw/docs/gtwvw.txt
  * extras/gtwvw/tests/wvwtest9.prg
  * extras/hbvpdf/core.prg
  * extras/hbvpdf/fonts.prg
  * extras/hbvpdf/tests/pdf_demo.prg
  * extras/httpsrv/cgifunc.prg
  * extras/httpsrv/home/counter.html
  * extras/httpsrv/home/testxmldb.html
  * extras/httpsrv/session.prg
  * extras/httpsrv/uhttpd.prg
  * tests/base64.prg
  * tests/boxtest.prg
  * tests/db_brows.prg
  * tests/ddate.prg
  * tests/inherit.prg
  * tests/langmsg.prg
  * tests/mathtest.prg
  * tests/memtst.prg
  * tests/readhrb.prg
  * tests/switch.prg
  * tests/testsha2.prg
  * tests/testwarn.prg
  * tests/tstdbi.prg
  * tests/utf8at.prg
  * utils/hbtest/hbtest.prg
  * utils/hbtest/rt_class.prg
  * utils/hbtest/rt_date.prg
  * utils/hbtest/rt_hvma.prg
  * utils/hbtest/rt_math.prg
  * utils/hbtest/rt_misc.prg
  * utils/hbtest/rt_trans.prg
  * website/news.html
  * website/news1.html
  * website/samples.html
  * website/samples/arreval.html
  * website/samples/codebl.prg.html
  * website/samples/dates3.html
  * website/samples/switch.prg.html
  * website/samples/testcgi.prg.html
  * website/samples/tstmacro.prg.html
    * rerun case fixer script after applying
      some fixes, and this time it run fully
      automatically.
2012-11-16 16:53:48 +00:00

98 lines
2.7 KiB
Plaintext

/*
* $Id$
*/
#include "hbmath.ch"
PROCEDURE Main()
LOCAL nOldMathErrMode
LOCAL bOldMathErr
CLS
? "Testing math function: Exp(), Log() and SQRT():"
?
? " I) Test with correct arguments:"
? " Exp(0.0) == 1.00 ? ", Exp( 0.0 )
? " Exp(1.0) == 2.71(8)... ? ", Exp( 1.0 )
? " Exp(-1.0) == 0.36(7)... ? ", Exp( -1.0 )
?
? " Log(1.0) == 0.00 ? ", Log( 1.0 )
? " Log(2.7) == 0.99(3)... ? ", Log( 2.7 )
? " Log(0.36) == -1.02(1)... ? ", Log( 0.36 )
?
? " Sqrt(1.0) == 1.00 ? ", Sqrt( 1.0 )
? " Sqrt(4.0) == 2.00 ? ", Sqrt( 4.0 )
? " Sqrt(2.0) == 1.41(4).. ? ", Sqrt( 2.0 )
?
? " II) Test with numeric but incorrect arguments:"
?
? " IIa) default error handling(by the functions themselves)"
? " Exp(-1000) == 0.00 ?", Exp( -1000 )
? " Exp(1000) == ****... ?", Exp( 1000 )
?
? " Log(0) == ****... ?", Log( 0 )
? " Log(-10) == *****... ?", Log( -10 )
?
? " Sqrt(-4) == 0.00 ?", Sqrt( -4 )
?
nOldMathErrMode := hb_matherMode( HB_MATH_ERRMODE_USERDEFAULT )
? " IIb) error handling by error(hb_matherMode() == HB_MATH_ERRMODE_USERDEFAULT)"
? " Exp(-1000) == 0.00 ?", Exp( -1000 )
? " Exp(1000) == ****... ?", Exp( 1000 )
?
? " Log(0) == ****... ?", Log( 0 )
? " Log(-10) == *****... ?", Log( -10 )
?
? " Sqrt(-4) == 0.00 ?", Sqrt( -4 )
?
hb_matherMode( nOldMathErrMode )
bOldMathErr := hb_matherBlock( {| nType, cFuncname, cError, nArg1, nArg2, aInfo | ;
localmatherr( nType, cFuncname, cError, nArg1, nArg2, aInfo ) } )
? " IIc) error handling by callback block(hb_matherBlock())"
? " Exp(-1000) == ?", Exp( -1000 )
? " Exp(1000) == ?", Exp( 1000 )
?
? " Log(0) == ?", Log( 0 )
? " Log(-10) == ?", Log( -10 )
?
? " Sqrt(-4) == ?", Sqrt( -4 )
hb_matherBlock( bOldMathErr )
RETURN
FUNCTION localmatherr( nType, cFuncname, cError, nArg1, nArg2, aInfo )
LOCAL cStr := "!! Local handling of math error MATH/"
cStr += hb_ntos( nType ) + " in " + cFuncname + "("
IF HB_ISNUMERIC( nArg1 )
cStr += hb_ntos( nArg1 )
ENDIF
IF HB_ISNUMERIC( nArg2 )
cStr += "," + hb_ntos( nArg2 )
ENDIF
cStr += "):"
? cStr
? "!! " + cError
IF aInfo[ HB_MATHERRORBLOCK_HANDLED ]
? "!! --> already handled with return value: " + ;
hb_ntos( aInfo[ HB_MATHERRORBLOCK_RETVAL ] )
RETURN 1
ENDIF
? "!! setting return value to --> 5.0"
aInfo[ HB_MATHERRORBLOCK_RETVAL ] := 5.0
aInfo[ HB_MATHERRORBLOCK_HANDLED ] := .T.
RETURN 1