💾 Archived View for mirrors.apple2.org.za › archive › www.textfiles.com › apple › DOCUMENTATION › pr… captured on 2024-12-17 at 17:20:14.
View Raw
More Information
⬅️ Previous capture (2023-01-29)
-=-=-=-=-=-=-
ProntoDOS TM
Copyright @ 1982, TOM WEISHAAR
10026 Roe, Overland Park, Kansas 66207
913-649-0567
Published by BEAGLE BROS INC.
4315 Sierra Vista, San Diego, California 92103
619-296-6400
[Editor's note: There are several margin notes in the original
manual. I placed these in-line with the main text at the appropriate
points in square brackets.]
WARRANTIES AND LIMITATIONS OF LIABILITY
Beagle Bros Inc. warrants that ProntoDOS will speed up Apple disk access.
In the event that ProntoDOS does not meet this warranty or any other
warranty, express or implied, Beagle Bros will refund the purchase price of
this program. BEAGLE BROS' LIABILITY IS LIMITED TO THIS PROGRAM'S
PURCHASE PRICE. In no case shall Beagle Bros or the author be liable for
any incidental or consequential damages, nor for any damages in excess
of the purchase price of ProntoDOS.
The ProntoDOS disk Includes software, Apple DOS 3.3, owned by Apple
Computer, Inc. This software is used under license from Apple. Apple
makes no warranties, either express or implied, regarding Apple DOS, its
merchantability, or its fitness for any particular purpose.
DISTRIBUTION LICENSES
PRONTO-DOS, HELLO PRONTO-DOS, PRONTO UPDATE, and DOS-UP are
copyrighted programs. They are distributed without copy protection
because this makes them easier to use and more valuable to you, the
user. You, in turn, have been entrusted to honor our copyrights.
If you would like to publish programs on disks that include ProntoDOS,
a special publisher's version is available for public licensing for a flat
$250.00 per year. Licenses are also available to organizations that would
like to include ProntoDOS on disks distributed internally. Contact the
author -
TOM WEISHAAR
10026 Roe Overland Park, Kansas 66207
913-649-0567
[Inside front cover]
TABLE OF CONTENTS
PRONTO-DOS SUMMARY . . . . . . . . . . . . . . . . . 1
GENERAL INFORMATION . . . . . . . . . . . . . . . . . 2
CREATING NEW PRONTO-DOS DISKS . . . . . . . . . . . . 4
UPDATING EXISTING DISKS . . . . .. . . . . . . . . . . 4
PRONTO-DOS ENHANCEMENTS (adding new features to DOS) . 6
HELLO PRONTO-DOS (when you can't boot ProntoDOS) . . 11
DOS-UP (moving DOS to high-memory) . . . . . . . . . 11
DO FID and DO RENUMBER .. . . . . . . . . . . . . . . 14
PRONTO-DOS AND OTHER PROGRAMS . . . . . . . . . . . . 14
PRONTO-DOS AND TEXT FILES . . . . . . . . . . . . . . 16
PRONTO-DOS AND INTEGER BASIC APPLES . . . . . . . . . 17
SAVING ARRAYS IN FAST BINARY FILES . . . . . . . . .. 18
INDEX . . . . . . . . . . . . . . . . . . . . . . . . 20
PRONTO-DOS SUMMARY
TO GET PRONTO-DOS IN MEMORY
* Boot the original ProntoDOS disk OR any disk you have
created using ProntoDOS.
TO REMOVE PRONTO-DOS FROM MEMORY
* Boot any non-ProntoDOS disk.
TO CREATE PRONTO-DOS DISKS
* CREATE NEW DISKS- Boot ProntoDOS, then INIT new
disks (which will contain 15 extra sectors), OR...
* UPDATE EXISTING DISKS- Boot ProntoDOS and RUN
PRONTO UPDATE (updated disks contain the standard
number of free sectors).
TO MOVE PRONTO-DOS TO HIGH-MEMORY
(requires Apple lie OR older Apple with Language Card)
* Boot ProntoDOS, then BRUN DOS-UP.
WARNINGS
* MAKE BACKUP COPIES of all disks before you update
them to ProntoDOS.
* NEVER UPDATE COPY-PROTECTED DISKS. You will ruin
them. Period.
* DON'T USE APPLE'S MASTER CREATE program on
ProntoDOS disks. Doing so will destroy data in the disk's
15 extra sectors.
[page 1]
PRONTO-DOS GENERAL INFORMATION
ProntoDOS is a set of assembly language modifications to
Apple's DOS 3.3. These modifications allow much faster handling
of Basic and Binary files. Text files are not affected,
although some bugs in Apple DOS pertaining to Text
Files have been removed. To use ProntoDOS, you need an Apple
II, II-plus or IIe with at least 48K and the Apple 3.3 (16-sector)
Disk Operating System.
ProntoDOS works exactly like Apple DOS. All commands
are the same. All error messages are the same. All
files and disks are the same. No conversion of files, "muffining",
or re-initialization of disks is necessary. Files created with
ProntoDOS are exact duplicates of files created with Apple
DOS. ProntoDOS will accept all pokes found in Beagle Bros
Tip Books and programs, Including DOS Boss, Key-Cat, Beagle
Menu, and so on.
[USING PRONTODOS IS ALMOST LIKE USING NORMAL APPLE DOS.]
Commands and file structure are fully-documented in
"The DOS Manual", which came with your Apple disk drive.
None of that Information is repeated here.
For some basic Information on how ProntoDOS does
what it does, see the article by Tom Weishaar, "DOS Be
Nimble, DOS Be Quick" In the March 1983 Softalk.
To get ProntoDOS running, boot the ProntoDOS disk or
any disk you have updated with ProntoDOS. It will load a
version of Apple DOS that includes the ProntoDOS modifica-
tions. You will then have access to ProntoDOS's speed until
you boot another disk or turn off your computer. If you boot
another disk, the DOS on that disk will wipe out ProntoDOS.
You can tell if ProntoDOS is active by typing the CATALOG
command. The area that normally says "DISK VOLUME ###"
will say "PRONTO-DOS V###".
[YOU MUST BOOT PRONTO-DOS TO INSTALL IT IN YOUR APPLES MEMORY.]
[BOOT PRONTODOS, THEN INIT AS MANY DISKS AS YOU WANT.]
Any disk you Initialize with the DOS "INIT" command
WHILE PRONTO-DOS IS ACTIVE will have ProntoDOS written on
it. This means that whenever you boot these disks, ProntoDOS
will be loaded automatically.
When creating ProntoDOS disks with the INIT command,
it is highly-recommended that you DO NOT RUN ANY
PROGRAMS (with the exception of PRONTO UPDATE) between
the time you boot ProntoDOS and the time you INITialize your
disks. In particular, do not run any programs that install
themselves between DOS and its buffers, such as GPLE or
Flex Text.
Disks initialized with ProntoDOS have an additional
bonus- 15 extra sectors of free space, compared to disks
initialized with Apple DOS.
[page 2]
You can also update your existing disks to ProntoDOS.
To do this, boot the ProntoDOS disk and RUN the program
called PRONTO UPDATE. Select Option-2, "Update DOS on
Existing Disks". Instructions for using this option will
appear on your screen. NOTE: ProntoDOS must be active
in your computer when you update your disks. If standard
Apple DOS is active, your disks will be "updated" to
standard Apple DOS. For complete information, see Updating
DOS on the next page.
[ADD PRONTO-DOS TO DISKS THAT ALREADY HAVE DATA ON THEM.]
You can move DOS to a Language Cans or to the upper
reaches of the Apple IIe's memory with the program DOS-UP.
For complete Information see page 11.
If you use a special version of DOS that must be booted
from another disk so you can interface with hard disks, disk
emulators, clock cards, or other devices, BRUN HELLO
PRONTO-DOS after booting the other disk. This program will
poke the ProntoDOS modifications into the DOS in memory.
See page 11.
If you own a Standard Apple II (the Integer Basic version),
see the section called "ProntoDOS and Integer Basic
Apples" on page 17.
Memory Usage: Earlier versions of ProntoDOS used
empty spaces normally present within the pre-Apple IIe ver-
sion of Apple DOS. This caused conflicts with several pro-
grams that also tried to use this space. It also conflicted with
the Apple IIe version of DOS, which used one of these empty
spaces.
[PRONTO-DOS HIDES ITSELF WELL.]
The version of ProntoDOS on this disk hides itself in other
areas of DOS. It is very improbable that any other program
will poke changes into areas of DOS that have been modified
by ProntoDOS, with one exception. Programs that use the
empty space at location 47721-65 ($BA69-95) will overwrite
both the new Apple IIe version of DOS and ProntoDOS.
All problems with ProntoDOS reported to date, except
one, have been traced to programs that have modified this
area or other areas of DOS. Again, to be safe, it is highly
recommended you DO NOT RUN ANY PROGRAMS BETWEEN
THE TIME YOU BOOT PRONTO-DOS AND THE TIME YOU INITIALIZE
OR UPDATE DISKS you intend to boot (except, of course,
PRONTO UPDATE).
The only problem reported by ProntoDOS users not associated
with DOS modifications by alien programs is that ProntoDOS,
for very technical reasons related to a bug in the Apple
itself, will drive your computer crazy if you try to BSAVE a
[page 3]
range of memory that begins between $C100 and $C103. This
area is associated with software (or "firmware") on the
peripheral card in Slot 1, usually a printer driver. The
circumstances under which a user would want to access this
area with DOS are extremely rare. If you need to do it for
some reason, use standard Apple DOS. Do not attempt to
save this area using ProntoDOS.
The Apple APPEND command has always contained an
exotic bug that caused it to fail whenever the stars were
right. That bug has been removed in ProntoDOS. In addition,
a complex bug relating to the use of the "R" and "B"
parameters with Text Files has been fixed. If your programs
use these parameters, see "ProntoDOS and Text Files"
on page 16.
The standard Apple DOS skew pattern works best with
ProntoDOS. If you have used Quality Software's Bag of
Tricks (R), or another program, to re-skew your disks,
you will have to normalize them again to obtain maximum
ProntoDOS speed.
CREATING NEW PRONTO-DOS DISKS
Turn off your Apple if it's not already off. Insert the
original ProntoDOS disk or ANY ProntoDOS disk in your
drive, and turn your Apple on to boot that disk. Now you
may create new ProntoDOS disks using Apple's normal INIT
command. For example, insert a new (or erasable) disk, and type:
)INIT HELLO
(Any legal file name instead of "Hello" is, of course,
acceptable.) This will create a disk that, when booted, will
install ProntoDOS in your Apple's memory. For more details
on INIT, see your DOS MANUAL. For more on ProntoDOS's
INIT syntax, see page 10 of this manual.
UPDATING DOS ON EXISTING DISKS
To update existing disks, run the program PRONTO UPDATE,
which is on your original ProntoDOS disk.
)RUN PRONTO UPDATE
[page 4]
Option (1) will take you to the ENHANCEMENT MENU,
which allows you to customize ProntoDOS (see page 6).
Option (2) will update your existing disks so that your
personalized ProntoDOS will be active whenever those
disks are booted.
You may update disks with plain old (uncustomized)
ProntoDOS, with Apple DOS, and with either of those after
modifying them with Beagle Bros' DOS Boss program (DOS
Boss allows you to rename DOS error messages and
commands for program protection- try "/" for CATALOG, for
example- and to personalize the Disk Volume heading,
among other useful things.).
It is only necessary to update existing disks that you
INTEND TO BOOT. Disks used only for program or data storage
do not need to be updated.
DO MAKE BACKUP COPIES of all disks before updating.
DON'T UPDATE copy-protected disks.
DON'T UPDATE disks originally initialized with DOS but from
which DOS has been removed.
To update your existing disks, choose Option 2 from the
Main Menu of PRONTO UPDATE. To update disks and keep
the same Hello File Name and "Run Command" as the original,
simply insert the disk to be updated and press RETURN. It
takes less than 3 seconds to update each disk.
If you would like to change the name of the Hello File on
the disk, or if you would like the Hello File to be BRUN or
EXECed Instead of RUN, press the SPACE BAR before pressing
RETURN. You will be prompted to enter the new Hello File
Name to be used as well as the new Run Command.
To remove ProntoDOS from a disk, boot standard Apple
DOS before running PRONTO UPDATE. You will then be able to
re-update a disk back to Apple DOS. Only disks that were
originally initialized with Apple DOS can be converted back
to Apple DOS. This Is because ProntoDOS disks use less room
for DOS than Apple DOS disks. If you could put Apple DOS on
a disk originally initialized with ProntoDOS it would overwrite
some of your data. Therefore, the Update feature will not
allow you to do this. You will also be unable to update a disk
that was originally INITialized without DOS.
[page 5]
PRONTO-DOS ENHANCEMENTS
The PRONTO UPDATE program allows you to make certain
helpful modifications to DOS. To use this Applesoft program,
insert your ProntoDOS disk, and enter:
]RUN PRONTO UPDATE
You will be asked to choose between the Enhancement
Menu and updating DOS on existing disks. Choose Option-1.
You will then see the following menu
PRONTO UPDATE
ENHANCEMENT MENU
(1) "TYPE" COMMAND ACTIVE . . . . . . . . . . YES/NO
(2) CTRL-C KILLS CATALOGS . .. . . . . . . .. YES/NO
(3) (ESC) KILLS EXECS & READS . . . . . . . . YES/NO
(4) AUTOMATIC VERIFY AFTER SAVE . . . . . . YES/NO
(5) FORCE LANGUAGE CARD RELOAD . . . . . . . YES/NO
(6) PRINT DISK FREE SPACE . . . . . . . . . . YES/NO
(7) PRINT BINARY FILE ADR & LEN . . . . . . . YES/NO
(8) INIT SAVES DOS & HELLO FILE . . . . . . . YES/NO
Either the "YES" or "NO" will be shown in inverse letters
for each item. The inverse lettering indicates the current
status of that item. By pressing the keys "1" through "8"
you are able to switch the status of the items from "YES"
to "NO" and back again.
Each of these enhancements modifies the version of
ProntoDOS active in your Apple's memory. You cannot
enhance or otherwise modify the DOS on a disk without also
using the Update feature, which was explained on page 4.
[EVERY TIME YOU PRESS A NUMBER, STAND BY; THE DOS IN
MEMORY IS BEING ALTERED.]
Some of the enhancements simply change existing DOS
instructions a bit. Others add new instructions to DOS as
well.
Those enhancements that require new instructions of
their own place these instructions in some empty spaces
inside DOS. These enhancements are not the first routines, nor
will they be the last, to try to capture this territory.
TEST ALL PROGRAMS that might use the empty spaces in
DOS- RUN the program first, then RUN PRONTO UPDATE. If the
program has modified an area of DOS, you will be unable to
turn on the affected enhancement.
KEEP BACKUP COPIES of your disks. Programs that modify
DOS empty space, when run AFTER the enhancements are
made, will cause your program to "hang up" or "crash"
[page 6]
when you access the enhancement and COULD DAMAGE YOUR
DATA. Please use care. In some sensitive situations, your
best choice may be not to use these enhancements.
(1) "TYPE" COMMAND ACTIVE
The "TYPE" command lets you display the contents of Text
Files on your screen or printer. With this feature active and a
disk with a text file on it in your drive, simply enter:
]TYPE fllename
The file must be a Text File. The contents of the file will
begin to scroll by on your screen. On most Apples you can
stop the scroll by pressing control-S. Restart the scrolling by
pressing control-S again, or ESC or most any key.
You can stop the display entirely and bring the TYPE
command to an early end by pressing ESC while the file is
scrolling. If the file has been stopped by control-S you have
to push ESC twice- once to restart the scroll (this keypress
gets eaten by a Pac-Man), and once to stop.
If you don't kill the display, It will expire naturally when
the end of the file is reached. If the file Is a Random Access
file, TYPE expires when it hits the first empty record. (Often
this will be the very first record of the file, Record-0, thus
limiting the display to nothing at all.)
Example: Once the TYPE command is active, you can insert
your ProntoDOS disk and see what's In the file "DO FID"
(the purpose of which is explained later). If you do, here's
what you will see:
]TYPE DO FID
POKE 2051, 96
BLOAD FID
POKE 2132, 169
POKE 2133, 120
CALL 2051
You can also use the "R" parameter with TYPE, just as you
can with EXEC. If you use "R", the display will skip R
lines before starting the display. For example:
]TYPE DO FID, R2
POKE 2132, 169
POKE 2133, 120
CALL 2051
To get a file to appear on your printer, simply use the
normal PR#slot command to activate your printer before
entering the TYPE command.
The TYPE command uses the position of the VERIFY command
in the DOS command name table. This means that if you
turn TYPE on, you will be unable to use VERIFY. If you try,
[page 7]
you will get a SYNTAX ERROR.
The TYPE command uses the DOS empty space at $BCDF.
(2) CTRL-C KILLS CATALOGS
[EXIT LONG CATALOGS WITHOUT RESET.]
This command is useful for long catalogs. The CATALOG
command normally stops when your screen is full of file
names and warts for a keypress before showing you another
screen-full. If this enhancement is active, pressing ctrl-C
will bring the Catalog to a natural end instead of continuing.
This keeps the file name you were looking for from scrolling
off the screen before you get a chance to type it in.
This enhancement uses the DOS empty space at $BA87-$BA91.
(3) (ESC) KILLS EXECS & READS
[PUT THE BRAKES ON TEXT FILES.]
If you've ever had an error in an EXEC file that caused it to run
amuck, or if you've ever started to READ a Text File 10 miles
long and then realized it was the wrong one, you'll appreciate this feature. In either case, pressing ESC will bring the EXEC or READ
to an end by telling it the end of the file has been reached. With
READ, this will cause an END OF DATA error; with EXEC, it causes
a natural death.
This feature is useful primarily to programmers creating and
testing programs. It is a dangerous feature to use with
finished software, since a misplaced keystroke could cause
incredible problems.
This feature uses the DOS empty space at $BCDF.
(4) AUTOMATIC VERIFY AFTER SAVE
[SAVE-SPEED IS INCREASED AN ADDITIONAL 10 TO 15%.]
Normally, both Apple DOS and ProntoDOS do an automatic
VERIFY right after saving Binary and Basic files. By turning
this feature OFF, you can increase the speed at which files
are saved by 10% to 15%. You do this, however, at some risk
of data loss.
The setting of this feature is completely independent of
the setting of the TYPE command, even though TYPE deletes
the VERIFY command. The automatic verification can still
take place even if you can't manually VERIFY a file.
This feature does not use any additional space inside DOS.
(5) FORCE LANGUAGE CARD RELOAD
Normally, both Apple DOS and ProntoDOS will modify one
byte ($E000) of a Language Card during a boot. This forces
the card to be reloaded each time DOS is booted. If you turn
this feature off (NO), the Language Card will only be loaded
if it needs to be. In a few circumstances, a DOS with this
feature off will fall to load the Language Card when it should.
The decision (and risk) is yours.
This feature does not use any additional space.
(6) PRINT DISK FREE SPACE
[FREE-SPACE IS DISPLAYED EVERY TIME YOU CATALOG.]
This enhancement shows you how many sectors are free on each disk you Catalog. For example:
]CATALOG
PRONTO-DOS V254 FS=123 <===;'FS" STANDS FOR 'FREE SPACE".
- A 010 FILE #1
- B 020 BINARY FILE
- T 030 TEXT FILE
This enhancement requires a rather long addition of
assembly language instructions and also requires the
availability of Basic. If you are using a program that
installs itself on the Language Card and tricks DOS into
thinking it is Applesoft or Integer Basic, this enhancement
will cause a CATALOG to hang up your computer or worse.
The new instructions are normally placed at $B6B3. If this
area is already in use and the INIT command has been
modified (Item-8 below), they will be placed at $B74A. A few
other programs also use these spaces. In particular, the
Language Card version of GPLE uses $B6B3. See page 15 for
more information on GPLE.
(7) PRINT BINARY FILE ADR & LEN
[THE ADDRESS & LENGTH OF BINARY FILES ARE DISPLAYED EVERY
TIME YOU BLOAD OR BRUN.]
This enhancement causes the Address and Length of a
Binary File to be displayed in hexadecimal when it is
BLOADed or BRUN. For example:
]BLOAD DOS-UP
A$4000 L$05BF
]BRUN HELLO PRONTO-DOS
A$4000 L$0458
This feature uses the same DOS empty space as the Disk
Free Space enhancement. Because of this, you cannot
turn them both on at the same time unless you modify the
INIT command (next item) and use its space. Again, note
that the Language Card version of GPLE also uses the
space at $B6B3.
[page 9]
(8) INIT SAVES DOS & HELLO FILE
[DON'T PUT DOS ON A DISK IF YOU DON'T NEED IT.]
Normally, of course, INIT not only "formats" and erases a disk,
but it also puts DOS on it and saves a Hello File. Now you can
turn this off (NO). INIT will still work, but nothing will be put on
the disk. It will contain 528 empty sectors. The disk will not boot,
but it makes an excellent "Data Disk".
When you use this enhancement, some Internal DOS space at $B74A is
opened up. This space will be used if you turn both the Disk Free
Space and Binary File Address and Length enhancements on at the same time.
When item-8 is set to NO, a ninth enhancement will appear on your menu--
(9) MODIFY INIT SYNTAX
When this item is set to YES, the INIT syntax is changed to
]INIT
Notice that no file name is used as is normally the case. If a file
name is given, as in:
]INIT HELLO
you will receive a SYNTAX ERROR to remind you the INIT command has
been modified. This enhancement can be useful, but it also causes
programs that use the INIT command, such as COPYA, to fail unless
they are revised to use the new syntax. The choice is yours.
Should you modify the INIT syntax, then later reset Item-8 so
INIT will save DOS and a Hello File, the INIT syntax will
be automatically normalized.
"---/NO" AND "??????"
If an Item shows "---/NO" at the right end of a line instead of
the normal "YES/NO", it means the feature cannot be turned on
because there is no space for it. You must turn some related
feature off first.
If an item shows "??????" it means the DOS you are working with
has been modified by some alien program. The location PRONTO
UPDATE looks at to determine whether a feature is active or not
is set to a value that indicates the feature is neither on nor off.
[page 10]
HELLO PRONTO-DOS
[LOADING PRONTODOS WHEN YOU AREN'T ALLOWED TO BOOT IT]
The program HELLO PRONTO-DOS is to be used only when a situation
will not allow you to boot a ProntoDOS disk. Few users will
encounter this problem.
The problem usually occurs when you must use a special DOS to
interface with a hard disk drive, a disk emulator, a clock card,
or other device. The problem is that these devices require you
to boot with their special DOS.
In this situation, you may BRUN HELLO PRONTO-DOS after booting.
This program checks to see if the locations used by ProntoDOS
have already been modified, and if not, pokes the ProntoDOS
modifications into the special DOS. If the special DOS is not
located at the normal 48K DOS location, HELLO PRONTO-DOS will
end with an error message.
If the special DOS was already using any of the memory
locations used by ProntoDOS, HELLO PRONTO-DOS will leave it
just as it is and give you a message that it was unable to
modify the special DOS.
If HELLO PRONTO-DOS was able to modify the special DOS
successfully, you will see a message saying ProntoDOS is
loaded and ready.
HELLO PRONTO-DOS does not change anything about the way disks
are initialized. If your special DOS allows you to INITialize
disks (most don't), you won't get the usual ProntoDOS
15-extra-sector bonus.
DOS-UP
[MOVING PRONTO DOS TO HIGH MEMORY OR LANGUAGE CARD]
DOS-UP is used to move ProntoDOS from its normal location in
memory to the Language Card (or "RAM Card") area ($D000-$FFFF)
of memory. This requires an Apple IIe OR a special card in
an older Apple's Slot-0. The advantage of moving DOS to the
Language Card is that Basic programs will have 10,415 extra
bytes of memory space to work with (a LOT of memory). If
space is a problem In your application, DOS-UP will help.
If space is not a problem, however, you will usually be
better-off leaving DOS in its standard location.
To use DOS-UP, boot ProntoDOS and then:
]BRUN DOS-UP
If DOS has already been moved, or if there is no Language
Card present, you will receive an error message.
Otherwise, the message "DOS NOW IN HIGH MEMORY" will be displayed.
[page 11]
Immediately after the message, DOS-UP attempts to RUN a
program named "Hello". This is done to create "Turnkey"
systems that automatically move DOS to high memory and
then execute the main program. When you BRUN DOS-UP
from inside a program, that program dies an unnatural
death after DOS is moved. The automatic running or
rerunning of "Hello" can bring it back to life.
[REASONS NOT TO MOVE DOS]
There are disadvantages of moving DOS to the Language
Card- One is that you can't use the card for an alternate
language. If you move DOS, the only Basic available to
you will be the one that is native to your computer
(usually Applesoft Basic).
Another disadvantage is that many assembly language
programs won't work correctly with DOS on a Language Card.
There are several reasons for this. Some assembly language
programs insert themselves between DOS and its buffers.
Few do this correctly with DOS on the Language Card.
Another problem is that many assembly language programs
poke an address into DOS to tell it what to do after a
disk error. But if DOS isn't where it's expected to be,
the poke has no effect. In this case, an error usually snatches
you from your program and drops you somewhere in Basic.
When DOS is in high-memory, the maximum MAXFILES value is 5
rather than the usual 16.
Yet another disadvantage is that the INIT command must be
modified when DOS is moved. If you haven't done this
yourself with PRONTO UPDATE, it will happen automatically
when DOS is moved. See page 10 for more.
Several other programs have been written to move DOS to
the Language Card. DOS MOVER by Cornelis Bongers,
published in the July/August 1981 Call-AP.P.L.E. served
as an inspiration for DOS-UP. However, DOS-UP has been
completely rewritten, because DOS MOVER and all other
programs like it that we have tested, have failed to move
ProntoDOS correctly.
To move ProntoDOS, you MUST use DOS-UP except when you
want to use the version of GPLE called "PLE.DM". For
more information, see page 15.
[HOW TO FIND DOS]
Your programs can tell if DOS-UP has already run or not
by PEEKing at location 978 ($3132). A value of 157 ($9D)
indicates that DOS is at its normal 48K location. When
DOS has been moved to the Language Card, this value
becomes 191 ($BF).
All ProntoDOS enhancements will work correctly from the
Language Card, but you must install them before running
DOS-UP. PRONTO UPDATE will refuse to run if DOS is not
at is standard 48K location.
[page 12]
If you would like to change the Hello-program name or
Run Command of the program DOS-UP runs automatically,
BLOAD DOS-UP and poke the new name in at 17262-17291
($436E-8B). The Run Command lives at 17205 ($4335).
Poke in a 6 for RUN; 20 ($14) for EXEC; 52 ($34) for
BRUN. Then:
]BSAVE DOS-UP,AS4000,L$5BF
[TECHNICAL INFORMATION FOR MACHINE LANGUAGERS]
Details, Details... The rest of this section presents
some technical details about DOS-UP. These are primarily of
interest to a handful of assembly language programmers.
After DOS Is moved to the Language Card, HIMEM is set at
$BEAF. The area from there to $BFFF is used for instructions
for switching the Language Card on/off, and other purposes.
One of those purposes is for storage of the HIMEM value
itself, which is at $BFFE-FF, in the normal backwards format.
If you would like to protect an assembly language program
from DOS and Basic, insert it just below HIMEM and revise the
value at $BFFE to reflect where your program starts. Then
coldstart DOS by calling the normal Page-3 vector at $3D3,
or use the DOS MAXFILES command. Either of these
automatically resets HIMEM to whatever is stored at $BFFE.
While your program is running, you may freely call Basic
and Monitor routines. You may also freely use the Page-3
DOS vectors. However, you cannot access other routines
inside DOS unless you turn the Language Card on yourself.
There is a subroutine that will do this for you at $BEAF.
To turn the card off again you can call $BEDE. Don't expect
the card to stay as you set it very long, however. Every time
a character passes through the Input/Output hooks, DOS
is activated to take a look at it. When DOS Is done looking
and passes control to the appropriate Input/Output
routine, the Language Card will be off again.
If you look at the DOS vectors on Page-3, you will find
that they all point to routines on page $BF. The IOB is at
$BFD5-E5 and the File Manager Parameter List is at $BFE6-FB.
These are the same locations used by Bongers' DOS Mover. Not
all programs that move DOS use these locations, however. You
should always use the Page-3 vectors at $3DC and $3E3 to locate
the Parmlist and IOB.
The internal DOS vectors normally at $9D56-61 have also been
moved. They are now at $BFC5-D0. Of particular interest are
the vectors at $BFC9 and $BFCD, which tell DOS where to go
after an error and a warmstart, respectively. You can poke
new addresses Into these locations to return control to your
program. Normally the addresses here send control to Basic.
If you change these locations, beware- A DOS coldstart or a
successful FP (or INT) command will reset the vector table
to the addresses for Basic, and your pokes will be lost.
[page 13]
DO FID and DO RENUMBER
[FOR USING APPLE'S FID AND RENUMBER PROGRAMS WHILE
PRONTO-DOS IS IN HIGH-MEMORY]
Two programs on your Apple System Master disk, FID and
RENUMBER, have strange bugs in them that normally prevent
them from being used when DOS is on the Language Card.
You can use them, however, if you execute them using the
EXEC files on the ProntoDOS disk called "DO FID" and "DO
RENUMBER". To use FID or RENUMBER while ProntoDOS is active:
]EXEC DO FID or...
]EXEC DO RENUMBER
Before DO FID and DO RENUMBER can be used, you must put them
on the same disk with FID and/or RENUMBER (use FID itself to
transfer programs while DOS is at its normal 48K location).
DO FID and DO RENUMBER load the specified program, poke
modifications into it, and run it. While DO FID is specifically
meant to use FID when DOS is on the Language Card, it also
works correctly when DOS is elsewhere.
DO RENUMBER, on the other hand, will only EXECute properly
when DOS is on the Language Card. Otherwise it will give you
a message saying "HIMEM IS ABNORMAL". If this happens when
DOS is in fact on the Language Card, you will have to start
over by rebooting DOS before you can renumber your program.
The only time you will usually see this message is if you
EXEC DO RENUMBER twice in one sitting.
You can thank Bongers for the information on how to fix these
programs. I certainly do. His fixes were included in the
original article mentioned above.
PRONTO-DOS AND OTHER PROGRAMS
In general, most programs will work with ProntoDOS, except for
some (usually copy-protected) programs that require you to
boot their particular brand of DOS. See HELLO PRONTO-DOS on
page 11 for possible help.
ALPHA PLOT
Beagle Bros' Alpha Plot may be used with ProntoDOS, but to
make it work, LINE 9 of the program ALPHA BOOT should read:
9 IF PEEK (115) +PEEK (116) *256 <> 38400 THEN
PRINT CHR$(4);"PR#";PEEK(43626)
[page 14]
BYTE ZAP
on the Beagle Bros Apple Mechanic disk refers to several
areas of DOS for possible alterations. ProntoDOS relocates
some of these areas
Item Normal DOS ProntoDOS
DOS COMMANDS . . . . . . Track-1, Sector-7 Track-1, Sector-5
ERROR MESSAGES . . . . . Track-1, Sector-8 Track-1, Sector-6
GREETING NAME . . . . . Track-1, Sector-9 Track-1, Sector-7
DISK VOLUME HEADING. . . Track 2, Sector-2 Track-2, Sector-0
FILE-TYPE CODES . . . . Track 2, Sector-2 Track-2, Sector-0
UTILITY CITY
Do not use the program KILL-CAT on the Utility City disk
with ProntoDOS. The PRONTO ENHANCEMENTS program provides
this same feature (Item-2 on the Enhancements Menu). Use
it instead.
G.P.L.E.
The Global Program Line Editor (by Nell Konzen, published
by Synergistic Software) is a program we couldn't program
without, and therefore highly recommend. If you don't have
it, buy it. But...
CAUTION: NEVER INITIALIZE A DISK WITH PLE.48 LOADED. This
applies to standard Apple DOS as well as ProntoDOS. If
anything is between DOS and its buffers when you do an INIT,
the new disk will leave space there whenever it is booted.
This will cause many mysterious problems.
GPLE comes in three versions, all on the GPLE disk--
PLE.48, the "standard" version of GPLE, is completely
compatible with ProntoDOS and its enhancements. To use
PLEAS with ProntoDOS:
1. Boot a ProntoDOS disk.
2. BRUN PLE.48.
PLE.LC puts GPLE on a Language Card and uses the empty
space in DOS at $B6B3. This means you cannot normally
use PRONTO UPDATE's "Print Disk Free Space" or
"Print Binary File Address and Length" options at the
same time as PLE.LC. Otherwise, the use and loading of
PLE.LC is identical to PLE.48.
PLE.DM is used when both DOS and GPLE are placed on the
Language Card. PLE.DM comes with an associated program
on the GPLE disk called PLE DOS MOVER. To use PLE.DM,
you must move DOS to the Language Card with PLE DOS MOVER.
Unfortunately, this program won't move
[page 15]
ProntoDOS correctly unless it is modified.
To use PLE.DM, you must put "PLE DOS MOVER" from the GPLE
disk and "DO FILE DOS MOVER" from the ProntoDOS disk
on the same disk. Then:
1. Boot a ProntoDOS disk.
2. Insert the disk with PLE DOS MOVER and DO PLE DOS MOVER.
3. EXEC DO PLE DOS MOVER.
The EXEC file will load PLE DOS MOVER, modify it as
necessary, and run it. PLE DOS MOVER will move ProntoDOS
to the Language Card and then try to run a Basic file
named "Hello".
Neither "Print Disk Free Space" nor "Print Binary File
Address and Length" from the PRONTO UPDATE program work
correctly with PLE DOS MOVER. The other enhancements
work fine.
PRONTO-DOS AND TEXT FILES
ProntoDOS does not speed up access of Text Files because
text files are handled one byte at a time. The bytes are
passed back and forth between DOS and the current input or
output routine. This process is relatively slow and
unaffected by the ProntoDOS speed-up technique.
Both pre- and post-Apple IIe DOS 3.3's have bugs in the
handling of the APPEND command. The two bugs are
different. Both have been removed in ProntoDOS.
Both versions of DOS also have a bug relating to the use
of the "R" and "B" parameters with Text Files. This bug is
complex, and if you never use the "R" or "B" parameters,
you may want to skip the rest of this section.
The "R" parameter is allowed with READ, WRITE, POSITION,
and EXEC. The "B" parameter is allowed only with
READ and WRITE.
When used with POSITION and EXEC, the "R" parameter causes
DOS to move forward through a file counting "carriage
returns". It stops at the first character following the
Rth carriage return. There are no bugs here.
When used with READ and WRITE, "R" has a completely different
meaning. In this context, it is to be used only with
Random Access Text Files, and it orders DOS to go to the Rth
record in the file (where the first record is 0, the second 1,
etc.). There are no bugs here.
[page 16]
The "B" parameter is also used with READ and WRITE.
Whenever you give a READ or WRITE command with either
an "R" or "B" (or both), DOS immediately moves its file
pointer to the byte that equals:
(R * L) + B
where L equals the length parameter given when the file was
opened. If no L was given (as with Sequential Files), L will
default to 1.
If you give an R parameter alone, or if you give both the R
and B parameters, DOS will always make the calculation
correctly. In the first case, where you give the R parameter
alone, the B parameter will default to zero.
Here's the bug: If you give the B parameter alone, the
default of the R parameter is uncertain under standard Apple
DOS. Under ProntoDOS, it is certain- if R is not specified, it
will always default to zero. This fixes a bug in Apple DOS
whereby the B parameter, used alone with Sequential Files,
performed erratically.
When using Random Access files, you should never use the Byte
parameter without also giving the Record parameter. If you do
not specify R when using B, the file pointer will be moved to
the Bth byte of record-zero. Under standard DOS, the pointer
usually, but not always, moves to the Bth byte of the last
record specified.
[SKIP THIS SECTION IF YOU NEVER MET THE FILE MANAGER.]
Programs that call the File Manager (a program within DOS)
directly, must use ONE-BYTE Reads and Writes when working
with Text Files, just as DOS itself does. Under ProntoDOS,
the File Manager's Read- and Wrlte-Range routines will not
return an End of File error, nor do they keep track of
Random Access file position. This is a concern only with
programs that call the File Manager directly and use the
Read- and Write-Range routines on Text Files. Programmers
who only use DOS commands such as OPEN, POSITION, READ
and WRITE should ignore this paragraph.
PRONTO-DOS AND INTEGER BASIC APPLES
This section pertains to owners of Standard Apple II
computers who use the version of Applesoft known as
"cassette" or "RAM" Applesoft.
[NOTE: APPLE QUIT MAKING INTEGER BASIC APPLES IN 1980.]
It doesn't apply to those who have an Apple II-Plus or
who never use Applesoft or to users of "ROM" Applesoft cards
or users of "Language Cards". If you have an Apple II-Plus or
[page 17]
never use Applesoft or if you use one of the "card" versions,
you may Ignore the rest of this section.
Still reading, huh? There are not many like you left in
Appledom!
Well, I must offer my apologies. ProntoDOS doesn't
support cassette Applesoft. If you like, you may return
ProntoDOS, or you could try to pick up a used Applesoft ROM
card (these should be available in many cities for next-
to-nothing), or get a 16K RAM card.
Even though ProntoDOS doesn't support cassette Applesoft,
it still will automatically run an Integer file called
"Applesoft" when you tell it to run a program written in
Applesoft. If this file is, in fact, cassette Applesoft, you will
shortly find yourself in a big mess. Don't do it.
If the Integer program, "Applesoft", instead loads FPBASIC
into a language card, however, all will be right with the
world.
SAVING ARRAYS IN FAST BINARY FILES
[USE BINARY FILES INSTEAD OF TEXT FILES TO TAKE ADVANTAGE
OF PRONTO-DOS'S INCREDIBLE SPEED.]
The normal method for saving numerical arrays is in Text Files.
This can be quite time-consuming with large arrays, however,
because of the slow speed at which DOS handles Text Files.
There are certain locations you can PEEK to find out where
an Applesoft array starts, and a simple formula that will
give you the array's length. Using this information, you can
BSAVE the numbers in the array in just a few seconds. In
addition to saving time, you will also find you save disk
space. An array saved in a Binary File is usually shorter
than the same array in a Text File.
This file can be BLOADed back into the same program or into
any other program that includes an array DIMensioned to the
same size as the original array.
How to determine the ADDRESS of arrays: Applesoft keeps the
address of the last variable used at memory locations
131-132 ($83-84). Retrieving this value is a bit tricky,
however, since any variable used in the statement retrieving
the value becomes the "last variable used". Here are two
ways to do it. In this example "A( )" is the name of
the target array.
METHOD 1: A(0) = PEEK (131) + PEEK(132) * 256
In this method, the address of the array is stored in the
zero-th element of the array itself.
[page 18]
METHOD 2: A(0)=A(0) : POKE 78,PEEK(131) : POKE 79, PEEK(132): AA=PEEK(78)+PEEK(79)*256
In this method, the address of the array is stored in the
variable AA. Don't separate the parts of this method, as the
intermediate memory locations it uses are scrambled by
various routines.
Note that the reference to the array must be to its zero-th
element in order to get the starting location correctly. For a
multi-dimension array, the reference should be, for example,
"A(0, 0, 0, 0)".
How to determine the LENGTH of arrays: This is simple. The
length is five-times the number of elements in the array for
Floating Point arrays, and two-times the number of elements
for Integer arrays. The only trick is that the "number of
elements" is always one more than the number you DIMensioned
the array with, because of the zero-th element. Some examples,
where "S" represents the size of the array and "AL"
represents the array's length:
Floating Point Arrays: DIM A (S) : AL= (S+1) *5
Integer Arrays: DIM A% (S) : AL= (S+1) *2
Multi-Dimensioned Arrays: DIM A (S1, S2, S3, S4)
AL=(S1+1)*(S2+1)*(S3+1)*(54+1)*5
All Together Now... Once you have DIMensioned an array and
used these formulas for determining its Address and
Length, the following commands will load or save it
where AA equals the Array Address; AL equals the Array
Length; F$ equals the Name of the file; and D$ is our old
friend, control-D.
To Load: PRINT D$;"BLOAD ";F$;",A";AA
To Save: PRINT D$;"BSAVE ";F$;",A";AA;",L";AL
Most people already know this, but I was surprised after
using Apple DOS for many months to find out the A and L
parameters in the above commands can indeed be decimal
(OR hex) numbers.
This information on arrays comes from a letter in the June
1980 Call-AP.P.L.E by Wayne Throop and a sample program
by Richard C. Horsfall in the January 1981 issue of the
same magazine. Horsfall also includes information on
saving Integer Basic arrays.
[page 19]
PRONTO-DOS INDEX
Alpha Plot . . . . . . . . . . . . . . . . . . . 14
APPEND . . . . . . . . . . . . . . . . . . . . 4, 16
Apple DOS . . . . . . . . . . . . . . . . . . . . 2
Apple Mechanic . . . . . . . . . . . . . . . . . 15
arrays . . . . . . . . . . . . . . . . . . . . 18-19
B parameter . . . . . . . . . . . . . . . . . 16-17
Bag of Tricks . . . . . . . . . . . . . . . . . . 4
binary files . . . . . . . . . . . . . . . 9, 18-19
Byte Zap . . . . . . . . . . . . . . . . . . . . 15
cassette Applesoft . . . . . . . . . . . . . . 17-18
CATALOG 8
clock cards . . . . . . . . . . . . . . . . . 3, 11
commands . . . . . . . . . . . . . . . . . . . . 2
customizing . . . . . . . . . . . . . . . . . . 6-10
disk emulators . . . . . . . . . . . . . . . . 3, 11
disk free space . . . . . . . . . . . . . . . . 3, 9
DO FID . . . . . . . . . . . . . . . . . . . 7-8, 14
DO RENUMBER . . . . . . . . . . . . . . . . . . . 14
DOS Boss . . . . . . . . . . . . . . . . . . . . . 5
DOS-UP . . . . . . . . . . . . . . . . . . . 11-14
enhancements . . . . . . . . . . . . . . . . . 6-10
ESC . . . . . . . . . . . . . . . . . . . . . . 7, 8
EXEC, killing . . . . . . . . . . . . . . . . . . 8
FID . . . . . . . . . . . . . . . . . . . . . . . 14
file manager . . . . . . . . . . . . . . . . . . 17
file structure . . . . . . . . . . . . . . . . . . 2
free space . . . . . . . . . . . . . . . . . . 3, 9
GPLE@ . . . . . . . . . . . . . . . . . . . . 15-16
hard disks . . . . . . . . . . . . . . . . . . 3, 11
HELLO file . . . . . . . . . . . . . . . . . . 5, 13
HELLO PRONTO-DOS . . . . . . . . . . . . . . . . 11
HIMEM . . . . . . . . . . . . . . . . . . . . . . 13
INIT . . . . . . . . . . . . . . . . . 2, 4, 10, 11
Integer Basic Apples . . . . . . . . . . . 3, 17-18
KILL-CAT . . . . . . . . . . . . . . . . . . . . 15
language card . . . . . . . . . . . . . 3, 9, 11-14
liability . . . . . . . . . . . . inside front cover
licenses . . . . . . . . . . . . inside front cover
MAXFILES . . . . . . . . . . . . . . . . . . . . 12
memory usage . . . . . . . . . . . . 3, 6-10, 11-14
---/NO . . . . . . . . . . . . . . . . . . . . 10
PLE@ . . . . . . . . . . . . . . . . . . . . 15-16
print disk space . . . . . . . . . . . . . . . . . 9
print binary adr . . . . . . . . . . . . . . . . . 9
PRONTO UPDATE . . . . . . . . . . . . . . . . . 4-10
?????? . . . . . . . . . . . . . . . . . . . . . 10
R parameter . . . . . . . . . . . . . . . 7-8, 16-17
Random Access files . . . . . . . . . . . . . 7, 17
READ, killing . . . . . . . . . . . . . . . . . . 8
RENUMBER . . . . . . . . . . . . . . . . . . . . 14
Run Command . . . . . . . . . . . . . . . . . 5, 13
skew . . . . . . . . . . . . . . . . . . . . . . . 4
syntax for INIT . . . . . . . . . . . . . . . . . 10
syntax for TYPE . . . . . . . . . . . . . . . . . 7
Text Files . . . . . . . . . . . . . . . . 7, 16-17
TYPE command . . . . . . . . . . . . . . . . . . . 7
updating disks . . . . . . . . . . . . . . . . . . 4
Utility City . . . . . . . . . . . . . . . . . . 15
VERIFY . . . . . . . . . . . . . . . . . . . 8, 8-9
warranty . . . . . . . . . . . . inside front cover
Winchester disks . . . . . . . . . . . . . . . 3, 11