by Steven B. Combs, Ph.D. tags: commodore - retro - plus4 - vic20 - c64 - keyboard - keys - calculations - numbers - basic
In this Commodore Plus/4 retroCombs episode and companion blog post, I cover Chapter 6, Beginning BASIC Programming, of the Commodore Plus/4 user’s manual. In this chapter, we begin where everyone should with their Commodore computer; learning the BASIC programming language. In previous chapters we have dabbled with BASIC; however, in this chapter, we dive in and learn the “basic” concepts you need to begin your BASIC programming journey.
This is not an all-inclusive chapter and you will not become a master programmer after learning these concepts; however, you will have the knowledge you need to create simple programs. This is what made all Commodore computers special; the creation of your own programs. After you work through chapter 6, I recommend you review the Plus/4 Encyclopedia located on page 101 of the user’s manual.
NOTE: Right before posting this video, my YouTube channel reached 1000 (or 1K) subscribers! Thanks to everyone who follows along and please, let others know about the channel so I can continue to bring you more tech and retro-computing video and blog posts.
This episode is a small part of my larger Commodore Plus/4 series. You can read the entire series and view additional resources at:
As I progress through the user’s manual, I enter and execute sample programs. The link below is to a
.d81 image that contains every program from each episode. Like the series, the image is not complete.
retroCombs User’s Manual Disk Image - UPDATED AS OF: 2020-11-24
I use the following file name convention to make it easy to locate specific programs:
Sample Program Name:
02 RCOMBS SCROLL.PRG
02- The chapter number
RCOMBS SCROLL- my self assigned name for the BASIC program which will be immediately identifiable if you follow along.
As part of my Commodore Plus/4 YouTube series, I work through each chapter of the Plus/4 manual. I’ve taken the time to scan each chapter so you can read and follow along. Use the link below to view chapter 6:
Below are the links for previous chapters covered:
In the video below, I work through Chapter 6 of the user’s manual.
None as of 2020-11-25.
Below are the links I mention in the video. All Amazon links are affialiate links. Thanks for supporting the blog and the YouTube channel!
Because the Commodore Plus/4 keyboard is so different from modern keyboards, I devised a modern key nomenclature to identify keystroke combinations as shown in the table below:
Finally! An introduction to BASIC programming even though we have been programming in basic since almost day 1!
The two programming modes are DIRECT (IMMEDIATE) and INDIRECT (PROGRAM).
RUNs a series of BASIC program statements one-by-one based on their line numbers.
Type syntax correct commands on an empty line followed the
⏎. Examples of DIRECT mode commands include:
LIST DSAVE DLOAD VERIFY RUN ? 2+2
Use this mode to create BASIC programs. Preface each program statement with a line number, followed by a single command or multiple commands separated by a
:. Store the program in memory by hitting the
⏎. Execute a program with the
TIP: Typically, programmers number BASIC lines beginning with 10 and then work their way up in increments of 10. That is, the next line would be
20. This allows the programmer to easily insert additional code between lines
BONUS: Commodore BASIC 3.5 includes a
RENUMBERcommand. The syntax is
RENUMBER[new starting line #[,increment[,old starting line #]]]. An example;
RENUMBER 20,20,1renumbers program line 1 to 20 with each subsequent line numbered increments of 20.
Input/Output (I/O) statements allow programmers to communicate with an individual running a program or other devices connected to the Plus/4 such as a Datasette, joystick, disk drive, or printer. We’ve used a common I/O command,
?) in previous chapters to display text on the screen.
Let’s take a look at some output statement examples. Two output statement examples are below that answer the questions, “Does my checking account have money?” and “Can I have a purple lizard in my control room?”
100 ? "YOU ARE BROKE!" 150 ? "YOU CAN'T BRING YOUR FRIEND INTO THE CONTROL ROOM!"
We already covered numbers and calculations with the
100 ? 58*15,23,45+1000-45*(4-3)
This BASIC program will print:
870 23 1000
10 R=10*2 : N=R-5 20 ? "R IS";R;"AND N IS";N 30 ? "BUT R TIMES 2 IS";R*2 40 ? "AND N MINUS 2 IS";N-2
💾 On Disk:
; will override and print the line next to the previous line as shown in the example below:
200 ? "THESE TWO SENTENCE PARTS WILL BE "; 210 ? "PRINTED ONE AFTER THE OTHER."
💾 On Disk:
06 SAME LINE
The next examples demonstrate how to collect user and user defined program data. The first example requests user input and then reprints that input as part of an output, or
10 ? "WHAT IS YOUR NAME"; 20 INPUT A$ 30 ? "I AM PLEASED TO MEET YOU";A$;"." 40 INPUT "HOW OLD ARE YOU";AG 50 ? AG;" IS A BIT OLDER THAN I AM."
💾 On Disk:
06 YOUR NAME
REMEMBER: Use the
RUNcommand to execute the program.
You may wonder why there isn’t a
? at the end of line 10. The
INPUT command automatically adds this symbol at the end of each
Line 40 includes a variable after the line to collect the numeric data whereas lines 10 and line 20 separated these functions. You can combine lines 10 and 20 as follows:
10 INPUT "WHAT IS YOUR NAME?";A$
GETKEY input statement accepts a single key press and requires a string variable such as
A$. The command does not require
⏎. Below is an example:
1000 ? "PLEASE CHOOSE A,B,C,D,E, OR F." 1010 GETKEY A$ 1020 ? A$
💾 On Disk:
06 A THRU F
NOTE: This code does not include exception handling. You can type in any letter and and the code will print an incorrect result. This is not the intent of the program. We will look at exception handling later.
The final INPUT statement(s) is
READ statement is similar to the INPUT command; however, a program receives information from code rather than a user. Information is stored in code using
DATA statements. Below is an example the reads the names of the Marx Brothers:
10 READ A$, B$, C$, D$, E$ 20 ? A$ : ? B$ : ? C$: ? D$ : ? E$ 30 DATA GROUCHO, HARPO, CHICO, ZEPPO, GUMMO
💾 On Disk:
06 MARX BROTHERS
TIP: This example has the READ command collect character data using string variables in the format
X$. If you want to collect numeric data, use a numeric data variable such as
The output for this code is:
GROUCHO HARPO CHICO ZEPPO GUMMO
Is there any better example of the use of the
NOTE: The number of
READvariables must equal the number
DATAvariables or an
?OUT OF DATA ERROR IN XXerror will occur.
We can execute a line of code, one after another, but we can also jump around within code lines using control statements. Using loops, we run code over and over until we hit the [R/S] key or we specify, in the code for a group of code lines, to stop after a specific number of times.
In previous chapters, I would demonstrate a program that continually displays a line of text until the [R/S] key is hit. Remember that code? Here it is again:
10 ? "RETROCOMBS "; 20 GOTO 10
This type of program is know as an infinite loop because it “loops indefinitely” until you tap the [R/S] key.
GOTO control statement was introduce as early as Chapter 1. It is one of the first basic program commands most learn when they create their first “Hello World!” program as shown in the code above.
There is another way to create an infinite loop and that is with a
LOOP statement. This method of creating an infinite loop, that you can break out of within the program, is more elegant than our use of the
GOTO command as shown in the example below:
10 DO 20 ? "GOING UP "; 30 LOOP
💾 On Disk:
06 GOING UP
The statements between the
LOOP continue to execute without the need to reference a specific line number. Let’s rewrite my retroCombs screen fill program using a
10 DO : ? "RETROCOMBS"; 30 LOOP
TIP: As a reminder, use the
:character to place more than one program statement in a single line of code. This will reduce memory usage and in some cases, make your code more legible.
NEXT statements to create finite loops; or loops that repeat a certain number of times. A variable in a
NEXT loop counts the number of loops. Below is an example:
10 ? "COUNTUP..." 20 FOR J= 1 TO 10 30 ? "WE HAVE";J 40 NEXT J 50 ? "WE COUNTED UP TO";J
💾 On Disk:
06 COUNT UP
The program above “steps” through the loop in increments of one; however, you can modify the
STEP value. To increment by a value of 5, the
FOR line would like the one shown below:
20 FOR J = 10 TO 30 STEP 5
10, 15, 20, 25, 30
A negative STEP value allows the counter to count backward. To increment by a value of -5, the
FOR line will look like the one below:
20 FOR J = 30 TO 10 STEP -5
30, 25, 20, 15, 10
Using the negative step value, we can program a NASA rocket program countdown timer as shown below.
10 ? "COUNTDOWN..." 20 FOR J = 10 TO 1 STEP -1 30 ? "WE ARE AT";J 35 FOR T = 1 TO 500 : NEXT T 40 NEXT J 50 ? "WE HAVE LIFT-OFF!"
💾 On Disk:
06 LIFT OFF
NOTE: I modified the countdown program in the user’s manual. The program presented did not countdown with correct timing. My modification, line 35, adds another
NEXTloop to pause the program for about a second between each
TIP: Use the
RENUMBER,,10) if that single out of balance 35 line number doesn’t work for you and you like the lines numbered from 10 to 70 in increments of 10 as shown below:
10 ? "COUNTDOWN..." 20 FOR J = 10 TO 1 STEP -1 30 ? "WE ARE AT";J 40 FOR T = 1 TO 500 : NEXT T 50 NEXT J 60 ? "WE HAVE LIFT-OFF!"
Up to this point, our Plus/4 has been a basic calculator; albeit a pretty smart one; however, it’s time for the Plus/4 to grow up and make its own decisions using conditional, or decision making, statements such as
THEN. In other words,
IF this happens,
THEN do this.
We often use
THEN statements to act on user keyboard, or joystick, input as shown in the example below. This program asks the user to enter the tenth letter of the alphabet using the keyboard, evaluates whether the user’s input is correct, and then chides or rewards the user. If the user is wrong, the program will continue until the user enters the correct answer (which is
J, by the way.)
NOTE: The program in the book was a disaster. It appears as if there were two program smashed into a single listing. I’ve cleaned up the program so it makes sense.
10 INPUT "WHAT'S THE 10TH LETTER OF THE ALPHABET?";A$ 20 IF A$ = "J" THEN ? "CORRECT!" : GOTO 50 30 INPUT "ANSWER IS INCORRECT. TRY AGAIN? (Y OR N)";X$ 40 IF X$ = "Y" THEN 10 : ELSE 60 50 ? "YOU ANSWERED CORRECTLY, SO WHY CONTINUE?" : END 60 ? "I STUMPED YOU, HUH?"
💾 On Disk:
06 10TH LETTER
In my corrected example, I also include a very important adjunct to the
ELSE. For instance,
IF a variable,
B, is greater than (
ELSE (meaning if it isn’t)
END the program. The basic code for this statement is:
10 IF A>5 THEN 10 : ELSE END
Note that the THEN statement does not need to include the
GOTO statement; nor does the
ELSE statement. These combinations are used so frequently in BASIC, the interpreter was designed to understand this relationship. This understanding also saves memory.
We create a subroutine to execute the same code over and over in a larger program. Subroutines allow your program to “jump”, or
GOSUB, to a code’s location and then
RETURN to the original code, where the
GOSUB occurred, once the subroutine is complete. This may sound the like GOTO command; however, with GOTO, you have to know specifically which line number to return. The
RETURN combination does the heavy lifting for you and will reduce errors if you renumber lines of code.
The code below prompts the user for a number between 1 and 10. If the number entered is within that range, the program will prompt for the same range again. If the number is not within that range (
N>10), the GOSUB statement will send the code execution to line 100 that prints a statement saying the number is out of range and give it another shot. When two numbers within range are entered, the program will add their values and
END the program.
10 T=0 : FOR J = 1 TO 2 20 ? "TYPE A NUMBER FROM 1 TO 10 30 INPUT N 40 IF N<1 THEN GOSUB 100 : GOTO 20 50 IF N>10 THEN GOSUB 100 : GOTO 20 60 T=T+N 70 NEXT J 80 ? "THE TOTAL IS";T 90 END 100 ? "THAT NUMBER IS OUT OF RANGE" 110 ? "PLEASE TYPE A NUMBER BETWEEN 1 AND 10" 120 RETURN
💾 On Disk:
06 ONE TO TEN
NOTE: Earlier, I mentioned the concept of exception handling Lines 40 and 50 includes this concept. The program will not stop functioning if the users inputs any number outside our specified range of 1 through 10.
NOTE: The user’s manual original code required the user to type in 99 numbers! We have far too many important things to learn about our Commodore Plus/4 than how to type in 99 unique numbers between 1 and 10.
REM statement to add comments to your code. These can be their own unique lines or added at the end of lines.
REM statements are often used to show credit or describe a line’s operation. Below are a few examples:
10 REM TITLE: REM STATEMENTS 20 REM CODER: RETROCOMBS 30 E=R/T*9 : REM THIS FIGURES OUT A PITCHER'S ERA 40 INPUT A,B : REM A IS HEIGHT AND B IS WEIGHT
REM statements help code readability, portability, and transferability; however,
REM statements use memory, so use them sparingly in long programs that are pushing memory limits. After all, we only have 60671 bytes free on our Commodore Plus/4!
As the user’s manual states in the summary, this is not an exhaustive study of BASIC nor a complete tutorial. We only covered a fraction of the commands available. Read the BASIC 3.5 Encyclopedia beginning on page 101 to begin your real journey. BASIC is a capable, and fun language, that can bring you hours of fun and help you solve real world problems.
In the next chapter, we will use the basic commands we have already learned and combine with them with unique Commodore Plus/4 BASIC 3.5 graphics commands to create pretty pictures on our screen. These are commands that were not available on the base Commodore VIC-20 or C64. You won’t want to miss that fun, so make sure you SUBSCRIBE to my YouTube channel.
Help make this series better! Post feedback, questions, and ideas. Let me know if you are following along. Let’s make this a community project. For now, Leave your comments and thoughts below or in the comments under the YouTube video.
Thanks for watching and if you are so inclined, please let other Commodore fans know about the series by sharing these videos using #retroCombs.
🕹️ retroCombs, OUT!comments powered by Disqus