* tests/testsha1.prg
* tests/longdev.prg
* tests/clsccast.prg
* tests/cmphello.prg
* tests/clsicast.prg
* tests/testop.prg
* tests/clsscast.prg
* tests/objarr.prg
* tests/rddtest/rddmktst.prg
* tests/rddtest/adscl52.prg
* tests/rddtest/adscl53.prg
* tests/rddtest/ntxcl52.prg
* tests/rddtest/ntxcl53.prg
* tests/rddtest/cdxcl52.prg
* tests/rddtest/rddtst.prg
* tests/rddtest/cdxcl53.prg
* tests/transtst.prg
* tests/output.prg
* tests/ac_test2.prg
* tests/clsscope.prg
* tests/dosshell.prg
* tests/sbartest.prg
* tests/speedold.prg
* tests/sdf_test.prg
* tests/wcecon.prg
* tests/debugtst.prg
* tests/testdyn.c
* tests/multiarg.prg
* tests/fornext.prg
* tests/hbinline.prg
* tests/foreach2.prg
* tests/objasign.prg
* tests/scroll.prg
* tests/inherit.prg
* tests/rto_get.prg
* tests/boxtst2.prg
* tests/inkeytst.prg
* tests/overload.prg
* tests/cpinfo.prg
* tests/gtwin.prg
* tests/mt/mttest08.prg
* tests/mt/mttest09.prg
* tests/mt/mttest01.prg
* tests/mt/mttest10.prg
* tests/mt/mttest02.prg
* tests/mt/mttest11.prg
* tests/mt/mttest03.prg
* tests/mt/mttest12.prg
* tests/mt/mttest04.prg
* tests/mt/mttest05.prg
* tests/mt/mttest06.prg
* tests/mt/mttest07.prg
* tests/speedtst.prg
* tests/testsha2.prg
* tests/hsxtest.prg
* tests/arrayidx.prg
* tests/clsnv.prg
* tests/rto_tb.prg
* tests/gtchars.prg
* tests/disptest.prg
* tests/funcarr.prg
* tests/testhtml.prg
* tests/readhrb.prg
* tests/tstcolor.prg
* tests/gtxfnt.prg
* tests/devtest.prg
* tests/aliaslck.prg
* tests/stripem.prg
* tests/dynobj.prg
* tests/tb1.prg
* tests/round.prg
* tests/longstr.prg
* tests/testdyn.prg
* tests/testdyn1.prg
* tests/delimtst.prg
* tests/tstdspac.prg
* tests/version.prg
* tests/setkeys.prg
* tests/gtcolors.prg
* tests/destruct.prg
* tests/seconds.prg
* tests/gtkeys.prg
* tests/usrrdd/exarr.prg
* doc/en/diskspac.txt
* doc/en/string.txt
* doc/en/rdd.txt
* doc/en/hashes.txt
* doc/en/hb_apigt.txt
* doc/en/rddord.txt
* doc/en/hb_api.txt
* doc/en/hb_date.txt
* doc/en/math.txt
* doc/en/hb_vm.txt
* doc/en/treport.txt
* doc/en/terminal.txt
* doc/en/hb_apiln.txt
* doc/en/dir.txt
* doc/en/command.txt
* doc/en/rddmisc.txt
* doc/en/errsys.txt
* doc/en/nation.txt
* doc/en/var.txt
* doc/en/dbstrux.txt
* doc/en/datetime.txt
* doc/en/memo.txt
* doc/en/tgetlist.txt
* doc/en/tlabel.txt
* doc/en/1stread.txt
* doc/en/hb_set.txt
* doc/en/hb_compa.txt
* doc/en/hb_apier.txt
* doc/en/hbinet.txt
* doc/en/hb_macro.txt
* doc/en/array.txt
* doc/en/hb_apiit.txt
* doc/en/rdddb.txt
* doc/en/dbsdf.txt
* doc/en/hvm.txt
* doc/en/input.txt
* doc/en/dbdelim.txt
* doc/en/browse.txt
* doc/en/menu.txt
* doc/en/hb_apird.txt
* doc/en/hb_apifs.txt
* doc/en/file.txt
* doc/en/lang.txt
* doc/en/objfunc.txt
* doc/en/eval.txt
* doc/en/binnum.txt
* doc/en/tclass.txt
* doc/en/misc.txt
* doc/en/set.txt
* doc/en/readme.txt
* doc/man/harbour.1
* doc/man/hbmk2.1
* doc/man/hbpp.1
* doc/man/hbtest.1
* doc/man/hbrun.1
* examples/hbextern/hbextern.prg
* examples/pp/pp.c
* examples/pp/hbpragma.c
* examples/pp/hbppcore.c
* examples/pp/hbppcomp.c
* examples/pp/hbpptbl.c
* examples/pp/hbppdef.h
* examples/superlib/hbsuper.prg
* examples/hbsqlit2/hbsqlit2.ch
* examples/misc/mankala.prg
* examples/misc/guess.prg
* examples/rddado/adordd.prg
* examples/rddado/adordd.ch
* examples/hbapollo/apollo.ch
* examples/hbapollo/apollo.c
* examples/hbapollo/apollo1.prg
* examples/hbdoc2/gentpl.prg
* examples/hbdoc2/gentxt.prg
* examples/hbdoc2/tmplates.prg
* examples/hbdoc2/genxml.prg
* examples/hbdoc2/genhtml.prg
* examples/hbdoc2/hbdoc2.prg
* examples/hbdoc2/hbdoc2.ch
* examples/guestbk/guestbk.prg
* examples/httpsrv/uhttpd.ini
* examples/httpsrv/uhttpd.prg
* examples/httpsrv/cookie.prg
* examples/httpsrv/cgifunc.prg
* examples/httpsrv/session.prg
* examples/terminal/trm_cli.prg
* examples/terminal/terminal.prg
* examples/terminal/trm_srv.prg
* examples/terminal/trm_app.prg
* examples/hbbtree/hb_btree.h
* examples/hbbtree/hb_btree.ch
* examples/hbbtree/hb_btree.c
* examples/hbbtree/tbtree.prg
* examples/hscript/hscript.prg
* examples/hscript/dir.hs
* examples/hscript/multiply.hs
* examples/hscript/ugly.hs
* examples/hscript/hello.hs
* examples/gtwvw/hbole.h
* examples/gtwvw/wvwdraw.c
* examples/gtwvw/wvwmenu.c
* examples/gtwvw/gtwvw.c
* examples/gtwvw/wvwstbar.c
* examples/gtwvw/wvwcheck.c
* examples/gtwvw/wvwfuncs.c
* examples/gtwvw/wvwpush.c
* examples/gtwvw/wvwedit.c
* examples/gtwvw/wvwtbar.c
* examples/gtwvw/hbgtwvw.h
* Deleted 'www.' from harbour-project.org website name.
(www.harbour-project.org -> harbour-project.org)
408 lines
9.1 KiB
Plaintext
408 lines
9.1 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* The following parts are Copyright of the individual authors.
|
|
* www - http://harbour-project.org
|
|
*
|
|
* Copyright 1999 Jose Lanin <dezac@corevia.com>
|
|
* Documentation for: PROCLINE(),PROCFILE(),PROCNAME()
|
|
*
|
|
* Copyright 1999 Eddie Ruina
|
|
* Documentation for: __DBGVMVARLGET()
|
|
*
|
|
* Copyright 1999 Chen Kedem <niki@actcom.co.il>
|
|
* Documentation for: CLIPINIT(), __SETHELPK()
|
|
*
|
|
* Copyright 1999 Ryszard Glab <rglab@imid.med.pl>
|
|
* Documentation for: DO()
|
|
*
|
|
* See COPYING for licensing terms.
|
|
*
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* PROCNAME()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* Gets the name of the current function on the stack
|
|
* $SYNTAX$
|
|
* PROCNAME( <nLevel> ) --> <cProcName>
|
|
* $ARGUMENTS$
|
|
* <nLevel> is the function level required.
|
|
* $RETURNS$
|
|
* <cProcName> The name of the function that it is being executed.
|
|
* $DESCRIPTION$
|
|
* This function looks at the top of the stack and gets the current
|
|
* executed function if no arguments are passed. Otherwise it returns
|
|
* the name of the function or procedure at <nLevel>.
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* $TESTS$
|
|
* This test will show the functions and procedures in stack.
|
|
* before executing it.
|
|
* function Test()
|
|
* LOCAL n := 1
|
|
* while !Empty( ProcName( n ) )
|
|
* ? ProcName( n++ )
|
|
* end do
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCLINE(),PROCFILE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* PROCLINE()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* Gets the line number of the current function on the stack.
|
|
* $SYNTAX$
|
|
* PROCLINE( <nLevel> ) --> <nLine>
|
|
* $ARGUMENTS$
|
|
* <nLevel> is the function level required.
|
|
* $RETURNS$
|
|
* <nLine> The line number of the function that it is being executed.
|
|
* $DESCRIPTION$
|
|
* This function looks at the top of the stack and gets the current
|
|
* line number of the executed function if no arguments are passed.
|
|
* Otherwise it returns the line number of the function or procedure
|
|
* at <nLevel>.
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* $TESTS$
|
|
* function Test()
|
|
* ? ProcLine( 0 )
|
|
* ? ProcName( 2 )
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCNAME(),PROCFILE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* PROCFILE()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* This function allways returns an empty string.
|
|
* $SYNTAX$
|
|
* PROCFILE( <xExp> ) --> <cEmptyString>
|
|
* $ARGUMENTS$
|
|
* <xExp> is any valid type.
|
|
* $RETURNS$
|
|
* <cEmptyString> Return an empty string
|
|
* $DESCRIPTION$
|
|
* This function is added to the RTL for full compatibility. It
|
|
* always returns an empty string.
|
|
* $EXAMPLES$
|
|
* ? ProcFile()
|
|
* $TESTS$
|
|
* function Test()
|
|
* ? ProcFile()
|
|
* ? ProcFile( NIL )
|
|
* ? ProcFile( 2 )
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCNAME(),PROCLINE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* HB_PVALUE()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* Retrieves the value of an argument.
|
|
* $SYNTAX$
|
|
* HB_PVALUE( <nArg> ) --> <xExp>
|
|
* $ARGUMENTS$
|
|
* A number that indicates the argument to check.
|
|
* $RETURNS$
|
|
* <xExp> Returns the value stored by an argument.
|
|
* $DESCRIPTION$
|
|
* This function is useful to check the value stored in an argument.
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* $TESTS$
|
|
* function Test( nValue, cString )
|
|
* if PCount() == 2
|
|
* ? hb_PValue( 1 ), nValue
|
|
* ? hb_PValue( 2 ), cString
|
|
* endif
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* H
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PCOUNT()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* PCOUNT()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* Retrieves the number of arguments passed to a function.
|
|
* $SYNTAX$
|
|
* PCOUNT() --> <nArgs>
|
|
* $ARGUMENTS$
|
|
* None
|
|
* $RETURNS$
|
|
* <nArgs> A number that indicates the number of arguments
|
|
* passed to a function or procedure.
|
|
* $DESCRIPTION$
|
|
* This function is useful to check if a function or procedure
|
|
* has received the required number of arguments.
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* $TESTS$
|
|
* function Test( xExp )
|
|
* if PCount() == 0
|
|
* ? "This function needs a parameter"
|
|
* else
|
|
* ? xExp
|
|
* endif
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* HB_PVALUE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Procedure
|
|
* $NAME$
|
|
* __QUIT()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Events
|
|
* $ONELINER$
|
|
* Terminates an application.
|
|
* $SYNTAX$
|
|
* __QUIT()
|
|
* $ARGUMENTS$
|
|
* None
|
|
* $DESCRIPTION$
|
|
* This function terminates the current application and returns
|
|
* to the system.
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* $TESTS$
|
|
* function EndApp( lYesNo )
|
|
* if lYesNo
|
|
* __Quit()
|
|
* endif
|
|
* return nil
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* QUIT
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* CLIPINIT()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Internal
|
|
* $ONELINER$
|
|
* Initialize various Harbour sub-systems
|
|
* $SYNTAX$
|
|
* CLIPINIT() --> NIL
|
|
* $ARGUMENTS$
|
|
* none.
|
|
* $RETURNS$
|
|
* CLIPINIT() always return NIL.
|
|
* $DESCRIPTION$
|
|
* CLIPINIT() is one of the pre-defined INIT PROCEDURE and is executed
|
|
* at program startup. It declare an empty MEMVAR PUBLIC array called
|
|
* GetList that is going to be used by the Get system. It activates the
|
|
* default error handler, and (at least for the moment) calls the
|
|
* function that sets the default help key.
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* It is said that CLIPINIT() should not call the function that sets
|
|
* the default help key since CA-Cl*pper does it in some other place.
|
|
* $PLATFORMS$
|
|
* All
|
|
* $SEEALSO$
|
|
* INIT PROCEDURE
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Procedure
|
|
* $NAME$
|
|
* __SetHelpK()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Internal
|
|
* $ONELINER$
|
|
* Set F1 as the default help key
|
|
* $SYNTAX$
|
|
* __SetHelpK()
|
|
* $ARGUMENTS$
|
|
* None.
|
|
* $DESCRIPTION$
|
|
* Set F1 to execute a function called HELP if such a function is
|
|
* linked into the program.
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* __XHelp(),SET KEY,SETKEY()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Procedure
|
|
* $NAME$
|
|
* BREAK()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Error
|
|
* $ONELINER$
|
|
* Exits from a BEGIN SEQUENCE block
|
|
* $SYNTAX$
|
|
* BREAK( <xExp> )
|
|
* $ARGUMENTS$
|
|
* <xExp> is any valid expression. It is always required.
|
|
* If do not want to pass any argument, just use NIL.
|
|
* $DESCRIPTION$
|
|
* This function passes control to the RECOVER statement in a
|
|
* BEGIN SEQUENCE block.
|
|
* $EXAMPLES$
|
|
* Break( NIL )
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* BEGIN SEQUENCE
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $TEMPLATE$
|
|
* Function
|
|
* $NAME$
|
|
* DO()
|
|
* $CATEGORY$
|
|
* API
|
|
* $SUBCATEGORY$
|
|
* Application
|
|
* $ONELINER$
|
|
* Calls a procedure or a function
|
|
* $SYNTAX$
|
|
* DO( <xFuncProc> [, <xArguments...>] ) --> <xRetVal>
|
|
* $ARGUMENTS$
|
|
* <xFuncProc> = Either a string with a function/procedure name to be called
|
|
* or a codeblock to evaluate.
|
|
*
|
|
* <xArguments> = arguments passed to a called function/procedure or to
|
|
* a codeblock.
|
|
* $RETURNS$
|
|
* <xRetVal> A value that was returned from called function.
|
|
* $DESCRIPTION$
|
|
* This function can be called either by the harbour compiler or by user.
|
|
* The compiler always passes the item of IT_SYMBOL type that stores the
|
|
* name of procedure specified in DO <proc> WITH ... statement.
|
|
*
|
|
* If called procedure/function doesn't exist then a runtime error
|
|
* is generated.
|
|
*
|
|
* This function can be used as replacement of macro operator.
|
|
* It is also used internally to implement DO <proc> WITH <args...>
|
|
* In this case <xFuncProc> is of type HB_SYMB.
|
|
* $EXAMPLES$
|
|
* cbCode ={|x| MyFunc( x )}
|
|
* DO( cbCode, 1 )
|
|
*
|
|
* cFunction := "MyFunc"
|
|
* xRetVal := DO( cFunction, 2 )
|
|
*
|
|
* // Old style (slower):
|
|
* DO &cFunction WITH 3
|
|
* $COMPLIANCE$
|
|
* C
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $END$
|
|
*/
|