* make_deb.sh
* Removed wrong comment recently added.
(we will need to fix hbfimage compilation anyway)
* harbour-ce-spec
* harbour-w32-spec
* harbour.spec
* debian/control
* include/vm.api
* include/extend.api
* include/button.ch
* include/hbstack.h
* include/item.api
* include/rdd.api
* include/gt.api
* include/dbinfo.ch
* include/error.api
* include/filesys.api
* include/hbapigt.h
* include/clipdefs.h
* include/assert.ch
* include/fm.api
* include/extend.h
* source/compiler/genhrb.c
* config/os2/install.cf
* tests/db_brows.prg
* tests/debugtst.prg
* tests/ac_test.prg
* tests/testhtml.prg
* tests/tstcolor.prg
* doc/hdr_tpl.txt
* doc/man/harbour.1
* doc/dirstruc.txt
* doc/howtobld.txt
* doc/en/diskspac.txt
* doc/en/string.txt
* doc/en/rddord.txt
* doc/en/math.txt
* doc/en/error.txt
* doc/en/treport.txt
* doc/en/memvar2.txt
* doc/en/terminal.txt
* doc/en/dir.txt
* doc/en/rddmisc.txt
* doc/en/var.txt
* doc/en/nation.txt
* doc/en/dbstrux.txt
* doc/en/datetime.txt
* doc/en/memo.txt
* doc/en/tgetlist.txt
* doc/en/tlabel.txt
* doc/en/hb_compa.txt
* doc/en/array.txt
* doc/en/rdddb.txt
* doc/en/dbsdf.txt
* doc/en/tbrowse.txt
* doc/en/hvm.txt
* doc/en/input.txt
* doc/en/dbdelim.txt
* doc/en/browse.txt
* doc/en/menu.txt
* doc/en/file.txt
* doc/en/binnum.txt
* doc/en/tclass.txt
* doc/en/set.txt
* doc/en/misc.txt
* doc/en/sayget.txt
* doc/en/readme.txt
* doc/es/diskspac.txt
* doc/es/tlabel.txt
* doc/es/array.txt
* doc/es/dbsdf.txt
* doc/es/tbrowse.txt
* doc/es/math.txt
* doc/es/hvm.txt
* doc/es/treport.txt
* doc/es/input.txt
* doc/es/dbdelim.txt
* doc/es/browse.txt
* doc/es/memvar2.txt
* doc/es/command.txt
* doc/es/dir.txt
* doc/es/file.txt
* doc/es/eval.txt
* doc/es/binnum.txt
* doc/es/nation.txt
* doc/es/var.txt
* doc/es/tclass.txt
* doc/es/dbstrux.txt
* doc/es/misc.txt
* doc/es/datetime.txt
* doc/es/sayget.txt
* doc/es/memo.txt
* doc/es/readme.txt
* doc/es/tgetlist.txt
* doc/readme.txt
* contrib/hbct/ctnet.c
* contrib/hbct/video.c
* contrib/hbct/dattime3.c
* contrib/hbct/color.c
* contrib/hbnf/acctyear.prg
* contrib/hbnf/byteneg.prg
* contrib/hbnf/isshare.prg
* contrib/hbnf/sinkey.prg
* contrib/hbnf/dhkey.h
* contrib/hbnf/kspeed.c
* contrib/hbnf/prtscr.c
* contrib/hbnf/descendn.c
* contrib/hbnf/peek.c
* contrib/hbnf/scancode.prg
* contrib/hbnf/vidmode.prg
* contrib/hbnf/nwsem.prg
* contrib/hbnf/acctadj.prg
* contrib/hbnf/week.prg
* contrib/hbnf/vidcur.prg
* contrib/hbnf/iamidle.c
* contrib/hbnf/prtesc.prg
* contrib/hbnf/miltime.prg
* contrib/hbnf/proper.c
* contrib/hbnf/acctmnth.prg
* contrib/hbnf/savearr.prg
* contrib/hbnf/rand1.prg
* contrib/hbnf/madd.prg
* contrib/hbnf/dispmsg.prg
* contrib/hbnf/settime.prg
* contrib/hbnf/restsets.prg
* contrib/hbnf/page.prg
* contrib/hbnf/byt2bit.prg
* contrib/hbnf/setkeys.c
* contrib/hbnf/month.prg
* contrib/hbnf/byt2hex.prg
* contrib/hbnf/findith.prg
* contrib/hbnf/at2.prg
* contrib/hbnf/acctweek.prg
* contrib/hbnf/dispc.c
* contrib/hbnf/gcd.prg
* contrib/hbnf/pegs.prg
* contrib/hbnf/min2dhm.prg
* contrib/hbnf/acctqtr.prg
* contrib/hbnf/numlock.c
* contrib/hbnf/dosver.prg
* contrib/hbnf/nooccur.prg
* contrib/hbnf/dayofyr.prg
* contrib/hbnf/metaph.prg
* contrib/hbnf/ontick.c
* contrib/hbnf/menu1.prg
* contrib/hbnf/byteand.prg
* contrib/hbnf/sqzn.prg
* contrib/hbnf/bytexor.prg
* contrib/hbnf/ftidle.c
* contrib/hbnf/workdays.prg
* contrib/hbnf/byteor.prg
* contrib/hbnf/asum.prg
* contrib/hbnf/shift.c
* contrib/hbnf/sleep.prg
* contrib/hbnf/wda.prg
* contrib/hbnf/aavg.prg
* contrib/hbnf/woy.prg
* contrib/hbnf/origin.c
* contrib/hbnf/any2any.prg
* contrib/hbnf/chdir.c
* contrib/hbnf/adessort.prg
* contrib/hbnf/setdate.prg
* contrib/hbnf/netpv.prg
* contrib/hbnf/amedian.prg
* contrib/hbnf/blink.prg
* contrib/hbnf/stod.c
* contrib/hbnf/vertmenu.prg
* contrib/hbnf/qtr.prg
* contrib/hbnf/linked.prg
* contrib/hbnf/n2color.c
* contrib/hbnf/aredit.prg
* contrib/hbnf/alt.c
* contrib/hbnf/xbox.prg
* contrib/hbnf/ftround.prg
* contrib/hbnf/hex2dec.prg
* contrib/hbnf/nwuid.prg
* contrib/hbnf/dectobin.prg
* contrib/hbnf/bitset.prg
* contrib/hbnf/aemaxlen.prg
* contrib/hbnf/nwlstat.prg
* contrib/hbnf/invclr.prg
* contrib/hbnf/ctrl.c
* contrib/hbnf/lastday.prg
* contrib/hbnf/tempfile.prg
* contrib/hbnf/diskfunc.prg
* contrib/hbnf/scregion.prg
* contrib/hbnf/mouse2.prg
* contrib/hbnf/d2e.prg
* contrib/hbnf/ftisprn.c
* contrib/hbnf/pickday.prg
* contrib/hbnf/firstday.prg
* contrib/hbnf/daytobow.prg
* contrib/hbnf/anomatch.prg
* contrib/hbnf/pvid.prg
* contrib/hbnf/isbiton.prg
* contrib/hbnf/color2n.c
* contrib/hbnf/isbit.prg
* contrib/hbnf/putkey.c
* contrib/hbnf/cntryset.prg
* contrib/hbnf/datecnfg.prg
* contrib/hbnf/getenvrn.c
* contrib/hbnf/easter.prg
* contrib/hbnf/bytenot.prg
* contrib/hbnf/ntow.prg
* contrib/hbnf/poke.c
* contrib/hbnf/aeminlen.prg
* contrib/hbnf/floptst.prg
* contrib/hbnf/pchr.prg
* contrib/hbnf/savesets.prg
* contrib/hbnf/mkdir.c
* contrib/hbnf/year.prg
* contrib/hbnf/caplock.c
* contrib/hbnf/rmdir.c
* contrib/hbnf/calendar.prg
* contrib/hbnf/e2d.prg
* contrib/hbnf/elapsed.prg
* contrib/hbnf/sysmem.prg
* contrib/hbnf/bitclr.prg
* contrib/hbnf/eltime.prg
* contrib/hbnf/aading.prg
* contrib/hbnf/dfile.prg
* contrib/hbnf/elapmil.prg
* contrib/hbnf/setlastk.c
* contrib/hbnf/pending.prg
* contrib/hbnf/clrsel.prg
* contrib/rddads/doc/en/adsfuncs.txt
* contrib/rddads/doc/en/readme.txt
* contrib/hbclip/hbclip.ch
* contrib/hbclip/readme.txt
* contrib/hbmisc/doc/en/ht_dbf.txt
* utils/hbdoc/rtf.prg
* utils/hbdoc/fclass1.prg
* utils/hbdoc/genos2.prg
* utils/hbdoc/genng.prg
* utils/hbdoc/genasc.prg
* utils/hbdoc/genchm.prg
* utils/hbdoc/os2.prg
* utils/hbdoc/ng.prg
* utils/hbdoc/genhpc.prg
* utils/hbdoc/html.prg
* utils/hbdoc/ffile1.prg
* utils/hbdoc/ft_funcs.prg
* utils/hbdoc/hbdoc.prg
* utils/hbdoc/troff.prg
* utils/hbdoc/genhtm.prg
* utils/hbdoc/genpdf1.prg
* utils/hbdoc/gentrf.prg
* utils/hbdoc/genrtf.prg
* utils/hbmake/fclass1.prg
* utils/hbmake/prb_stak.prg
* utils/hbmake/ffile1.prg
* utils/hbmake/ft_funcs.prg
* utils/hbmake/pickfile.prg
* utils/hbmake/hbmutils.prg
* More cleanups, formatting (filename casing, CA-Cl*pper, etc).
406 lines
10 KiB
Plaintext
406 lines
10 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* The following parts are Copyright of the individual authors.
|
|
* www - http://www.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 doc/license.txt for licensing terms.
|
|
*
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* PROCNAME()
|
|
* $CATEGORY$
|
|
* Misc
|
|
* $ONELINER$
|
|
* Gets the name of the current function on the stack
|
|
* $SYNTAX$
|
|
* PROCNAME( <nLevel> ) --> <cProcName>
|
|
* $ARGUMENTS$
|
|
* <nLevel> is the function level required. </par>
|
|
* $RETURNS$
|
|
* <cProcName> The name of the function that it is being executed. </par>
|
|
* $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>. </par>
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* </fixed>
|
|
* $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
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* PROCNAME() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCLINE(),PROCFILE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* PROCLINE()
|
|
* $CATEGORY$
|
|
* Misc
|
|
* $ONELINER$
|
|
* Gets the line number of the current function on the stack.
|
|
* $SYNTAX$
|
|
* PROCLINE( <nLevel> ) --> <nLine>
|
|
* $ARGUMENTS$
|
|
* <nLevel> is the function level required. </par>
|
|
* $RETURNS$
|
|
* <nLine> The line number of the function that it is being executed. </par>
|
|
* $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>. </par>
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* </fixed>
|
|
* $TESTS$
|
|
* function Test()
|
|
* ? ProcLine( 0 )
|
|
* ? ProcName( 2 )
|
|
* return nil
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* PROCLINE() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCNAME(),PROCFILE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* PROCFILE()
|
|
* $CATEGORY$
|
|
* Misc
|
|
* $ONELINER$
|
|
* This function allways returns an empty string.
|
|
* $SYNTAX$
|
|
* PROCFILE( <xExp> ) --> <cEmptyString>
|
|
* $ARGUMENTS$
|
|
* <xExp> is any valid type. </par>
|
|
* $RETURNS$
|
|
* <cEmptyString> Return an empty string </par>
|
|
* $DESCRIPTION$
|
|
* This function is added to the RTL for full compatibility. It
|
|
* always returns an empty string. </par>
|
|
* $EXAMPLES$
|
|
* ? ProcFile()
|
|
* </fixed>
|
|
* $TESTS$
|
|
* function Test()
|
|
* ? ProcFile()
|
|
* ? ProcFile( NIL )
|
|
* ? ProcFile( 2 )
|
|
* return nil
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* PROCFILE() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PROCNAME(),PROCLINE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* HB_PVALUE()
|
|
* $CATEGORY$
|
|
* Parameter Checks
|
|
* $ONELINER$
|
|
* Retrieves the value of an argument.
|
|
* $SYNTAX$
|
|
* HB_PVALUE( <nArg> ) --> <xExp>
|
|
* $ARGUMENTS$
|
|
* A number that indicates the argument to check. </par>
|
|
* $RETURNS$
|
|
* <xExp> Returns the value stored by an argument. </par>
|
|
* $DESCRIPTION$
|
|
* This function is useful to check the value stored in an argument. </par>
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* </fixed>
|
|
* $TESTS$
|
|
* function Test( nValue, cString )
|
|
* if PCount() == 2
|
|
* ? hb_PValue( 1 ), nValue
|
|
* ? hb_PValue( 2 ), cString
|
|
* endif
|
|
* return nil
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* HB_PVALUE() is a new function and hence not CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* PCOUNT()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* PCOUNT()
|
|
* $CATEGORY$
|
|
* Parameter Checks
|
|
* $ONELINER$
|
|
* Retrieves the number of arguments passed to a function.
|
|
* $SYNTAX$
|
|
* PCOUNT() --> <nArgs>
|
|
* $ARGUMENTS$
|
|
* None </par>
|
|
* $RETURNS$
|
|
* <nArgs> A number that indicates the number of arguments
|
|
* passed to a function or procedure. </par>
|
|
* $DESCRIPTION$
|
|
* This function is useful to check if a function or procedure
|
|
* has received the required number of arguments. </par>
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* </fixed>
|
|
* $TESTS$
|
|
* function Test( xExp )
|
|
* if PCount() == 0
|
|
* ? "This function needs a parameter"
|
|
* else
|
|
* ? xExp
|
|
* endif
|
|
* return nil
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* PCOUNT() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* HB_PVALUE()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* __QUIT()
|
|
* $CATEGORY$
|
|
* Events
|
|
* $ONELINER$
|
|
* Terminates an application.
|
|
* $SYNTAX$
|
|
* __QUIT() --> NIL
|
|
* $ARGUMENTS$
|
|
* None </par>
|
|
* $RETURNS$
|
|
* NIL </par>
|
|
* $DESCRIPTION$
|
|
* This function terminates the current application and returns
|
|
* to the system. </par>
|
|
* $EXAMPLES$
|
|
* See Test
|
|
* </fixed>
|
|
* $TESTS$
|
|
* function EndApp( lYesNo )
|
|
* if lYesNo
|
|
* __Quit()
|
|
* endif
|
|
* return nil
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* __QUIT() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* QUIT
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* CLIPINIT()
|
|
* $CATEGORY$
|
|
* Internal
|
|
* $ONELINER$
|
|
* Initialize various Harbour sub-systems
|
|
* $SYNTAX$
|
|
* CLIPINIT() --> NIL
|
|
* $ARGUMENTS$
|
|
* none. </par>
|
|
* $RETURNS$
|
|
* CLIPINIT() always return NIL. </par>
|
|
* $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. </par>
|
|
* $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. </par>
|
|
* $PLATFORMS$
|
|
* All </par>
|
|
* $SEEALSO$
|
|
* INIT PROCEDURE
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* __SetHelpK()
|
|
* $CATEGORY$
|
|
* Internal
|
|
* $ONELINER$
|
|
* Set F1 as the default help key
|
|
* $SYNTAX$
|
|
* __SetHelpK() --> NIL
|
|
* $ARGUMENTS$
|
|
* None. </par>
|
|
* $RETURNS$
|
|
* __SetHelpK() always return NIL. </par>
|
|
* $DESCRIPTION$
|
|
* Set F1 to execute a function called HELP if such a function is
|
|
* linked into the program. </par>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* __SetHelpK() works exactly like CA-Cl*pper's __SetHelpK() </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* __XHelp(),SET KEY,SETKEY()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* BREAK()
|
|
* $CATEGORY$
|
|
* Error recovery
|
|
* $ONELINER$
|
|
* Exits from a BEGIN SEQUENCE block
|
|
* $SYNTAX$
|
|
* BREAK( <xExp> ) --> NIL
|
|
* $ARGUMENTS$
|
|
* <xExp> is any valid expression. It is always required.
|
|
* If do not want to pass any argument, just use NIL. </par>
|
|
* $RETURNS$
|
|
* NIL </par>
|
|
* $DESCRIPTION$
|
|
* This function passes control to the RECOVER statement in a
|
|
* BEGIN SEQUENCE block. </par>
|
|
* $EXAMPLES$
|
|
* Break( NIL )
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* BREAK() is fully CA-Cl*pper compliant. </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $SEEALSO$
|
|
* BEGIN SEQUENCE
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* DO()
|
|
* $CATEGORY$
|
|
* Utility
|
|
* $ONELINER$
|
|
* Calls a procedure or a function
|
|
* $SYNTAX$
|
|
* DO( <xFuncProc> [, <xArguments...>] )
|
|
* $ARGUMENTS$
|
|
* <xFuncProc> = Either a string with a function/procedure name to be called
|
|
* or a codeblock to evaluate. </par>
|
|
* <xArguments> = arguments passed to a called function/procedure or to
|
|
* a codeblock. </par>
|
|
* $RETURNS$
|
|
* A value that was returned from called function. </par>
|
|
* $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. </par>
|
|
* If called procedure/function doesn't exist then a runtime error
|
|
* is generated. </par>
|
|
* 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. </par>
|
|
* $EXAMPLES$
|
|
* cbCode ={|x| MyFunc( x )}
|
|
* DO( cbCode, 1 )
|
|
*
|
|
* cFunction := "MyFunc"
|
|
* xRetVal :=DO( cFunction, 2 )
|
|
*
|
|
* Old style (slower):
|
|
* DO &cFunction WITH 3
|
|
* </fixed>
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* __DBGVMVARLGET()
|
|
* $CATEGORY$
|
|
* Variable Management
|
|
* $ONELINER$
|
|
* Retrive a local variable from a procedure level
|
|
* $SYNTAX$
|
|
* __DBGVMVARLGET( <nProcLevel>, <nLocal> )
|
|
* $ARGUMENTS$
|
|
* <nProcLevel> Is the procedure level, same as used in ProcName()
|
|
* and ProcLine(), from which a local variable containts is going to
|
|
* be retrieved. </par>
|
|
* <nLocal> Is the index of the local variable to retrieve. </par>
|
|
* $RETURNS$
|
|
* The containts of a specific local variable </par>
|
|
* $DESCRIPTION$
|
|
* This function is used from the debugger </par>
|
|
* $FILES$
|
|
* Library is vm
|
|
* $END$
|
|
*/
|