(BBC BASIC version 5 or later only)
MID$ may also be used to the
left of an equals sign to change part of a string whilst leaving the rest alone.
You can use this function to select any part of a string. For instance, ifC$ = MID$(A$,start_posn,num) C$ = MID$(A$,Z) MID$(A$,4,2) = B$
thenname$="BBC BASIC for Z80"
would set part$ to "BAS". If the third parameter is omitted or there are insufficient characters to the right of the specified position, MID$ returns the right hand part of the string starting at the specified position. Thus,part$=MID$(name$,5,3)
would set part$ to "Z80".part$=MID$(name$,15)
For example,
would printname$="BBC BASIC for Z80" FOR i=5 TO 15 PRINT MID$(name$,i,11) NEXT
(BBC BASIC version 5 or later only)BASIC for Z ASIC for Z8 SIC for Z80 IC for Z80 C for Z80 for Z80 for Z80 or Z80 r Z80 Z80 Z80
will set A$ equal to "BBC ZZSIC". Although the sub-string length is set to four, only two characters are actually modified since that is the length of the string "ZZ".A$ = "BBC BASIC" MID$(A$,5,4) = "ZZ"
<s-var>=MID$(<string>,<numeric>[,<numeric>]) MID$(<s-var>,<numeric>[,<numeric>])=<string>
LEFT$, RIGHT$, LEN, INSTR
MOD is defined such that,X=A MOD B
If you are doing integer division (DIV) of whole numbers it is often desirable to know the remainder (a 'teach children to divide' program for instance). For example, 23 divided by 3 is 7, remainder 2. Thus,A MOD B = A - ( A DIV B ) * B.
would printPRINT 23 DIV 3 PRINT 23 MOD 3
You can use real numbers in these calculations, but they are truncated to their integer part before BBC BASIC calculates the result. Thus,7 2
would give exactly the same results as the previous example.PRINT 23.1 DIV 3.9 PRINT 23.1 MOD 3.9
(BBC BASIC version 5 or later only)
MOD can also be used as a function which operates on an entire numeric array. It returns
the modulus (the square-root of the sum of the squares of all the elements) in the array.
See the array arithmetic section.
<n-var>=<numeric> MOD <numeric> <n-var>MOD=<numeric> <n-var>=MOD(<array()>)
DIV
MODE |
MO. |
The MODE command sets the screen display mode. The screen is cleared and all the graphics and text parameters (colours, origin, etc) are reset to their default values.
MODE n is equivalent to VDU 22,n.
(BBC BASIC version 5 or later only)
MODE can also be used as a function. It returns the current mode number
(or −1 if no MODE statement has been executed, or a 'custom' mode
is in use).
MODE <numeric> <n-var> = MODE
CLS, CLG
A multi-purpose statement which controls, or returns information about, the mouse. The different variants of the statement are as follows (not all may be implemented):
MOUSE <n-var>,<n-var>,<n-var> MOUSE ON [<numeric>] MOUSE OFF MOUSE TO <n-var>,<n-var> MOUSE RECTANGLE <n-var>,<n-var>,<n-var>,<n-var> MOUSE RECTANGLE OFF
ON, OFF
Not implemented in the generic CP/M version of BBC BASIC (Z80)
MOVE [BY] <numeric>,<numeric>
DRAW, MODE, GCOL, PLOT
This command effectively 'removes' a program from the computer's memory. In reality, the program is still there, but BBC BASIC (Z80) has been told to forget about it.NEW
If you have made a mistake, you can recover your old program by typing OLD. However, this won't work if you have begun to enter a new program.
NEW
OLD
NEXT |
N. |
If the control variable is present then FOR....NEXT loops may be 'popped' automatically in an attempt to match the correct FOR statement (this should not be necessary). If a matching FOR statement cannot be found, a 'Can't match FOR' error will be reported.NEXT NEXT J
Leaving out the control variable will make the program run quicker, but this is not to be encouraged.
See the keyword FOR for more details about the structure of FOR....NEXT loops.
NEXT [<n-var>{,<n-var>}]
FOR, TO, STEP
NOT is most commonly used in an IF....THEN....ELSE statement to reverse the effect of the test.A=NOT 3 flag=NOT flag flag=NOT(A=B)
BBC BASIC (Z80) does not have true boolean variables; it makes do with numeric variables. This can lead to confusion because the testable condition in an IF....THEN....ELSE statement is evaluated mathematically and can result in something other than -1 (TRUE) or 0 (FALSE).IF NOT(rate>5 AND TIME<100) THEN ..... IF NOT flag THEN .....
When the test in an IF....THEN....ELSE is evaluated, FALSE=0 and anything else is considered to be TRUE. If you wish to use NOT to reverse the action of an IF statement it is important to ensure that the testable condition does actually evaluate to -1 for TRUE.
If the testable condition evaluates to 1, for example, the result of the test would be considered to be TRUE and the THEN part of the IF....THEN....ELSE statement would be carried out. However, using NOT in front of the testable condition would not reverse the action. NOT 1 evaluates to -2, which would also be considered to be TRUE.
<n-var>=NOT<numeric>
None
A keyword which is part of the CASE... ENDCASE clause. OF follows the name of the CASE variable, and must be the last item on the program line (not even followed by a REMark).
CASE die% OF WHEN 1,2,3 : bet$ = "lose" WHEN 4,5,6 : bet$ = "win" OTHERWISE bet$ = "cheat" ENDCASE
CASE <var> OF
CASE, ENDCASE, OTHERWISE, WHEN
A statement which hides the text cursor (which is normally a flashing underscore). The cursor can be switched on again with ON. OFF is equivalent to VDU 23,1,0;0;0;0;.
OFF is also used in the ON ERROR OFF statement.
OFF
ON
OLD works even if BBCBASIC(86) has been re-loaded and re-started from MS-DOS. However, it will only work if no other programs have been run and BBCBASIC(86) loads at the same address as before.OLD
OLD
NEW
The ON statement alters the path through your program by transferring control to one of a selection of line numbers depending on the value of a variable. For example,ON option GOTO 1000,2000,3000,4000 ON action GOSUB 100,3000,200,5000,30 ON choice PROC_add,PROC_find,PROC_delete
would send your program to line 1000 if 'number' was 1, to line 2000 if 'number' was 2, to line 500 if 'number' was 3 and to line 100 if 'number' was 4.200 ON number GOTO 1000,2000,500,100
Exceptions may be trapped using the ELSE statement delimiter.
If there is no statement after the ELSE, the program will 'drop through' to the following line if an exception occurs. In the two following examples, the program would drop through to the error handling part of the program if 'choice' or 'B-46' was less than one or more than 3.ON action GOTO 100,300,120 ELSE PRINT"Illegal"
You can use ON...GOTO, ON...GOSUB, and ON...PROC to execute the appropriate part of your program as the result of a menu selection. The following skeleton example offers a menu with three choices.ON choice PROC_add,PROC_find(a$),PROC_delete ELSE PRINT "Illegal Choice - Try again" ON B-46 GOSUB 100,200,(C/200) ELSE PRINT "ERROR"
20 CLS 30 PRINT "SELECT THE ACTION YOU WISH TO TAKE" 40 PRINT "1 OPEN A NEW DATA FILE" 50 PRINT "2 ADD DATA TO THE FILE" 60 PRINT "3 CLOSE THE FILE AND END"'' 70 REPEAT 80 INPUT TAB(10,20)"WHAT DO YOU WANT ? "choice 90 UNTIL choice>0 AND choice<4 100 ON choice PROC_open,PROC_add,PROC_close ELSE 110 .....etc
would be interpreted asON entry PROC_start,PROC_add(":"),PROC_end
and give rise to an interesting crop of error messages.ON entry PROC_start,PROC_add(" :"),PROC_end
ON <numeric> GOTO <l-num>{,<l-num>} [ELSE <stmt>{:<stmt>}] ON <numeric> GOSUB <l-num>{,<l-num>} [ELSE <stmt>{:<stmt>}] ON <numeric> PROC<name>[(<exp>{,<exp>})] {,PROC<name>[(<exp>{,<exp>})]} [ELSE <stmt>{:<stmt>}]
ON can also be used on its own to enable the text cursor (caret). ON is equivalent to VDU 23,1,1;0;0;0;.
ON ERROR, ON ERROR LOCAL, GOTO, GOSUB, PROC, ON
ON ERROR OFF returns the control of error handling to BBC BASIC (Z80).
For example, the ON ERROR statement can be used to trap out the escape key to prevent a program being terminated at the wrong time by its accidental use.ON ERROR PRINT"Suicide":END ON ERROR GOTO 100 ON ERROR OFF
Error handling is explained more fully in the General Information section.50 ON ERROR IF ERR=17 THEN 70 60 PRINT:REPORT:PRINT " at line ";ERL:END 70 : etc.
ON ERROR <stmt>{:<stmt>} ON ERROR OFF
ON, GOTO, GOSUB, PROC
A statement controlling error trapping. If an ON ERROR LOCAL statement has been encountered, BBC BASIC will transfer control to it (without taking any reporting action) when an error is detected. This allows error reporting/recovery to be controlled by the program.
Unlike the ON ERROR statement, ON ERROR LOCAL prevents BBC BASIC clearing the program stack. By using this statement, you can trap errors within a FOR ... NEXT, REPEAT ... UNTIL or WHILE ... ENDWHILE, loop or a subroutine, function or procedure without BBC BASIC losing its place within the program structure.
ON ERROR OFF returns the control of error handling to BBC BASIC.
The following example program will continue after the inevitable 'Division by zero' error.ON ERROR LOCAL PRINT"Suicide":END ON ERROR LOCAL ENDPROC ON ERROR OFF
If ON ERROR LOCAL is used within a procedure, function, or loop structure then the previous error-trapping status (which might be an earlier ON ERROR LOCAL) is automatically restored on exit from the structure. However, ON ERROR LOCAL can be used anywhere within a BBC BASIC program, not just in these structures. In this case you must explicitly restore the previous error-trapping status using RESTORE ERROR.FOR n=-5 TO 5 ok% = TRUE ON ERROR LOCAL PRINT "Infinity" : ok% = FALSE IF ok% PRINT "The reciprocal of ";n;" is ";1/n NEXT n
ON ERROR LOCAL OFF temporarily disables error trapping; the default error reporting mechanism will be used until the previous error-trapping status is restored.
ON ERROR LOCAL <stmt>{:<stmt>} ON ERROR LOCAL OFF ON ERROR OFF
ON, ON ERROR, GOTO, GOSUB, PROC, RESTORE
OPENIN |
OP. |
A returned value of zero signifies that the specified file was not found on the disk.
The example below reads data from disk into an array. If the data file does not exist, an error message is printed and the program ends.X=OPENIN "jim" X=OPENIN A$ X=OPENIN (A$) X=OPENIN ("FILE1")
10 DIM posn(10),name$(10) 20 fnum=OPENIN "TOPTEN" 30 IF fnum=0 THEN PRINT "No TOPTEN data": END 40 FOR i=1 TO 10 50 INPUT#fnum,posn(i),name$(i) 60 NEXT 70 CLOSE#fnum
<n-var>=OPENIN(<str>)
OPENOUT, OPENUP, CLOSE#, PTR#, PRINT#, INPUT#, BGET#, GET$#, BPUT#, EOF#
A returned value of zero indicates that the specified file could not be created.
You can also read from a file which has been opened using OPENOUT. This is of little use until you have written some data to it. However, once you have done so, you can move around the file using PTR# and read back previously written data.X=OPENOUT(A$) X=OPENOUT("DATAFILE") X=OPENOUT("LPT1")
Data is not written to the file at the time it is opened. Consequently, it is possible to successfully open a file on a full disk. Under these circumstances, a 'Disk full' error would be reported when you tried to write data to the file for the first time.
The example below writes the contents of two arrays (tables) to a file called 'TOPTEN.BBC'.
10 A=OPENOUT "TOPTEN" 20 FOR Z=1 TO 10 30 PRINT#A,N(Z),N$(Z) 40 NEXT 50 CLOSE#A 60 END
<n-var>=OPENOUT(<str>)
OPENIN, OPENUP, CLOSE#, PTR#, PRINT#, INPUT#, BGET#, BPUT#, GET$#, EOF#
A returned value of zero signifies that the specified file was not found on the disk.
See the random file examples (F-RAND?) in the BBC BASIC Disk Files section for examples of the use of OPENUP.X=OPENUP "jim" X=OPENUP A$ X=OPENUP (A$) X=OPENUP ("FILE1")
<n-var>=OPENUP(<str>)
OPENIN, OPENOUT, CLOSE#, PTR#, PRINT#, INPUT#, BGET#, BPUT#, GET$#, EOF#
Value Action 0 assembler errors suppressed; no listing. 1 assembler errors suppressed; listing. 2 assembler errors reported; no listing. 3 assembler errors reported; listing (default).
The possible assembler errors are:
Value Action 4 assembler errors suppressed; no listing. 5 assembler errors suppressed; listing. 6 assembler errors reported; no listing. 7 assembler errors reported; listing.
Out of range - error code 40.
No such variable - error code 26.
OPT <numeric>
None
You can leave out the space between OR and a preceding constant, but it makes your programs difficult to read.IF A=2 OR B=3 THEN 110 X=B OR 4
You can use OR as a logical operator or as a 'bit-by-bit' (bitwise) operator. The operands can be boolean (logical) or numeric.
Unfortunately, BBC BASIC does not have true boolean variables; it uses numeric variables and assigns the value 0 for FALSE and -1 for TRUE. This can lead to confusion at times. (See NOT for more details.)
In the example below, the operands are boolean (logical). In other words, the result of the tests (IF) A=2 and (IF) B=3 is either TRUE or FALSE. The result of this example will be TRUE if A=2 or B=3.
The brackets are not necessary, they have been included to make the example easier to follow.answer=(A=2 OR B=3)
The last example, uses the OR in a similar fashion to the numeric operators (+, -, etc).
Suppose X was -20 in the following example,
the OR operation would be:A=X OR 11
11111111 11111111 11111111 11101100 00000000 00000000 00000000 00001011 11111111 11111111 11111111 11101111 = -17
<n-var>=<numeric> OR <numeric>
AND, EOR, NOT
A statement which sets the graphics origin. ORIGIN is followed by the X and Y coordinates of the new origin; subsequent graphics commands operate with respect to these coordinates. The coordinates must be in the range −32768 to +32767.
ORIGIN x,y is equivalent to VDU 29,x;y;
ORIGIN 640,512
ORIGIN <numeric>,<numeric>
MODE, PLOT, VDU
See the Operating System Interface section for more details.command$="ERA PHONE.DTA" OSCLI command$ command$="REN ADDRESS.DTA=NAME.DTA" OSCLI command$
OSCLI <str>
All operating system (*) commands.
A keyword which is an optional part of the CASE ... ENDCASE clause. OTHERWISE precedes the statement(s) which should be executed if the CASE variable matches none of the values specified in a WHEN statement. OTHERWISE must be the first item on the program line.
CASE die% OF WHEN 1,2,3 : bet$ = "lose" WHEN 4,5,6 : bet$ = "win" OTHERWISE bet$ = "cheat" ENDCASE
OTHERWISE [<stmt>]{:<stmt>}
CASE, ENDCASE, OF, WHEN
PAGE |
PA. |
PAGE is automatically initialised by BBC BASIC (Z80) to the address of the lowest available page in RAM, but you may change it.PAGE=&3100 PRINT ~PAGE PAGE=TOP+&100: REM Move to start of next page.
If you make PAGE less than its original value or greater than the original value of HIMEM, you will get a 'Bad program' error when you try to enter a program line and you may well crash BBC BASIC (Z80).
If you make PAGE greater than HIMEM, a 'No room' error will occur if the program exits to command level.
With care, several programs can be left around in RAM without the need for saving them.
USE WITH CARE.
PAGE=<numeric> <n-var>=PAGE
TOP, LOMEM, HIMEM
You can use PI to calculate the circumference and area of a circle. The example below calculates the circumference and area of a circle of a given radius.X=PI
PI can also be used to convert degrees to radians and radians to degrees.10 CLS 20 INPUT "What is the radius of the circle ",rad 30 PRINT "The circumference is: ";2*PI*rad 40 PRINT "The area is: ";PI*rad*rad 50 END
However, BBC BASIC (Z80) has two functions (RAD and DEG) which perform these conversions to a higher accuracy.radians=PI/180*degrees degrees=180/PI*radians
<n-var>=PI
RAD, DEG
PLOT |
PL. |
Not implemented in the generic CP/M version of BBC BASIC (Z80)
PLOT [BY] <numeric>,<numeric>,<numeric>
MODE, CIRCLE, CLG, MOVE, DRAW, ELLIPSE, LINE, ORIGIN, RECTANGLE, POINT, VDU, GCOL
Not implemented in the generic CP/M version of BBC BASIC (Z80)
<n-var>=POINT(<numeric>,<numeric>)
PLOT, DRAW, MOVE, GCOL
COUNT will tell you the print head position of the printer. It is an uncertain indicator of the horizontal position of the cursor on the screen. (See the keyword COUNT for details.)X=POS
See VPOS for an example of the use of POS and VPOS.
<n-var>=POS
COUNT, TAB, VPOS
P. |
In the examples which follow, commas have been printed instead of spaces to help you count.
The screen is divided into zones (initially) 10 characters wide. By default, numeric quantities are printed right justified in the print zone and strings are printed just as they are (with no leading spaces). Numeric quantities can be printed left justified by preceding them with a semi-colon. In the examples the zone width is indicated as z10, z4 etc.
Initially numeric items are printed in decimal. If a tilde (~) is encountered in the print list, the numeric items which follow it are printed in hexadecimal. If a comma or a semi-colon is encountered further down the print list, the format reverts to decimal.z10 012345678901234567890123456789 PRINT 23.162 ,,,,23.162 PRINT "HELLO" HELLO PRINT ;23.162 23.162
A comma (,) causes the cursor to TAB to the beginning of the next print zone unless the cursor is already at the start of a print zone. A semi-colon causes the next and following items to be printed on the same line immediately after the previous item. This 'no-gap' printing continues until a comma (or the end of the print list) is encountered. An apostrophe (') will force a new line. TAB(X) and TAB(Y,Z) can also be used at any position in the print line to position the cursor.z10 012345678901234567890123456789 PRINT ~10 58,58 ,,,,,,,,,A,,,,,,,,3A,,,,,,,,58
Unlike most other versions of BASIC, a comma at the end of the print list will not suppress the new line and advance the cursor to the next zone. If you wish to split a line over two or more PRINT statements, end the previous print list with a semicolon and start the following list with a comma or end the line with a comma followed by a semicolon.z10 012345678901234567890123456789 PRINT "HELLO",24.2 HELLO ,,,,,,24.2 PRINT "HELLO";24.2 HELLO24.2 PRINT ;2 5 4.3,2 254.3 ,,,,,,,,,2 PRINT "HELLO"'2.45 HELLO ,,,,,,2.45
orz10 012345678901234567890123456789 PRINT "HELLO" 12; HELLO,,,,,,,,12,,,,,,,,,,23.67 PRINT ,23.67
Printing a string followed by a numeric effectively moves the start of the print zones towards the right by the length of the string. This displacement continues until a comma is encountered.PRINT "HELLO" 12,; PRINT 23.67
z10 012345678901234567890123456789 PRINT "HELLO"12 34 HELLO,,,,,,,,12,,,,,,,,34 PRINT "HELLO"12,34 HELLO,,,,,,,,12 ,,,,,,,,34
@%=&SSNNPPWW
Byte Range Default Purpose SS 00-01 00 STR$ Format Control NN 00-02 00 Format Selection PP ??-?? 09 Number of Digits Printed WW 00-0F 0A(10) Zone and Print Field Width
00 General Format (G).
01 Exponential Format (E).
02 Fixed Format (F).
G Format | Numbers that are integers are printed as such. Numbers in the range 0.1 to 1 will be printed as such. Numbers less than 0.1 will be printed in E format. Numbers greater than the range set by Byte 1 will be printed in E format. In which case, the number of digits printed will still be controlled by Byte 1, but according to the E format rules. |
The earlier examples were all printed in G9 format. | |
E Format | Numbers are printed in the scientific (engineering) notation. |
F Format | Numbers are printed with a fixed number of decimal places. |
Format | Range | Control Function |
---|---|---|
G | 01-0A | The maximum number of digits which can be printed, excluding
the decimal point, before changing to the E format.
01234567890123456789 &030A - G3z10 (00'00'03'0A) PRINT 1000.31 ,,,,,,,1E3 PRINT 1016.31 ,,,,1.02E3 PRINT 10.56 ,,,,,,10.6 |
E | 01-FF | The total number of digits to be printed excluding the
decimal point and the digits after the E. Three characters or spaces
are always printed after the E. If the number of significant figures
called for is greater than 10, then trailing zeros will be printed.
01030A - E3z10 (00'01'03'0A) 01234567890123456789 PRINT 10.56 ,,1.06E1 &010F0A - E15z10 (00'01'0F'0A) 01234567890123456789 PRINT 10.56 1.05600000000000E1 |
F | 00-0A | The number of digits to be printed after the decimal
point.
&02020A - F2z10 (00'02'02'0A) 01234567890123456789 PRINT 10.56 ,,,,,10.56 PRINT 100.5864 ,,,,100.59 PRINT .64862 ,,,,,,0.65 |
followed by&020208 - F2z8 (00'00'02'08)
&020206 - F2z6 (00'02'02'06) 01234567890123456789 PRINT 10.2,3.8 ,,,10.20,,,,3.80 PRINT 10.2,3.8 ,10.20,,3.80
Functions have to return an answer, but the value returned by this function is a null string. Consequently, its only effect is to change the print control variable. Thus the PRINT statementDEF FN_pformat(N):@%=N:=""
will print x in G9z10 format and y in F2z10 format.PRINT FN_pformat(&90A) x FN_pformat(&2020A) y
The results obtained by running the following example program show the effect of changing the zone width. The results for zone widths of 5 and 10 (&0A) illustrate what happens when the zone width is too small for the number to be printed properly. The example also illustrates what happens when the number is too large for the chosen precision.G9z10 G2z10 &00090A &00020A 012345678901234 012345678901234 1111.11111 ,,,,,1.1E3 13.7174211 ,,,,,,,,14 ,1.5241579 ,,,,,,,1.5 1.88167642E-2 ,,,,1.9E-2 2.09975158E-3 ,,,,2.1E-3 F2z10 E2z10 &02020A &0102A 012345678901234 012345678901234 ,,,1111.11 ,,,1.1E3 ,,,,,13.72 ,,,1.4E1 ,,,,,,1.52 ,,,1.5E0 ,,,,,,0.02 ,,,1.9E-2 ,,,,,,0.00 ,,,2.1E-3
10 test=7.8123 20 FOR i=5 TO 25 STEP 5 30 PRINT 40 @%=&020200+i 50 PRINT "@%=&000";~@% 60 PRINT STRING$(3,"0123456789") 70 FOR j=1 TO 10 80 PRINT test^j 90 NEXT 100 PRINT ' 110 NEXT 120 @%=&90A &00020205 012345678901234567890123456789 7.81 61.03 476.80 3724.91 29100.11 227338.75 1776038.54 13874945.89 1.083952398E8 8.46816132E8 &0002020A 012345678901234567890123456789 7.81 61.03 476.80 3724.91 29100.11 227338.75 1776038.54 13874945.89 1.083952398E8 8.46816132E8 &0002020F 012345678901234567890123456789 7.81 61.03 476.80 3724.91 29100.11 227338.75 1776038.54 13874945.89 1.083952398E8 8.46816132E8 &00020214 012345678901234567890123456789 7.81 61.03 476.80 3724.91 29100.11 227338.75 1776038.54 13874945.89 1.083952398E8 8.46816132E8 &00020219 012345678901234567890123456789 7.81 61.03 476.80 3724.91 29100.11 227338.75 1776038.54 13874945.89 1.083952398E8 8.46816132E8
PRINT {[TAB(<numeric>[,<numeric>])][SPC(<numeric>] ['][,][;][~][<str>|<numeric>]}
PRINT#, TAB, POS, STR$, WIDTH, INPUT, VDU
CONTENTS |
CONTINUE |