* utils/hbmk2/hbmk2.*.po
* utils/hbmk2/hbmk2.prg
+ do not share plugin variables (hbmk[ "vars" ])
between different plugins. It avoids potentially nasty
issues with plugins stepping onto each other's toes.
[INCOMPATIBLE - though it's unlikely anyone is
affected. If you must communicate between plugins,
use public function or variable.]
+ clarified in help that -icon might not work on all
platforms/compilers and detailed Windows implementation
(in particular it's disabled on bcc/bcc64 and on
mingw it won't work when a manual .rc is specified,
also on some (old?) msvc versions. Consult your
C compiler's Windows resource handling limitations.)
+ clarified in help the syntax of filters
+ clarified in help that .hbp references are handled as
sub-projects
+ clarification to command substitution macro
+ clarification to filter syntax note
! strict parameter checks in all public shell APIs to
avoid RTEs inside hbmk2 due to faulty API usage by scripts
* utils/hbmk2/examples/plug_bis.hb
* updated according to latest plugin changes
* include/harbour.hbx
* include/hbapi.h
* src/vm/debug.c
* src/vm/hvm.c
+ added internal function hb_vmInternalsEnabled()
to query whether potentially sensitive internals
are allowed to be accessed by public Harbour APIs
+ added .prg level function __vmNoInternals()
to disable potentially sensitive internals
by default accessible via public APIs.
Intentionally a one-way function: once disabled,
it cannot be reenabled from .prg or .c level.
NOTE: It will break Harbour debug functionality,
so it'd will be useful for hbrun scripts and
release (non-debug) builds.
+ modified internal __dbg*() functions to return
dummy values when internals are disabled via
__vmNoInternals() functions. While the function
return types are kept, apps relying on their
specific values and certain relationships between
them might break.
; NOTE: In the future, some more internals might
be protected by this setting (f.e. low-level
object and class functions and some API from
hbdebug lib)
; Please review
* tests/debugtst.prg
! fixed to compile warning-free without lowering
warning level
! fixed to run RTE-free with internals disabled
* bin/3rdpatch.hb
* bin/commit.hb
* config/postinst.hb
* contrib/make.hb
* contrib/hbtest/hbtest.ch
* src/debug/*.prg
* src/rtl/tclass.prg
* utils/hbmk2/examples/plug_bis.hb
* utils/hbmk2/examples/plug_tpl.hb
* use short form #pragmas (the ones identical
to Harbour options)
; NOTE: Except -l which works reversed compared
to cmdline -l option. TOFIX? (I tried and failed)
* src/rtl/hbi18n2.prg
* contrib/xhb/tfile.prg
* use F_ERROR instead of -1 literal
* contrib/xhb/xhbtedit.prg
! replaced dirty xhb extension with std SubStr() call
Reported by Tony Quick
[pls report such bugs on Harbour devl list]
* contrib/hbodbc/todbc.prg
! Don't continue ::Open() when SQLExecDir() have error
Fix from xhb via Vicente Guerra, with cleanups.
* tests/multifnc/multifnc.hbp
+ added comment
+ support for watcom
* tests/multifnc/t1.prg
! missing file ending EOL
* tests/*.prg
* extras/gtwvw/tests/wvwtest9.prg
* formatting
263 lines
6.4 KiB
Plaintext
263 lines
6.4 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* $Doc$
|
|
* $Description$ Debug function tests.
|
|
* Based on classes.prg
|
|
* $End$
|
|
*
|
|
* 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() )
|
|
|
|
Pause()
|
|
|
|
? "-DEBUG Functions-"
|
|
? "-Statics-"
|
|
? hb_ValToExp( __dbgVMVarSList() )
|
|
|
|
? "-Global Stack-"
|
|
? hb_ValToExp( __dbgVMStkGList() )
|
|
|
|
? "-Local Stack-"
|
|
? hb_ValToExp( __dbgVMStkLList() )
|
|
|
|
? "-Parameters-"
|
|
? hb_ValToExp( __dbgVMParLList() )
|
|
|
|
Pause()
|
|
|
|
FuncSecond( 241, "Hello" )
|
|
|
|
RETURN
|
|
|
|
FUNCTION Pause()
|
|
|
|
RETURN __Accept( "" )
|
|
|
|
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
|
|
|
|
Pause()
|
|
|
|
RETURN NIL
|
|
|
|
|
|
/* $Doc$
|
|
* $FuncName$ <oForm> TForm()
|
|
* $Description$ Returns TForm object
|
|
* $End$ */
|
|
|
|
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
|
|
|
|
|
|
/* $Doc$
|
|
* $FuncName$ <oForm> TForm:New()
|
|
* $Description$ Constructor
|
|
* $End$ */
|
|
|
|
STATIC FUNCTION New()
|
|
|
|
LOCAL Self := QSelf()
|
|
|
|
::nTop := 10
|
|
::nLeft := 10
|
|
::nBottom := 20
|
|
::nRight := 40
|
|
|
|
RETURN Self
|
|
|
|
|
|
/* $Doc$
|
|
* $FuncName$ TForm:Show()
|
|
* $Description$ Show a form
|
|
* $End$ */
|
|
|
|
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
|