]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - fish/fish.c
.include <bsd.own.mk> early
[bsdgames-darwin.git] / fish / fish.c
index 03171e963515e36ffc26dd81676e2caf76f9c085..06e15859c34aefa275a6954fd9fe21fcd8768a6e 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: fish.c,v 1.4 1997/10/10 12:58:32 lukem Exp $   */
+/*     $NetBSD: fish.c,v 1.13 2000/05/08 07:56:03 mycroft Exp $        */
 
 /*-
  * Copyright (c) 1990, 1993
@@ -46,41 +46,46 @@ __COPYRIGHT("@(#) Copyright (c) 1990, 1993\n\
 #if 0
 static char sccsid[] = "@(#)fish.c     8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: fish.c,v 1.4 1997/10/10 12:58:32 lukem Exp $");
+__RCSID("$NetBSD: fish.c,v 1.13 2000/05/08 07:56:03 mycroft Exp $");
 #endif
 #endif /* not lint */
 
 #include <sys/types.h>
-#include <sys/errno.h>
+#include <sys/wait.h>
+#include <errno.h>
 #include <fcntl.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include <unistd.h>
 #include <string.h>
 #include <time.h>
+#include <err.h>
 #include "pathnames.h"
 
 #define        RANKS           13
 #define        HANDSIZE        7
 #define        CARDS           4
+#define        TOTCARDS        RANKS * CARDS
 
 #define        USER            1
 #define        COMPUTER        0
 #define        OTHER(a)        (1 - (a))
 
-char *cards[] = {
+const char *const cards[] = {
        "A", "2", "3", "4", "5", "6", "7",
        "8", "9", "10", "J", "Q", "K", NULL,
 };
 #define        PRC(card)       (void)printf(" %s", cards[card])
 
 int promode;
-int asked[RANKS], comphand[RANKS], deck[RANKS];
+int asked[RANKS], comphand[RANKS], deck[TOTCARDS];
 int userasked[RANKS], userhand[RANKS];
+int curcard = TOTCARDS;
 
-void   chkwinner __P((int, int *));
+void   chkwinner __P((int, const int *));
 int    compmove __P((void));
-int    countbooks __P((int *));
-int    countcards __P((int *));
+int    countbooks __P((const int *));
+int    countcards __P((const int *));
 int    drawcard __P((int, int *));
 int    gofish __P((int, int, int *));
 void   goodmove __P((int, int, int *, int *));
@@ -88,10 +93,10 @@ void        init __P((void));
 void   instructions __P((void));
 int    main __P((int, char *[]));
 int    nrandom __P((int));
-void   printhand __P((int *));
+void   printhand __P((const int *));
 void   printplayer __P((int));
 int    promove __P((void));
-void   usage __P((void));
+void   usage __P((void)) __attribute__((__noreturn__));
 int    usermove __P((void));
 
 int
@@ -101,6 +106,9 @@ main(argc, argv)
 {
        int ch, move;
 
+       /* Revoke setgid privileges */
+       setgid(getgid());
+
        while ((ch = getopt(argc, argv, "p")) != -1)
                switch(ch) {
                case 'p':
@@ -108,8 +116,7 @@ main(argc, argv)
                        break;
                case '?':
                default:
-                       (void)fprintf(stderr, "usage: fish [-p]\n");
-                       exit(1);
+                       usage();
                }
 
        srandom(time((time_t *)NULL));
@@ -150,7 +157,7 @@ int
 usermove()
 {
        int n;
-       char **p;
+       const char *const *p;
        char buf[256];
 
        (void)printf("\nYour hand is:");
@@ -159,13 +166,13 @@ usermove()
        for (;;) {
                (void)printf("You ask me for: ");
                (void)fflush(stdout);
-               if (fgets(buf, BUFSIZ, stdin) == NULL)
+               if (fgets(buf, sizeof(buf), stdin) == NULL)
                        exit(0);
                if (buf[0] == '\0')
                        continue;
                if (buf[0] == '\n') {
                        (void)printf("%d cards in my hand, %d in the pool.\n",
-                           countcards(comphand), countcards(deck));
+                           countcards(comphand), curcard);
                        (void)printf("My books:");
                        (void)countbooks(comphand);
                        continue;
@@ -265,9 +272,7 @@ drawcard(player, hand)
 {
        int card;
 
-       while (deck[card = nrandom(RANKS)] == 0);
-       ++hand[card];
-       --deck[card];
+       ++hand[card = deck[--curcard]];
        if (player == USER || hand[card] == CARDS) {
                printplayer(player);
                (void)printf("drew %s", cards[card]);
@@ -325,7 +330,7 @@ goodmove(player, move, hand, opphand)
 void
 chkwinner(player, hand)
        int player;
-       int *hand;
+       const int *hand;
 {
        int cb, i, ub;
 
@@ -368,7 +373,7 @@ printplayer(player)
 
 void
 printhand(hand)
-       int *hand;
+       const int *hand;
 {
        int book, i, j;
 
@@ -389,7 +394,7 @@ printhand(hand)
 
 int
 countcards(hand)
-       int *hand;
+       const int *hand;
 {
        int i, count;
 
@@ -400,7 +405,7 @@ countcards(hand)
 
 int
 countbooks(hand)
-       int *hand;
+       const int *hand;
 {
        int i, count;
 
@@ -418,19 +423,21 @@ countbooks(hand)
 void
 init()
 {
-       int i, rank;
+       int i, j, temp;
 
-       for (i = 0; i < RANKS; ++i)
-               deck[i] = CARDS;
-       for (i = 0; i < HANDSIZE; ++i) {
-               while (!deck[rank = nrandom(RANKS)]);
-               ++userhand[rank];
-               --deck[rank];
+       for (i = 0; i < TOTCARDS; ++i)
+               deck[i] = i % RANKS;
+       for (i = 0; i < TOTCARDS - 1; ++i) {
+               j = nrandom(TOTCARDS-i);
+               if (j == 0)
+                       continue;
+               temp = deck[i];
+               deck[i] = deck[i+j];
+               deck[i+j] = temp;
        }
        for (i = 0; i < HANDSIZE; ++i) {
-               while (!deck[rank = nrandom(RANKS)]);
-               ++comphand[rank];
-               --deck[rank];
+               ++userhand[deck[--curcard]];
+               ++comphand[deck[--curcard]];
        }
 }
 
@@ -446,7 +453,10 @@ void
 instructions()
 {
        int input;
-       char buf[1024];
+       pid_t pid;
+       int fd;
+       const char *pager;
+       int status;
 
        (void)printf("Would you like instructions (y or n)? ");
        input = getchar();
@@ -454,8 +464,28 @@ instructions()
        if (input != 'y')
                return;
 
-       (void)sprintf(buf, "%s %s", _PATH_MORE, _PATH_INSTR);
-       (void)system(buf);
+       switch (pid = fork()) {
+       case 0: /* child */
+               if (!isatty(1))
+                       pager = "cat";
+               else {
+                       if (!(pager = getenv("PAGER")) || (*pager == 0))
+                               pager = _PATH_MORE;
+               }
+               if ((fd = open(_PATH_INSTR, O_RDONLY)) == -1)
+                       err(1, "open %s", _PATH_INSTR);
+               if (dup2(fd, 0) == -1)
+                       err(1, "dup2");
+               (void)execl("/bin/sh", "sh", "-c", pager, NULL);
+               err(1, "exec sh -c %s", pager);
+               /*NOTREACHED*/
+       case -1:
+               err(1, "fork");
+               /*NOTREACHED*/
+       default:
+               (void)waitpid(pid, &status, 0);
+               break;
+       }
        (void)printf("Hit return to continue...\n");
        while ((input = getchar()) != EOF && input != '\n');
 }