Avendar:Prog Section 1

Prog Structure and Practice

"It's just a puzzle box." 
  -- Kirstie, Hellraiser

Firstly, there are three classes of entities in the game which can have progs: Mobiles, Objects, and Rooms. Broadly speaking, the syntax used on each of these prog types is the same. Respectively, these are referred to as mobprogs, objprogs, or room progs. Over time, the prog system has been rationalized so that the syntax for mpcommands and if checks is the same across the type of entity. "Mobprog" is therefore often used to refer to the general class of all prog types, and this is the usage which will be employed in this document. Every prog has the following structure:

  [prog_trigger] [modifier] [argument]
  Body of Prog: 
  {
  (Control structures)
  (Commands)
  }

It isn't immediately obvious by what we mean by all these terms, so let's try to clarify them:

prog_trigger

The prog_trigger reflects a central fact about progs: All progs are, in fact, a set of actions which occur in response to a triggering event. What a trigger really says is, "Execute the commands that are in my body when conditions matching my trigger are met".

To take a concrete example, consider the following prog_trigger:

Greet_prog:
Syntax: greet_prog <Percentage value from 1-100>

A greet_prog triggers whenever a pc enters the room with the object/room/mob. The chance that the greet prog triggers is equal to the percentage value given as an argument.

Ex:
greet_prog 50
say Hello there!

So, this mob has a 50% chance any time a pc enters the room of triggering the prog, at which point the pc will see the mob saying "Hello there!"

Another example of a prog trigger which does not have a percentage argument is the speech_prog.

Syntax: speech_prog [p] [argument]

Speech_prog triggers if [argument] is said aloud in the same room as mobile or object. The "p" determines whether or not the match must be exact or simply a substring match. If no argument is specified, the speech_prog will trigger on any speech at all.

Ex:
speech_prog p Hello
say Hi there!

Now, a mobile with this program would respond whenever someone said "hello" to the mob.


The Prog Body: The body of the prog is where the 'meat' of the prog resides. Broadly speaking, you will find two types of things within the body:

Commands
Control Structures

(i) Commands

Commands are actions that the mob can perform. As a general rule, mobiles can perform any action a player can that does not involve the use of a skill or spell. (They can do these as well, but it requires a special other thing to be done first.)

In addition to these normal commands, there are a suite of prog-specific commands. These commands are designed to allow progs to duplicate imm commands, player skills or spells, or to just generally do interesting things. To take a concrete example, consider the following prog specific command:

mpgoto:
Syntax: mpgoto <vnum>

When executed from within a mob prog, mpgoto causes the mobile in question to goto the room with vnum specified. Taking the examples we've seen, we can construct a very simple prog:

greet_prog 100
say Oh no, people!
mpgoto 5000

In the above prog, "greet_prog" is the prog trigger, and the say and the mpgoto are examples of commands. This prog basically says, "Whenever someone enters the same room as this mob, have it say "Oh no, people!", then have the mob goto room 5000".

This is a very basic prog, but might be used on a mischievous imp or forest spirit. (And a cunning player would go to room 5000, and ambush the imp there!) There are many, many different mpcommands, so we'll detail those in their own chapter.

(ii) Control Structures

Normally, commands in the body of a prog are executed in linear order. I.e., if we have a prog:

prog_trigger
command 1
command 2
command 3

When the prog triggers, it will execute command 1, then command 2, then command 3, and so on, line by line, from top to bottom.

Control structures allow us to control the natural order of prog execution. Structures exist to allow for logical branching, multiple conditionals, looping, subroutines, and numerous other functions. To take a concrete example, consider the "loop" statement:

Loop:
Syntax: loop <lower number> to <higher number>
[Body of loop]
endloop

The loop structure, like its name implies, will loop through the body of the loop, executing the lines within for every iteration of the loop. So, consider the following prog:

greet_prog 100
loop 1 to 3
say Hey Hey!
endloop

This prog will trigger when someone enters the room. It will then hit the loop, so it will execute its contents three times. So, if I enter a room with a mob who had this prog, I will see:

Mob says, 'Hey Hey!' [this is when the loop is on 1]
Mob says, 'Hey Hey!' [this is when the loop is on 2]
Mob says, 'Hey Hey!' [this is when the loop is on 3]

Later, we'll give control structures their own chapter. But for right now, the important thing is to realize is that the default behavior for a prog is to execute its commands in order, and control structures exist to change the order in which commands are executed.