Merge from vendor branch BSDTAR:
[dragonfly.git] / games / adventure / wizard.c
1 /*-
2  * Copyright (c) 1991, 1993
3  *      The Regents of the University of California.  All rights reserved.
4  *
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.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
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.
25  *
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
36  * SUCH DAMAGE.
37  *
38  * @(#)wizard.c 8.1 (Berkeley) 6/2/93
39  * $FreeBSD: src/games/adventure/wizard.c,v 1.10.2.1 2001/03/05 11:43:11 kris Exp $
40  * $DragonFly: src/games/adventure/wizard.c,v 1.2 2003/06/17 04:25:22 dillon Exp $
41  */
42
43 /*      Re-coding of advent in C: privileged operations                 */
44
45 #include <sys/types.h>
46 #include <stdio.h>
47 #include <stdlib.h>
48 #include <string.h>
49 #include <time.h>
50 #include <sys/cdefs.h>
51 #include "hdr.h"
52
53 static int wizard (void);
54
55 void
56 datime(d,t)
57 int *d,*t;
58 {       struct tm *tptr;
59         time_t tvec;
60
61         time(&tvec);
62         tptr=localtime(&tvec);
63         /* day since 1977 */
64         *d = (tptr->tm_yday + 365 * (tptr->tm_year - 77)
65                 + (tptr->tm_year - 77) / 4 - (tptr->tm_year - 1) / 100
66                 + (tptr->tm_year + 299) / 400);
67         /* bug: this will overflow in the year 2066 AD (with 16 bit int) */
68         /* it will be attributed to Wm the C's millenial celebration    */
69         /* and minutes since midnite */
70         *t=tptr->tm_hour*60+tptr->tm_min;
71 }
72
73
74 char magic[6];
75
76 void
77 poof()
78 {
79         strcpy(magic, DECR(d,w,a,r,f));
80         latncy = 45;
81 }
82
83 int
84 Start()
85 {       int d,t,delay;
86
87         datime(&d,&t);
88         delay=(d-saved)*1440+(t-savet); /* good for about a month     */
89
90         if (delay >= latncy)
91         {       saved = -1;
92                 return(FALSE);
93         }
94         printf("This adventure was suspended a mere %d minute%s ago.",
95                 delay, delay == 1? "" : "s");
96         if (delay <= latncy/3)
97         {       mspeak(2);
98                 exit(0);
99         }
100         mspeak(8);
101         if (!wizard())
102         {       mspeak(9);
103                 exit(0);
104         }
105         saved = -1;
106         return(FALSE);
107 }
108
109 static int
110 wizard()                /* not as complex as advent/10 (for now)        */
111 {
112         char *word,*x;
113         if (!yesm(16,0,7)) return(FALSE);
114         mspeak(17);
115         getin(&word,&x);
116         if (strncmp(word,magic,5))
117         {       mspeak(20);
118                 return(FALSE);
119         }
120         mspeak(19);
121         return(TRUE);
122 }
123
124 void
125 ciao()
126 {       char *c;
127         char fname[80];
128
129         printf("What would you like to call the saved version?\n");
130         /* XXX - should use fgetln to avoid arbitrary limit */
131         for (c = fname; c < fname + sizeof fname - 1; c++) {
132                 int ch;
133                 ch = getchar();
134                 if (ch == '\n' || ch == EOF)
135                         break;
136                 *c = ch;
137         }
138         *c=0;
139         if (save(fname) != 0) return;           /* Save failed */
140         printf("To resume, say \"adventure %s\".\n", fname);
141         printf("\"With these rooms I might now have been familiarly acquainted.\"\n");
142         exit(0);
143 }
144
145
146 int
147 ran(range)
148 int range;
149 {
150         int i;
151
152         i = random() % range;
153         return(i);
154 }