Home | History | Annotate | Line # | Download | only in battlestar
      1  1.16  dholland /*	$NetBSD: init.c,v 1.16 2014/03/22 23:33:33 dholland Exp $	*/
      2   1.4       cgd 
      3   1.1       cgd /*
      4   1.4       cgd  * Copyright (c) 1983, 1993
      5   1.4       cgd  *	The Regents of the University of California.  All rights reserved.
      6   1.1       cgd  *
      7   1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8   1.1       cgd  * modification, are permitted provided that the following conditions
      9   1.1       cgd  * are met:
     10   1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11   1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12   1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13   1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14   1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15  1.13       agc  * 3. Neither the name of the University nor the names of its contributors
     16   1.1       cgd  *    may be used to endorse or promote products derived from this software
     17   1.1       cgd  *    without specific prior written permission.
     18   1.1       cgd  *
     19   1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20   1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21   1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22   1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23   1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24   1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25   1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26   1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27   1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28   1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29   1.1       cgd  * SUCH DAMAGE.
     30   1.1       cgd  */
     31   1.1       cgd 
     32   1.6     lukem #include <sys/cdefs.h>
     33   1.1       cgd #ifndef lint
     34   1.4       cgd #if 0
     35   1.5       tls static char sccsid[] = "@(#)init.c	8.4 (Berkeley) 4/30/95";
     36   1.4       cgd #else
     37  1.16  dholland __RCSID("$NetBSD: init.c,v 1.16 2014/03/22 23:33:33 dholland Exp $");
     38   1.4       cgd #endif
     39   1.7     lukem #endif				/* not lint */
     40   1.1       cgd 
     41   1.5       tls #include "extern.h"
     42   1.1       cgd 
     43  1.14       jsm static int checkout(const char *);
     44  1.14       jsm static const char *getutmp(void);
     45  1.14       jsm static int wizard(const char *);
     46  1.12       jsm 
     47   1.6     lukem void
     48  1.15       jmc initialize(const char *filename)
     49   1.1       cgd {
     50   1.8   hubertf 	const struct objs *p;
     51   1.9   hubertf 	char *savefile;
     52   1.1       cgd 
     53   1.1       cgd 	puts("Version 4.2, fall 1984.");
     54   1.1       cgd 	puts("First Adventure game written by His Lordship, the honorable");
     55   1.1       cgd 	puts("Admiral D.W. Riggle\n");
     56   1.5       tls 	location = dayfile;
     57  1.16  dholland 	srandom(time(NULL));
     58  1.12       jsm 	username = getutmp();
     59   1.1       cgd 	wordinit();
     60   1.9   hubertf 	if (filename == NULL) {
     61   1.1       cgd 		direction = NORTH;
     62   1.6     lukem 		ourtime = 0;
     63   1.1       cgd 		snooze = CYCLE * 1.5;
     64   1.1       cgd 		position = 22;
     65   1.1       cgd 		setbit(wear, PAJAMAS);
     66   1.1       cgd 		fuel = TANKFULL;
     67   1.1       cgd 		torps = TORPEDOES;
     68   1.1       cgd 		for (p = dayobjs; p->room != 0; p++)
     69   1.1       cgd 			setbit(location[p->room].objects, p->obj);
     70   1.9   hubertf 	} else {
     71   1.9   hubertf 		savefile = save_file_name(filename, strlen(filename));
     72   1.9   hubertf 		restore(savefile);
     73   1.9   hubertf 		free(savefile);
     74   1.9   hubertf 	}
     75  1.10       jsm 	wiz = wizard(username);
     76   1.6     lukem 	signal(SIGINT, diesig);
     77   1.1       cgd }
     78   1.1       cgd 
     79  1.12       jsm static const char *
     80  1.15       jmc getutmp(void)
     81   1.1       cgd {
     82   1.1       cgd 	struct passwd *ptr;
     83   1.1       cgd 
     84   1.1       cgd 	ptr = getpwuid(getuid());
     85  1.12       jsm 	if (ptr == NULL)
     86  1.12       jsm 		return "";
     87  1.12       jsm 	else
     88  1.12       jsm 		return strdup(ptr->pw_name);
     89   1.1       cgd }
     90   1.1       cgd 
     91  1.12       jsm /* Hereditary wizards.  A configuration file might make more sense. */
     92  1.12       jsm static const char *const list[] = {
     93   1.1       cgd 	"riggle",
     94   1.1       cgd 	"chris",
     95   1.1       cgd 	"edward",
     96   1.1       cgd 	"comay",
     97   1.1       cgd 	"yee",
     98   1.1       cgd 	"dmr",
     99   1.1       cgd 	"ken",
    100   1.1       cgd 	0
    101   1.1       cgd };
    102   1.1       cgd 
    103  1.12       jsm static const char *const badguys[] = {
    104   1.1       cgd 	"wnj",
    105   1.1       cgd 	"root",
    106   1.1       cgd 	"ted",
    107   1.1       cgd 	0
    108   1.1       cgd };
    109   1.1       cgd 
    110  1.12       jsm static int
    111  1.15       jmc wizard(const char *uname)
    112   1.1       cgd {
    113   1.7     lukem 	int     flag;
    114   1.1       cgd 
    115   1.6     lukem 	if ((flag = checkout(uname)) != 0)
    116   1.1       cgd 		printf("You are the Great wizard %s.\n", uname);
    117   1.1       cgd 	return flag;
    118   1.1       cgd }
    119   1.1       cgd 
    120  1.12       jsm static int
    121  1.15       jmc checkout(const char *uname)
    122   1.1       cgd {
    123   1.8   hubertf 	const char  *const *ptr;
    124   1.1       cgd 
    125   1.1       cgd 	for (ptr = list; *ptr; ptr++)
    126   1.1       cgd 		if (strcmp(*ptr, uname) == 0)
    127   1.1       cgd 			return 1;
    128   1.1       cgd 	for (ptr = badguys; *ptr; ptr++)
    129   1.1       cgd 		if (strcmp(*ptr, uname) == 0) {
    130   1.1       cgd 			printf("You are the Poor anti-wizard %s.  Good Luck!\n",
    131   1.7     lukem 			    uname);
    132   1.1       cgd 			CUMBER = 3;
    133   1.1       cgd 			WEIGHT = 9;	/* that'll get him! */
    134   1.6     lukem 			ourclock = 10;
    135   1.1       cgd 			setbit(location[7].objects, WOODSMAN);	/* viper room */
    136   1.1       cgd 			setbit(location[20].objects, WOODSMAN);	/* laser " */
    137   1.1       cgd 			setbit(location[13].objects, DARK);	/* amulet " */
    138   1.1       cgd 			setbit(location[8].objects, ELF);	/* closet */
    139   1.1       cgd 			return 0;	/* anything else, Chris? */
    140   1.1       cgd 		}
    141   1.1       cgd 	return 0;
    142   1.1       cgd }
    143