Home | History | Annotate | Line # | Download | only in trek
main.c revision 1.3
      1  1.1      cgd /*
      2  1.1      cgd  * Copyright (c) 1980 Regents of the University of California.
      3  1.1      cgd  * All rights reserved.
      4  1.1      cgd  *
      5  1.1      cgd  * Redistribution and use in source and binary forms, with or without
      6  1.1      cgd  * modification, are permitted provided that the following conditions
      7  1.1      cgd  * are met:
      8  1.1      cgd  * 1. Redistributions of source code must retain the above copyright
      9  1.1      cgd  *    notice, this list of conditions and the following disclaimer.
     10  1.1      cgd  * 2. Redistributions in binary form must reproduce the above copyright
     11  1.1      cgd  *    notice, this list of conditions and the following disclaimer in the
     12  1.1      cgd  *    documentation and/or other materials provided with the distribution.
     13  1.1      cgd  * 3. All advertising materials mentioning features or use of this software
     14  1.1      cgd  *    must display the following acknowledgement:
     15  1.1      cgd  *	This product includes software developed by the University of
     16  1.1      cgd  *	California, Berkeley and its contributors.
     17  1.1      cgd  * 4. Neither the name of the University nor the names of its contributors
     18  1.1      cgd  *    may be used to endorse or promote products derived from this software
     19  1.1      cgd  *    without specific prior written permission.
     20  1.1      cgd  *
     21  1.1      cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     22  1.1      cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     23  1.1      cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     24  1.1      cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     25  1.1      cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     26  1.1      cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     27  1.1      cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     28  1.1      cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     29  1.1      cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     30  1.1      cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     31  1.1      cgd  * SUCH DAMAGE.
     32  1.1      cgd  */
     33  1.1      cgd 
     34  1.1      cgd #ifndef lint
     35  1.1      cgd char copyright[] =
     36  1.1      cgd "@(#) Copyright (c) 1980 Regents of the University of California.\n\
     37  1.1      cgd  All rights reserved.\n";
     38  1.1      cgd #endif /* not lint */
     39  1.1      cgd 
     40  1.1      cgd #ifndef lint
     41  1.2  mycroft /*static char sccsid[] = "from: @(#)main.c	5.7 (Berkeley) 2/28/91";*/
     42  1.3      jtc static char rcsid[] = "$Id: main.c,v 1.3 1994/05/24 23:54:17 jtc Exp $";
     43  1.1      cgd #endif /* not lint */
     44  1.1      cgd 
     45  1.1      cgd # include	"trek.h"
     46  1.1      cgd # include	<stdio.h>
     47  1.1      cgd # include	<setjmp.h>
     48  1.3      jtc # include	<termios.h>
     49  1.1      cgd 
     50  1.1      cgd # define	PRIO		00	/* default priority */
     51  1.1      cgd 
     52  1.1      cgd int	Mother	= 51 + (51 << 8);
     53  1.1      cgd 
     54  1.1      cgd /*
     55  1.1      cgd **	 ####  #####    #    ####          #####  ####   #####  #   #
     56  1.1      cgd **	#        #     # #   #   #           #    #   #  #      #  #
     57  1.1      cgd **	 ###     #    #####  ####            #    ####   ###    ###
     58  1.1      cgd **	    #    #    #   #  #  #            #    #  #   #      #  #
     59  1.1      cgd **	####     #    #   #  #   #           #    #   #  #####  #   #
     60  1.1      cgd **
     61  1.1      cgd **	C version by Eric P. Allman 5/76 (U.C. Berkeley) with help
     62  1.1      cgd **		from Jeff Poskanzer and Pete Rubinstein.
     63  1.1      cgd **
     64  1.1      cgd **	I also want to thank everyone here at Berkeley who
     65  1.1      cgd **	where crazy enough to play the undebugged game.  I want to
     66  1.1      cgd **	particularly thank Nick Whyte, who made considerable
     67  1.1      cgd **	suggestions regarding the content of the game.  Why, I'll
     68  1.1      cgd **	never forget the time he suggested the name for the
     69  1.1      cgd **	"capture" command.
     70  1.1      cgd **
     71  1.1      cgd **	Please send comments, questions, and suggestions about this
     72  1.1      cgd **		game to:
     73  1.1      cgd **			Eric P. Allman
     74  1.1      cgd **			Project INGRES
     75  1.1      cgd **			Electronics Research Laboratory
     76  1.1      cgd **			Cory Hall
     77  1.1      cgd **			University of California
     78  1.1      cgd **			Berkeley, California  94720
     79  1.1      cgd **
     80  1.1      cgd **	If you make ANY changes in the game, I sure would like to
     81  1.1      cgd **	know about them.  It is sort of an ongoing project for me,
     82  1.1      cgd **	and I very much want to put in any bug fixes and improvements
     83  1.1      cgd **	that you might come up with.
     84  1.1      cgd **
     85  1.1      cgd **	FORTRASH version by Kay R. Fisher (DEC) "and countless others".
     86  1.1      cgd **	That was adapted from the "original BASIC program" (ha!) by
     87  1.1      cgd **		Mike Mayfield (Centerline Engineering).
     88  1.1      cgd **
     89  1.1      cgd **	Additional inspiration taken from FORTRAN version by
     90  1.1      cgd **		David Matuszek and Paul Reynolds which runs on the CDC
     91  1.1      cgd **		7600 at Lawrence Berkeley Lab, maintained there by
     92  1.1      cgd **		Andy Davidson.  This version is also available at LLL
     93  1.1      cgd **		and at LMSC.  In all fairness, this version was the
     94  1.1      cgd **		major inspiration for this version of the game (trans-
     95  1.1      cgd **		lation:  I ripped off a whole lot of code).
     96  1.1      cgd **
     97  1.1      cgd **	Minor other input from the "Battelle Version 7A" by Joe Miller
     98  1.1      cgd **		(Graphics Systems Group, Battelle-Columbus Labs) and
     99  1.1      cgd **		Ross Pavlac (Systems Programmer, Battelle Memorial
    100  1.1      cgd **		Institute).  That version was written in December '74
    101  1.1      cgd **		and extensively modified June '75.  It was adapted
    102  1.1      cgd **		from the FTN version by Ron Williams of CDC Sunnyvale,
    103  1.1      cgd **		which was adapted from the Basic version distributed
    104  1.1      cgd **		by DEC.  It also had "neat stuff swiped" from T. T.
    105  1.1      cgd **		Terry and Jim Korp (University of Texas), Hicks (Penn
    106  1.1      cgd **		U.), and Rick Maus (Georgia Tech).  Unfortunately, it
    107  1.1      cgd **		was not as readable as it could have been and so the
    108  1.1      cgd **		translation effort was severely hampered.  None the
    109  1.1      cgd **		less, I got the idea of inhabited starsystems from this
    110  1.1      cgd **		version.
    111  1.1      cgd **
    112  1.1      cgd **	Permission is given for use, copying, and modification of
    113  1.1      cgd **		all or part of this program and related documentation,
    114  1.1      cgd **		provided that all reference to the authors are maintained.
    115  1.1      cgd **
    116  1.1      cgd **
    117  1.1      cgd **********************************************************************
    118  1.1      cgd **
    119  1.1      cgd **  NOTES TO THE MAINTAINER:
    120  1.1      cgd **
    121  1.1      cgd **	There is a compilation option xTRACE which must be set for any
    122  1.1      cgd **	trace information to be generated.  It is probably defined in
    123  1.1      cgd **	the version that you get.  It can be removed, however, if you
    124  1.1      cgd **	have trouble finding room in core.
    125  1.1      cgd **
    126  1.1      cgd **	Many things in trek are not as clear as they might be, but are
    127  1.1      cgd **	done to reduce space.  I compile with the -f and -O flags.  I
    128  1.1      cgd **	am constrained to running with non-seperated I/D space, since
    129  1.1      cgd **	we don't have doubleing point hardware here; even if we did, I
    130  1.1      cgd **	would like trek to be available to the large number of people
    131  1.1      cgd **	who either have an 11/40 or do not have FP hardware.  I also
    132  1.1      cgd **	found it desirable to make the code run reentrant, so this
    133  1.1      cgd **	added even more space constraints.
    134  1.1      cgd **
    135  1.1      cgd **	I use the portable C library to do my I/O.  This is done be-
    136  1.1      cgd **	cause I wanted the game easily transportable to other C
    137  1.1      cgd **	implementations, and because I was too lazy to do the doubleing
    138  1.1      cgd **	point input myself.  Little did I know.  The portable C library
    139  1.1      cgd **	released by Bell Labs has more bugs than you would believe, so
    140  1.1      cgd **	I ended up rewriting the whole blessed thing.  Trek excercises
    141  1.1      cgd **	many of the bugs in it, as well as bugs in some of the section
    142  1.1      cgd **	III UNIX routines.  We have fixed them here.  One main problem
    143  1.1      cgd **	was a bug in alloc() that caused it to always ask for a large
    144  1.1      cgd **	hunk of memory, which worked fine unless you were almost out,
    145  1.1      cgd **	which I inevitably was.  If you want the code for all of this
    146  1.1      cgd **	stuff, it is also available through me.
    147  1.1      cgd **
    148  1.1      cgd ***********************************************************************
    149  1.1      cgd */
    150  1.1      cgd 
    151  1.1      cgd jmp_buf env;
    152  1.1      cgd 
    153  1.1      cgd main(argc, argv)
    154  1.1      cgd int	argc;
    155  1.1      cgd char	**argv;
    156  1.1      cgd {
    157  1.1      cgd 	long			vect;
    158  1.1      cgd 	/* extern FILE		*f_log; */
    159  1.1      cgd 	register char		opencode;
    160  1.1      cgd 	int			prio;
    161  1.1      cgd 	register int		ac;
    162  1.1      cgd 	register char		**av;
    163  1.3      jtc 	struct	termios		argp;
    164  1.1      cgd 
    165  1.1      cgd 	av = argv;
    166  1.1      cgd 	ac = argc;
    167  1.1      cgd 	av++;
    168  1.1      cgd 	time(&vect);
    169  1.1      cgd 	srand(vect);
    170  1.1      cgd 	opencode = 'w';
    171  1.1      cgd 	prio = PRIO;
    172  1.3      jtc 
    173  1.3      jtc 	if (tcgetattr(1, &argp) == 0)
    174  1.1      cgd 	{
    175  1.3      jtc 		if (cfgetispeed(&argp) < B1200)
    176  1.1      cgd 			Etc.fast++;
    177  1.1      cgd 	}
    178  1.3      jtc 
    179  1.1      cgd 	while (ac > 1 && av[0][0] == '-')
    180  1.1      cgd 	{
    181  1.1      cgd 		switch (av[0][1])
    182  1.1      cgd 		{
    183  1.1      cgd 		  case 'a':	/* append to log file */
    184  1.1      cgd 			opencode = 'a';
    185  1.1      cgd 			break;
    186  1.1      cgd 
    187  1.1      cgd 		  case 'f':	/* set fast mode */
    188  1.1      cgd 			Etc.fast++;
    189  1.1      cgd 			break;
    190  1.1      cgd 
    191  1.1      cgd 		  case 's':	/* set slow mode */
    192  1.1      cgd 			Etc.fast = 0;
    193  1.1      cgd 			break;
    194  1.1      cgd 
    195  1.1      cgd #		ifdef xTRACE
    196  1.1      cgd 		  case 't':	/* trace */
    197  1.1      cgd 			if (getuid() != Mother)
    198  1.1      cgd 				goto badflag;
    199  1.1      cgd 			Trace++;
    200  1.1      cgd 			break;
    201  1.1      cgd #		endif
    202  1.1      cgd 
    203  1.1      cgd 		  case 'p':	/* set priority */
    204  1.1      cgd 			if (getuid() != Mother)
    205  1.1      cgd 				goto badflag;
    206  1.1      cgd 			prio = atoi(av[0] + 2);
    207  1.1      cgd 			break;
    208  1.1      cgd 
    209  1.1      cgd 		  default:
    210  1.1      cgd 		  badflag:
    211  1.1      cgd 			printf("Invalid option: %s\n", av[0]);
    212  1.1      cgd 
    213  1.1      cgd 		}
    214  1.1      cgd 		ac--;
    215  1.1      cgd 		av++;
    216  1.1      cgd 	}
    217  1.1      cgd 	if (ac > 2)
    218  1.1      cgd 		syserr(0, "arg count");
    219  1.1      cgd 		/*
    220  1.1      cgd 	if (ac > 1)
    221  1.1      cgd 		f_log = fopen(av[0], opencode);
    222  1.1      cgd 		*/
    223  1.1      cgd 
    224  1.1      cgd 	printf("\n   * * *   S T A R   T R E K   * * *\n\nPress return to continue.\n");
    225  1.1      cgd 
    226  1.1      cgd 	if (setjmp(env))
    227  1.1      cgd 	{
    228  1.1      cgd 		if ( !getynpar("Another game") )
    229  1.1      cgd 			exit(0);
    230  1.1      cgd 	}
    231  1.1      cgd 	do
    232  1.1      cgd 	{
    233  1.1      cgd 		setup();
    234  1.1      cgd 		play();
    235  1.1      cgd 	} while (getynpar("Another game"));
    236  1.1      cgd 
    237  1.1      cgd 	fflush(stdout);
    238  1.1      cgd }
    239