home *** CD-ROM | disk | FTP | other *** search
/ Amiga Games Extra 1996 May / Amiga_Games_Extra_CD_5-96.bin / spiele / publicdomain / amsrc / building / bguild.m next >
Text File  |  1996-02-19  |  30KB  |  669 lines

  1. /*
  2.  * Amiga MUD
  3.  *
  4.  * Copyright (c) 1996 by Chris Gray
  5.  */
  6.  
  7. /*
  8.  * bguild.m - set up the builder's guild.
  9.  */
  10.  
  11. private tp_bguild CreateTable().
  12. use tp_bguild
  13.  
  14. use t_streets
  15.  
  16. define tp_bguild BGUILD_ID NextEffectId().
  17.  
  18. define tp_bguild proc drawGuild()void:
  19.  
  20.     if not KnowsEffect(nil, BGUILD_ID) then
  21.     DefineEffect(nil, BGUILD_ID);
  22.     GSetImage(nil, "Town/bguild");
  23.     IfFound(nil);
  24.         GShowImage(nil, "", 0, 0, 160, 100, 0, 0);
  25.     Else(nil);
  26.         GSetPen(nil, C_TAN);
  27.         GAMove(nil, 123, 26);
  28.         GRDraw(nil, 0, -10);
  29.         GRDraw(nil, 20, 0);
  30.         GRDraw(nil, 0, 10);
  31.         GAMove(nil, 0, 26);
  32.         GRDraw(nil, 158, 0);
  33.         GRDraw(nil, 0, 60);
  34.         GRDraw(nil, -158, 0);
  35.         GRDraw(nil, 0, -60);
  36.         GAMove(nil, 50, 26);
  37.         GRDraw(nil, 0, 60);
  38.         GAMove(nil, 50, 48);
  39.         GRDraw(nil, 58, 0);
  40.         GAMove(nil, 50, 64);
  41.         GRDraw(nil, 58, 0);
  42.         GAMove(nil, 79, 26);
  43.         GRDraw(nil, 0, 22);
  44.         GAMove(nil, 79, 64);
  45.         GRDraw(nil, 0, 22);
  46.         GAMove(nil, 108, 26);
  47.         GRDraw(nil, 0, 22);
  48.         GAMove(nil, 108, 64);
  49.         GRDraw(nil, 0, 22);
  50.     
  51.         GSetPen(nil, C_BROWN);
  52.         GAMove(nil, 59, 48);
  53.         HorizontalDoor();
  54.         GAMove(nil, 88, 48);
  55.         HorizontalDoor();
  56.         GAMove(nil, 59, 64);
  57.         HorizontalDoor();
  58.         GAMove(nil, 88, 64);
  59.         HorizontalDoor();
  60.         GAMove(nil, 128, 26);
  61.         HorizontalDoor();
  62.         GAMove(nil, 50, 52);
  63.         VerticalDoor();
  64.         GAMove(nil, 158, 52);
  65.         VerticalDoor();
  66.  
  67.         GSetPen(nil, C_GOLD);
  68.         GAMove(nil, 13, 59);
  69.         GText(nil, "LIB");
  70.         GAMove(nil, 60, 41);
  71.         GText(nil, "A ");
  72.         GAMove(nil, 89, 41);
  73.         GText(nil, "B ");
  74.         GAMove(nil, 60, 79);
  75.         GText(nil, "W ");
  76.         GAMove(nil, 89, 79);
  77.         GText(nil, "M ");
  78.     Fi(nil);
  79.     EndEffect();
  80.     fi;
  81.     CallEffect(nil, BGUILD_ID);
  82. corp;
  83.  
  84. define tp_bguild GUILD_MAP_GROUP NextMapGroup().
  85.  
  86. define tp_bguild r_buildEntry CreateThing(r_indoors).
  87. SetupRoom(r_buildEntry, "in the foyer of the builder's guild",
  88.     "The floor in here is an expensive-looking black and white tile. Potted "
  89.     "plants abound, as do black leather upholstery and brass fixtures. A long "
  90.     "hallway leads off to the west, a small door half-hidden behind a palm "
  91.     "tree leads north, and the doors out to the street are to the east.").
  92. r_buildEntry@p_rNoMachines := true.
  93. Connect(r_sw2, r_buildEntry, D_WEST).
  94. Connect(r_sw2, r_buildEntry, D_ENTER).
  95. ExtendDesc(r_sw2,
  96.     "There is a fancy entryway here, complete with a somewhat worn red carpet "
  97.     "and overhead marquee. Double glass doors lead into a large entry hall. "
  98.     "There are potted shrubs to either side of the door, and a brass sign "
  99.     "beside the door reads \"Builder's Guild\".").
  100. RoomGraphics(r_buildEntry, "Foyer", "", GUILD_MAP_GROUP, 130, 53, drawGuild).
  101. Sign(r_sw2, "sign;brass.door;brass,sign,beside,the",
  102.     "The brass sign is one of those expensive things carved from a hunk of "
  103.     "brass. The resulting raised letters are brass coloured, and the "
  104.     "carved-out areas are painted flat black.",
  105.     "\"Builder's Guild\"").
  106. Scenery(r_sw2,
  107.     "entryway,entry;fancy."
  108.     "carpet;somewhat,worn,red."
  109.     "marquee;overhead."
  110.     "door;double,glass."
  111.     "hall;large,entry."
  112.     "shrub;potted").
  113. Scenery(r_buildEntry,
  114.     "floor;expensive,black,and,white,tiled."
  115.     "tile;expensive,black,and,white."
  116.     "plant;potted."
  117.     "upholstery;black,leather."
  118.     "fixture;brass."
  119.     "hallway;long."
  120.     "tree;palm."
  121.     "door;small,wooden").
  122.  
  123. define tp_bguild r_buildHall1 CreateThing(r_indoors).
  124. SetupRoom(r_buildHall1, "in an east-west hallway",
  125.     "On each side of the hall are simple wooden doors. Beside each is a sign "
  126.     "which reads \"Members Only\". The entry hall is to the east.").
  127. Connect(r_buildEntry, r_buildHall1, D_WEST).
  128. RoomGraphics(r_buildHall1, "East", "Hallway", GUILD_MAP_GROUP, 90, 53,
  129.          drawGuild).
  130. Scenery(r_buildHall1, "door;simple,wooden").
  131. Sign(r_buildHall1, "sign", "", "\"Members Only\"").
  132.  
  133. define tp_bguild r_buildHall2 CreateThing(r_indoors).
  134. SetupRoom(r_buildHall2, "in an east-west hallway",
  135.     "On each side of the hall are simple wooden doors. Beside each is a sign "
  136.     "which reads \"Members Only\". A set of double doors to the west marks "
  137.     "the end of the hallway. Beside those doors is a sign which reads "
  138.     "\"Library\".").
  139. Connect(r_buildHall1, r_buildHall2, D_WEST).
  140. RoomGraphics(r_buildHall2, "West", "Hallway", GUILD_MAP_GROUP, 61, 53,
  141.          drawGuild).
  142. Scenery(r_buildHall2, "door;simple,wooden,double").
  143. Sign(r_buildHall2, "sign", "", "").
  144. Sign(r_buildHall2, "sign", "", "").
  145.  
  146. define tp_bguild r_buildLibrary CreateThing(r_indoors).
  147. SetupRoom(r_buildLibrary, "in the builder's library",
  148.     "Rows and rows of shelves here are filled to overflowing with plans, "
  149.     "blueprints, permits, announcements, etc. Most of the material is of no "
  150.     "interest, but one set of volumes bears investigation. Double doors lead "
  151.     "out to the east.").
  152. Connect(r_buildHall2, r_buildLibrary, D_WEST).
  153. UniConnect(r_buildLibrary, r_buildHall2, D_EXIT).
  154. RoomGraphics(r_buildLibrary, "Library", "", GUILD_MAP_GROUP, 21, 53,
  155.          drawGuild).
  156. Scenery(r_buildLibrary,
  157.     "shelves,shelf;rows,and,of."
  158.     "plan."
  159.     "blueprint."
  160.     "announcement."
  161.     "material").
  162. Sign(r_buildLibrary, "volume;set,of.set",
  163.     "The volumes you see are the ones you should read.",
  164.     "Read the volumes by name, one at a time.").
  165.  
  166. define tp_bguild o_buildBook1 CreateThing(nil).
  167. SetupObject(o_buildBook1, r_buildLibrary, "introduction,intro;book,of.book",
  168.     "This tattered volume is right at the beginning of the heap. It is "
  169.     "securely attached to the shelf by a brass chain, so you can't take it "
  170.     "out. The text inside describes the miscellaneous building commands.").
  171. o_buildBook1@p_oNotGettable := true.
  172. o_buildBook1@p_oReadString :=
  173. "The following miscellaneous build (@) commands exist:\n"
  174. "  @showtable <table> - show the symbols defined in the table.\n"
  175. "  @describesymbol <table> <symbol> - describe the given symbol.\n"
  176. "  @deletesymbol <table> <symbol> - delete the given symbol. You must be the\n"
  177. "\towner of the symbol in order to delete it.\n"
  178. "  @movesymbol <fromtable> <totable> <symbol> - move a symbol from one table\n"
  179. "\tto another.\n"
  180. "  @renamesymbol <table> <old-symbol> <new-symbol> - rename a symbol.\n"
  181. "  @flag <table> <symbol> - define a new flag property.\n"
  182. "  @counter <table> <symbol> - define a new counter property.\n"
  183. "  @string <table> <symbol> - define a new string property.\n"
  184. "  @table <table> <symbol> - define a new private table.\n"
  185. "  @use <table> - add table to set used for symbol lookup.\n"
  186. "  @unuse <table> - remove table from set used for symbol lookup.\n"
  187. "  @symbolhere <table> <symbol> - define the given symbol for this room.\n"
  188. "  @poof <symbol> - poof to your given named room.\n"
  189. "Use table name 'private' to refer to your main private symbol table.\n"
  190. "Only an Apprentice or Wizard can make you an official builder.".
  191.  
  192. define tp_bguild o_buildBook2 CreateThing(nil).
  193. SetupObject(o_buildBook2, r_buildLibrary, "rooms,room;book,of.book",
  194.     "This book shows much sign of wear. If it wasn't attached to the wall "
  195.     "with an iron chain, it probably wouldn't be here anymore! Inside, it "
  196.     "details the basic methods for building rooms.").
  197. o_buildBook2@p_oNotGettable := true.
  198. o_buildBook2@p_oReadString :=
  199. "The following forms of the @room (@r) command exist:\n"
  200. "  @room new <dir> <kind> <room-name> - create a new room with a two-way\n"
  201. "\tlink in the indicated direction. <kind> is one of: indoors, forest\n"
  202. "\toutdoors, field, road, path, sidewalk or park. <room-name> is the\n"
  203. "\tstring which will be printed after the 'You are'. E.g.\n"
  204. "\t\t@room new north indoors in a new room\n"
  205. "  @room newname <room-name> - rename the current room.\n"
  206. "  @room same <old-dir> <new-dir> - make a one-way link in direction\n"
  207. "\t<new-dir> which goes the same place as <old-dir> does. E.g.\n"
  208. "\t\t@room same north in\n"
  209. "  @room hide <dir> - toggle the visibility of the given link.\n"
  210. "  @room scenery <word> ... <word> - add scenery words here.\n"
  211. "  @room newdesc - replace the long description of the current room.\n"
  212. "  @room adddesc - append to the long description of the current room.\n"
  213. "  @room setdescaction <action-symbol> - set a descaction proc here.\n"
  214. "  @room linkto <dir> <symbol> - make a one-way link in direction <dir> to\n"
  215. "\tthe room which you have given name <symbol> to.\n"
  216. "  @room unlink <dir> - remove path in the indicated direction.\n"
  217. "  @room dark [ yes | no ] - make the current room dark or light.\n"
  218. "  @room lock [ yes | no ] - lock/unlock the current room for public access.\n"
  219. "  @room status { readonly | wizard | public } - set the status of the\n"
  220. "\tcurrent room with regards to who can build onto it.\n"
  221. "  @room dirdesc <dir> - enter a new direction-specific description for the\n"
  222. "\tcurrent room. This is the message that the character will be shown\n"
  223. "\tif he/she looks in that direction.\n"
  224. "  @room dirmessage <dir> - set the message that the character will see when\n"
  225. "\the/she goes in that direction. <dir> can be 'nogo'.\n"
  226. "  @room diromessage <dir> - set the message that other characters in the\n"
  227. "\tsame room will see when a character goes in the given direction.\n"
  228. "\tThe character's name and a space will be prepended to the message.\n"
  229. "  @room diremessage <dir> - set the message that other characters in the\n"
  230. "\tsame room will see when a character arrives from the given\n"
  231. "\tdirection. Note that the character's name and a space will be\n"
  232. "\tprepended to the message.\n"
  233. "  @room adddircheck <dir> <action-symbol> - enter a new checker procedure\n"
  234. "\tfor going the given direction from the current room. <dir> can also\n"
  235. "\tbe 'anyenter' or 'anyexit'.\n"
  236. "  @room subdircheck <dir> <action-symbol> - remove the checker.\n"
  237. "  @room showdirchecks <dir> - list all checkers for the given direction.\n"
  238. "  @room addspecialaction <action-symbol> <verb-form> - add special action\n"
  239. "\tas in:   @r addspecialaction doSmoogle \"smoogle,grundle\"\n"
  240. "  @room subspecialaction <action-symbol> <verb-form> - remove action.\n"
  241. "  @room checker <table> <action-symbol> - define a checker action.\n"
  242. "  @room descaction <table> <action-symbol> - define a description action.\n"
  243. "  @room specialaction <table> <action-symbol> - define special action.\n"
  244. "  @room makebank - make the current room into a bank.\n"
  245. "  @room makestore - make the current room into a store.\n"
  246. "  @room addforsale <object-symbol> <price> - make object for sale here.\n"
  247. "  @room subforsale <object-symbol> - remove it from sale.".
  248.  
  249. define tp_bguild o_buildBook3 CreateThing(nil).
  250. SetupObject(o_buildBook3, r_buildLibrary, "objects,object,obj;book,of.book",
  251.     "This solid volume is tied to the desk with a steel chain, so you can't "
  252.     "check it out of the library. It details the building of objects.").
  253. o_buildBook3@p_oNotGettable := true.
  254. o_buildBook3@p_oReadString :=
  255. "The following forms of the @object (@o) command exist:\n"
  256. "  @object new <table> <object-symbol> <visible-name> - create a new object\n"
  257. "\twith name <object-symbol> and visible name <visible-name>. E.g.\n"
  258. "\t\t@object new private candle \"candlestick;shiny,brass\"\n"
  259. "  @object newname <object-symbol> <visible-name> - supply new visible name.\n"
  260. "  @object newdesc <object-symbol> - supply new description for the object.\n"
  261. "  @object setdescaction <object-symbol> <action-symbol> - set the action\n"
  262. "\tto be the description action for the object.\n"
  263. "  @object setactword <object-symbol> <word-list> - set the special actions\n"
  264. "\tthat this object can do. E.g.\n"
  265. "\t\t@object setactword candle \"blow,puff,snuff\"\n"
  266. "  @object setactstring <object-symbol> - set the special action string.\n"
  267. "  @object setactaction <object-symbol> <action-symbol> - set special action\n"
  268. "\tprocedure to be triggered by the object's action word.\n"
  269. "  @object gettable <object-symbol> [ yes | no ] - is the object gettable?\n"
  270. "  @object islight <object-symbol> [ yes | no ] - does it emit light?\n"
  271. "  @object invisible <object-symbol> [ yes | no ] - is it seen in room?\n"
  272. "  @object container <object-symbol> <count> - make it a container\n"
  273. "  @object { sitin | siton | liein | lieon | standin | standon }\n"
  274. "\t<object-symbol> <count> - E.g. to make the couch have room for two\n"
  275. "\tpeople to sit on\n"
  276. "\t\t@object siton couch 2\n"
  277. "  @object destroy <table> <object-symbol> - destroy the indicated object.\n"
  278. "  @object checker <table> <action-symbol> - define object checker action.\n"
  279. "  @object descaction <table> <action-symbol> - define a description action.\n"
  280. "  @object actaction <table> <action-symbol> - define a special action.\n"
  281. "XXX := { play | erase | eat | use | activate | deactivate | light |\n"
  282. "\textinguish | wear | read | touch | smell | listen | open | close |\n"
  283. "\tpush | pull | turn | lift | lower }\n"
  284. "  @object XXXstring <object-symbol> - set action string on object.\n"
  285. "\tAlso 'getstring' and 'unlockstring'.\n"
  286. "  @object XXXaction <object-symbol> <action-symbol> - set checker on object.".
  287.  
  288. define tp_bguild o_buildBook4 CreateThing(nil).
  289. SetupObject(o_buildBook4, r_buildLibrary, "procedures,procs;book,of.book",
  290.     "This immaterial book is firmly tied to nothing with an intangible chain, "
  291.     "so you cannot remove it from the library. Inside are many words "
  292.     "detailing the building of checker/action/description procedures.").
  293. o_buildBook4@p_oNotGettable := true.
  294. o_buildBook4@p_oReadString :=
  295. "Checker/action/description procedures are a way of attaching conditions "
  296. "and/or actions to an exit or to an object. "
  297. "They are executed when a character tries to take the exit or do something "
  298. "with the object. "
  299. "They can cause things to happen, such as a message to the character or "
  300. "others, and can conditionally allow the taking of the exit or the "
  301. "completion of the action. "
  302. "They are entered line by line and each line of the procedure is checked for "
  303. "validity against the rules for the kind of procedure being entered. "
  304. "Note that this is NOT full-fledged AmigaMUD programming - wizards and "
  305. "apprentices have access to a much more flexible and powerful programming "
  306. "language.\n\n"
  307. "Checker/action procedures consist of a series (possibly none) of actions to "
  308. "be executed unconditionally; "
  309. "followed by a condition, which is built from none or more simple "
  310. "conditionals; "
  311. "followed by the actions to be executed if the condition succeeds; "
  312. "followed by the actions to be executed if the condition fails. "
  313. "The allowable conditions and actions vary depending on whether the procedure "
  314. "governs a room exit or an object operation. "
  315. "A condition passes only if ALL of its simple conditionals are satisfied. "
  316. "See the books titled 'book of conditionals' and 'book of actions' for "
  317. "details.\n\n"
  318. "Description procedures are used to produce room or object descriptions which "
  319. "vary depending on the state of some variables. "
  320. "They are essentially just a string, as described in the 'book of strings'.".
  321.  
  322. define tp_bguild o_buildBook5 CreateThing(nil).
  323. SetupObject(o_buildBook5, r_buildLibrary,
  324.         "conditionals,cond,condition,conditions,conditional;book,of.book",
  325.     "This book describes the simple conditionals which can be attached to "
  326.     "a checker/action procedure.").
  327. o_buildBook5@p_oNotGettable := true.
  328. o_buildBook5@p_oReadString :=
  329. "'character' and 'room' values can be tested for either exit or object "
  330. "conditionals, but 'object' values must be used appropriately. "
  331. "The 'XXXhasYYY' tests refer to the object being carried by the character, "
  332. "in the room, or in the main object. "
  333. "Each of these simple conditions can be preceeded by 'not' to reverse its "
  334. "test.\n"
  335. "  characterflag/roomflag/objectflag <flag-symbol> - the conditional is true\n"
  336. "\tif the specified flag is 'true'.\n"
  337. "  charactercounter/roomcounter/objectcounter <counter-symbol>\n"
  338. "\t<counter-value> - the conditional is true if the counter has the\n"
  339. "\tgiven value.\n"
  340. "  characterhasspecific/roomhasspecific/objecthasspecific <object-symbol> -\n"
  341. "\tthe conditional is true if the character has the thing, or it is in\n"
  342. "\tthe room, or it is inside the main object. <object-symbol> is the\n"
  343. "\tdefining character's private symbol name for the object.\n"
  344. "  characterhaschild/roomhaschild/objecthaschild <object-symbol> - the\n"
  345. "\tconditional is true if the character/room/object has/contains an\n"
  346. "\tobject cloned from the indicated one (see 'book of actions').\n"
  347. "  characterhasname/roomhasname/objecthasname <name-string> - the\n"
  348. "\tconditional is true if the character/room/object has/contains an\n"
  349. "\tobject whose name matches the given <name-string>. Note that the\n"
  350. "\t<name-string> is in the standard 'noun;adj,adj' format.\n"
  351. "  characterhasflag/roomhasflag/objecthasflag <flag-symbol> - the\n"
  352. "\tconditional is true if the character/room/object has/contains an\n"
  353. "\tobject so flagged.\n"
  354. "  random <chance> - the conditional passes with '<chance> / 10' percent\n"
  355. "\tlikelihood. E.g. \"random 500\" gives a 50% chance.".
  356.  
  357. define tp_bguild o_buildBook6 CreateThing(nil).
  358. SetupObject(o_buildBook6, r_buildLibrary,
  359.         "actions,action,act,acts;book,of.book",
  360.     "This book describes the actions which can be attached to "
  361.     "a checker/action procedure.").
  362. o_buildBook6@p_oNotGettable := true.
  363. o_buildBook6@p_oReadString :=
  364. "'character' and 'room' values can be changed for either exit or object "
  365. "procedures, but 'object' values must be used appropriately.\n"
  366. "  charactersetflag/characterclearflag/roomsetflag/roomclearflag/\n"
  367. "    objectsetflag/objectclearflag <flag-symbol> - the given flag is set or\n"
  368. "\tcleared, as appropriate.\n"
  369. "  characterinccounter/characterdeccounter/roominccounter/roomdeccounter/\n"
  370. "    objectinccounter/objectdeccounter <counter-symbol> - the given counter\n"
  371. "\tis incremented or decremented, as appropriate.\n"
  372. "  charactersetcounter/objectsetcounter/roomsetcounter <counter-symbol>\n"
  373. "\t<value> - the given counter is set to the given value.\n"
  374. "  charactersetstring/objectsetstring/roomsetstring <string-symbol>\n"
  375. "\t<s-val> - the given string property is set based on s-val: 'date' or\n"
  376. "\t'time' give the current date/time as in \"Mon Jan 25 19:47:40 1993\";\n"
  377. "\t'charactername' gives the name of the current character; 'roomname'\n"
  378. "\tgives the name of the room, as in \"in the playpen\"; and\n"
  379. "\t'objectname' gives the object name, as in \"delicate blue vase\".\n"
  380. "  characterclearstring/objectclearstring/roomclearstring <string-symbol> -\n"
  381. "\tthe string property is removed from the character/room/object.\n"
  382. "  clonehere <object-symbol> - a clone of the named object is created and\n"
  383. "\tdeposited in this room.\n"
  384. "  cloneat <room-symbol> <object-symbol> - a clone of the named object is\n"
  385. "\tmade and placed in the indicated room.\n"
  386. "  destruct - the object (only valid there) is destroyed.\n"
  387. "  drop - the object is dropped.\n"
  388. "  setit <kind> <object-symbol> - if kind is 'specific' then the named\n"
  389. "\tobject becomes the main object, which is affected by further actions\n"
  390. "\tin this branch of the procedure. If kind is 'characterchild',\n"
  391. "\t'roomchild' or 'objectchild', then the first object being carried,\n"
  392. "\tin the room or in the object is so set. If kind is 'flag', then\n"
  393. "\tthe first object with that flag set becomes the main object. If\n"
  394. "\tkind is 'name', then the object-symbol must be the visible name of\n"
  395. "\tan object to look for.\n"
  396. "  saycharacter - input mode changes to accept a message which is to be\n"
  397. "\tgiven to the character. See the 'book of strings' for details.\n"
  398. "  sayothers - input mode changes to accept a message which is to be given\n"
  399. "\tto other characters in the same room.\n"
  400. "  if - allows a nested condition/true/false sequence to be inserted. These\n"
  401. "\tcannot be further nested.".
  402.  
  403. define tp_bguild o_buildBook7 CreateThing(nil).
  404. SetupObject(o_buildBook7, r_buildLibrary, "strings,string;book,of.book",
  405.     "This book describes the special things that can be put in strings in "
  406.     "procedures, both description procedures and as part of others.").
  407. o_buildBook7@p_oNotGettable := true.
  408. o_buildBook7@p_oReadString :=
  409. "Most input here is just text that is part of the string. Do not attempt to "
  410. "format the text - the system will format it, along with any other text that "
  411. "is part of the relevant output, according to the width of the player's "
  412. "output device. "
  413. "If a line input here starts with an '@', however, it is a special command "
  414. "which causes things to be put in that place in the string when the string "
  415. "is being used during execution. "
  416. "The special string commands are\n"
  417. "  @characterstring/roomstring/objectstring <string-symbol> - the value of\n"
  418. "\tthe indicated string property is inserted.\n"
  419. "  @charactercounter/roomcounter/objectcounter <counter-symbol> - the value\n"
  420. "\tof the indicated counter is inserted in numeric form.\n"
  421. "  @charactername/roomname/objectname - the name of the character/room/\n"
  422. "\tobject is inserted. See the 'book of actions' for the formats used.".
  423.  
  424. define tp_bguild proc buildCheck()status:
  425.  
  426.     if Me()@p_pBuilder then
  427.     continue
  428.     else
  429.     Print("Not being a member of the guild, you cannot go through "
  430.         "the door.\n");
  431.     fail
  432.     fi
  433. corp;
  434.  
  435. define tp_bguild r_buildOffice1 CreateThing(r_indoors).
  436. SetupRoom(r_buildOffice1, "in a private office",
  437.     "This office is decorated in a traditional British style. Oak panelling "
  438.     "covers the wall, a massive fireplace on the north wall is complete with "
  439.     "a large mantelpiece filled with knick-knacks, and a wool carpet covers "
  440.     "the floor. The furniture consists of a huge oak desk, and several "
  441.     "overstuffed armchairs.").
  442. Connect(r_buildHall1, r_buildOffice1, D_NORTH).
  443. UniConnect(r_buildOffice1, r_buildHall1, D_EXIT).
  444. AddNorthChecker(r_buildHall1, buildCheck, false).
  445. RoomGraphics(r_buildOffice1, "British", "Office", GUILD_MAP_GROUP, 89, 35,
  446.          drawGuild).
  447. Scenery(r_buildOffice1,
  448.     "panelling,panel;oak."
  449.     "wall;oak-panelled,oak,panelled,north."
  450.     "fireplace;massive."
  451.     "mantelpiece;large."
  452.     "knick-knack,knack;knick."
  453.     "carpet;wool."
  454.     "floor."
  455.     "furniture."
  456.     "desk;huge,oak."
  457.     "armchairs,chair;arm,overstuffed").
  458.  
  459. define tp_bguild r_buildOffice2 CreateThing(r_indoors).
  460. SetupRoom(r_buildOffice2, "in a private office",
  461.     "This office sports a distinctly modern look. The desk is of stainless "
  462.     "steel and black plastic, and sports the latest Amiga computer. The "
  463.     "bookcases, shelving, coffee tables, etc. are all of gleaming brass and "
  464.     "glass. Abstract dodads fill much of the shelf space. The couch is much "
  465.     "too low to be comfortable, but is certainly big enough to sleep on.").
  466. Connect(r_buildHall1, r_buildOffice2, D_SOUTH).
  467. UniConnect(r_buildOffice2, r_buildHall1, D_EXIT).
  468. AddSouthChecker(r_buildHall1, buildCheck, false).
  469. RoomGraphics(r_buildOffice2, "Modern", "Office", GUILD_MAP_GROUP, 89, 73,
  470.          drawGuild).
  471. Scenery(r_buildOffice2,
  472.     "desk;stainless,steel,and,black,plastic."
  473.     "computer,keyboard,screen,drive,disk;amiga,disk."
  474.     "shelving,shelves,shelf,table,case;book,coffee,gleaming,brass,and,glass."
  475.     "dodad;abstract."
  476.     "space;shelf."
  477.     "couch;low,big,uncomfortable").
  478. MakeBulletinBoard(r_buildOffice2).
  479.  
  480. define tp_bguild r_buildOffice3 CreateThing(r_indoors).
  481. SetupRoom(r_buildOffice3, "in a private office",
  482.     "This office would be more appropriate in Nairobi! The furniture is all "
  483.     "cane and bamboo, large tubs of tropical plants fill the walls, and you "
  484.     "can even make out mounted animal heads peering through the greenery. "
  485.     "Display cases hold feathered spears, brightly decorated shields, and "
  486.     "gruesome carved masks. Unfortunately, the cases, like everything else "
  487.     "around here, cannot be opened.").
  488. Connect(r_buildHall2, r_buildOffice3, D_NORTH).
  489. UniConnect(r_buildOffice3, r_buildHall2, D_EXIT).
  490. AddNorthChecker(r_buildHall2, buildCheck, false).
  491. RoomGraphics(r_buildOffice3, "African", "Office", GUILD_MAP_GROUP, 60, 35,
  492.          drawGuild).
  493. Scenery(r_buildOffice3,
  494.     "furniture;cane,and,bamboo."
  495.     "tub,plant;large,tubs,of,tropical."
  496.     "wall."
  497.     "head;mounted,animal."
  498.     "greenery."
  499.     "case;display."
  500.     "spear;feathered."
  501.     "shield;brightly,decorated."
  502.     "mask;gruesome,carved.").
  503.  
  504. define tp_bguild r_buildOffice4 CreateThing(r_indoors).
  505. SetupRoom(r_buildOffice4, "in a private office",
  506.     "This office must belong to someone lost in the past! The walls are "
  507.     "covered with vertical log stakes, held together by large iron bands and "
  508.     "spikes. The furniture is all rough-cut wood with a bit of varnish. The "
  509.     "desk looks massive enough to park a car on. Locked gun-cases can be "
  510.     "seen on one wall, while another is full of small, faded photographs of "
  511.     "someone's distant relatives.").
  512. Connect(r_buildHall2, r_buildOffice4, D_SOUTH).
  513. UniConnect(r_buildOffice4, r_buildHall2, D_EXIT).
  514. AddSouthChecker(r_buildHall2, buildCheck, false).
  515. RoomGraphics(r_buildOffice4, "Western", "Office", GUILD_MAP_GROUP, 60, 73,
  516.          drawGuild).
  517. Scenery(r_buildOffice4,
  518.     "wall;vertical,log,stake."
  519.     "band,spike;large,iron."
  520.     "furniture;rough-cut,rough,cut,wood,wooden,varnished."
  521.     "desk;massive."
  522.     "case,gun-case;gun,locked."
  523.     "photograph,relative;small,faded,someone's,distant").
  524.  
  525. define tp_bguild r_buildStairs1 CreateThing(r_indoors).
  526. SetupRoom(r_buildStairs1, "at the top of some stairs",
  527.     "Concrete block walls enclose a small landing here. A drab steel door "
  528.     "opens on the south wall, and dirty metal stairs head down. You can hear "
  529.     "some strange high-pitched noises coming from below.").
  530. Connect(r_buildEntry, r_buildStairs1, D_NORTH).
  531. UniConnect(r_buildStairs1, r_buildEntry, D_EXIT).
  532. RoomGraphics(r_buildStairs1, "Top of", "Stairs", GUILD_MAP_GROUP, 130, 18,
  533.          drawGuild).
  534. Scenery(r_buildStairs1,
  535.     "wall;concrete,block,south."
  536.     "stair;dirty,metal."
  537.     "door;drab,steel").
  538.  
  539. define tp_bguild r_buildStairs2 CreateThing(r_indoors).
  540. SetupRoom(r_buildStairs2, "at the bottom of some stairs",
  541.     "Garbage litters the floor here at the bottom of some rusty metal stairs. "
  542.     "A door in the stained concrete wall leads to the south. You can hear "
  543.     "what sounds like children playing behind it. A sign beside the door "
  544.     "reads \"Playpen - Enter At Own Risk\".").
  545. Connect(r_buildStairs1, r_buildStairs2, D_DOWN).
  546. define tp_bguild o_playpenSign CreateThing(nil).
  547. FakeObject(o_playpenSign, r_buildStairs2, "sign", "").
  548. o_playpenSign@p_oReadString := "\"Playpen - Enter At Own Risk.\"".
  549. Scenery(r_buildStairs2,
  550.     "garbage,litter,floor,door."
  551.     "wall;stained,concrete."
  552.     "stair;rusty,metal").
  553. define tp_bguild proc drawStairsBottom()void:
  554.     GSetPen(nil, C_DARK_BROWN);
  555.     GAMove(nil, 0, 0);
  556.     GRectangle(nil, 159, 99, true);
  557.     GSetPen(nil, C_TAN);
  558.     GAMove(nil, 65, 41);
  559.     GRectangle(nil, 29, 18, false);
  560.     GSetPen(nil, C_BLACK);
  561.     GAMove(nil, 66, 42);
  562.     GRectangle(nil, 27, 16, true);
  563.     GSetPen(nil, C_BROWN);
  564.     GAMove(nil, 75, 59);
  565.     HorizontalDoor();
  566.     DrawUpArrow(C_GOLD);
  567. corp;
  568. AutoGraphics(r_buildStairs2, drawStairsBottom).
  569. RoomName(r_buildStairs2, "Bottom of", "Stairs").
  570.  
  571. define tp_bguild proc enterPlayPen()status:
  572.  
  573.     if PrivateTable() = nil then
  574.     /* Do not let machines in */
  575.     fail
  576.     else
  577.     if not Me()@p_pBuilder then
  578.         setupBuild();
  579.     fi;
  580.     continue
  581.     fi
  582. corp;
  583.  
  584. define tp_bguild proc scanList(list thing lt)void:
  585.     int count, n;
  586.     thing th;
  587.  
  588.     count := Count(lt);
  589.     n := 0;
  590.     while n < count do
  591.     th := lt[n];
  592.     if th@p_oContents ~= nil then
  593.         scanList(th@p_oContents);
  594.     fi;
  595.     if th@p_rPlayPen then
  596.         AddTail(r_playPen@p_rContents, th);
  597.         DelElement(lt, th);
  598.         th -- p_oCarryer;
  599.         th@p_oWhere := r_playPen;
  600.         Print(FormatName(th@p_oName) + " is dropped.\n");
  601.         count := count - 1;
  602.     else
  603.         n := n + 1;
  604.     fi;
  605.     od;
  606. corp;
  607.  
  608. define tp_bguild proc exitPlayPen()status:
  609.     thing me;
  610.  
  611.     me := Me();
  612.     if not me@p_pBuilder then
  613.     clearBuild();
  614.     fi;
  615.     scanList(me@p_pCarrying);
  616.     continue
  617. corp;
  618.  
  619. /* the room 'r_playPen' is created and used in 'build.m' */
  620. SetupRoom(r_playPen, "in the PLAYPEN",
  621.     "This room is the builder's playpen. Anyone can be a builder in here. "
  622.     "This means that you should be careful of any rooms and/or objects you "
  623.     "find in this area, since they may not have been built very carefully! "
  624.     "The way out of the mayhem is to the north.").
  625. SetThingStatus(r_playPen, ts_public).
  626. Connect(r_buildStairs2, r_playPen, D_SOUTH).
  627. Connect(r_buildStairs2, r_playPen, D_ENTER).
  628. AddSouthChecker(r_buildStairs2, enterPlayPen, false).
  629. AddEnterChecker(r_buildStairs2, enterPlayPen, false).
  630. AddNorthChecker(r_playPen, exitPlayPen, false).
  631. AddExitChecker(r_playPen, exitPlayPen, false).
  632. r_playPen@p_rPlayPen := true.
  633. AutoGraphics(r_playPen, AutoClosedRoom).
  634. AutoPens(r_playPen, C_DARK_BROWN, C_CADMIUM_YELLOW, C_BLUE_GREEN, C_ORANGE).
  635.  
  636. define tp_bguild proc questPhotoDesc()string:
  637.  
  638.     "Bring me a photograph of " + Me()@p_pName + "'s whatzit."
  639. corp;
  640.  
  641. define tp_bguild proc questPhotoGive()status:
  642.     thing photo;
  643.  
  644.     photo := It();
  645.     if MatchName(photo@p_oName,
  646.     "whatzit;photograph,of," + TrueMe()@p_pName + "'s") ~= -1
  647.     then
  648.     GiveToQuestor(FormatName(photo@p_oName));
  649.     if Parent(photo) = o_photograph then
  650.         succeed
  651.     else
  652.         SPrint(TrueMe(), "Questor is not impressed.\n");
  653.         fail
  654.     fi
  655.     else
  656.     continue
  657.     fi
  658. corp;
  659.  
  660. define tp_bguild proc questPhotoHint()string:
  661.  
  662.     "They are impossible to find."
  663. corp;
  664.  
  665. QuestGive("Whatzit", questPhotoDesc, questPhotoGive, questPhotoHint).
  666.  
  667. unuse t_streets
  668. unuse tp_bguild
  669.