2 * Copyright (c) 1991, 1993
3 * The Regents of the University of California. All rights reserved.
5 * The game adventure was originally written in Fortran by Will Crowther
6 * and Don Woods. It was later translated to C and enhanced by Jim
7 * Gillogly. This code is derived from software contributed to Berkeley
8 * by Jim Gillogly at The Rand Corporation.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 * 3. All advertising materials mentioning features or use of this software
19 * must display the following acknowledgement:
20 * This product includes software developed by the University of
21 * California, Berkeley and its contributors.
22 * 4. Neither the name of the University nor the names of its contributors
23 * may be used to endorse or promote products derived from this software
24 * without specific prior written permission.
26 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
27 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
29 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
30 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
31 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
32 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
33 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
34 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
35 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 * @(#) Copyright (c) 1991, 1993 The Regents of the University of California. All rights reserved.
39 * @(#)main.c 8.1 (Berkeley) 6/2/93
40 * $FreeBSD: src/games/adventure/main.c,v 1.9.2.1 2001/03/05 11:43:11 kris Exp $
41 * $DragonFly: src/games/adventure/main.c,v 1.3 2005/03/25 12:56:48 liamfoy Exp $
44 /* Re-coding of advent in C: main program */
48 #include <sys/types.h>
58 main(int argc, char **argv)
67 init(); /* Initialize everything */
68 signal(SIGINT,trapdel);
70 if (argc > 1) /* Restore file specified */
71 { /* Restart is label 8305 (Fortran) */
72 i = restore(argv[1]); /* See what we've got */
75 case 0: /* The restore worked fine */
78 unlink(argv[1]);/* Don't re-use the save */
79 goto l8; /* Get where we're going */
80 case 1: /* Couldn't open it */
81 exit(1); /* So give up */
82 case 2: /* Oops -- file was altered */
83 rspeak(202); /* You dissolve */
84 exit(1); /* File could be non-adventure */
85 } /* So don't unlink it. */
88 startup(); /* prepare for a user */
90 for (;;) /* main command loop (label 2) */
91 { if (newloc<9 && newloc!=0 && closng)
92 { rspeak(130); /* if closing leave only by */
93 newloc=loc; /* main office */
94 if (!panic) clock2=15;
98 rval=fdwarf(); /* dwarf stuff */
99 if (rval==99) die(99);
101 l2000: if (loc==0) die(99); /* label 2000 */
103 if ((abb[loc]%abbnum)==0 || kk->seekadr==0)
105 if (!forced(loc) && dark())
106 { if (wzdark && pct(35))
112 if (toting(bear)) rspeak(141); /* 2001 */
117 if (loc==33 && pct(25)&&!closng) rspeak(8);
120 for (i=atloc[loc]; i!=0; i=linkx[i]) /*2004 */
122 if (obj>100) obj -= 100;
123 if (obj==steps && toting(nugget)) continue;
125 { if (closed) continue;
127 if (obj==rug||obj==chain)
130 if (tally==tally2 && tally != 0)
131 if (limit>35) limit=35;
133 ll = prop[obj]; /* 2006 */
134 if (obj==steps && loc==fixed[steps])
139 l2009: k=54; /* 2009 */
143 l2012: verb=0; /* 2012 */
145 l2600: checkhints(); /* to 2600-2602 */
147 { if (prop[oyster]<0 && toting(oyster))
149 for (i=1; i<100; i++)
150 if (toting(i)&&prop[i]<0) /*2604 */
151 prop[i] = -1-prop[i];
153 wzdark=dark(); /* 2605 */
154 if (knfloc>0 && knfloc!=loc) knfloc=1;
156 if (delhit) /* user typed a DEL */
157 { delhit=0; /* reset counter */
158 strcpy(wd1,"quit"); /* pretend he's quitting*/
161 l2608: if ((foobar = -foobar)>0) foobar=0; /* 2608 */
162 /* should check here for "magic mode" */
164 if (demo && turns>=SHORT) done(1); /* to 13000 */
166 if (verb==say && *wd2!=0) verb=0;
169 if (tally==0 && loc>=15 && loc!=33) clock1--;
171 { closing(); /* to 10000 */
174 if (clock1<0) clock2--;
176 { caveclose(); /* to 11000 */
177 continue; /* back to 2 */
179 if (prop[lamp]==1) limit--;
180 if (limit<=30 && here(batter) && prop[batter]==0
182 { rspeak(188); /* 12000 */
184 if (toting(batter)) drop(batter,loc);
190 { limit = -1; /* 12400 */
196 { rspeak(185); /* 12600 */
198 done(2); /* to 20000 */
201 { if (lmwarn|| !here(lamp)) goto l19999; /*12200*/
204 if (place[batter]==0) spk=183;
205 if (prop[batter]==1) spk=189;
209 if (liqloc(loc)==water) k=70;
210 if (!strncmp(wd1,"enter",5) &&
211 (!strncmp(wd2,"strea",5)||!strncmp(wd2,"water",5)))
213 if (!strncmp(wd1,"enter",5) && *wd2!=0) goto l2800;
214 if ((strncmp(wd1,"water",5)&&strncmp(wd1,"oil",3))
215 || (strncmp(wd2,"plant",5)&&strncmp(wd2,"door",4)))
217 if (at(vocab(wd2,1,0))) strcpy(wd2,"pour");
219 l2610: if (!strncmp(wd1,"west",4))
220 if (++iwest==10) rspeak(17);
221 l2630: i=vocab(wd1,-1,0);
242 { case 2: continue; /* i.e. goto l2 */
249 l2800: strcpy(wd1,wd2);
255 if (*wd2!=0 && verb!=say) goto l2800;
256 if (verb==say) obj= *wd2;
257 if (obj!=0) goto l4090;
259 { case 1: /* take = 8010 */
260 if (atloc[loc]==0||linkx[atloc[loc]]!=0) goto l8000;
262 if (dloc[i]==loc&&dflag>=2) goto l8000;
265 case 2: case 3: case 9: /* 8000 : drop,say,wave */
266 case 10: case 16: case 17: /* calm,rub,toss */
267 case 19: case 21: case 28: /* find,feed,break */
269 l8000: printf("%s what?\n",wd1);
272 case 4: case 6: /* 8040 open,lock */
274 if (here(clam)) obj=clam;
275 if (here(oyster)) obj=oyster;
276 if (at(door)) obj=door;
277 if (at(grate)) obj=grate;
278 if (obj!=0 && here(chain)) goto l8000;
279 if (here(chain)) obj=chain;
280 if (obj==0) goto l2011;
282 case 5: goto l2009; /* nothing */
283 case 7: goto l9070; /* on */
284 case 8: goto l9080; /* off */
285 case 11: goto l8000; /* walk */
286 case 12: goto l9120; /* kill */
287 case 13: goto l9130; /* pour */
288 case 14: /* eat: 8140 */
289 if (!here(food)) goto l8000;
293 case 15: goto l9150; /* drink */
294 case 18: /* quit: 8180 */
295 gaveup=yes(22,54,54);
296 if (gaveup) done(2); /* 8185 */
298 case 20: /* invent=8200 */
300 for (i=1; i<=100; i++)
301 { if (i!=bear && toting(i))
302 { if (spk==98) rspeak(99);
309 if (toting(bear)) spk=141;
311 case 22: goto l9220; /* fill */
312 case 23: goto l9230; /* blast */
313 case 24: /* score: 8240 */
315 printf("If you were to quit now, you would score");
316 printf(" %d out of a possible ",score());
317 printf("%d.",mxscor);
319 gaveup=yes(143,54,54);
322 case 25: /* foo: 8250 */
325 if (foobar==1-k) goto l8252;
326 if (foobar!=0) spk=151;
329 if (k!=4) goto l2009;
331 if (place[eggs]==plac[eggs]
332 ||(toting(eggs)&&loc==plac[eggs])) goto l2011;
333 if (place[eggs]==0&&place[troll]==0&&prop[troll]==0)
337 if (loc==plac[eggs]) k=0;
338 move(eggs,plac[eggs]);
341 case 26: /* brief=8260 */
346 case 27: /* read=8270 */
347 if (here(magzin)) obj=magzin;
348 if (here(tablet)) obj=obj*100+tablet;
349 if (here(messag)) obj=obj*100+messag;
350 if (closed&&toting(oyster)) obj=oyster;
351 if (obj>100||obj==0||dark()) goto l8000;
353 case 30: /* suspend=8300 */
355 if (demo) goto l2011;
356 printf("I can suspend your adventure for you so");
357 printf(" you can resume later, but\n");
358 printf("you will have to wait at least");
359 printf(" %d minutes before continuing.",latncy);
360 if (!yes(200,54,54)) goto l2012;
361 datime(&saved,&savet);
362 ciao(); /* Do we quit? */
363 continue; /* Maybe not */
364 case 31: /* hours=8310 */
365 printf("Colossal cave is closed 9am-5pm Mon ");
366 printf("through Fri except holidays.\n");
373 { case 1: /* take = 9010 */
374 l9010: switch(trtake())
375 { case 2011: goto l2011;
376 case 9220: goto l9220;
377 case 2009: goto l2009;
378 case 2012: goto l2012;
381 l9020: case 2: /* drop = 9020 */
383 { case 2011: goto l2011;
385 case 2012: goto l2012;
390 { case 2012: goto l2012;
391 case 2630: goto l2630;
394 l9040: case 4: case 6: /* open, close */
396 { case 2011: goto l2011;
397 case 2010: goto l2010;
400 case 5: goto l2009; /* nothing */
401 case 7: /* on 9070 */
402 l9070: if (!here(lamp)) goto l2011;
404 if (limit<0) goto l2011;
407 if (wzdark) goto l2000;
411 l9080: if (!here(lamp)) goto l2011;
414 if (dark()) rspeak(16);
418 if ((!toting(obj))&&(obj!=rod||!toting(rod2)))
420 if (obj!=rod||!at(fissur)||!toting(obj)||closng)
422 prop[fissur]=1-prop[fissur];
423 pspeak(fissur,2-prop[fissur]);
425 case 10: case 11: case 18: /* calm, walk, quit */
426 case 24: case 25: case 26: /* score, foo, brief */
427 case 30: case 31: /* suspend, hours */
429 l9120: case 12: /* kill */
431 { case 8000: goto l8000;
433 case 2011: goto l2011;
434 case 2608: goto l2608;
438 l9130: case 13: /* pour */
439 if (obj==bottle||obj==0) obj=liq();
440 if (obj==0) goto l8000;
441 if (!toting(obj)) goto l2011;
443 if (obj!=oil&&obj!=water) goto l2011;
447 if (!(at(plant)||at(door))) goto l2011;
449 { prop[door]=0; /* 9132 */
450 if (obj==oil) prop[door]=1;
455 if (obj!=water) goto l2011;
456 pspeak(plant,prop[plant]+1);
457 prop[plant]=(prop[plant]+2)% 6;
458 prop[plant2]=prop[plant]/2;
461 case 14: /* 9140 - eat */
462 if (obj==food) goto l8142;
463 if (obj==bird||obj==snake||obj==clam||obj==oyster
464 ||obj==dwarf||obj==dragon||obj==troll
467 l9150: case 15: /* 9150 - drink */
468 if (obj==0&&liqloc(loc)!=water&&(liq()!=water
469 ||!here(bottle))) goto l8000;
470 if (obj!=0&&obj!=water) spk=110;
471 if (spk==110||liq()!=water||!here(bottle))
477 case 16: /* 9160: rub */
478 if (obj!=lamp) spk=76;
480 case 17: /* 9170: throw */
482 { case 2011: goto l2011;
483 case 9020: goto l9020;
484 case 9120: goto l9120;
486 case 9210: goto l9210;
489 case 19: case 20: /* 9190: find, invent */
490 if (at(obj)||(liq()==obj&&at(bottle))
491 ||k==liqloc(loc)) spk=94;
493 if (dloc[i]==loc&&dflag>=2&&obj==dwarf)
496 if (toting(obj)) spk=24;
498 l9210: case 21: /* feed */
500 { case 2011: goto l2011;
503 l9220: case 22: /* fill */
505 { case 2011: goto l2011;
506 case 8000: goto l8000;
507 case 9020: goto l9020;
510 l9230: case 23: /* blast */
511 if (prop[rod2]<0||!closed) goto l2011;
513 if (loc==115) bonus=134;
514 if (here(rod2)) bonus=135;
517 l9270: case 27: /* read */
518 if (dark()) goto l5190;
519 if (obj==magzin) spk=190;
520 if (obj==tablet) spk=196;
521 if (obj==messag) spk=191;
522 if (obj==oyster&&hinted[2]&&toting(oyster)) spk=194;
523 if (obj!=oyster||hinted[2]||!toting(oyster)
524 ||!closed) goto l2011;
525 hinted[2]=yes(192,193,54);
528 if (obj==mirror) spk=148;
529 if (obj==vase&&prop[vase]==0)
531 if (toting(vase)) drop(vase,loc);
536 if (obj!=mirror||!closed) goto l2011;
541 if (obj!=dwarf||!closed) goto l2011;
550 if (fixed[k]!=loc && !here(k)) goto l5100;
551 l5010: if (*wd2!=0) goto l2800;
552 if (verb!=0) goto l4090;
553 printf("What do you want to do with the %s?\n",wd1);
555 l5100: if (k!=grate) goto l5110;
556 if (loc==1||loc==4||loc==7) k=dprssn;
557 if (loc>9&&loc<15) k=entrnc;
558 if (k!=grate) goto l8;
559 l5110: if (k!=dwarf) goto l5120;
561 if (dloc[i]==loc&&dflag>=2) goto l5010;
562 l5120: if ((liq()==k&&here(bottle))||k==liqloc(loc)) goto l5010;
563 if (obj!=plant||!at(plant2)||prop[plant2]==0) goto l5130;
566 l5130: if (obj!=knife||knfloc!=loc) goto l5140;
570 l5140: if (obj!=rod||!here(rod2)) goto l5190;
573 l5190: if ((verb==find||verb==invent)&&*wd2==0) goto l5010;
574 printf("I see no %s here\n",wd1);