]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - backgammon/teachgammon/teach.c
PR/55695: Andreas Gustafsson: factor(6) -h option doesn't always work
[bsdgames-darwin.git] / backgammon / teachgammon / teach.c
index 8a0089a7709abca1170a51b78e1a086acf7807bb..d2947923cd1adadcf810a1ed3f7fd52b48ec1a9f 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: teach.c,v 1.6 1998/08/29 22:53:04 hubertf Exp $        */
+/*     $NetBSD: teach.c,v 1.25 2019/02/03 03:19:25 mrg 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.
  *
 
 #include <sys/cdefs.h>
 #ifndef lint
-__COPYRIGHT("@(#) Copyright (c) 1980, 1993\n\
      The Regents of the University of California.  All rights reserved.\n");
+__COPYRIGHT("@(#) Copyright (c) 1980, 1993\
The Regents of the University of California.  All rights reserved.");
 #endif                         /* not lint */
 
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)teach.c    8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: teach.c,v 1.6 1998/08/29 22:53:04 hubertf Exp $");
+__RCSID("$NetBSD: teach.c,v 1.25 2019/02/03 03:19:25 mrg Exp $");
 #endif
 #endif                         /* not lint */
 
 #include "back.h"
 #include "tutor.h"
 
-extern speed_t ospeed;         /* tty output speed for termlib */
-
-char   *helpm[] = {
-       "\nEnter a space or newline to roll, or",
-       "     b   to display the board",
-       "     d   to double",
-       "     q   to quit\n",
-       0
-};
-
-char   *contin[] = {
+static const char *const contin[] = {
        "",
        0
 };
 
 int
-main(argc, argv)
-       int     argc;
-       char   *argv[];
+main(int argc __unused, char *argv[])
 {
        int     i;
+       struct move mmstore, *mm;
+
+       /* revoke setgid privileges */
+       setgid(getgid());
 
        signal(SIGINT, getout);
        if (tcgetattr(0, &old) == -1)   /* get old tty mode */
@@ -81,20 +69,20 @@ main(argc, argv)
        raw.c_lflag &= ~ICANON; /* set up modes */
        ospeed = cfgetospeed(&old);     /* for termlib */
        tflag = getcaps(getenv("TERM"));
-#ifdef V7
+
+       /* need this now beceause getarg() may try to load a game */
+       mm = &mmstore;
+       move_init(mm);
        while (*++argv != 0)
-#else
-       while (*++argv != -1)
-#endif
-               getarg(&argv);
+               getarg(mm, &argv);
        if (tflag) {
                noech.c_oflag &= ~(ONLCR | OXTABS);
                raw.c_oflag &= ~(ONLCR | OXTABS);
                clear();
        }
-       text(hello);
-       text(list);
-       i = text(contin);
+       wrtext(hello);
+       wrtext(list);
+       i = wrtext(contin);
        if (i == 0)
                i = 2;
        init();
@@ -104,58 +92,66 @@ main(argc, argv)
                        leave();
 
                case 2:
-                       if ((i = text(intro1)) != 0)
+                       if ((i = wrtext(intro1)) != 0)
                                break;
                        wrboard();
-                       if ((i = text(intro2)) != 0)
+                       if ((i = wrtext(intro2)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 3:
-                       if ((i = text(moves)) != 0)
+                       if ((i = wrtext(moves)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 4:
-                       if ((i = text(removepiece)) != 0)
+                       if ((i = wrtext(removepiece)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 5:
-                       if ((i = text(hits)) != 0)
+                       if ((i = wrtext(hits)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 6:
-                       if ((i = text(endgame)) != 0)
+                       if ((i = wrtext(endgame)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 7:
-                       if ((i = text(doubl)) != 0)
+                       if ((i = wrtext(doubl)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 8:
-                       if ((i = text(stragy)) != 0)
+                       if ((i = wrtext(stragy)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 9:
-                       if ((i = text(prog)) != 0)
+                       if ((i = wrtext(prog)) != 0)
                                break;
 
+                       /* FALLTHROUGH */
                case 10:
-                       if ((i = text(lastch)) != 0)
+                       if ((i = wrtext(lastch)) != 0)
                                break;
                }
-       tutor();
+       tutor(mm);
        /* NOTREACHED */
        return (0);
 }
 
 void
-leave()
+leave(void)
 {
        if (tflag)
                clear();
        else
                writec('\n');
        fixtty(&old);
-       execl(EXEC, "backgammon", args, "n", 0);
+       execl(EXEC, "backgammon", "-n", args[0]?args:0, (char *) 0);
        writel("Help! Backgammon program is missing\007!!\n");
-       exit(-1);
+       exit(1);
 }