1 /* $NetBSD: one.c,v 1.6 2005/07/01 01:12:39 jmc Exp $ */
4 * Copyright (c) 1980, 1993
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 #include <sys/cdefs.h>
35 static char sccsid
[] = "@(#)one.c 8.1 (Berkeley) 5/31/93";
37 __RCSID("$NetBSD: one.c,v 1.6 2005/07/01 01:12:39 jmc Exp $");
43 static int checkd(int);
44 static int last(void);
54 max
= (*offptr
< 0 ? 7 : last());
55 if (board
[p
[i
]] * cturn
<= 0)
56 return (checkd(d
) + 2);
57 if (g
[i
] != home
&& board
[g
[i
]] * cturn
< -1)
58 return (checkd(d
) + 3);
60 if (n
== max
? D1
< n
: D1
!= n
)
61 return (checkd(d
) + 1);
63 if (n
== max
? D0
< n
&& D1
< n
: D0
!= n
&& D1
!= n
)
64 return (checkd(d
) + 1);
65 if (n
== max
? D0
< n
: D0
!= n
) {
67 return (checkd(d
) + 1);
71 if (g
[i
] == home
&& *offptr
< 0)
72 return (checkd(d
) + 4);
76 if (board
[g
[i
]] == -cturn
) {
80 if (abs(bar
- g
[i
]) < 7) {
87 if (abs(home
- g
[i
]) < 7 && abs(home
- p
[i
]) > 6) {
89 if (*inptr
+ *offptr
== 0)
109 for (j
= 0; j
<= i
; j
++) {
134 for (i
= home
- 6 * cturn
; i
!= home
; i
+= cturn
)
135 if (board
[i
] * cturn
> 0)
136 return (abs(home
- i
));
145 for (j
= i
- 1; j
>= 0; j
--)
152 board
[p
[i
]] += cturn
;
154 board
[g
[i
]] -= cturn
;
155 if (abs(g
[i
] - home
) < 7 && abs(p
[i
] - home
) > 6) {
157 if (*inptr
+ *offptr
< 15 && *offptr
>= 0)
165 board
[home
] += cturn
;
166 board
[g
[i
]] = -cturn
;
167 if (abs(bar
- g
[i
]) < 7) {
169 if (*inopp
+ *offopp
== 0)