SpectNet IDE

Visual Studio 2017/2019 integrated ZX Spectrum IDE for the Community

Spectrum48 BASIC » The system variables

CHAPTER 25: The system variables

The bytes in memory from 23552 to 23733 are set aside for specific uses by the system. You can peek them to find out various things about the system, and some of them can be usefully poked. They are listed here with their uses.

These are called system variables, and have names, but do not confuse them with the variables used by the BASIC. The computer will not recognize the names as referring to system variables, and they are given solely as mnemonics for we humans. The abbreviations in column 1 have the following meanings:

X The variables should not be poked because the system might crash.

N Poking the variable will have no lasting effect

The number in column 1 is the number of bytes in the variable. For two bytes, the first one is the less significant byte the reverse of what you might expect. So to poke a value v to a two byte variable at address n, use POKE n,v-256*1NT (v/256)

POKE n+1,lNT (v/256)

and to peek its value, use the expression

PEEK n+256*PEEK (n+1)

Notes Address Name Contents
N8 23552 KSTATE Used in reading the keyboard.
Nl 23560 LAST K Stores newly pressed key.
1 23561 REPDEL Time (in 50ths of a second in 60ths of a second in N. America) that a key must be held down before it repeats. This starts off at 35, but you can POKE in other values.
1 23562 REPPER Delay (in 50ths of a second in 60ths of a second in N. America) between successive repeats of a key held down: initially 5.
N2 23563 DEFADD Address of arguments of user defined function if one is being evaluated; otherwise 0.
Nl 23565 K DATA Stores 2nd byte of colour controls entered from keyboard .
N2 23566 TVDATA Stores bytes of coiour, AT and TAB controls going to television.
X38 23568 STRMS Addresses of channels attached to streams.
2 23606 CHARS 256 less than address of character set (which starts with space and carries on to the copyright symbol). Normally in ROM, but you can set up your own in RAM and make CHARS point to it.
1 23608 RASP Length of warning buzz.
1 23609 PIP Length of keyboard click.
1 23610 ERR NR 1 less than the report code. Starts off at 255 (for 1) so PEEK 23610 gives 255.
X1 23611 FLAGS Various flags to control the BASIC system.
X1 23612 TV FLAG Flags associated with the television.
X2 23613 ERR SP Address of item on machine stack to be used as error return.
N2 23615 LIST SP Address of return address from automatic listing.
N1 23617 MODE Specifies K, L, C. E or G cursor.
2 23618 NEWPPC Line to be jumped to.
1 23620 NSPPC Statement number in line to be jumped to. Poking first NEWPPC and then NSPPC forces a jump to a specified statement in a line.
2 23621 PPC Line number of statement currently being executed.
1 23623 SUBPPC Number within line of statement being executed.
1 23624 BORDCR Border colour * 8; also contains the attributes normally used for the lower half of the screen.
2 23625 E PPC Number of current line (with program cursor).
X2 23627 VARS Address of variables.
N2 23629 DEST Address of variable in assignment.
X2 23631 CHANS Address of channel data.
X2 23633 CURCHL Address of information currently being used for input and output.
X2 23635 PROG Address of BASIC program.
X2 23637 NXTLIN Address of next line in program.
X2 23639 DATADD Address of terminator of last DATA item.
X2 23641 E LINE Address of command being typed in.
2 23643 K CUR Address of cursor.
X2 23645 CH ADD Address of the next character to be interpreted: the character after the argument of PEEK, or the NEWLINE at the end of a POKE statement.
2 23647 X PTR Address of the character after the ? marker.
X2 23649 WORKSP Address of temporary work space.
X2 23651 STKBOT Address of bottom of calculator stack.
X2 23653 STKEND Address of start of spare space.
N1 23655 BREG Calculator’s b register.
N2 23656 MEM Address of area used for calculator’s memory. (Usually MEMBOT, but not always.)
1 23658 FLAGS2 More flags.
X1 23659 DF SZ The number of lines (including one blank line) in the lower part of the screen.
2 23660 S TOP The number of the top program line in automatic listings.
2 23662 OLDPPC Line number to which CONTINUE jumps.
1 23664 OSPCC Number within line of statement to which CONTINUE jumps.
N1 23665 FLAGX Various flags.
N2 23666 STRLEN Length of string type destination in assignment.
N2 23668 T ADDR Address of next item in syntax table (very unlikely to be useful).
2 23670 SEED The seed for RND. This is the variable that is set by RANDOMIZE.
3 23672 FRAMES 3 byte (least significant first), frame counter. Incremented every 20ms. See Chapter 18.
2 23675 UDG Address of 1st user defined graphic You can change this for instance to save space by having fewer user defined graphics.
1 23677 COORDS x-coordinate of last point plotted.
1 23678   y-coordinate of last point plotted.
1 23679 P POSN 33 column number of printer position
X2 23680 PR CC Full address of next position for LPRINT to print at (in ZX printer buffer). Legal values 5B00 - 5B1F. [Not used in 128K mode or when certain peripherals are attached]
2 23682 ECHO E 33 column number and 24 line number (in lower half) of end of input buffer.
2 23684 DF CC Address in display file of PRINT position.
2 23686 DFCCL Like DF CC for lower part of screen.
X1 23688 S POSN 33 column number for PRINT position
X1 23689   24 line number for PRINT position.
X2 23690 SPOSNL Like S POSN for lower part
1 23692 SCR CT Counts scrolls: it is always 1 more than the number of scrolls that will be done before stopping with scroll? If you keep poking this with a number bigger than 1 (say 255), the screen will scroll on and on without asking you.
1 23693 ATTR P Permanent current colours, etc (as set up by colour statements).
1 23694 MASK P Used for transparent colours, etc. Any bit that is 1 shows that the corresponding attribute bit is taken not from ATTR P, but from what is already on the screen.
N1 23695 ATTR T Temporary current colours, etc (as set up by colour items).
N1 23696 MASK T Like MASK P, but temporary.
1 23697 P FLAG More flags.
N30 23698 MEMBOT Calculator’s memory area; used to store numbers that cannot conveniently be put on the calculator stack.
2 23728 NMIADD This is the address of a user supplied NMI address which is read by the standard ROM when a peripheral activates the NMI.Probably intentionally disabled so that the effect is to perform a reset if both locations hold zero, but do nothing if the locations hold a non-zero value. Interface 1’s with serial number greater than 87315 will initialize these locations to 0 and 80 to allow the RS232 “T” channel to use a variable line width. 23728 is the current print position and 23729 the width - default 80.
2 23730 RAMTOP Address of last byte of BASIC system area.
2 23732 P RAMT Address of last byte of physical RAM.

This program tells you the first 22 bytes of the variables area:

10 FOR n=0 TO 21
20 PRINT PEEK (PEEK 23627+256\*PEEK 23628+n)
30 NEXT n

Try to match up the control variable n with the descriptions above. Now change line 20 to

20 PRINT PEEK (23755+n)

This tells you the first 22 bytes of the program area. Match these up with the program itself.