* 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).
450 lines
15 KiB
Plaintext
450 lines
15 KiB
Plaintext
/*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* The following parts are Copyright of the individual authors.
|
|
* www - http://www.harbour-project.org
|
|
*
|
|
* Copyright 1999 Chen Kedem <niki@actcom.co.il>
|
|
* Documentation for: READKEY()
|
|
*
|
|
* See doc/license.txt for licensing terms.
|
|
*
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* INKEY()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Extracts the next key code from the Harbour keyboard buffer.
|
|
* $SYNTAX$
|
|
* INKEY( [<nTimeout>] [,<nEvents>] ) --> nKey
|
|
* $ARGUMENTS$
|
|
* <nTimeout> is an optional timeout value in seconds, with a granularity
|
|
* of 1/10th of a second. If omitted, INKEY() returns immediately. If set
|
|
* to 0, INKEY() waits until an input event occurs. If set to any other
|
|
* value, INKEY() will return either when an input event occurs or when
|
|
* the timeout period has elapsed. If only this parameter is specified
|
|
* and it is not numeric, it will be treated as if it were 0. But if both
|
|
* parameters are specified and this parameter is not numeric, it will be
|
|
* treated as if it were not present.
|
|
*
|
|
* <nEvents> is an optional mask of input events that are to be enabled.
|
|
* If omitted, defaults to hb_set.HB_SET_EVENTMASK. Valid input masks are
|
|
* in inkey.ch and are explained below. It is recommended that the mask
|
|
* names be used rather than their numeric values, in case the numeric
|
|
* values change in future releases of Harbour. To allow more than one
|
|
* type of input event, simply add the various mask names together.
|
|
*
|
|
* <table>
|
|
* inkey.ch Meaning
|
|
*
|
|
* INKEY_MOVE Mouse motion events are allowed
|
|
* INKEY_LDOWN The mouse left click down event is allowed
|
|
* INKEY_LUP The mouse left click up event is allowed
|
|
* INKEY_RDOWN The mouse right click down event is allowed
|
|
* INKEY_RUP The mouse right click up event is allowed
|
|
* INKEY_KEYBOARD All keyboard events are allowed
|
|
* INKEY_ALL All mouse and keyboard events are allowed
|
|
* HB_INKEY_EXTENDED Extended keyboard codes are used.
|
|
* </table>
|
|
* If the parameter is not numeric, it will be treated as if it were set
|
|
* to hb_set.HB_SET_EVENTMASK.
|
|
* $RETURNS$
|
|
* 0 in case of timeout with no input event, otherwise returns a value
|
|
* in the range -47 to 386 for keyboard events or the range 1001 to 1007
|
|
* for mouse events. Mouse events and non-printable keyboard events are
|
|
* represented by the K_<event> values listed in inkey.ch. Keyboard
|
|
* event return codes in the range 32 through 127 are equivalent to the
|
|
* printable ASCII character set. Keyboard event return codes in the
|
|
* range 128 through 255 are assumed to be printable, but results may
|
|
* vary based on hardware and nationality. If HB_INKEY_EXTENDED mode is
|
|
* used, then the return value for keyboard events ranges from 1 through
|
|
* 767 and 1077 through 1491, although not all codes are used.
|
|
*
|
|
* Extended key codes consist of the PC keyboard scan code and one
|
|
* or more offset values. If no keyboard modifier was used, then
|
|
* HB_INKEY_NONE is added. The Alt key adds HB_INKEY_ALT, the Ctrl
|
|
* key adds HB_INKEY_CTRL, the Shift key adds HB_INKEY_SHIFT, and
|
|
* enhanced keys (KeyPad+/ and CursorPad keys) add HB_INKEY_ENHANCED.
|
|
* For example, F1 is scan code 59, so if you just press F1, you get
|
|
* key code 315, but Alt+F1 gives 443, Ctrl+F1 gives 571, and Shift+
|
|
* F1 gives 699. And NumPad+/ gives 1077, 1205, 1333, and 1461. At
|
|
* this time, the only value that can combine with other values is
|
|
* HB_INKEY_ENHANCED (i.e., there are no Alt+Ctl combinations, etc.)
|
|
*
|
|
* Note: The extended key code set is larger than the normal key code
|
|
* set. As a result, if you switch between the normal and extended
|
|
* modes, you need to be aware that some codes get translated into a
|
|
* zero in normal mode (because there is no corresponding code in
|
|
* normal mode) and that these codes get removed from the keyboard
|
|
* input buffer in normal mode and you won't be able to go back and
|
|
* fetch them later in extended mode.
|
|
* $DESCRIPTION$
|
|
* INKEY() can be used to detect input events, such as keypress, mouse
|
|
* movement, or mouse key clicks (up and/or down).
|
|
* $EXAMPLES$
|
|
* // Wait for the user to press the Esc key
|
|
* ? "Please press the ESC key."
|
|
* WHILE INKEY( 0.1 ) != K_ESC
|
|
* END
|
|
* </fixed>
|
|
* $TESTS$
|
|
* KEYBOARD "AB"; ? INKEY(), INKEY() ==> 65 66
|
|
* </fixed>
|
|
* $STATUS$
|
|
* S
|
|
* $COMPLIANCE$
|
|
* INKEY() is compliant with the Clipper 5.3 INKEY() function with one
|
|
* exception: The Harbour INKEY() function will raise an argument error
|
|
* if the first parameter is less than or equal to 0 and the second
|
|
* parameter (or the default mask) is not valid, because otherwise INKEY
|
|
* would never return, because it was, in effect, asked to wait forever
|
|
* for no events (Note: In Clipper, this also blocks SET KEY events).
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* inkey.ch
|
|
* $END$
|
|
*/
|
|
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* __KEYBOARD()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* DO NOT CALL THIS FUNCTION DIRECTLY!
|
|
* $SYNTAX$
|
|
* KEYBOARD <cString>
|
|
* CLEAR TYPEAHEAD
|
|
* $ARGUMENTS$
|
|
* <cString> is the optional string to stuff into the Harbour keyboard
|
|
* buffer after clearing it first. Note: The character ";" is converted
|
|
* to CHR(13) (this is an undocumented CA-Cl*pper feature).
|
|
* $RETURNS$
|
|
* There is no return value.
|
|
* $DESCRIPTION$
|
|
* Clears the Harbour keyboard typeahead buffer and then inserts an
|
|
* optional string into it.
|
|
* $EXAMPLES$
|
|
* // Stuff an Enter key into the keyboard buffer
|
|
* KEYBOARD CHR(13)
|
|
* // Clear the keyboard buffer
|
|
* CLEAR TYPEAHEAD
|
|
* </fixed>
|
|
* $TESTS$
|
|
* KEYBOARD CHR(13); ? INKEY() ==> 13
|
|
* KEYBOARD ";" ? INKEY() ==> 13
|
|
* KEYBOARD "HELLO"; CLEAR TYPEAHEAD; ? INKEY() ==> 0
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* __KEYBOARD() is compliant with CA-Cl*pper 5.3
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* CLEAR TYPEAHEAD,KEYBOARD
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* HB_KEYPUT()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Put an inkey code to the keyboard buffer.
|
|
* $SYNTAX$
|
|
* HB_KEYPUT( <nInkeyCode> )
|
|
* $ARGUMENTS$
|
|
* <nInkeyCode> is the inkey code, which should be inserted into the
|
|
* keyboard buffer.
|
|
* $RETURNS$
|
|
* There is no return value.
|
|
* $DESCRIPTION$
|
|
* Inserts an inkey code to the string buffer. The buffer is *not*
|
|
* cleared in this operation. This function allows to insert such
|
|
* inkey codes which are not in the range of 0 to 255. To insert more
|
|
* than one code, call the function repeatedly. The zero code cannot
|
|
* be inserted.
|
|
* $EXAMPLES$
|
|
* // Stuff an Alt+PgDn key into the keyboard buffer
|
|
* HB_KEYPUT( K_ALT_PGDN )
|
|
* </fixed>
|
|
* $TESTS$
|
|
* HB_KEYPUT( K_ALT_PGDN ) ; ? INKEY() ==> 417
|
|
* HB_KEYPUT( K_F11 ) ; ? INKEY() ==> -40
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* HB_KEYPUT() is a Harbour extension.
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* KEYBOARD,CLEAR TYPEAHEAD,INKEY()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* NEXTKEY()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Get the next key code in the buffer without extracting it.
|
|
* $SYNTAX$
|
|
* NEXTKEY( [<nInputMask>] ) --> nKey
|
|
* $ARGUMENTS$
|
|
* nInputMask is an optional integer value composed of one or more
|
|
* INKEY_ or HB_INKEY_ constants. The sole purpose of this argument
|
|
* is to allow switching between using HB_INKEY_EXTENDED key codes
|
|
* and using the normal Clipper-compatible key codes
|
|
* $RETURNS$
|
|
* <nKey> The value of the next key in the Harbour keyboard buffer.
|
|
* $DESCRIPTION$
|
|
* Returns the value of the next key in the Harbour keyboard buffer
|
|
* without extracting it.
|
|
* $EXAMPLES$
|
|
* // Use NEXTKEY() with INKEY() to change display characters, or by
|
|
* // itself to exit the loop, so that the caller can detect the Esc.
|
|
* LOCAL nKey, cChar := "+"
|
|
* WHILE TRUE
|
|
* ?? cChar
|
|
* nKey := NEXTKEY()
|
|
* IF nKey == K_ESC
|
|
* EXIT
|
|
* ELSE
|
|
* IF nKey != 0
|
|
* cChar := CHR( nKey )
|
|
* END IF
|
|
* END IF
|
|
* END WHILE
|
|
* </fixed>
|
|
* $TESTS$
|
|
* KEYBOARD "AB"; ? NEXTKEY(), NEXTKEY() ==> 65 65
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* NEXTKEY() is compliant with CA-Cl*pper 5.3, but has been extended
|
|
* for Harbour.
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* INKEY(),LASTKEY()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* LASTKEY()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Get the last key extracted from the keyboard buffer.
|
|
* $SYNTAX$
|
|
* LASTKEY( [<nInputMask>] ) --> nKey
|
|
* $ARGUMENTS$
|
|
* nInputMask is an optional integer value composed of one or more
|
|
* INKEY_ or HB_INKEY_ constants. The sole purpose of this argument
|
|
* is to allow switching between using HB_INKEY_EXTENDED key codes
|
|
* and using the normal Clipper-compatible key codes
|
|
* $RETURNS$
|
|
* <nKey> The last key extracted from the keyboard buffer.
|
|
* $DESCRIPTION$
|
|
* Returns the value of the last key exttracted from the Harbour
|
|
* keyboard buffer
|
|
* $EXAMPLES$
|
|
* // Continue looping unless the ESC key was pressed in MainFunc()
|
|
* WHILE TRUE
|
|
* MainFunc()
|
|
* IF LASTKEY() == K_ESC
|
|
* EXIT
|
|
* ENDIF
|
|
* END WHILE
|
|
* </fixed>
|
|
* $TESTS$
|
|
* KEYBOARD "AB"; ? INKEY(), LASTKEY() ==> 65 65
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* LASTKEY() is compliant with CA-Cl*pper 5.3, but has been extended
|
|
* for Harbour.
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* INKEY(),LASTKEY()
|
|
* $END$
|
|
*/
|
|
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* KEYBOARD
|
|
* $CATEGORY$
|
|
* Command
|
|
* $ONELINER$
|
|
* Stuffs the keyboard with a string.
|
|
* $SYNTAX$
|
|
* KEYBOARD <cString>
|
|
* $ARGUMENTS$
|
|
* <cString> String to be processed, one character at a time,
|
|
* by the Harbour keyboard processor
|
|
* $DESCRIPTION$
|
|
* This command stuffs the input buffer with <cString>. The
|
|
* number of characters that can be stuffed into the keyboard
|
|
* buffer is controlled by the SET TYPEAHEAD command and may range
|
|
* from 0 to 32,622, with each character appearing in the ASCII
|
|
* range of 0 to 255. None of the extended keys may be stuffed
|
|
* into the keyboard buffer.
|
|
* Issuing a KEYBOARD " " will clear the keyboard buffer.
|
|
* $EXAMPLES$
|
|
* // Stuff an Enter key into the keyboard buffer
|
|
* KEYBOARD CHR(13)
|
|
* // Clear the keyboard buffer
|
|
* CLEAR TYPEAHEAD
|
|
* </fixed>
|
|
* $TESTS$
|
|
* KEYBOARD CHR(13); ? INKEY() ==> 13
|
|
* KEYBOARD "HELLO"; CLEAR TYPEAHEAD; ? INKEY() ==> 0
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* __KEYBOARD() is compliant with CA-Cl*pper 5.3
|
|
* $SEEALSO$
|
|
* CLEAR TYPEAHEAD,__KEYBOARD()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* READKEY()*
|
|
* $CATEGORY$
|
|
* Data input and output
|
|
* $ONELINER$
|
|
* Find out which key terminated a READ.
|
|
* $SYNTAX$
|
|
* READKEY() --> nKeyCode
|
|
* $ARGUMENTS$
|
|
* None.
|
|
* $RETURNS$
|
|
* READKEY() returns a numeric code representing the key that caused READ
|
|
* to terminate.
|
|
* $DESCRIPTION$
|
|
* READKEY() is used after a READ was terminated to determine the exit
|
|
* key pressed. If the GET buffer was updated during READ, 256 is added
|
|
* to the return code.
|
|
*
|
|
* <table>
|
|
* Exit Return code Return code
|
|
* Key (not updated) (updated)
|
|
|
|
* Up 4 260
|
|
* Down 5 261
|
|
* Page-Up 6 262
|
|
* Page-Down 7 263
|
|
* Ctrl Page-Up 34 290
|
|
* Ctrl Page-Down 35 291
|
|
* Esc 12 268
|
|
* Ctrl End 14 270
|
|
* Enter 15 271
|
|
* Key >= 32 15 271
|
|
* otherwise 0 0
|
|
* </table>
|
|
* READKEY() is a compatibility function so try not to use it.
|
|
* READKEY() is superseded by LASTKEY() which returns the INKEY()
|
|
* code for that key. UPDATED() could be used to find if the
|
|
* GET buffer was changed during the READ.
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* READKEY() is compliant with CA-Cl*pper 5.3
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* @...GET,INKEY(),LASTKEY(),READ,READEXIT(),UPDATED()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* MROW()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Returns the mouse cursor row position.
|
|
* $SYNTAX$
|
|
* MRow() --> nMouseRow
|
|
* $ARGUMENTS$
|
|
* None
|
|
* $RETURNS$
|
|
* <nMouseRow> The mouse cursor row position.
|
|
* $DESCRIPTION$
|
|
* This function returns the current mouse row cursor position.
|
|
* On graphical systems the value represents pixel rows.
|
|
* On character-based systems the value represents character
|
|
* rows as in Clipper.
|
|
* $EXAMPLES$
|
|
* IF MRow() < 1
|
|
* ? "Mouse is on top row!"
|
|
* ENDIF
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* MROW() is compliant with CA-Cl*pper 5.3, but has been extended
|
|
* to work on graphical systems as well as character-based systems.
|
|
* $PLATFORMS$
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* MCOL()
|
|
* $END$
|
|
*/
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* MCOL()
|
|
* $CATEGORY$
|
|
* Console input
|
|
* $ONELINER$
|
|
* Returns the mouse cursor column position.
|
|
* $SYNTAX$
|
|
* MCol() --> nMouseColumn
|
|
* $ARGUMENTS$
|
|
* None
|
|
* $RETURNS$
|
|
* <nMouseColumn> The mouse cursor column position.
|
|
* $DESCRIPTION$
|
|
* This function returns the column position of the mouse cursor.
|
|
* On graphical systems the value represents pixels.
|
|
* On character-based systems the value represents character
|
|
* columns as in Clipper.
|
|
* $EXAMPLES$
|
|
* IF MCol() < 1
|
|
* ? "Mouse is on left edge!"
|
|
* ENDIF
|
|
* </fixed>
|
|
* $STATUS$
|
|
* R
|
|
* $COMPLIANCE$
|
|
* MROW() is compliant with CA-Cl*pper 5.3, but has been extended
|
|
* to work on graphical systems as well as character-based systems.
|
|
* $PLATFORMS$
|
|
* All
|
|
* $FILES$
|
|
* Library is rtl
|
|
* $SEEALSO$
|
|
* MROW()
|
|
* $END$
|
|
*/
|