-/* $NetBSD: teach.c,v 1.10 1999/08/14 16:29:23 tron Exp $ */
+/* $NetBSD: teach.c,v 1.23 2012/10/13 19:25:22 dholland 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.10 1999/08/14 16:29:23 tron Exp $");
+__RCSID("$NetBSD: teach.c,v 1.23 2012/10/13 19:25:22 dholland Exp $");
#endif
#endif /* not lint */
#include "back.h"
#include "tutor.h"
-extern short ospeed; /* tty output speed for termlib */
-
-const char *const helpm[] = {
+static const char *const helpm[] = {
"\nEnter a space or newline to roll, or",
" b to display the board",
" d to double",
0
};
-const char *const 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 */
- setregid(getgid(), getgid());
+ setgid(getgid());
signal(SIGINT, getout);
if (tcgetattr(0, &old) == -1) /* get old tty mode */
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();
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;
case 3:
- if ((i = text(moves)) != 0)
+ if ((i = wrtext(moves)) != 0)
break;
case 4:
- if ((i = text(removepiece)) != 0)
+ if ((i = wrtext(removepiece)) != 0)
break;
case 5:
- if ((i = text(hits)) != 0)
+ if ((i = wrtext(hits)) != 0)
break;
case 6:
- if ((i = text(endgame)) != 0)
+ if ((i = wrtext(endgame)) != 0)
break;
case 7:
- if ((i = text(doubl)) != 0)
+ if ((i = wrtext(doubl)) != 0)
break;
case 8:
- if ((i = text(stragy)) != 0)
+ if ((i = wrtext(stragy)) != 0)
break;
case 9:
- if ((i = text(prog)) != 0)
+ if ((i = wrtext(prog)) != 0)
break;
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", "-n", args[0]?args:0, 0);
+ execl(EXEC, "backgammon", "-n", args[0]?args:0, (char *) 0);
writel("Help! Backgammon program is missing\007!!\n");
- exit(-1);
+ exit(1);
}