bas7advr.hlp (
Topic list)
Important Notice
The pages on this site contain documentation for very old MS-DOS software,
purely for historical purposes.
If you're looking for up-to-date documentation, particularly for programming,
you should not rely on the information found here, as it will be woefully
out of date.
ON PEN Statement Details
◄Syntax► ◄Details► ◄Example► ◄Contents► ◄Index► ◄Back►
──────────────────────────────────────────────────────────────────────────────
ON PEN is an event trapping statement that specifies a routine to branch to
when the lightpen is activated.
ON PEN GOSUB {linenumber | linelabel}
■ linenumber or A linenumber value of 0 disables event trapping and
linelabel does not specify line 0 as the start of the
routine.
Usage Notes
■ The ON PEN statement specifies only the start of an event-trapping
routine. The ◄PEN Statements► determine whether routine is called
and how events are handled when trapping is off:
PEN ON Enables event trapping. Event trapping occurs only
after a PEN ON statement is executed.
PEN OFF Disables event trapping. Even if an event takes place,
it is not remembered.
PEN STOP Suspends event trapping. Any events that occur are
remembered and are trapped as soon as a PEN ON statement
is executed.
■ If your program contains event-handling statements and you are
compiling from the BC command line, use the BC /W or /V option.
(The /W option checks for events at every label or line number; the
/V option checks at every statement.) If you do not use these
options and your program contains event traps, BASIC generates the
error message, "ON event without /V or /W on command line."
■ The RETURN linenumber or RETURN linelabel forms of RETURN can be
used to return to a specific line from the trapping routine. Use
this type of return with care, however, because any other GOSUB,
WHILE, or FOR statements active at the time of the trap remain
active. BASIC may generate error messages such as "NEXT without
FOR." In addition, if an event occurs in a procedure, a RETURN
linenumber or RETURN linelabel statement cannot get back into the
procedure because the line number or label must be in the
module-level code.