]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - hack/hack.do_name.c
tetris: Use arc4random_uniform instead of modulo for better randomness
[bsdgames-darwin.git] / hack / hack.do_name.c
index e29e4d20c25918947e370555e4584ab48a182da8..c01e35b4568c4c7bc800bd1a1a5589ccb2d27d9d 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: hack.do_name.c,v 1.8 2009/06/07 18:30:39 dholland Exp $        */
+/*     $NetBSD: hack.do_name.c,v 1.13 2011/08/07 06:03:45 dholland Exp $       */
 
 /*
  * Copyright (c) 1985, Stichting Centrum voor Wiskunde en Informatica,
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: hack.do_name.c,v 1.8 2009/06/07 18:30:39 dholland Exp $");
+__RCSID("$NetBSD: hack.do_name.c,v 1.13 2011/08/07 06:03:45 dholland Exp $");
 #endif                         /* not lint */
 
 #include <stdlib.h>
 #include "hack.h"
 #include "extern.h"
 
+static void do_oname(struct obj *);
+static char *xmonnam(struct monst *, int);
+static char *lmonnam(struct monst *);
+static char *visctrl(int);
+
 coord
 getpos(int force, const char *goal)
 {
@@ -114,7 +119,8 @@ do_mname(void)
 {
        char            buf[BUFSZ];
        coord           cc;
-       int             cx, cy, lth;
+       int             cx, cy;
+       size_t lth;
        unsigned        i;
        struct monst   *mtmp, *mtmp2;
        cc = getpos(0, "the monster you want to name");
@@ -164,11 +170,11 @@ do_mname(void)
  * when there might be pointers around in unknown places. For now: only
  * when  obj  is in the inventory.
  */
-void
+static void
 do_oname(struct obj *obj)
 {
        struct obj     *otmp, *otmp2;
-       int lth;
+       size_t lth;
        char            buf[BUFSZ];
        pline("What do you want to name %s? ", doname(obj));
        getlin(buf);
@@ -206,7 +212,7 @@ do_oname(struct obj *obj)
 #if 0
        obfree(obj, otmp2);     /* now unnecessary: no pointers on bill */
 #endif
-       free((char *) obj);     /* let us hope nobody else saved a pointer */
+       free(obj);      /* let us hope nobody else saved a pointer */
 }
 
 int
@@ -256,19 +262,20 @@ docall(struct obj *obj)
        *str1 = str;
 }
 
-const char *const ghostnames[] = {/* these names should have length < PL_NSIZ */
+static const char *const ghostnames[] = {
+       /* these names should have length < PL_NSIZ */
        "adri", "andries", "andreas", "bert", "david", "dirk", "emile",
        "frans", "fred", "greg", "hether", "jay", "john", "jon", "kay",
        "kenny", "maud", "michiel", "mike", "peter", "robert", "ron",
        "tom", "wilmar"
 };
 
-char           *
+static char *
 xmonnam(struct monst *mtmp, int vb)
 {
        static char     buf[BUFSZ];     /* %% */
        if (mtmp->mnamelth && !vb) {
-               (void) strcpy(buf, NAME(mtmp));
+               (void) strlcpy(buf, NAME(mtmp), sizeof(buf));
                return (buf);
        }
        switch (mtmp->data->mlet) {
@@ -279,30 +286,30 @@ xmonnam(struct monst *mtmp, int vb)
                                gn = ghostnames[rn2(SIZE(ghostnames))];
                                if (!rn2(2))
                                        (void)
-                                               strcpy((char *) mtmp->mextra, !rn2(5) ? plname : gn);
+                                               strlcpy((char *) mtmp->mextra, !rn2(5) ? plname : gn, mtmp->mxlth);
                        }
-                       (void) sprintf(buf, "%s's ghost", gn);
+                       (void) snprintf(buf, sizeof(buf), "%s's ghost", gn);
                }
                break;
        case '@':
                if (mtmp->isshk) {
-                       (void) strcpy(buf, shkname(mtmp));
+                       (void) strlcpy(buf, shkname(mtmp), sizeof(buf));
                        break;
                }
-               /* fall into next case */
+               /* FALLTHROUGH */
        default:
-               (void) sprintf(buf, "the %s%s",
+               (void) snprintf(buf, sizeof(buf), "the %s%s",
                               mtmp->minvis ? "invisible " : "",
                               mtmp->data->mname);
        }
        if (vb && mtmp->mnamelth) {
-               (void) strcat(buf, " called ");
-               (void) strcat(buf, NAME(mtmp));
+               (void) strlcat(buf, " called ", sizeof(buf));
+               (void) strlcat(buf, NAME(mtmp), sizeof(buf));
        }
        return (buf);
 }
 
-char           *
+static char *
 lmonnam(struct monst *mtmp)
 {
        return (xmonnam(mtmp, 1));
@@ -331,7 +338,7 @@ amonnam(struct monst *mtmp, const char *adj)
 
        if (!strncmp(bp, "the ", 4))
                bp += 4;
-       (void) sprintf(buf, "the %s %s", adj, bp);
+       (void) snprintf(buf, sizeof(buf), "the %s %s", adj, bp);
        return (buf);
 }
 
@@ -355,7 +362,7 @@ Xmonnam(struct monst *mtmp)
        return (bp);
 }
 
-char           *
+static char *
 visctrl(int c)
 {
        static char     ccc[3];