]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - robots/score.c
sprintf -> snprintf
[bsdgames-darwin.git] / robots / score.c
index 7781e3ade81477d593a058448f5ef864bf16cffc..62709435e500044a3145253aa8f6dba3169d087b 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: score.c,v 1.6 1999/05/15 23:56:36 christos Exp $       */
+/*     $NetBSD: score.c,v 1.18 2006/03/17 23:11:47 abs Exp $   */
 
 /*
  * Copyright (c) 1980, 1993
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *     This product includes software developed by the University of
- *     California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
+ * 3. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
  *
 #if 0
 static char sccsid[] = "@(#)score.c    8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: score.c,v 1.6 1999/05/15 23:56:36 christos Exp $");
+__RCSID("$NetBSD: score.c,v 1.18 2006/03/17 23:11:47 abs Exp $");
 #endif
 #endif /* not lint */
 
 # include      "robots.h"
 # include      "pathnames.h"
 
-char   *Scorefile = _PATH_SCORE;
+const char     *Scorefile = _PATH_SCORE;
 
 int    Max_per_uid = MAX_PER_UID;
 
@@ -53,6 +49,9 @@ static SCORE  Top[MAXSCORES];
 
 static u_int32_t       numscores, max_uid;
 
+static void read_score(int);
+static void write_score(int);
+
 /*
  * read_score:
  *     Read the score file in MI format
@@ -91,7 +90,7 @@ write_score(inf)
 {
        SCORE   *scp;
 
-       lseek(inf, 0L, 0);
+       lseek(inf, 0L, SEEK_SET);
 
        max_uid = htonl(max_uid);
        write(inf, &max_uid, sizeof max_uid);
@@ -113,18 +112,17 @@ write_score(inf)
  *     top list.
  */
 void
-score()
+score(score_wfd)
+       int score_wfd;
 {
-       int                     inf;
+       int                     inf = score_wfd;
        SCORE                   *scp;
-       int                     uid;
+       u_int32_t               uid;
        bool                    done_show = FALSE;
 
        Newscore = FALSE;
-       if ((inf = open(Scorefile, O_RDWR)) < 0) {
-               warn("opening `%s'", Scorefile);
+       if (inf < 0)
                return;
-       }
 
        read_score(inf);
 
@@ -132,8 +130,7 @@ score()
        if (Top[MAXSCORES-1].s_score <= Score) {
                numscores = 0;
                for (scp = Top; scp < &Top[MAXSCORES]; scp++)
-                       if (scp->s_score < 0 ||
-                           (scp->s_uid == uid && ++numscores == max_uid)) {
+                       if ((scp->s_uid == uid && ++numscores == max_uid)) {
                                if (scp->s_score > Score)
                                        break;
                                scp->s_score = Score;
@@ -158,7 +155,7 @@ score()
 
        if (!Newscore) {
                Full_clear = FALSE;
-               close(inf);
+               lseek(inf, 0, SEEK_SET);
                return;
        }
        else
@@ -174,9 +171,9 @@ score()
                move((scp - Top) + 2, 15);
                if (!done_show && scp->s_uid == uid && scp->s_score == Score)
                        standout();
-               printw("%5.5d %5.5d %-8.8s %-9.9s %5.5d",
-                   (scp - Top) + 1, scp->s_score, scp->s_name,
-                   Auto_bot ? "(autobot)" : "", scp->s_level);
+               printw("%5ld %5d %-8.8s %-9.9s %5d",
+                   (long)(scp - Top) + 1, scp->s_score, scp->s_name,
+                   scp->s_auto ? "(autobot)" : "", scp->s_level);
                if (!done_show && scp->s_uid == uid && scp->s_score == Score) {
                        standend();
                        done_show = TRUE;
@@ -188,7 +185,7 @@ score()
        if (Newscore) {
                write_score(inf);
        }
-       close(inf);
+       lseek(inf, 0, SEEK_SET);
 }
 
 void
@@ -198,8 +195,9 @@ set_name(scp)
        PASSWD  *pp;
 
        if ((pp = getpwuid(scp->s_uid)) == NULL)
-               pp->pw_name = "???";
-       strncpy(scp->s_name, pp->pw_name, MAXNAME);
+               strncpy(scp->s_name, "???", MAXNAME);
+       else
+               strncpy(scp->s_name, pp->pw_name, MAXNAME);
 }
 
 /*
@@ -210,7 +208,7 @@ int
 cmp_sc(s1, s2)
        const void *s1, *s2;
 {
-       return ((SCORE *)s2)->s_score - ((SCORE *)s1)->s_score;
+       return ((const SCORE *)s2)->s_score - ((const SCORE *)s1)->s_score;
 }
 
 /*
@@ -235,7 +233,7 @@ show_score()
            " ", "Level");
        for (scp = Top; scp < &Top[MAXSCORES]; scp++)
                if (scp->s_score > 0)
-                       printf("%5.5d %5.5d %-8.8s %-9.9s %5.5d\n",
+                       printf("%5d %5d %-8.8s %-9.9s %5d\n",
                            inf++, scp->s_score, scp->s_name,
                            scp->s_auto ? "(autobot)" :  "", scp->s_level);
 }