* 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/
96 lines
2.7 KiB
Plaintext
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
|