* Curses interface for GNU Shogi
*
* ----------------------------------------------------------------------
- *
- * Copyright (c) 2012 Free Software Foundation
+ * Copyright (c) 1993, 1994, 1995 Matthias Mutz
+ * Copyright (c) 1999 Michael Vanier and the Free Software Foundation
*
* GNU SHOGI is based on GNU CHESS
*
+ * Copyright (c) 1988, 1989, 1990 John Stanback
+ * Copyright (c) 1992 Free Software Foundation
+ *
* This file is part of GNU SHOGI.
*
* GNU Shogi is free software; you can redistribute it and/or modify it
#include <ctype.h>
#include <signal.h>
+#include <stdio.h>
#include <sys/param.h>
#include <sys/types.h>
#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;
void
-ShowNodeCnt(long NodeCnt)
+Curses_AlwaysShowMessage(const char *format, ...)
+{
+ static char buffer[60];
+ va_list ap;
+ va_start(ap, format);
+ vsnprintf(buffer, sizeof(buffer), format, ap);
+ Curses_ShowMessage(buffer);
+ va_end(ap);
+}
+
+
+void
+Curses_Printf(const char *format, ...)
+{
+ static char buffer[60];
+ va_list ap;
+ va_start(ap, format);
+ vsnprintf(buffer, sizeof(buffer), format, ap);
+ printw("%s", buffer);
+ va_end(ap);
+}
+
+
+void
+Curses_doRequestInputString(const char* fmt, char* buffer)
+{
+ FLUSH_SCANW(fmt, buffer);
+}
+
+
+int
+Curses_GetString(char* sx)
+{
+ fflush(stdout);
+ return (getstr(sx) == ERR);
+}
+
+
+void
+Curses_ShowNodeCnt(long NodeCnt)
{
gotoXY(TAB, 22);
/* printw(CP[90], NodeCnt, (et > 100) ? NodeCnt / (et / 100) : 0); */
{
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]);
}
void
-ShowPrompt(void)
+Curses_ShowPrompt(void)
{
+ Curses_ShowSidetoMove();
gotoXY(TAB, 17);
printw(CP[121]); /* Your move is? */
ClearEoln();
}
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)