[MUD-Dev] Re: (fwd) Re: command parsers: a modest proposal (with apologies to J. Swift)
Richard Bartle
76703.3042 at compuserve.com
Wed Jul 8 11:13:00 CEST 1998
Chris Gray <cg at ami-cg.GraySage.Edmonton.AB.CA> wrote:
>I don't actually build lists of matching nouns and then restrict based on
>adjectives - I do my searching with the adjectives in effect. Consequence:
>I don't currently support notions like "all but".
This is a good technique for databases in general, as it can mean the
entire database doesn't get searched twice. In a MUD where locality gives a
reasonably small data structure, though, it's not a problem.
>In "drop rock", it seems MUD2 would drop all rocks.
That's right, it would.
>What are the choices here:
> - drop all of them
> - complain about ambiguity
> - drop some "random" rock
> - allow the user to choose
Of these, the second and fourth get in the way of the game. The real
choice is between the first and the third. I chose the first because it fell
naturally from the way I was processing adjectives and so on as operators
applied to sets of candidate objects. Once players got used to it, switching
to another version was not an attractive option.
If I were to rewrite the parser for a new MUD, though, I think I'd
take plural forms into account, ie. DROP ROCK drops one, DROP ROCKS drops
them all. There would have to be some minor messing about for cases like
DROP EVERYTHING, but nothing intractable.
>it had never occurred to me that "drop rock" would drop more than one rock,
>and I would have been surprised by that behaviour.
Not as surprised as the players who type KILL RAT when there are
18 of them in the room...
>Actually, I think I don't like that particular choice.
OK, fair enough!
>Dr. Bartle speaks of "compiling", which suggests that his entire system
>is a single compiled binary.
Wellll...
It's several compiled binaries. The game itself is written in MUDDLE,
which is interpreted by an interpreter written in C. However, the code
which is interpreted is an intermediate code, to which the MUDDLE original
has to be compiled. If I add new words to the vocabulary, that's where I
do it, and that's why it needs to be recompiled. If I change any of the
stages up to the parsing stage, I need to change the C code instead.
>Are there in fact possibilities of adding to the vocabulary at run time?
Yes, there are.
>If so, then abbreviations for things becomes a lot tricker.
Not at all.
>Either you avoid more abbreviations because they *might* conflict, or you
>have to do a lot of searching and checking at runtime, to see what an
>abbreviation should refer to.
No, abbreviations aren't created dynamically, I use them as secondary
names for specific things. In other words, I add abbreviations manually and
state what they point at. If I later add something which could have the
same abbreviation, I may decide to switch the abbreviation to it but more
often than not I'll stick with the original. Abbreviations which the game
figured out on its own and associated with objects at the time of use would
be very dangerous, especially if player names were candidates for such
abbreviation.
Richard
More information about the mud-dev-archive
mailing list