Files
harbour-core/harbour/tests/codebloc.prg
Viktor Szakats 32b3c2a1cd 2012-10-12 01:41 UTC+0200 Viktor Szakats (harbour syenar.net)
* extras/hbxlsxml/xlsxml.prg
    ! fixed missing UTF-8 mime-type svn prop

  * tests/gtkeys.prg
    ! fixed typo in recent mods causing it to fail under Clipper

  * contrib/hbunix/tests/testdmn.prg
  * contrib/xhb/tfile.prg
  * contrib/xhb/xhberr.prg
  * contrib/xhb/xhbtedit.prg
  * contrib/gtwvg/class.prg
  * contrib/gtwvg/tests/utils.prg
  * contrib/hbnf/dfile.prg
  * contrib/hbgd/tests/counter.prg
  * contrib/hbtip/tests/tipmime.prg
  * src/debug/debugger.prg
  * src/rtl/teditor.prg
  * src/rtl/typefile.prg
  * src/rdd/usrrdd/rdds/logrdd.prg
  * tests/testrdd2.prg
  * tests/inifiles.prg
  * extras/gtwvw/tests/drawimg.prg
  * extras/httpsrv/cgifunc.prg
  * extras/httpsrv/session.prg
    % File() -> hb_FileExists()
    ; pls review me in core

  * contrib/gtwvg/class.prg
  * contrib/gtwvg/menubar.prg
  * contrib/gtwvg/paint.prg
  * contrib/gtwvg/parthdlr.prg
  * contrib/gtwvg/tests/modal.prg
  * contrib/gtwvg/tests/utils.prg
  * contrib/gtwvg/toolbar.prg
    % VALTYPE() -> HB_IS*() and some related optimizations

  * tests/codebloc.prg
  * tests/newrdd.prg
  * tests/inkeytst.prg
  * tests/files.prg
  * tests/testrdd.prg
  * tests/wcecon.prg
  * tests/testrdd2.prg
  * tests/inifiles.prg
    * *LTRIM(STR()) -> hb_ntos()
      (keeping macro for Clipper where seemed necessary)
2012-10-11 23:46:23 +00:00

129 lines
2.6 KiB
Plaintext

/*
* $Id$
*/
// codeblocks test
PROCEDURE Main()
LOCAL B := "this will never print"
LOCAL a := {| b, c | OutStd( "I am a codeblock" + b + c ) }
LOCAL d
LOCAL de
LOCAL ar := { 1, 2 }
LOCAL YY, X
LOCAL x1, x2
HB_SYMBOL_UNUSED( b )
OutStd( "this should print first" )
OutStd( hb_eol() )
Eval( a, " with parameters", " ... and it works!" )
OutStd( hb_eol() )
d := "with access to local variables"
a := {| b, c | OutStd( "I am a second codeblock " + d + b + ;
iif( c == NIL, " empty second parameter ", c ) ), OutStd( hb_eol() ), "WITH return value" }
Eval( a, ", codeblock parameters" )
OutStd( hb_eol() )
Eval( a, ", codeblock parameters ", "and with second parameter" )
OutStd( hb_eol() )
OutStd( MyEval( a ) )
OutStd( hb_eol() )
OtherTest( a )
OutStd( hb_eol() )
AnotherTest( a, "==> Another " )
OutStd( hb_eol() )
a := {| c | iif( c == NIL, {| a | "First " + a }, {| a | "Second " + a } ) }
a := Eval( a )
OutStd( hb_eol() )
OutStd( Eval( a, "codeblock created in a codeblock" ) )
OutStd( hb_eol() )
OutStd( ar[ 1 ] )
OutStd( hb_eol() )
a := {|| ar[ 1 ]++ }
Eval( a )
OutStd( ar[ 1 ] )
OutStd( hb_eol() )
yy := 5
x := {| xx | OutStd( hb_ntos( xx ) ), OutStd( "+" ), OutStd( hb_ntos( yy ) ), OutStd( "=" ), xx + yy }
OutStd( Eval( x, 1 ) ) //this is OK
OutStd( hb_eol() )
OutStd( Eval( x, 1, 2 ) ) //this should ignore unnecesary parameters
QOut( Eval( RetBlock(), 5 ) )
// BugToFix()
OutStd( hb_eol() )
OutStd( "Trying to use detached variable ..." )
OutStd( hb_eol() )
x1 := 5
x2 := 6
de := DetachLocal( x1, x2 )
OutStd( Eval( de ) )
//changing the value of variables
OutStd( hb_eol() )
x1 := 10
x2 := 11
QOut( Eval( de ) )
de := DetachLocal( x1, x2 )
QOut( Eval( de ) )
RETURN
FUNCTION MyEval( bCodeBlock )
LOCAL D := "this is another variable"
RETURN Eval( bCodeBlock, " from ", "MyEval Function" )
PROCEDURE OtherTest( cblock )
LOCAL cb
cb := {| a, b | Eval( cblock, a, b ) }
Eval( cb, "--> with nested ", "EVAL" )
RETURN
PROCEDURE AnotherTest( cb, a )
OutStd( Eval( cb, a ) )
OutStd( hb_eol() )
OutStd( Eval( cb, a, "again and again" ) )
OutStd( hb_eol() )
RETURN
FUNCTION DetachLocal( x, y )
//NOTE! this should work
LOCAL z := x + y
LOCAL cb := {|| QOut( "z=x+y=" ), QOut( z ), QOut( "x*x=" ), QOut( x * x ), QOut( "x*x+z=" ), x * x + z }
RETURN cb
PROCEDURE BugToFix()
LOCAL b, a := {|| a + b }
b := "bug "
Eval( a )
RETURN
FUNCTION RetBlock()
RETURN {| x | x * x }