NetBSD/games/backgammon/teachgammon/tutor.c

157 lines
3.5 KiB
C
Raw Normal View History

2005-07-01 05:12:39 +04:00
/* $NetBSD: tutor.c,v 1.7 2005/07/01 01:12:39 jmc Exp $ */
1995-03-21 18:03:38 +03:00
1993-03-21 12:45:37 +03:00
/*
1995-03-21 18:03:38 +03:00
* Copyright (c) 1980, 1993
* The Regents of the University of California. All rights reserved.
1993-03-21 12:45:37 +03:00
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 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. Neither the name of the University nor the names of its contributors
1993-03-21 12:45:37 +03:00
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#include <sys/cdefs.h>
1993-03-21 12:45:37 +03:00
#ifndef lint
1995-03-21 18:03:38 +03:00
#if 0
static char sccsid[] = "@(#)tutor.c 8.1 (Berkeley) 5/31/93";
#else
2005-07-01 05:12:39 +04:00
__RCSID("$NetBSD: tutor.c,v 1.7 2005/07/01 01:12:39 jmc Exp $");
1995-03-21 18:03:38 +03:00
#endif
#endif /* not lint */
1993-03-21 12:45:37 +03:00
#include "back.h"
#include "tutor.h"
2005-07-01 05:12:39 +04:00
static const char better[] =
"That is a legal move, but there is a better one.\n";
1993-03-21 12:45:37 +03:00
void
2005-07-01 05:12:39 +04:00
tutor(void)
{
int i, j;
1993-03-21 12:45:37 +03:00
i = 0;
begscr = 18;
cturn = -1;
home = 0;
bar = 25;
inptr = &in[0];
inopp = &in[1];
offptr = &off[0];
offopp = &off[1];
Colorptr = &color[0];
colorptr = &color[2];
colen = 5;
wrboard();
while (1) {
if (!brdeq(test[i].brd, board)) {
1993-03-21 12:45:37 +03:00
if (tflag && curr == 23)
curmove(18, 0);
writel(better);
1993-03-21 12:45:37 +03:00
nexturn();
movback(mvlim);
if (tflag) {
1993-03-21 12:45:37 +03:00
refresh();
clrest();
1993-03-21 12:45:37 +03:00
}
if ((!tflag) || curr == 19) {
1993-03-21 12:45:37 +03:00
proll();
writec('\t');
} else
curmove(curr > 19 ? curr - 2 : curr + 4, 25);
1993-03-21 12:45:37 +03:00
getmove();
if (cturn == 0)
leave();
continue;
}
if (tflag)
curmove(18, 0);
text(*test[i].com);
if (!tflag)
writec('\n');
1993-03-21 12:45:37 +03:00
if (i == maxmoves)
break;
D0 = test[i].roll1;
D1 = test[i].roll2;
d0 = 0;
mvlim = 0;
for (j = 0; j < 4; j++) {
1993-03-21 12:45:37 +03:00
if (test[i].mp[j] == test[i].mg[j])
break;
p[j] = test[i].mp[j];
g[j] = test[i].mg[j];
mvlim++;
}
if (mvlim)
for (j = 0; j < mvlim; j++)
if (makmove(j))
writel("AARGH!!!\n");
1993-03-21 12:45:37 +03:00
if (tflag)
refresh();
nexturn();
D0 = test[i].new1;
D1 = test[i].new2;
d0 = 0;
i++;
mvlim = movallow();
if (mvlim) {
1993-03-21 12:45:37 +03:00
if (tflag)
clrest();
proll();
writec('\t');
getmove();
if (tflag)
refresh();
if (cturn == 0)
leave();
}
}
leave();
}
void
2005-07-01 05:12:39 +04:00
clrest(void)
{
int r, c, j;
1993-03-21 12:45:37 +03:00
r = curr;
c = curc;
for (j = r + 1; j < 24; j++) {
curmove(j, 0);
1993-03-21 12:45:37 +03:00
cline();
}
curmove(r, c);
1993-03-21 12:45:37 +03:00
}
int
2005-07-01 05:12:39 +04:00
brdeq(const int *b1, const int *b2)
1993-03-21 12:45:37 +03:00
{
const int *e;
1993-03-21 12:45:37 +03:00
e = b1 + 26;
1993-03-21 12:45:37 +03:00
while (b1 < e)
if (*b1++ != *b2++)
return (0);
return (1);
1993-03-21 12:45:37 +03:00
}