Subversion Repositories Games.Chess Giants

Rev

Rev 108 | Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
33 pmbaty 1
#include "chess.h"
2
#include "data.h"
3
/* last modified 05/08/14 */
4
/*
5
 *******************************************************************************
6
 *                                                                             *
7
 *   Edit() is used to edit (alter) the current board position.  It clears the *
8
 *   board and then allows the operator to enter a position using the syntax   *
9
 *   defined by the xboard/winboard "edit" command.                            *
10
 *                                                                             *
11
 *   White sets the color of pieces added to white.  This color will stay in   *
12
 *   effect until specifically changed.                                        *
13
 *                                                                             *
14
 *   Black sets the color of pieces added to black.  This color will stay in   *
15
 *   effect until specifically changed.                                        *
16
 *                                                                             *
17
 *   # clears the chessboard completely.                                       *
18
 *                                                                             *
19
 *   C changes (toggles) the color of pieces being placed on the board.        *
20
 *                                                                             *
21
 *   End (or . for ICS/Xboard) terminates Edit().                              *
22
 *                                                                             *
23
 *   Pieces are placed on the board by three character "commands" of the form  *
24
 *   [piece][square] where piece is a member of the normal set of pieces       *
25
 *   {P,N,B,R,Q,K} and [square] is algebraic square notation (a1-h8).  Ex: Ke8 *
26
 *   puts a king (of the current "color") on square e8.                        *
27
 *                                                                             *
28
 *******************************************************************************
29
 */
30
void Edit(void) {
31
  int athome = 1, i, piece, readstat, square, tfile, trank, wtm = 1, error =
32
      0;
33
  static const char pieces[] =
34
      { 'x', 'X', 'P', 'p', 'N', 'n', 'B', 'b', 'R', 'r',
35
    'Q', 'q', 'K', 'k', '\0'
36
  };
37
  TREE *const tree = block[0];
38
 
39
/*
40
 ************************************************************
41
 *                                                          *
42
 *  Process the commands to set the board[n] form of the    *
43
 *  chess position.                                         *
44
 *                                                          *
45
 ************************************************************
46
 */
47
  while (1) {
48
    if ((input_stream == stdin) && !xboard) {
49
      if (wtm)
50
        printf("edit(white): ");
51
      else
52
        printf("edit(black): ");
53
    }
54
    fflush(stdout);
55
    readstat = Read(1, buffer, sizeof (buffer));
56
    if (readstat < 0)
57
      return;
58
    nargs = ReadParse(buffer, args, "   ;");
59
    if (xboard)
60
      Print(128, "edit.command:%s\n", args[0]);
61
    if (!strcmp(args[0], "white"))
62
      wtm = 1;
63
    else if (!strcmp(args[0], "black"))
64
      wtm = 0;
65
    if (!strcmp(args[0], "#"))
66
      for (i = 0; i < 64; i++)
67
        PcOnSq(i) = 0;
68
    else if (!strcmp(args[0], "c"))
69
      wtm = Flip(wtm);
70
    else if (!strcmp(args[0], "end") || (!strcmp(args[0], ".")))
71
      break;
72
    else if (!strcmp(args[0], "d"))
73
      DisplayChessBoard(stdout, tree->position);
74
    else if (strlen(args[0]) == 3) {
75
      if (strchr(pieces, args[0][0])) {
76
        piece = (strchr(pieces, args[0][0]) - pieces) >> 1;
77
        tfile = args[0][1] - 'a';
78
        trank = args[0][2] - '1';
79
        square = (trank << 3) + tfile;
80
        if ((square < 0) || (square > 63))
81
          printf("unrecognized square %s\n", args[0]);
82
        if (wtm)
83
          PcOnSq(square) = piece;
84
        else
85
          PcOnSq(square) = -piece;
86
      }
87
    } else if (strlen(args[0]) == 2) {
88
      piece = pawn;
89
      tfile = args[0][0] - 'a';
90
      trank = args[0][1] - '1';
91
      square = (trank << 3) + tfile;
92
      if ((square < 0) || (square > 63))
93
        printf("unrecognized square %s\n", args[0]);
94
      if (wtm)
95
        PcOnSq(square) = piece;
96
      else
97
        PcOnSq(square) = -piece;
98
    } else
99
      printf("unrecognized piece %s\n", args[0]);
100
  }
101
/*
102
 ************************************************************
103
 *                                                          *
104
 *  Now, if a king is on its original square, check the     *
105
 *  rooks to see if they are and set the castle status      *
106
 *  accordingly.  Note that this checks for pieces on the   *
107
 *  original rank, but not their original squares (ICS      *
108
 *  "wild" games) and doesn't set castling if true.         *
109
 *                                                          *
110
 *  The winboard/xboard "edit" command does not give us a   *
111
 *  way of setting castling status, so we have to guess.    *
112
 *                                                          *
113
 ************************************************************
114
 */
115
  Castle(0, white) = 0;
116
  Castle(0, black) = 0;
117
  EnPassant(0) = 0;
118
  for (i = 0; i < 16; i++)
119
    if (PcOnSq(i) == 0 || PcOnSq(i + 48) == 0)
120
      athome = 0;
121
  if (!athome || (PcOnSq(A1) == rook && PcOnSq(B1) == knight &&
122
          PcOnSq(C1) == bishop && PcOnSq(D1) == queen && PcOnSq(E1) == king &&
123
          PcOnSq(F1) == bishop && PcOnSq(G1) == knight && PcOnSq(H1) == rook
124
          && PcOnSq(A8) == -rook && PcOnSq(B8) == -knight &&
125
          PcOnSq(C8) == -bishop && PcOnSq(D8) == -queen && PcOnSq(E8) == -king
126
          && PcOnSq(F8) == -bishop && PcOnSq(G8) == -knight &&
127
          PcOnSq(H8) == -rook)) {
128
    if (PcOnSq(E1) == king) {
129
      if (PcOnSq(A1) == rook)
130
        Castle(0, white) = Castle(0, white) | 2;
131
      if (PcOnSq(H1) == rook)
132
        Castle(0, white) = Castle(0, white) | 1;
133
    }
134
    if (PcOnSq(E8) == -king) {
135
      if (PcOnSq(A8) == -rook)
136
        Castle(0, black) = Castle(0, black) | 2;
137
      if (PcOnSq(H8) == -rook)
138
        Castle(0, black) = Castle(0, black) | 1;
139
    }
140
  }
141
/*
142
 ************************************************************
143
 *                                                          *
144
 *  Basic board is now set.  Now it's time to set the bit   *
145
 *  board representation correctly.                         *
146
 *                                                          *
147
 ************************************************************
148
 */
149
  SetChessBitBoards(tree);
150
  error += InvalidPosition(tree);
151
  if (!error) {
152
    if (log_file)
153
      DisplayChessBoard(log_file, tree->position);
154
    wtm = 1;
155
    move_number = 1;
156
    tree->rep_index = 0;
157
    tree->rep_list[0] = HashKey;
158
    Reversible(0) = 0;
159
    moves_out_of_book = 0;
160
  } else {
161
    InitializeChessBoard(tree);
162
    Print(4095, "Illegal position, using normal initial chess position\n");
163
  }
164
}