Introduction

Chris Gray cg at ami-cg.GraySage.Edmonton.AB.CA
Sat Apr 5 11:22:17 CEST 1997


OK, I'll do one too.

First, I have to admit a few things:

    - I've never really played a MUD other than mine (other than about
	4 hours on Northern Crossroads, and some LP experimenting)
    - I'm old enough to be the father of most of you, so my perspectives
	might be quite different
    - I've done very little RPG-ing, but a fair amount of Adventure gaming
    - I think the Web and C++ suck big time! (shocking!)

My background:

I started university in an honors physics program, and took Computing
Science first in my third year. I became unhappy with physics (I find it
virtually impossible take *anything* on faith!), and so switched over to
Computing Science. Because my courses were a mess (not enough), I didn't
expect to graduate after my fourth year, so I wasn't prepared when they
sent me a diploma that summer. After some phone calls, etc. I ended up
in graduate studies in Computing Science at the same university (University
of Alberta, here in Edmonton). My field of study was programming languages
for artificial intelligence, and my project was the design of such a
language, called 'ALAI' (A Language for Artificial Intelligence - original,
huh?) It was a big language, strongly typed (moreso than C), with a
syntax flavoured after Algol68 (going strong at the time). One of my
supervisors hired me to implement the beast, while also doing Teaching
Assistant work. Previously I had implemented in my spare time a compiler
for a language called "QD" (Quick and Dirty) for the IBM mainframe. I
started the ALAI project in 360 assembler (ick!) and got really bogged
down after a few months. So, I invented "QC" (Quick and Clean), and
wrote a compiler for that, then resumed the ALAI project in it. It still
got bogged down (it was essentially too big for one person to do). My
supervisor got tired of this (not unexpectedly!), so I ended up teaching
for the department, in the areas of computer architecture, programming
languages, and adaptive information systems. I eventually decided to go
for a PhD (at the same university!!!), and started in on that. I made
a poor choice of supervisor - I wanted to study what internal features
are required for any multi-user protected operating system, but he wanted
it to be theoretically grounded (something I strongly dislike). I had
done all the course work, and was left with having to do the thesis, and
a whole slew of math stuff to make up for the fact that I hadn't done
the zillion math courses they required for a PhD. I threw up my hands
in disgust and went to work for the department as a programmer analyst.

During this phase I bought my first two computers - both CP/M systems.
I also created the programming language 'Draco', which was first for
CP/M, and later got ported to the Amiga/68000. It is what my current
system is written in. The CP/M version of Draco is still in the "Simtel"
archives, and was used by a reasonable number of people around the world.
My docs were even put into a McGraw-Hill book (without even asking me!)
My boss then was not, and still isn't, suited to being a boss, so I ended
up quitting in a huff one day. I spent a couple of years doing some
consulting type stuff, doing commercial CP/M software and custom dBase-II
programming. Income was negligible, so when some friends offered me a
job with their new parallel computer company (Myrias), I jumped. I was
hired to write their ANSI C compiler (this was before C++ was invented,
and before even the ANSI C spec was finalized). I did most of that, plus
a symbolic debugger, parallel linker, etc. I then switched to doing
lower-level stuff, writing stand-alone mini OS stuff for custom hardware.
By then I was well into Amiga's, and was writing a set of shared libraries
to provide a customizable family of programming languages for use in
things like editors, shells, spreadsheets, databases, etc. I had already
written Amiga Empire, which was a rewritten version of Peter Langston's
original multi-player military conquest game (in Draco of course!). I
then heard about MUDs (I had dabbled a bit before, after hearing about
the old multi-player D&D game on the CDC Plato systems). I decided to
take a break from the library set and write a quickie MUD system, to be
called AmigaDUM. If it worked out, I was going to use the language
libraries to make a better one complete with a MUD language. Well, the
AmigaDUM project has been going on for 6+ years now, and is now called
AmigaMUD. The language libraries still sit forlornly on my HD, as do
the in-progress optimization improvements to the Amiga Draco compiler.

About two months after starting AmigaDUM, the company Myrias went
bankrupt (no connection, honest!), and I started work on the MUD stuff
full-time. That lasted a few months, until my current boss convinced a
local entrepreneur to buy the remnants of Myrias, and we were back in
business, much reduced in size and ambition. Instead of our own custom
hardware, our parallel stuff now runs on UNIX workstations, and we
do contract work with IBM, HP, Sun, HAL, etc. I've learned more than I
really wanted to know about UNIX. Early in the port to UNIX, I needed
to learn all about sockets, so that I could do a reliable asynchronous
protocol on top of UDP (TCP is too synchronous - we always ended up
deadlocking). To learn that, I wrote a quicky MUD system for UNIX. Later,
I decided to add a programming language to that system, and to see just
how little code would be needed for a MUD like that. It is about 3500
lines of ANSI C, and works fairly well, although not very efficiently.

I'm currently working to get release 1.1 of AmigaMUD out. I've wasted a
tremendous amount of time on (to me) boring things like making the
custom client a lot more general, and adding and using fixed-point numbers
to the system (so the graphics can be scaled properly).


Whew! Am I ever long-winded! However, this might show you where I'm
coming from, and why my emphasis is often more on programming language
and efficiency issues than on other issues.

--
Chris Gray   cg at ami-cg.GraySage.Edmonton.AB.CA



More information about the mud-dev-archive mailing list