a75b256eb6e8350a1023819e988177d8f18db87a
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\
* This is GNU Go, a Go program. Contact gnugo@gnu.org, or see *
* http://www.gnu.org/software/gnugo/ for more information. *
* Copyright 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, *
* 2008 and 2009 by the Free Software Foundation. *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License as *
* published by the Free Software Foundation - version 3 or *
* (at your option) any later version. *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License in file COPYING for more details. *
* You should have received a copy of the GNU General Public *
* License along with this program; if not, write to the Free *
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, *
* Boston, MA 02111, USA. *
\* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#define DFA_MAX_BOARD MAX_BOARD
#define DFA_MAX_ORDER ((2 * DFA_MAX_BOARD - 1) \
* (2 * DFA_MAX_BOARD - 1))
#define DFA_BASE (3 * DFA_MAX_BOARD)
#define DFA_POS(i, j) (((i) + DFA_MAX_BOARD) * DFA_BASE \
#define OUT_BOARD 3 /* # */
/* Maximum pattern matched at one positions. */
#define DFA_MAX_MATCHED (8 * 24)
extern int spiral
[DFA_MAX_ORDER
][8];
void build_spiral_order(void);
/* The run-time data structures declared here are different from those
* used internally to build the DFA. */
const state_rt_t
*states
;
const attrib_rt_t
*indexes
;