xref: /netbsd/games/trek/score.c (revision bf9ec67e)
1 /*	$NetBSD: score.c,v 1.4 1997/10/12 21:25:13 christos Exp $	*/
2 
3 /*
4  * Copyright (c) 1980, 1993
5  *	The Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the following acknowledgement:
17  *	This product includes software developed by the University of
18  *	California, Berkeley and its contributors.
19  * 4. Neither the name of the University nor the names of its contributors
20  *    may be used to endorse or promote products derived from this software
21  *    without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  * SUCH DAMAGE.
34  */
35 
36 #include <sys/cdefs.h>
37 #ifndef lint
38 #if 0
39 static char sccsid[] = "@(#)score.c	8.1 (Berkeley) 5/31/93";
40 #else
41 __RCSID("$NetBSD: score.c,v 1.4 1997/10/12 21:25:13 christos Exp $");
42 #endif
43 #endif /* not lint */
44 
45 #include <stdio.h>
46 #include "trek.h"
47 #include "getpar.h"
48 
49 /*
50 **  PRINT OUT THE CURRENT SCORE
51 */
52 
53 long score()
54 {
55 	int		u;
56 	int		t;
57 	long		s;
58 	double		r;
59 
60 	printf("\n*** Your score:\n");
61 	s = t = Param.klingpwr / 4 * (u = Game.killk);
62 	if (t != 0)
63 		printf("%d Klingons killed\t\t\t%6d\n", u, t);
64 	r = Now.date - Param.date;
65 	if (r < 1.0)
66 		r = 1.0;
67 	r = Game.killk / r;
68 	s += (t = 400 * r);
69 	if (t != 0)
70 		printf("Kill rate %.2f Klingons/stardate  \t%6d\n", r, t);
71 	r = Now.klings;
72 	r /= Game.killk + 1;
73 	s += (t = -400 * r);
74 	if (t != 0)
75 		printf("Penalty for %d klingons remaining\t%6d\n", Now.klings, t);
76 	if (Move.endgame > 0)
77 	{
78 		s += (t = 100 * (u = Game.skill));
79 		printf("Bonus for winning a %s%s game\t\t%6d\n", Skitab[u - 1].abrev, Skitab[u - 1].full, t);
80 	}
81 	if (Game.killed)
82 	{
83 		s -= 500;
84 		printf("Penalty for getting killed\t\t  -500\n");
85 	}
86 	s += (t = -100 * (u = Game.killb));
87 	if (t != 0)
88 		printf("%d starbases killed\t\t\t%6d\n", u, t);
89 	s += (t = -100 * (u = Game.helps));
90 	if (t != 0)
91 		printf("%d calls for help\t\t\t%6d\n", u, t);
92 	s += (t = -5 * (u = Game.kills));
93 	if (t != 0)
94 		printf("%d stars destroyed\t\t\t%6d\n", u, t);
95 	s += (t = -150 * (u = Game.killinhab));
96 	if (t != 0)
97 		printf("%d inhabited starsystems destroyed\t%6d\n", u, t);
98 	if (Ship.ship != ENTERPRISE)
99 	{
100 		s -= 200;
101 		printf("penalty for abandoning ship\t\t  -200\n");
102 	}
103 	s += (t = 3 * (u = Game.captives));
104 	if (t != 0)
105 		printf("%d Klingons captured\t\t\t%6d\n", u, t);
106 	s += (t = -(u = Game.deaths));
107 	if (t != 0)
108 		printf("%d casualties\t\t\t\t%6d\n", u, t);
109 	printf("\n***  TOTAL\t\t\t%14ld\n", s);
110 	return (s);
111 }
112