11 #define coord_raw(c) (c)
12 #define coord_x(c, b) ((c) % board_size(b))
13 #define coord_y(c, b) ((c) / board_size(b))
14 #define coord_eq(c1, c2) ((c1) == (c2))
15 /* TODO: Smarter way to do this? */
16 #define coord_dx(c1, c2, b) (coord_x(c1, b) - coord_x(c2, b))
17 #define coord_dy(c1, c2, b) (coord_y(c1, b) - coord_y(c2, b))
19 static coord_t pass
= -1;
20 static coord_t resign
= -2;
21 #define is_pass(c) (coord_eq(c, pass))
22 #define is_resign(c) (coord_eq(c, resign))
24 /* Initialize existing coord */
25 #define coord_pos(coord, pos_, board) do { (coord) = (pos_); } while (0)
26 #define coord_xy(board, x, y) ((x) + (y) * board_size(board))
27 #define coord_xy_otf(x, y, board) coord_xy(board, x, y) // obsolete
29 #define coord_is_adjecent(c1, c2, b) (abs(c1 - c2) == 1 || abs(c1 - c2) == board_size(b))
30 #define coord_is_8adjecent(c1, c2, b) (abs(c1 - c2) == 1 || abs(abs(c1 - c2) - board_size(b)) < 2)
33 static coord_t
*coord_init(int x
, int y
, int size
);
34 static coord_t
*coord_copy(coord_t c
);
35 static coord_t
*coord_pass(void);
36 static coord_t
*coord_resign(void);
37 static void coord_done(coord_t
*c
);
40 char *coord2str(coord_t c
, struct board
*b
);
41 char *coord2sstr(coord_t c
, struct board
*b
);
42 coord_t
*str2coord(char *str
, int board_size
);
52 static inline coord_t
*
53 coord_init(int x
, int y
, int size
)
55 coord_t
*c
= calloc(1, sizeof(coord_t
));
60 static inline coord_t
*
63 coord_t
*c2
= calloc(1, sizeof(coord_t
));
64 memcpy(c2
, &c
, sizeof(c
));
68 static inline coord_t
*
71 return coord_copy(pass
);
74 static inline coord_t
*
77 return coord_copy(resign
);
81 coord_done(coord_t
*c
)