Warning: Unknown: Unable to allocate memory for pool. in Unknown on line 0

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/api.php on line 50

Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/WebStart.php on line 63

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 94

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 97

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 100

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 103

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/Defines.php on line 187

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 115

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 134

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/LocalSettings.php on line 137

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/LocalSettings.php on line 139

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/LocalSettings.php on line 144

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/LocalSettings.php on line 145

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/LocalSettings.php on line 153

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 150

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/WebStart.php on line 157

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/Setup.php on line 381

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/Setup.php on line 382

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/Setup.php on line 383

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/Setup.php on line 384

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require_once(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/languages/Language.php on line 20

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/Feed.php on line 229

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007

Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/WebResponse.php on line 38

Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/WebResponse.php on line 38

Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/WebResponse.php on line 38
http://fileformats.archiveteam.org/api.php?action=feedcontributions&feedformat=atom&user=Shram86 Just Solve the File Format Problem - User contributions [en] 2025-01-10T21:10:41Z User contributions MediaWiki 1.19.2 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T18:59:57Z <p>Shram86: /* ZX Spectrum 128-BASIC Tokens */ Updated for both 48/128</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral. The token 0x7E before the number indicates floating-point, and 0x0E indicates an integral number.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 01 00 00}}||1<br /> |-<br /> |{{magic|00 00 02 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> <br /> ==== ZX Spectrum 48/128 BASIC Tokens ====<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Hex)<br /> ! title=&quot;Description&quot; | Description<br /> <br /> |-<br /> |0xA3 || SPECTRUM&lt;sup&gt;1&lt;/sup&gt;<br /> |-<br /> |0xA4 || PLAY&lt;sup&gt;1&lt;/sup&gt;<br /> |-<br /> |0xA5 || RND <br /> |-<br /> |0xA6 || INKEY$ <br /> |-<br /> |0xA7 || PI <br /> |-<br /> |0xA8 || FN <br /> |-<br /> |0xA9 || POINT <br /> |-<br /> |0xAA || SCREEN$ <br /> |-<br /> |0xAB || ATTR <br /> |-<br /> |0xAC || AT <br /> |-<br /> |0xAD || TAB <br /> |-<br /> |0xAE || VAL$ <br /> |-<br /> |0xAF || CODE <br /> |-<br /> |0xB0 || VAL <br /> |-<br /> |0xB1 || LEN <br /> |-<br /> |0xB2 || SIN <br /> |-<br /> |0xB3 || COS <br /> |-<br /> |0xB4 || TAN <br /> |-<br /> |0xB5 || ASN <br /> |-<br /> |0xB6 || ACS <br /> |-<br /> |0xB7 || ATN <br /> |-<br /> |0xB8 || LN <br /> |-<br /> |0xB9 || EXP <br /> |-<br /> |0xBA || INT <br /> |-<br /> |0xBB || SQR <br /> |-<br /> |0xBC || SGN <br /> |-<br /> |0xBD || ABS <br /> |-<br /> |0xBE || PEEK <br /> |-<br /> |0xBF || IN <br /> |-<br /> |0xC0 || USR <br /> |-<br /> |0xC1 || STR$ <br /> |-<br /> |0xC2 || CHR$ <br /> |-<br /> |0xC3 || NOT <br /> |-<br /> |0xC4 || BIN <br /> |-<br /> |0xC5 || OR <br /> |-<br /> |0xC6 || AND <br /> |-<br /> |0xC7 || &lt;= <br /> |-<br /> |0xC8 || &gt;= <br /> |-<br /> |0xC9 || &lt;&gt; <br /> |-<br /> |0xCA || LINE <br /> |-<br /> |0xCB || THEN <br /> |-<br /> |0xCC || TO <br /> |-<br /> |0xCD || STEP <br /> |-<br /> |0xCE || DEF FN <br /> |-<br /> |0xCF || CAT <br /> |-<br /> |0xD0 || FORMAT <br /> |-<br /> |0xD1 || MOVE <br /> |-<br /> |0xD2 || ERASE <br /> |-<br /> |0xD3 || OPEN # <br /> |-<br /> |0xD4 || CLOSE # <br /> |-<br /> |0xD5 || MERGE <br /> |-<br /> |0xD6 || VERIFY <br /> |-<br /> |0xD7 || BEEP <br /> |-<br /> |0xD8 || CIRCLE <br /> |-<br /> |0xD9 || INK <br /> |-<br /> |0xDA || PAPER <br /> |-<br /> |0xDB || FLASH <br /> |-<br /> |0xDC || BRIGHT <br /> |-<br /> |0xDD || INVERSE <br /> |-<br /> |0xDE || OVER <br /> |-<br /> |0xDF || OUT <br /> |-<br /> |0xE0 || LPRINT <br /> |-<br /> |0xE1 || LLIST <br /> |-<br /> |0xE2 || STOP <br /> |-<br /> |0xE3 || READ <br /> |-<br /> |0xE4 || DATA <br /> |-<br /> |0xE5 || RESTORE <br /> |-<br /> |0xE6 || NEW <br /> |-<br /> |0xE7 || BORDER <br /> |-<br /> |0xE8 || CONTINUE <br /> |-<br /> |0xE9 || DIM <br /> |-<br /> |0xEA || REM <br /> |-<br /> |0xEB || FOR <br /> |-<br /> |0xEC || GO TO <br /> |-<br /> |0xED || GO SUB <br /> |-<br /> |0xEE || INPUT <br /> |-<br /> |0xEF || LOAD <br /> |-<br /> |0xF0 || LIST <br /> |-<br /> |0xF1 || LET <br /> |-<br /> |0xF2 || PAUSE <br /> |-<br /> |0xF3 || NEXT <br /> |-<br /> |0xF4 || POKE <br /> |-<br /> |0xF5 || PRINT <br /> |-<br /> |0xF6 || PLOT <br /> |-<br /> |0xF7 || RUN <br /> |-<br /> |0xF8 || SAVE <br /> |-<br /> |0xF9 || RANDOMIZE <br /> |-<br /> |0xFA || IF <br /> |-<br /> |0xFB || CLS <br /> |-<br /> |0xFC || DRAW <br /> |-<br /> |0xFD || CLEAR <br /> |-<br /> |0xFE || RETURN <br /> |-<br /> |0xFF || COPY <br /> |-<br /> |}<br /> [1]: This token is only available in 128 BASIC.<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:59:32Z <p>Shram86: Added128BASIC token chart</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral. The token 0x7E before the number indicates floating-point, and 0x0E indicates an integral number.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 01 00 00}}||1<br /> |-<br /> |{{magic|00 00 02 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> <br /> ==== ZX Spectrum 128-BASIC Tokens ====<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Hex)<br /> ! title=&quot;Description&quot; | Description<br /> <br /> |-<br /> |0xA3 || SPECTRUM <br /> |-<br /> |0xA4 || PLAY <br /> |-<br /> |0xA5 || RND <br /> |-<br /> |0xA6 || INKEY$ <br /> |-<br /> |0xA7 || PI <br /> |-<br /> |0xA8 || FN <br /> |-<br /> |0xA9 || POINT <br /> |-<br /> |0xAA || SCREEN$ <br /> |-<br /> |0xAB || ATTR <br /> |-<br /> |0xAC || AT <br /> |-<br /> |0xAD || TAB <br /> |-<br /> |0xAE || VAL$ <br /> |-<br /> |0xAF || CODE <br /> |-<br /> |0xB0 || VAL <br /> |-<br /> |0xB1 || LEN <br /> |-<br /> |0xB2 || SIN <br /> |-<br /> |0xB3 || COS <br /> |-<br /> |0xB4 || TAN <br /> |-<br /> |0xB5 || ASN <br /> |-<br /> |0xB6 || ACS <br /> |-<br /> |0xB7 || ATN <br /> |-<br /> |0xB8 || LN <br /> |-<br /> |0xB9 || EXP <br /> |-<br /> |0xBA || INT <br /> |-<br /> |0xBB || SQR <br /> |-<br /> |0xBC || SGN <br /> |-<br /> |0xBD || ABS <br /> |-<br /> |0xBE || PEEK <br /> |-<br /> |0xBF || IN <br /> |-<br /> |0xC0 || USR <br /> |-<br /> |0xC1 || STR$ <br /> |-<br /> |0xC2 || CHR$ <br /> |-<br /> |0xC3 || NOT <br /> |-<br /> |0xC4 || BIN <br /> |-<br /> |0xC5 || OR <br /> |-<br /> |0xC6 || AND <br /> |-<br /> |0xC7 || &lt;= <br /> |-<br /> |0xC8 || &gt;= <br /> |-<br /> |0xC9 || &lt;&gt; <br /> |-<br /> |0xCA || LINE <br /> |-<br /> |0xCB || THEN <br /> |-<br /> |0xCC || TO <br /> |-<br /> |0xCD || STEP <br /> |-<br /> |0xCE || DEF FN <br /> |-<br /> |0xCF || CAT <br /> |-<br /> |0xD0 || FORMAT <br /> |-<br /> |0xD1 || MOVE <br /> |-<br /> |0xD2 || ERASE <br /> |-<br /> |0xD3 || OPEN # <br /> |-<br /> |0xD4 || CLOSE # <br /> |-<br /> |0xD5 || MERGE <br /> |-<br /> |0xD6 || VERIFY <br /> |-<br /> |0xD7 || BEEP <br /> |-<br /> |0xD8 || CIRCLE <br /> |-<br /> |0xD9 || INK <br /> |-<br /> |0xDA || PAPER <br /> |-<br /> |0xDB || FLASH <br /> |-<br /> |0xDC || BRIGHT <br /> |-<br /> |0xDD || INVERSE <br /> |-<br /> |0xDE || OVER <br /> |-<br /> |0xDF || OUT <br /> |-<br /> |0xE0 || LPRINT <br /> |-<br /> |0xE1 || LLIST <br /> |-<br /> |0xE2 || STOP <br /> |-<br /> |0xE3 || READ <br /> |-<br /> |0xE4 || DATA <br /> |-<br /> |0xE5 || RESTORE <br /> |-<br /> |0xE6 || NEW <br /> |-<br /> |0xE7 || BORDER <br /> |-<br /> |0xE8 || CONTINUE <br /> |-<br /> |0xE9 || DIM <br /> |-<br /> |0xEA || REM <br /> |-<br /> |0xEB || FOR <br /> |-<br /> |0xEC || GO TO <br /> |-<br /> |0xED || GO SUB <br /> |-<br /> |0xEE || INPUT <br /> |-<br /> |0xEF || LOAD <br /> |-<br /> |0xF0 || LIST <br /> |-<br /> |0xF1 || LET <br /> |-<br /> |0xF2 || PAUSE <br /> |-<br /> |0xF3 || NEXT <br /> |-<br /> |0xF4 || POKE <br /> |-<br /> |0xF5 || PRINT <br /> |-<br /> |0xF6 || PLOT <br /> |-<br /> |0xF7 || RUN <br /> |-<br /> |0xF8 || SAVE <br /> |-<br /> |0xF9 || RANDOMIZE <br /> |-<br /> |0xFA || IF <br /> |-<br /> |0xFB || CLS <br /> |-<br /> |0xFC || DRAW <br /> |-<br /> |0xFD || CLEAR <br /> |-<br /> |0xFE || RETURN <br /> |-<br /> |0xFF || COPY <br /> |-<br /> |}<br /> <br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:24:19Z <p>Shram86: /* 5-byte numeric format */ single typo, apologies for all the edits</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral. The token 0x7E before the number indicates floating-point, and 0x0E indicates an integral number.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 01 00 00}}||1<br /> |-<br /> |{{magic|00 00 02 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:23:38Z <p>Shram86: /* 5-byte numeric format */ fixed errors in table</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral. The token Ox7E before the number indicates floating-point, and 0x0E indicates an integral number.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 01 00 00}}||1<br /> |-<br /> |{{magic|00 00 02 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:22:48Z <p>Shram86: /* 5-byte numeric format */ Added token information</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral. The token Ox7E before the number indicates floating-point, and 0x0E indicates an integral number.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 00 00 00}}||1<br /> |-<br /> |{{magic|00 00 00 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:21:02Z <p>Shram86: /* BASIC lines */ Fixed section link</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [[#5-byte numeric format|5-byte numeric format]].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 00 00 00}}||1<br /> |-<br /> |{{magic|00 00 00 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:18:51Z <p>Shram86: Clarified slight misinformation on BASIC number constants</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by one of two tokens (indicating floating-point or integral) and then the number in [5-byte numeric format].<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 00 00 00}}||1<br /> |-<br /> |{{magic|00 00 00 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86 http://fileformats.archiveteam.org/wiki/Sinclair_BASIC_tokenized_file Sinclair BASIC tokenized file 2020-02-10T14:14:11Z <p>Shram86: /* BASIC lines */ Added newline byte for Spectrum computers</p> <hr /> <div>{{FormatInfo<br /> |subcat=Source code<br /> |subcat2=Tokenized BASIC<br /> }}<br /> <br /> '''Sinclair BASIC''' is a dialect of the BASIC programming language created by Nine Tiles Networks Ltd and used in the 8-bit home computers from Sinclair Research and Timex Sinclair.<br /> <br /> The original 4KB version was developed for the Sinclair ZX80, followed by an 8KB version for the ZX81 and 16KB version for ZX Spectrum.<br /> <br /> Some unusual features of the Sinclair BASIC:<br /> * There were keys on the keyboard for each BASIC keyword. For example, pressing P caused the entire command PRINT to appear. Some commands needed multiple keypresses to enter, For example, BEEP was keyed by pressing CAPS SHIFT plus SYMBOL SHIFT to access extended mode, keeping SYMBOL SHIFT held down and pressing Z. <br /> * When programs were SAVEd, the file written to disk or tape contained all of BASIC's internal state information, including the values of any defined basic variables, as well as the BASIC tokens. <br /> <br /> === BASIC File Layout ===<br /> On a ZX81, a saved BASIC file is a snapshot of the computer memory from memory location 16393 through to the end of the variable table. There is no header.<br /> <br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Memory Address&quot; | Address<br /> ! title=&quot;Name&quot; | Name<br /> ! title=&quot;Description&quot; |Description<br /> |-<br /> <br /> |16393||VERSN ||0 Identifies ZX81 BASIC in saved programs.<br /> |-<br /> |16394||E_PPC||Number of current line (with program cursor).<br /> |-<br /> |16396||D_FILE||Pointer to the start of the 'Display file', i.e. what is being displayed on screen<br /> |-<br /> |16398||DF_CC||Address of PRINT position in display file. Can be poked so that PRINT output is sent elsewhere.<br /> |-<br /> |16400||VARS||Pointer to start of BASIC Variable table<br /> |-<br /> |16402||DEST||Address of variable in assignment.<br /> |-<br /> |16404||E_LINE||Pointer to line currently being entered<br /> |-<br /> |16406||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.<br /> |-<br /> |16408||X_PTR||Address of the character preceding the marker.<br /> |-<br /> |16410||STKBOT||pointer to start (bottom) of stack<br /> |-<br /> |16412||STKEND||pointer to end (top) of stack<br /> |-<br /> |16414||BERG||Calculator's b register.<br /> |-<br /> |16415||MEM||Address of area used for calculator's memory. (Usually MEMBOT, but not always.)<br /> |-<br /> |16417|| ||not used <br /> |-<br /> |16418||DF_SZ||The number of lines (including one blank line) in the lower part of the screen.<br /> |-<br /> |16419||S_TOP||The number of the top program line in automatic listings.<br /> |-<br /> |16421||LAST_K||Shows which keys pressed.<br /> |- <br /> |16423|| || Debounce status of keyboard.<br /> |-<br /> |16424||MARGIN||Number of blank lines above or below picture: 55 in Britain, 31 in America.<br /> |-<br /> |16425||NXTLIN||Address of next program line to be executed.<br /> |-<br /> |16427||OLDPPC||Line number of which CONT jumps.<br /> |-<br /> |16429||FLAGX||Various flags.<br /> |-<br /> |16430||STRLEN||Length of string type destination in assignment.<br /> |-<br /> |16432||T_ADDR||Address of next item in syntax table (very unlikely to be useful).<br /> |-<br /> |16434||SEED||The seed for RND. This is the variable that is set by RAND.<br /> |-<br /> |16436||FRAMES||Counts the frames displayed on the television. Bit 15 is 1. Bits 0 to 14 are decremented for each frame set to the television. This can be used for timing, but PAUSE also uses it. PAUSE resets to 0 bit 15, &amp; puts in bits 0 to 14 the length of the pause. When these have been counted down to zero, the pause stops. If the pause stops because of a key depression, bit 15 is set to 1 again.<br /> |-<br /> |16438||COORDS||x-coordinate of last point PLOTted.<br /> |-<br /> |16439|| || y-coordinate of last point PLOTted.<br /> |-<br /> |16440||PR_CC||Less significant byte of address of next position for LPRINT to print as (in PRBUFF).<br /> |-<br /> |16441||S_POSN||Column number for PRINT position.<br /> |-<br /> |16442|| ||Line number for PRINT position.<br /> |-<br /> |16443||CDFLAG||Various flags. Bit 7 is on (1) during compute &amp; display mode.<br /> |-<br /> |16444||PRBUFF||Printer buffer (33rd character is NEWLINE).<br /> |-<br /> |16477||MEMBOT||Calculator's memory area; used to store numbers that cannot conveniently be put on the calculator stack.<br /> |-<br /> |16507|| || not used<br /> |-<br /> |16509|| || First BASIC line.<br /> |}<br /> <br /> === BASIC lines ===<br /> <br /> Each BASIC line is stored as:<br /> <br /> * 2 byte line number (in [[Endianness|big-endian]] format)<br /> * 2 byte length of text including NEWLINE (in little endian format, length &quot;excludes&quot; the line number and length, i.e. to skip between lines you add &quot;length of text&quot; +4 bytes.<br /> * text (BASIC tokens)<br /> * NEWLINE (0x76 on ZX80/81, 0x0D on Spectrum)<br /> <br /> When a numeric constant is included in the text of a BASIC line, an ASCII string displaying the constant value will be inserted, followed by the token 0x7E, and the next 5 bytes are the value of the constant in floating point format.<br /> <br /> === BASIC Variables Table ===<br /> Following the last BASIC line comes the variables table. Each entry in this table is of varying length and format.<br /> <br /> The first byte in each entry is the variable name, of which the upper 3 bits indicate the variable type.<br /> <br /> Most types of variables can only have a one-character name: A to Z for numerics, A$ to Z$ for strings. Numeric variables can have a multi-character names beginning with A-Z and continuing with A-Z or 0-9, e.g. &lt;code&gt;F0O&lt;/code&gt; or &lt;code&gt;BAR&lt;/code&gt;. Names are case-insensitive and whitespace insensitive (&lt;code&gt;hello world&lt;/code&gt; is the same variable as &lt;code&gt;HeLlOwOrL d&lt;/code&gt;). Numeric variables and FOR-NEXT control variables share the same namespace, but no other types do. Numeric variable A, string variable A$, numeric array A(10) and string array A$(10) can all coexist under the name &quot;A&quot;&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap7.html&lt;/ref&gt;<br /> <br /> {| class=&quot;wikitable&quot;<br /> !First byte!!Format!!Examples<br /> |-<br /> |011nnnnn<br /> |numeric variable<br /> * 1 byte: variable name (0x61 to 0x7A)<br /> * 5 bytes: numeric value <br /> |<br /> * {{magic|61 00 00 01 00 00}} &amp;rarr; &lt;code&gt;LET a=1&lt;/code&gt;<br /> * {{magic|69 00 FF 02 00 00}} &amp;rarr; &lt;code&gt;LET i=-65534&lt;/code&gt;<br /> * {{magic|6A 00 00 FE FF 00}} &amp;rarr; &lt;code&gt;LET j=65534&lt;/code&gt;<br /> * {{magic|62 93 3C 61 4E 00}} &amp;rarr; &lt;code&gt;LET b=12345678&lt;/code&gt;<br /> ** 12345678 = 0xBC614E<br /> * {{magic|63 93 BC 61 4E 00}} &amp;rarr; &lt;code&gt;LET c=-12345678&lt;/code&gt; <br /> * {{magic|65 82 2D F8 4C AD}} &amp;rarr; &lt;code&gt;LET e=2.71828&lt;/code&gt;<br /> |-<br /> |101nnnnn<br /> |numeric variable with multi-character name<br /> * 1 byte: first character of variable name (0xA1 to 0xBA)<br /> * n bytes: remainder of name (A-Z, a-z, 0-9 allowed, final character has high bit set)<br /> * 5 bytes: numeric value<br /> |<br /> * {{magic|B0 69 E5 82 49 4A F0 41}} &amp;rarr; &lt;code&gt;LET pie=3.1452&lt;/code&gt;<br /> ** &quot;p&quot;=0x10 ORed with 0xA0<br /> ** &quot;i&quot; is regular ASCII (0x69)<br /> ** &quot;e&quot; is regular ASCII (0x65) ORed with 0x80 to indicate the end of the variable name<br /> |-<br /> |010nnnnn<br /> |string variable<br /> * 1 byte: variable name (0x41 to 0x5A)<br /> * 2 bytes: little-endian string length (''n'')<br /> * ''n'' bytes: string value (the character set is mostly ASCII)&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanappa.html&lt;/ref&gt;<br /> |<br /> * {{magic|41 04 00 54 45 53 54}} &amp;rarr; &lt;code&gt;LET a$=&quot;TEST&quot;&lt;/code&gt;<br /> |-<br /> |100nnnnn<br /> |numeric array<br /> * 1 byte: array name (0x81 to 0x9A)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 5-byte number) in C-style order, iterating rightmost index first and the leftmost index last, e.g. &lt;code&gt;DIM a(2,3,4)&lt;/code&gt; will store values in this order: a(1,1,1), a(1,1,2), a(1,1,3), (1,1,4), a(1,2,1), a(1,2,2), a(1,2,3), a(1,2,4), a(1,3,1), a(1,3,2), a(1,3,3), a(1,3,4), a(2,1,1), ...<br /> |<br /> *{{magic|81 1C 00 01 05 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00}} &amp;rarr; &lt;code&gt;DIM a(5)&lt;/code&gt;<br /> *{{magic|81 19 00 02 02 00 02 00 00 00 01 00 00 00 00 02 00 00 00 00 03 00 00 00 00 04 00 00}} &amp;rarr; &lt;code&gt;DIM a(2,2); LET a(1,1)=1; LET a(1,2)=2; LET a(2,1)=3; LET a(2,2)=4&lt;/code&gt;<br /> |<br /> |-<br /> |110nnnnn<br /> |character array<br /> * 1 byte: array name (0xC1 to 0xDA)<br /> * 2 bytes: little-endian size of data to follow in bytes, so you can easily skip to the next variable without computing full array size<br /> * 1 byte: number of dimensions in the array (1-255?)<br /> * 2 bytes: little-endian valid range of first dimension e.g. &lt;code&gt;0A 00&lt;/code&gt; is valid range 1-10<br /> * ... 2 bytes more for every other dimension to declare the rest of the dimension ranges<br /> * ... array values (each a 1-byte character) in C-style order, iterating rightmost index first and the leftmost index last<br /> <br /> A single-dimensional character array acts like a string, but has a fixed length. If it is set to a shorter string, the remaining space in the array will be padded with spaces (0x20). In general, an ''n'' dimensional character array where n&gt;1 acts like an ''n''-1 dimensional string array, e.g. &lt;code&gt;DIM a$(5,10); LET a$(1)=&quot;FOO&quot;; LET a$(2)=&quot;BAR&quot;&lt;/code&gt; is valid, and sets a$(1,1) to a$(1,10) to &quot;FOO&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;, and sets a$(2,1) to a$(2,10) to &quot;BAR&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&quot;<br /> |<br /> * {{magic|C8 12 00 01 0F 00 68 65 6C 6C 6F 2C 20 77 6F 72 6C 64 20 20 20}} &amp;rarr; &lt;code&gt;DIM h$(15); LET h$=&quot;hello, world&quot;&lt;/code&gt;<br /> * {{magic|D7 0F 00 02 02 00 05 00 68 65 6C 6C 6F 77 6F 72 6C 64}} &amp;rarr; &lt;code&gt;DIM w$(2,5); LET w$(1)=&quot;hello&quot;; LET w$(2)=&quot;world&quot;&lt;/code&gt;<br /> |-<br /> |111nnnnnn<br /> |control variable of a FOR-NEXT loop.<br /> * 1 byte: variable name (0xE1 to 0xFA)<br /> * 5 bytes: current value (number)<br /> * 5 bytes: loop end limit (number)<br /> * 5 bytes: loop step increment (number)<br /> * 2 bytes: little-endian line number where the FOR loop was started<br /> * 1 byte: statement number within line where the FOR loop was started<br /> |<br /> * {{magic|E9 00 00 01 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (before loop has run)<br /> * {{magic|E9 00 00 06 00 00 00 00 05 00 00 00 00 01 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 5&lt;/code&gt; (after loop has run)<br /> * {{magic|E9 00 00 01 00 00 00 00 0A 00 00 00 00 02 00 00 FF FE 02}} &amp;rarr; &lt;code&gt;FOR i=1 TO 10 STEP 2&lt;/code&gt;<br /> * {{magic|E9 81 0C CC CC CD 83 76 66 66 66 7D 4C CC CC CC FE FF 02}} &amp;rarr; &lt;code&gt;FOR i=1.1 TO 7.7 STEP .1&lt;/code&gt; <br /> |}<br /> <br /> ==== 5-byte numeric format ====<br /> Numbers have one of two formats:&lt;ref&gt;http://www.worldofspectrum.org/ZXBasicManual/zxmanchap24.html&lt;/ref&gt; integers between -65535 and +65535 (inclusive) are in an &quot;integral&quot; format, while all other numbers are in &quot;floating point&quot; format. The value 0 can't be represented by the floating point format, so is always stored as an integral.<br /> <br /> With &quot;integral&quot; format:<br /> * 1 byte: always 0<br /> * 1 byte: 0 if the number is positive or -1 (0xFF) if the number is negative<br /> * 2 bytes: little-endian unsigned integer from 0 to 65535. Subtract 65536 from this if number is flagged as negative<br /> * 1 byte: always 0<br /> <br /> With &quot;floating point&quot; format:<br /> * 1 byte: exponent + 128 (0 &amp;rarr; e=-128, 255 &amp;rarr; e=127)<br /> * 4 bytes: big-endian mantissa<br /> <br /> The number has to be normalised so that its most significant mantissa bit is ''always'' 1. This bit is then assumed to be 1 and is overwritten with a sign bit: cleared to 0 for positive numbers and set to 1 for negative numbers<br /> {|<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Floating point examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|7F 7F FF FF FF}}||0.5<br /> |-<br /> |{{magic|7E 7F FF FF FF}}||0.25<br /> |-<br /> |{{magic|7D 7F FF FF FF}}||0.125<br /> |-<br /> |{{magic|91 00 00 00 00}}||65536<br /> |-<br /> |{{magic|A0 07 65 43 21}}||2271560481 (0x87654321)<br /> |-<br /> |{{magic|7F FF FF FF FF}}||-0.5<br /> |-<br /> |{{magic|7E FF FF FF FF}}||-0.25<br /> |-<br /> |{{magic|7D FF FF FF FF}}||-0.125<br /> |-<br /> |{{magic|91 80 00 00 00}}||-65536<br /> |-<br /> |{{magic|A0 87 65 43 21}}||-2271560481 (-0x87654321)<br /> |}<br /> |valign=&quot;top&quot;|<br /> {|class=&quot;wikitable&quot;<br /> |+Integral examples<br /> !Representation!!Value<br /> |-<br /> |{{magic|00 FF 01 00 00}}||-65535<br /> |-<br /> |{{magic|00 FF 02 00 00}}||-65534<br /> |-<br /> |{{magic|00 FF FE FF 00}}||-2<br /> |-<br /> |{{magic|00 FF FF FF 00}}||-1<br /> |-<br /> |{{magic|00 00 00 00 00}}||0<br /> |-<br /> |{{magic|00 00 00 00 00}}||1<br /> |-<br /> |{{magic|00 00 00 00 00}}||2<br /> |-<br /> |{{magic|00 00 FE FF 00}}||65534<br /> |-<br /> |{{magic|00 00 FF FF 00}}||65535<br /> |-<br /> |}<br /> |}<br /> <br /> === ZX81 BASIC Tokens ===<br /> {|<br /> {| class=&quot;wikitable&quot;<br /> ! title=&quot;Token&quot; | Token (Decimal)<br /> ! title=&quot;Description&quot; |Description<br /> <br /> |-<br /> |0||<br /> |-<br /> |11||&quot;<br /> |-<br /> |12||£<br /> |-<br /> |13||$<br /> |-<br /> |14||:<br /> |-<br /> |15||?<br /> |-<br /> |16||(<br /> |-<br /> |17||)<br /> |-<br /> |18||&gt;<br /> |-<br /> |19||&lt;<br /> |-<br /> |20||=<br /> |-<br /> |21||+<br /> |-<br /> |22||-<br /> |-<br /> |23||*<br /> |-<br /> |24||/<br /> |-<br /> |25||;<br /> |-<br /> |26||,<br /> |-<br /> |27||.<br /> |-<br /> |28||0<br /> |-<br /> |29||1<br /> |-<br /> |30||2<br /> |-<br /> |31||3<br /> |-<br /> |32||4<br /> |-<br /> |33||5<br /> |-<br /> |34||6<br /> |-<br /> |35||7<br /> |-<br /> |36||8<br /> |-<br /> |37||9<br /> |-<br /> |38||A<br /> |-<br /> |39||B<br /> |-<br /> |40||C<br /> |-<br /> |41||D<br /> |-<br /> |42||E<br /> |-<br /> |43||F<br /> |-<br /> |44||G<br /> |-<br /> |45||H<br /> |-<br /> |46||I<br /> |-<br /> |47||J<br /> |-<br /> |48||K<br /> |-<br /> |49||L<br /> |-<br /> |50||M<br /> |-<br /> |51||N<br /> |-<br /> |52||O<br /> |-<br /> |53||P<br /> |-<br /> |54||Q<br /> |-<br /> |55||R<br /> |-<br /> |56||S<br /> |-<br /> |57||T<br /> |-<br /> |58||U<br /> |-<br /> |59||V<br /> |-<br /> |60||W<br /> |-<br /> |61||X<br /> |-<br /> |62||Y<br /> |-<br /> |63||Z<br /> |-<br /> |64||RND<br /> |-<br /> |65||INKEY$<br /> |-<br /> |66||PI<br /> |-<br /> |112||&lt;cursor up&gt;<br /> |-<br /> |113||&lt;cursor down&gt;<br /> |-<br /> |114||&lt;cursor left&gt;<br /> |-<br /> |115||&lt;cursor right&gt;<br /> |-<br /> |116||GRAPHICS<br /> |-<br /> |117||EDIT<br /> |-<br /> |118||NEWLINE<br /> |-<br /> |119||RUBOUT<br /> |-<br /> |120||/<br /> |-<br /> |121||FUNCTION<br /> |-<br /> |127||cursor<br /> |-<br /> |128||<br /> |-<br /> |139||&quot;<br /> |-<br /> |140||£<br /> |-<br /> |141||$<br /> |-<br /> |142||:<br /> |-<br /> |143||?<br /> |-<br /> |144||(<br /> |-<br /> |145||)<br /> |-<br /> |146||&gt;<br /> |-<br /> |147||&lt;<br /> |-<br /> |148||=<br /> |-<br /> |149||+<br /> |-<br /> |150||-<br /> |-<br /> |151||*<br /> |-<br /> |152||/<br /> |-<br /> |153||;<br /> |-<br /> |154|||-<br /> |-<br /> |155||.<br /> |-<br /> |156||0<br /> |-<br /> |157||1<br /> |-<br /> |158||2<br /> |-<br /> |159||3<br /> |-<br /> |160||4<br /> |-<br /> |161||5<br /> |-<br /> |162||6<br /> |-<br /> |163||7<br /> |-<br /> |164||8<br /> |-<br /> |165||9<br /> |-<br /> |166||A<br /> |-<br /> |167||B<br /> |-<br /> |168||C<br /> |-<br /> |169||D<br /> |-<br /> |170||E<br /> |-<br /> |171||F<br /> |-<br /> |172||G<br /> |-<br /> |173||H<br /> |-<br /> |174||I<br /> |-<br /> |175||J<br /> |-<br /> |176||K<br /> |-<br /> |177||L<br /> |-<br /> |178||M<br /> |-<br /> |179||N<br /> |-<br /> |180||O<br /> |-<br /> |181||P<br /> |-<br /> |182||Q<br /> |-<br /> |183||R<br /> |-<br /> |184||S<br /> |-<br /> |185||T<br /> |-<br /> |186||U<br /> |-<br /> |187||V<br /> |-<br /> |188||W<br /> |-<br /> |189||X<br /> |-<br /> |190||Y<br /> |-<br /> |191||Z<br /> |-<br /> |192||&quot;&quot;<br /> |-<br /> |193||AT<br /> |-<br /> |194||TAB<br /> |-<br /> |195||?<br /> |-<br /> |196||CODE<br /> |-<br /> |197||VAL<br /> |-<br /> |198||LEN<br /> |-<br /> |199||SIN<br /> |-<br /> |200||COS<br /> |-<br /> |201||TAN<br /> |-<br /> |202||ASN<br /> |-<br /> |203||ACS<br /> |-<br /> |204||ATN<br /> |-<br /> |205||LN<br /> |-<br /> |206||EXP<br /> |-<br /> |207||INT<br /> |-<br /> |208||SQR<br /> |-<br /> |209||SGN<br /> |-<br /> |210||ABS<br /> |-<br /> |211||PEEK<br /> |-<br /> |212||USR<br /> |-<br /> |213||STR$<br /> |-<br /> |214||CHR$<br /> |-<br /> |215||NOT<br /> |-<br /> |216||**<br /> |-<br /> |217||OR<br /> |-<br /> |218||AND<br /> |-<br /> |219||&lt;=<br /> |-<br /> |220||&gt;=<br /> |-<br /> |221||&lt;&gt;<br /> |-<br /> |222||THEN<br /> |-<br /> |223||TO<br /> |-<br /> |224||STEP<br /> |-<br /> |225||LPRINT<br /> |-<br /> |226||LLIST<br /> |-<br /> |227||STOP<br /> |-<br /> |228||SLOW<br /> |-<br /> |229||FAST<br /> |-<br /> |230||NEW<br /> |-<br /> |231||SCROLL<br /> |-<br /> |232||CONT<br /> |-<br /> |233||DIM<br /> |-<br /> |234||REM<br /> |-<br /> |235||FOR<br /> |-<br /> |236||GOTO<br /> |-<br /> |237||GOSUB<br /> |-<br /> |238||INPUT<br /> |-<br /> |239||LOAD<br /> |-<br /> |240||LIST<br /> |-<br /> |241||LET<br /> |-<br /> |242||PAUSE<br /> |-<br /> |243||NEXT<br /> |-<br /> |244||POKE<br /> |-<br /> |245||PRINT<br /> |-<br /> |246||PLOT<br /> |-<br /> |247||RUN<br /> |-<br /> |248||SAVE<br /> |-<br /> |249||RAND<br /> |-<br /> |250||IF<br /> |-<br /> |251||CLS<br /> |-<br /> |252||UNPLOT<br /> |-<br /> |253||CLEAR<br /> |-<br /> |254||RETURN<br /> |-<br /> |255||COPY<br /> <br /> |}<br /> <br /> === Links and references ===<br /> * [http://www.worldofspectrum.org/ZX81BasicProgramming/ ZX81 BASIC Programming]<br /> * [http://www.trustedreviews.com/sinclair-zx81_Desktop-PC_review Sinclair ZX81 review (2012)]<br /> * [http://www.old-computers.com/museum/docs.asp?c=263 Sinclair ZX81 BASIC Programming Manual]<br /> &lt;references/&gt;<br /> <br /> [[Category:ZX Spectrum]]</div> Shram86
Warning: Cannot modify header information - headers already sent in /usr/local/www/mediawiki/includes/WebResponse.php on line 38

Warning: require(): Unable to allocate memory for pool. in /usr/local/www/mediawiki/includes/AutoLoader.php on line 1007