Files
harbour-core/harbour/tests/debug.prg
Viktor Szakats 13aa09f395 2013-03-11 12:07 UTC+0100 Viktor Szakats (harbour syenar.net)
* utils/hbmk2/hbmk2.prg
    + added help and Markdown output for hbrun mode,
      using same options as in hbmk2 mode, run 'hbrun -help'
    + documented how to disable hbrun history
    + documented script search and and script autodetection details
    + documented opening .dbf files
    + documented how to paste text into shell prompt
    + documented limitation that in script INIT PROCEDUREs,
      automatic selection of interactive GT doesn't work
    + __Accept(), __Wait() to trigger interactive GT in scripts

  * src/rtl/objfunc.prg
    ! __objGetMsgList(): fixed to not rely on any assumption
      about the collation. In UTF8EX mode it was always
      returning empty array.
      Plus cleanup/optimizations

  * contrib/xhb/hbxml.c
    ! fix to a memory double free
      Thanks to Jose F. Gimenez for the patch.

  * contrib/hbtest/core.prg
  * contrib/hbtest/tests/test.prg
  * contrib/hbamf/tests/test.prg
    + added support and tests for tests returning
      array, hash and object types
    * changed zero byte to be escaped to \0 (was \000)
    + added memo tests and related engine cleanups

  * src/rtl/valtoexp.prg
    + hb_ValToExp(): output for objects changed to use double
      quotes for strings instead of a mixture of double/single
      ones, to make it easier stringifying the result

  * src/rtl/hbfilehi.prg
    % hb_DirSepDel(): minor optimization

  * tests/fixcase.hb
    + correct casing of EXTERN/REQUEST references

  * contrib/hbwin/tests/olesrv4.prg
  * contrib/hbxpp/hbxpp.ch
  * contrib/xhb/hterrsys.prg
  * contrib/xhb/xhb.ch
  * extras/httpsrv/uhttpd.prg
  * src/rdd/dbdelim.prg
  * src/rtl/tgetint.prg
  * src/rtl/tpersist.prg
  * tests/ppapi.prg
  * tests/set.prg
    ! run fixcase.hb to format REQUEST/EXTERNs

  * contrib/hbmisc/spd.c
  * contrib/hbmisc/hbnf.hbx
    ! missing casing for one function

  + tests/extend1.hbp
  * tests/extend1.prg
  * tests/extend2.c
    ! fixed to build and run again under Harbour

  * tests/debug.prg
  * tests/dynobj.prg
  * tests/for2.prg
  * tests/memvar.prg
  * tests/ppapi.prg
  * tests/scroll.prg
  * tests/set.prg
  * tests/str.prg
    * __Accept() changed to WAIT or Inkey( 0 )

  - contrib/hbrun/hbrun.1
  * config/postinst.hb
    * deleted hbrun's (outdated) man doc.
      Now built into hbmk2.prg as hbrun help.

  * contrib/hbmisc/hb_f.c
  * contrib/xhb/tests/xml1.prg
  * tests/hrbext.prg
    * comment/minor update

  * tests/hrb.prg
  * tests/hrbext.prg
    + hrb.prg to create .hrb file if it doesn't exist
    + added INIT PROCEDURE

  * contrib/gtwvg/*.h
  * contrib/gtwvg/gtwvgd.c
  * contrib/hbnf/fttext.c
  * contrib/hbwin/hbwinole.h
  * contrib/rddads/adsfunc.c
  * contrib/rddbm/bmdbfx.c
  * doc/c_std.txt
  * extras/gtwvw/docs/funclist.txt
  * extras/gtwvw/wvwpush.c
  * include/*.h
  * src/codepage/cp_utf8.c
  * src/common/*.c
  * src/compiler/*.c
  * src/rdd/dbfcdx/dbfcdx1.c
  * src/rdd/dbffpt/dbffpt1.c
  * src/rdd/dbfnsx/dbfnsx1.c
  * src/rdd/dbfntx/dbfntx1.c
  * src/rdd/hsx/hsx.c
  * src/rdd/usrrdd/rdds/arrayrdd.prg
  * src/rdd/*.c
  * src/rtl/*.c
  * src/rtl/gtsln/gtsln.h
  * src/rtl/gttrm/gttrm.c
  * src/rtl/gtwvt/gtwvt.c
  * src/vm/*.c
    * ! operator synced with uncrustify format
    * minor corrections in comment/text

  * tests/codebl.prg
  * tests/codebloc.prg
  * tests/dates3.prg
  * tests/foreach.prg
  * tests/macro.prg
  * tests/mouse.prg
  * tests/onidle.prg
  * tests/tbrowse.prg
  * tests/vmasort.prg
  * tests/wvtext.prg
  * website/samples/codebl.prg.html
  * website/samples/codebloc.prg.html
  * website/samples/dates3.prg.html
  * website/samples/foreach.prg.html
  * website/samples/macro.prg.html
  * website/samples/mouse.prg.html
  * website/samples/onidle.prg.html
  * website/samples/tbrowse.prg.html
    % local functions marked STATIC

  * contrib/hbmisc/spd.c
  * contrib/hbnf/clrsel.prg
  * contrib/hbnf/doc/en/*.txt
  * contrib/hbnf/popadder.prg
  * contrib/hbnf/tests/clrsel.prg
  * contrib/hbwin/win_tprn.prg
  * doc/en/datetime.txt
  * doc/en/set.txt
  * doc/oldnews.txt
  * extras/gfspell/spell.prg
  * extras/gtwvw/docs/gtwvw.txt
  * extras/gtwvw/hbgtwvw.h
  * extras/gtwvw/tests/ebtest7.prg
  * extras/gtwvw/wvwdraw.c
  * extras/gtwvw/wvwpush.c
  * tests/clsscope.prg
  * tests/extend1.prg
    ! few more dates converted to ISO format
2013-03-11 11:14:16 +00:00

241 lines
6.1 KiB
Plaintext

/*
* $Id$
*/
/*
* Debug function tests
*
* Written by Eddie Runia <eddie@runia.com>
* www - http://harbour-project.org
*
* Placed in the public domain
*/
PROCEDURE Main()
LOCAL oForm := TForm():New()
LOCAL nNumber := 15
HB_SYMBOL_UNUSED( nNumber )
? oForm:ClassName()
oForm:Show()
?
? "-OBJECT additions-"
? "What is in oForm ? "
? hb_ValToExp( oForm:Transfer() )
? "Does transfer exists ? ", __objHasMsg( oForm, "Transfer" )
? "Is transfer DATA ? ", __objHasData( oForm, "Transfer" )
? "Is transfer METHOD ? ", __objHasMethod( oForm, "Transfer" )
? "Does nLeft exists ? ", __objHasMsg( oForm, "nLeft" )
? "Is nLeft DATA ? ", __objHasData( oForm, "nLeft" )
? "Is nLeft METHOD ? ", __objHasMethod( oForm, "nLeft" )
? "Does unknown exists ? ", __objHasMsg( oForm, "Unknown" )
? "Is unknown DATA ? ", __objHasData( oForm, "Unknown" )
? "Is unknown METHOD ? ", __objHasMethod( oForm, "Unknown" )
? "Set nLeft to 50 and nRight to 100"
oForm:Transfer( { "nLeft", 50 }, { "nRight", 100 } )
? hb_ValToExp( oForm:Transfer() )
Inkey( 0 )
? "-DEBUG Functions-"
? "-Statics-"
? hb_ValToExp( __dbgVMVarSList() )
? "-Global Stack-"
? hb_ValToExp( __dbgVMStkGList() )
? "-Local Stack-"
? hb_ValToExp( __dbgVMStkLList() )
? "-Parameters-"
? hb_ValToExp( __dbgVMParLList() )
Inkey( 0 )
FuncSecond( 241, "Hello" )
RETURN
STATIC FUNCTION FuncSecond( nParam, cParam, uParam )
LOCAL cWhat := "Something"
LOCAL nNumber := 2
LOCAL xParam
LOCAL xStack
HB_SYMBOL_UNUSED( cWhat )
HB_SYMBOL_UNUSED( nNumber )
HB_SYMBOL_UNUSED( nParam )
HB_SYMBOL_UNUSED( cParam )
HB_SYMBOL_UNUSED( uParam )
?
? "-Second procedure-"
?
? "-Statics-"
? hb_ValToExp( __dbgVMVarSList() )
?
? "-Global Stack- Len=", __dbgVMStkGCount()
? hb_ValToExp( __dbgVMStkGList() )
?
? "-Local Stack- Len=", __dbgVMStkLCount()
? hb_ValToExp( xStack := __dbgVMStkLList() )
?
? "-Parameters-"
? hb_ValToExp( xParam := __dbgVMParLList() )
IF ! Empty( xStack ) .AND. xParam[ xStack[ 7 ] ] == "Hello"
? ":-)"
ENDIF
Inkey( 0 )
RETURN NIL
/* TForm() -> <oTForm> */
STATIC FUNCTION TForm()
STATIC s_oClass
IF s_oClass == NIL
s_oClass := HBClass():New( "TFORM" ) // starts a new class definition
s_oClass:AddData( "cName" ) // define this class objects datas
s_oClass:AddData( "nTop" )
s_oClass:AddData( "nLeft" )
s_oClass:AddData( "nBottom" )
s_oClass:AddData( "nRight" )
s_oClass:AddVirtual( "aExcept" ) // Export exceptions
s_oClass:AddMethod( "New", @New() ) // define this class objects methods
s_oClass:AddMethod( "Show", @Show() )
s_oClass:AddMethod( "Transfer", @Transfer() )
s_oClass:Create() // builds this class
ENDIF
RETURN s_oClass:Instance() // builds an object of this class
STATIC FUNCTION New()
LOCAL Self := QSelf()
::nTop := 10
::nLeft := 10
::nBottom := 20
::nRight := 40
RETURN Self
STATIC FUNCTION Show()
LOCAL Self := QSelf()
? "lets show a form from here :-)"
RETURN NIL
//
// <xRet> TForm:Transfer( [<xArg,..>] )
//
// Generic object import and export function
//
// <xArg> is present.
//
// Maximum number of arguments passed is limited to 10 !
//
// An argument can be one of the following :
//
// { <cSymbol>, <xValue> } Set DATA <cSymbol> to <xValue>
// { { <cSym1>, <xVal1> }, { <cSym2>, <xVal2> }, ... }
// Set a whole list symbols to value
// Normal way of set objects from external
// sources, like memo files.
// <oObject> Set self according to the DATA
// contained in <oObject>
// Can be used to transfer info from
// one class to another
//
// If <xArg> is not present, the current object will be returned as an array
// for description see __objSetValueList / __objGetValueList.
//
// The method aExcept() is called to determine the DATA which should not
// be returned. Eg. hWnd ( do not copy this DATA from external source )
//
// Say we want to copy oSource into oTarget we say :
//
// oTarget:Transfer( oSource )
//
// If we do not want 'cName' duplicated we have to use __objGetValueList :
//
// aNewExcept := AClone( oSource:aExcept() )
// AAdd( aNewExcept, "cName" ) /* Add cName to exception list */
// oTarget:Transfer( __objGetValueList( oSource, aNewExcept ) )
// /* Get DATA from oSource with new exceptions */
// /* Transfer DATA to oTarget */
//
// To set two DATA of oTarget :
//
// oTarget:Transfer( { "nLeft", 10 }, { "nRight", 5 } )
//
// or :
//
// aCollect := {}
// AAdd( aCollect, { "nLeft" , 10 } )
// AAdd( aCollect, { "nRight", 5 } )
// oTarget:Transfer( aCollect )
//
// Copy oSource to a memo field :
//
// DbObject->Memo := oSource:Transfer()
//
// (Re)create oTarget from the memo field :
//
// oTarget := TTarget():New()
// oTarget:Transfer( DbObject->Memo )
//
STATIC FUNCTION Transfer( ... )
LOCAL self := QSelf()
LOCAL aParam := __dbgVMParLList()
LOCAL nLen := PCount()
LOCAL xRet
LOCAL xData
IF nLen == 0
xRet := __objGetValueList( self, ::aExcept() )
ELSE
FOR EACH xData IN aParam
IF HB_ISARRAY( xData )
IF HB_ISARRAY( xData[ 1 ] ) // 2D array passed
xRet := __objSetValueList( self, xData )
ELSE // 1D array passed
xRet := __objSetValueList( self, { xData } )
ENDIF
ELSEIF HB_ISOBJECT( xData ) // Object passed
xRet := ::Transfer( xData:Transfer() )
ELSEIF !( ValType( xData ) == "U" )
? "TRANSFER: Incorrect argument(", xData:__enumIndex(), ") ", xData
ENDIF
NEXT
ENDIF
RETURN xRet