[Coco] I think you'll like this (especially Allen)
Andrew Ayers
keeper63 at cox.net
Thu Mar 20 21:32:43 EDT 2025
Juan,
You mention quite often in this series "things they could have easily
fixed" in/on the CoCo 3.
Maybe you already know this...but they (Microware) likely couldn't, not
without modifying the BASIC.
If they could've modified the BASIC, they very well might have done just
that - along with a host of other things:
1. Extending SCREEN (and/or PMODE), PCLS, PPOINT, LINE, etc - to support
the new graphics
2. Extending POKE/PEEK to support the extra address space (though I
don't see why they would have gone beyond 0xFFFFFF; that's a 16 megabyte
space...and back then, an ordinary Radio Shack customer buying a CoCo 3
would not likely have had the money for that amount of memory -
especially for an 8-bit machine; nor was there any hardware to support it)
3. ...and anything else.
The reason being, as I understand it...Microsoft wouldn't allow them
(Tandy/Radio Shack) to change any of the underlying code of the
interpreter...which is likely why Microware was only able to add new
commands (and they were probably lucky to be allowed to do that much).
Basically, I think Microsoft was "washing their hands" of any further
involvement with their 8-bit BASIC; maybe they would've done it for a
particular price, but if that was the case, Tandy didn't take them up on
the offer. Probably whatever was needed to extend it was all the leeway
they got from Microsoft (or the existing contract allowed for it).
Microsoft likely at that time was moving forward rapidly with Windows
(not sure if it was still Windows 1.0, or something else), and DOS, and
PCs...they likely wanted out of the 8-bit hobbyist market (it was on
it's "last legs" - had Tandy/Radio Shack made the CoCo 3 a 16-bit
machine, that might've made a difference to Microsoft).
Today, I really doubt that Microsoft cares at all what happens to the
BASIC in the CoCo (or elsewhere). What I think would be neat, would be
an updated ROM image that fixes all those bugs, plus adds whatever it is
you're doing (I'm sure you have a good reason for it), plus maybe some
of the extras...maybe an extension of ADOS, or something else?
A interesting alternative - one that would break things, though - would
be a "re-imagining" of the entirety of the BASIC on the CoCo 3; like,
what if Microsoft had decided to extend the BASIC "properly", what would
they have done? Like, could we get some of the features of other BASICs
around that era?
I'd vote for something like a mashup between parts of the BASIC for the
BBC (bus manipulation commands to make it easier to use, beyond PEEK and
POKE, might be fun), plus parts of some of the other minicomputer (PDP
line, perhaps) BASICs that existed (like maybe matrix operation
keywords, or extensions to the existing operators, that could somehow
know when A and B were arrays, so you could do things like "DIM A(10),
B(10,10), C(whatever)" then set the arrays, and "C = A * B"; how cool
would that be?
As long as I'm "blue skying" here, what about fixing DRAW so that it
could have arbitrary rotations (and not the fixed ones it has)? That
way, you could do "turtle graphics" fairly easily, or something akin to
the "shapes" the Apple IIe (I don't recall versions on this)...
There's probably a ton of other things that could be done; whether they
could all fit into the "allotted memory space" is a different matter, of
course...
Heh...what about extending the PLAY command to allow access to the
Orch-90 cartridge (or better, the SSC)?
Oh - here's another one: Allow the definition of "textures" for PAINT
(and BF?) to use; add in a "TRIANGLE" kind of command - that would be
icing on the cake for 3D stuff in BASIC (something I always hated; if
you wanted "filled in" triangle polys, you had to draw the lines in one
color, "fill-in" with another, then re-draw the lines in the fill color
- to make a solid triangle that would overlap/overdraw stuff already on
screen - and not use that one "border" color anywhere else).
Of course, the new TRIANGLE command would be a rasterized version; maybe
you could just extend the LINE command to something like
"LINE(x1,y1)-(x2,y2)-(x3,y3),BF" or such - and if only two coords were
passed, it could just split the rectangle up into two triangles; it
would of course depend on whether a 2-pass triangle thing is smaller
than having two independent routines, along with maybe speed issues - or
maybe the rasterizer could be augmented in some manner?
Of course, all of that is just because I played around with Lee Adams
"High-Performance Interactive Graphics" series of books back then on the
CoCo 3 and HSCREEN 4 - I would've loved such routines (also, some way to
do easy page flipping and double-buffering would've been nice, even if
it had to be limited to a 512K machine).
:)
Andrew L. Ayers
Glendale, Arizona
phoenixgarage.org
github.com/andrew-ayers
More information about the Coco
mailing list