Since THE SERVANT pops up whenever you turn on or reset your computer, it would be quite annoying if you were stuck with THE SERVANTs original appearance.
Modifying THE SERVANT not hard. First, load THE SERVANT into computer RAM memory. To verify that THE SERVANT really is present and working in the computer's memory, invoke THE SERVANTs main menu. You should see the author's name and address below the main menu, and the message "Hit CONTROL/+ to save EPROM burner file". DO NOT save THE SERVANT yet. First, modify your copy according to your preferences. To do that, hit RETURN to return to BASIC. Now, you're ready to make modifications.
FUNCTION KEYS:
Whenever you power up or reset your computer, THE SERVANT will install its own function keys definitions. The default definitions are as follows:
F1 = dload " (Load a BASIC program)
F2 = dsave "@ (Save a BASIC program)
F3 = cA (Directory on disk drive 8)
F4 = cAu9 (Directory on disk drive 9)
F5 = clear screen, set colors, set fast mode if using 80 columns.
F6 = bank15:sysdec("1300") (Call a ML routine at 4864/$1300)
F7 = lI (List a BASIC program)
F8 = moN (Go to the ML monitor.)
Type KEY, and then RETURN. A list of the current function keys will appear on the screen. Please note how control characters are utilized. The control characters will make the function keys work flawlessly, even if they are pressed in the middle of a screen full of text (try that using the C128's default definitions!).
Please note about F5 above: Even if you wish to keep the overall definition of the key, you may wish to modify it to suit your color preferences. The definition of the colors in the function key string does NOT automatically change with the default color preferences you set for THE SERVANT itself (see below).
You can change or modify any of the definitions using the BASIC "KEY" command. If you want, you can change the function of the HELP key and the SHIFT/RUN-STOP combination as well. Here's how:
To change the RUN key:
bank 15:sys 24812 ,,8,,,"definition"
To change the HELP key:
bank 15:sys 24812 ,,9,,,"definition"
Replace the word "definition" with the actual definition you want to use. Please note the use of commas, you'll need to use them exactly as shown for this trick to work.
You won't need to include a function key definition to invoke THE SERVANT itself. However, THE SERVANT will automatically claim one function key definition (of your own choice) for this purpose. See the section on THE SERVANT call key below. Please note that the total number of characters in the function key strings is limited to 246. THE SERVANT call key use 16 characters, so a total of 230 characters are available for your use.
When you think your custom function keys are OK, test them to verify that they really work according to your expectations. The final step is to copy the definitions into THE SERVANT itself. Do it using the following BASIC line:
bank0:for x=0to255:poke32795+x,peek(4096+x):next
DISABLING THE SERVANTs FUNCTION KEY INSTALLATION:
If you don't want THE SERVANT to install function keys upon power up or reset, use the command:
bank0:poke33058,0
This will disable THE SERVANT function keys installation. To re-enable the function key definition, poke a nonzero value into location 33058. Please note that you cannot disable THE SERVANTs automatic call key definition (see below).
SETTING THE SERVANT CALL KEY:
One key must be reserved to call THE SERVANT. THE SERVANT automatically sets this definition. It's up to you however, to decide which function key THE SERVANT is going to use. Use the command:
bank0:poke33057,function key number.
The function key numbers are 1 through 8 for the function keys 1 through 8; 9 is the SHIFT/RUN-STOP combination, and 10 is the HELP key. Take your pick. The default is 9, using the SHIFT/RUN-STOP combination.
Please note that these color codes are different from the codes for the 40 column screen. The color codes are as follows:
0 = black 4 = dark green 8 = dark red 12 = brown
1 = dark gray 5 = light green 9 = light red 13 = yellow
2 = dark blue 6 = dark cyan 10 = dark purple 14 = light gray
3 = light blue 7 = light cyan 11 = light purple 15 = white
SETTING UPPERCASE ON EXIT:
If you have played around with THE SERVANT a bit, you'll notice that the letters are lowercase when you exit.
To set uppercase upon exit:
bank0:poke33056,142
To set lowercase upon exit:
bank0:poke33056,14
DISABLING FAST (2Mhz) MODE:
THE SERVANT will use fast mode whenever the 80 column screen is active. If you need to, you can prohibit THE SERVANT from using fast mode:
bank0:poke32774,81
Setting this byte to any other value (avoid 0 or 1; it will make THE SERVANT malfunction) will enable fast mode as usual. Setting this location to 0 will disable THE SERVANTs autostart. Still, THE SERVANT can be called by bank12:sys32777 and will work flawlessly.
SAVING THE MODIFIED VERSION OF THE SERVANT:
When you have made all your modifications, type bank0:sys32768 and press RETURN to cold start THE SERVANT. Check that the colors are as you expect. Exit THE SERVANT again and check that the function key definitions works as expected. Press THE SERVANT call key to see if THE SERVANT main menu pops up as expected. Try all of this in both 40 and 80 column mode.
If everything seems OK, save THE SERVANT to disk by holding down CONTROL and pressing the "+" key. Please make sure that the disk has at least 130 blocks free. THE SERVANT will be saved to disk drive 8 using the file name "the servant.mod". If a file of that name already exist on the disk (a previously saved SERVANT), that file will be deleted. Please note that you should NOT use BSAVE from BASIC, "S" from the machine language monitor, or any other save function. If THE SERVANT is saved in any of those ways, it may be corrupted. Use CONTROL/+!
The file just saved can be programmed directly into an EPROM.
IMPORTANT: You MUST test your modified THE SERVANT running in computer RAM before you have it programmed into the EPROM. A wrong POKE during your customizing may make THE SERVANT malfunction. It is better to reveal errors at this point rather than when THE SERVANT is physically installed into your computer. An error discovered at after the installation will make it much harder to figure out where the error really is.