Files
harbour-core/harbour/tests/mathtest.prg
Viktor Szakats 7e7aaf9044 2012-10-02 13:52 UTC+0200 Viktor Szakats (harbour syenar.net)
* tests/adirtest.prg
  * tests/ainstest.prg
  * tests/and_or.prg
  * tests/array16.prg
  * tests/arrayidx.prg
  * tests/arrays.prg
  * tests/arrindex.prg
  * tests/atest.prg
  * tests/base64.prg
  * tests/byref.prg
  * tests/calling.prg
  * tests/cdow.prg
  * tests/clasinit.prg
  * tests/clasname.prg
  * tests/classch.prg
  * tests/classes.prg
  * tests/clsdata.prg
  * tests/cmphello.prg
  * tests/codebl.prg
  * tests/curdirt.prg
  * tests/cursrtst.prg
  * tests/dates.prg
  * tests/dates2.prg
  * tests/dates3.prg
  * tests/debugtst.prg
  * tests/delimtst.prg
  * tests/devtest.prg
  * tests/dirtest.prg
  * tests/disptest.prg
  * tests/docase.prg
  * tests/dosshell.prg
  * tests/dttest.prg
  * tests/dupvars.prg
  * tests/dynobj.prg
  * tests/dynsym.prg
  * tests/exittest.prg
  * tests/extend1.prg
  * tests/fib.prg
  * tests/fornext.prg
  * tests/fortest.prg
  * tests/funcarr.prg
  * tests/hbdoctst.prg
  * tests/hsxtest.prg
  * tests/ifelse.prg
  * tests/inifiles.prg
  * tests/initexit.prg
  * tests/inkeytst.prg
  * tests/inline_c.prg
  * tests/inline.prg
  * tests/iotest.prg
  * tests/iotest2.prg
  * tests/ipclnt.prg
  * tests/ipsvr.prg
  * tests/longstr.prg
  * tests/mathtest.prg
  * tests/memvar.prg
  * tests/multiarg.prg
  * tests/nums.prg
  * tests/objarr.prg
  * tests/objasign.prg
  * tests/objects.prg
  * tests/os.prg
  * tests/overload.prg
  * tests/parexpr.prg
  * tests/passref.prg
  * tests/procname.prg
  * tests/recursiv.prg
  * tests/returns.prg
  * tests/round.prg
  * tests/sdf_test.prg
  * tests/seconds.prg
  * tests/set_num.prg
  * tests/set_test.prg
  * tests/sound.prg
  * tests/statfun.prg
  * tests/statics.prg
  * tests/statics1.prg
  * tests/statics2.prg
  * tests/strdelim.prg
  * tests/stripem.prg
  * tests/t1.prg
  * tests/test.prg
  * tests/testerro.prg
  * tests/testfor.prg
  * tests/testget.prg
  * tests/testhtml.prg
  * tests/testid.prg
  * tests/testop.prg
  * tests/teststr.prg
  * tests/testtok.prg
  * tests/testvars.prg
  * tests/tflock.prg
  * tests/tstalias.prg
  * tests/version.prg
  * tests/videotst.prg
  * tests/while.prg
  * tests/wvtext.prg
    ! various cleanups and fixes after running almost all of them

  * ChangeLog
    * changed hbqt new repository to its new location:
        http://sourceforge.net/projects/qtcontribs/
2012-10-02 11:59:22 +00:00

96 lines
2.7 KiB
Plaintext

/*
* $Id$
*/
#include "hbmath.ch"
PROCEDURE Main()
LOCAL nOldMathErrMode
LOCAL bOldMathErr
? "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 ValType( nArg1 ) == "N"
cStr += hb_ntos( nArg1 )
ENDIF
IF ValType( nArg2 ) == "N"
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