]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - trek/score.c
Don't give special privileges to uid 13107.
[bsdgames-darwin.git] / trek / score.c
index eff3f8d8f9bade386354c7765b88247cafe39597..7d8deae89caa2faa2dc5d65e3de925aca55372bf 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: score.c,v 1.8 2009/05/24 22:55:03 dholland Exp $       */
+/*     $NetBSD: score.c,v 1.10 2009/05/25 00:03:18 dholland Exp $      */
 
 /*
  * Copyright (c) 1980, 1993
 #if 0
 static char sccsid[] = "@(#)score.c    8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: score.c,v 1.8 2009/05/24 22:55:03 dholland Exp $");
+__RCSID("$NetBSD: score.c,v 1.10 2009/05/25 00:03:18 dholland Exp $");
 #endif
 #endif /* not lint */
 
+#include <stdarg.h>
 #include <stdio.h>
 #include "trek.h"
 #include "getpar.h"
@@ -46,6 +47,25 @@ __RCSID("$NetBSD: score.c,v 1.8 2009/05/24 22:55:03 dholland Exp $");
 **  PRINT OUT THE CURRENT SCORE
 */
 
+static void scoreitem(long amount, const char *descfmt, ...)
+       __printflike(2, 3);
+
+static void
+scoreitem(long amount, const char *descfmt, ...)
+{
+       va_list ap;
+       char buf[128];
+
+       if (amount == 0)
+               return;
+
+       va_start(ap, descfmt);
+       vsnprintf(buf, sizeof(buf), descfmt, ap);
+       va_end(ap);
+
+       printf("%-40s %10ld\n", buf, amount);
+}
+
 long
 score(void)
 {
@@ -55,53 +75,57 @@ score(void)
        double          r;
 
        printf("\n*** Your score:\n");
+
        s = t = Param.klingpwr / 4 * (u = Game.killk);
-       if (t != 0)
-               printf("%d Klingons killed\t\t\t%6d\n", u, t);
+       scoreitem(t, "%d Klingons killed", u);
+
        r = Now.date - Param.date;
        if (r < 1.0)
                r = 1.0;
        r = Game.killk / r;
        s += (t = 400 * r);
-       if (t != 0)
-               printf("Kill rate %.2f Klingons/stardate  \t%6d\n", r, t);
+       scoreitem(t, "Kill rate %.2f Klingons/stardate", r);
+
        r = Now.klings;
        r /= Game.killk + 1;
        s += (t = -400 * r);
-       if (t != 0)
-               printf("Penalty for %d klingons remaining\t%6d\n", Now.klings,
-                       t);
+       scoreitem(t, "Penalty for %d klingons remaining", Now.klings);
+
        if (Move.endgame > 0) {
                s += (t = 100 * (u = Game.skill));
-               printf("Bonus for winning a %s%s game\t\t%6d\n",
-                       Skitab[u - 1].abrev, Skitab[u - 1].full, t);
+               scoreitem(t, "Bonus for winning a %s%s game",
+                       Skitab[u - 1].abrev, Skitab[u - 1].full);
        }
+
        if (Game.killed) {
                s -= 500;
-               printf("Penalty for getting killed\t\t  -500\n");
+               scoreitem(-500, "Penalty for getting killed");
        }
+
        s += (t = -100 * (u = Game.killb));
-       if (t != 0)
-               printf("%d starbases killed\t\t\t%6d\n", u, t);
+       scoreitem(t, "%d starbases killed", u);
+
        s += (t = -100 * (u = Game.helps));
-       if (t != 0)
-               printf("%d calls for help\t\t\t%6d\n", u, t);
+       scoreitem(t, "%d calls for help", u);
+
        s += (t = -5 * (u = Game.kills));
-       if (t != 0)
-               printf("%d stars destroyed\t\t\t%6d\n", u, t);
+       scoreitem(t, "%d stars destroyed", u);
+
        s += (t = -150 * (u = Game.killinhab));
-       if (t != 0)
-               printf("%d inhabited starsystems destroyed\t%6d\n", u, t);
+       scoreitem(t, "%d inhabited starsystems destroyed", u);
+
        if (Ship.ship != ENTERPRISE) {
                s -= 200;
-               printf("penalty for abandoning ship\t\t  -200\n");
+               scoreitem(-200, "penalty for abandoning ship");
        }
+
        s += (t = 3 * (u = Game.captives));
-       if (t != 0)
-               printf("%d Klingons captured\t\t\t%6d\n", u, t);
+       scoreitem(t, "%d Klingons captured", u);
+
        s += (t = -(u = Game.deaths));
-       if (t != 0)
-               printf("%d casualties\t\t\t\t%6d\n", u, t);
-       printf("\n***  TOTAL\t\t\t%14ld\n", s);
+       scoreitem(t, "%d casualties", u);
+
+       printf("\n");
+       scoreitem(s, "***  TOTAL");
        return (s);
 }