*
* This file is part of GNU SHOGI.
*
- * GNU Shogi 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; either version 1, or (at your option)
- * any later version.
+ * GNU Shogi 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; either version 3 of the License,
+ * or (at your option) any later version.
*
- * GNU Shogi 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 for more details.
+ * GNU Shogi 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
+ * for more details.
*
- * You should have received a copy of the GNU General Public License
- * along with GNU Shogi; see the file COPYING. If not, write to
- * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+ * You should have received a copy of the GNU General Public License along
+ * with GNU Shogi; see the file COPYING. If not, see
+ * <http://www.gnu.org/licenses/>.
+ * ----------------------------------------------------------------------
*/
#define TAB (58)
-#define VIR_C(s) ((flag.reverse) ? (8 - column(s)) : column(s))
-#define VIR_R(s) ((flag.reverse) ? (8 - row(s)) : row(s))
+#define VIR_C(s) ((flag.reverse) ? (NO_COLS - 1 - column(s)) : column(s))
+#define VIR_R(s) ((flag.reverse) ? (NO_ROWS - 1 - row(s)) : row(s))
unsigned short MV[MAXDEPTH];
int MSCORE;
{
if (flag.post)
{
- gotoXY(TAB + 10 + 3 * side, 20);
+ gotoXY(TAB + 10 + 3 * side, 20); /* CHECKME */
if (n >= 0)
printw("%3d", n);
void
ShowPlayers(void)
{
- gotoXY(5, ((flag.reverse) ? 23 : 2));
+ gotoXY(5, ((flag.reverse) ? (5 + 2*NO_ROWS) : 2));
printw("%s", (computer == white) ? CP[218] : CP[74]);
- gotoXY(5, ((flag.reverse) ? 2 : 23));
+ gotoXY(5, ((flag.reverse) ? 2 : (5 + 2*NO_ROWS)));
printw("%s", (computer == black) ? CP[218] : CP[74]);
}
}
else
{
- c = '9' - s[1];
- r = 'i' - s[2];
+ c = COL_NAME(s[1]);
+ r = ROW_NAME(s[2]);
}
if ((c >= 0) && (c < NO_COLS) && (r >= 0) && (r < NO_ROWS))
signal(SIGINT, Curses_TerminateSearch);
signal(SIGQUIT, Curses_TerminateSearch);
- for (i = 4; i < 14; i++)
+ for (i = 4; i < 14; i++) /* CHECKME */
{
gotoXY(TAB, i);
ClearEoln();
y = pxx[(int)piece];
}
- gotoXY(8 + 5 * VIR_C(sq), 4 + 2 * (8 - VIR_R(sq)));
+ gotoXY(8 + 5 * VIR_C(sq), 4 + 2 * ((NO_ROWS - 1) - VIR_R(sq)));
printw("%c%c%c%c", l, p, y, r);
}
{
short score;
- gotoXY(4 + 5 * VIR_C(sq), 5 + 2 * (7 - VIR_R(sq)));
+ gotoXY(4 + 5 * VIR_C(sq), 5 + 2 * (7 - VIR_R(sq))); /* CHECKME */
score = ScorePosition(color[sq]);
if (color[sq] != neutral)
Curses_UpdateDisplay(short f, short t, short redraw, short isspec)
{
short i, sq, z;
+ int j;
if (redraw)
{
i = 2;
gotoXY(3, ++i);
- printw(" +----+----+----+----+----+----+----+----+----+");
+ printw(" +");
+ for (j=0; j<NO_COLS; j++)
+ printw("----+");
- while (i < 20)
+ while (i <= 1 + 2*NO_ROWS)
{
gotoXY(1, ++i);
if (flag.reverse)
z = (i / 2) - 1;
else
- z = 11 - ((i + 1) / 2);
+ z = NO_ROWS + 2 - ((i + 1) / 2);
- printw(" %c | | | | | |"
- " | | | |", 'a' + 9 - z);
+ printw(" %c |", ROW_NAME(z+1));
+ for (j=0; j<NO_COLS; j++)
+ printw(" |");
gotoXY(3, ++i);
- if (i < 20)
+ if (i < 2 + 2*NO_ROWS)
{
- printw(" +----+----+----+----+----+----+----+----+----+");
+ printw(" +");
+ for (j=0; j<NO_COLS; j++)
+ printw("----+");
}
}
- printw(" +----+----+----+----+----+----+----+----+----+");
+ printw(" +");
+ for (j=0; j<NO_COLS; j++)
+ printw("----+");
- gotoXY(3, 22);
+ gotoXY(3, 4 + 2*NO_ROWS);
printw(" ");
if (flag.reverse)