Fix deferral on sweep promotions
[xboard.git] / board.c
diff --git a/board.c b/board.c
index 7b3535a..a0ce36e 100644 (file)
--- a/board.c
+++ b/board.c
@@ -194,7 +194,7 @@ SetPremoveHighlights (int fromX, int fromY, int toX, int toY)
     }
     if (pm2X != toX || pm2Y != toY) {
        if (pm2X >= 0 && pm2Y >= 0) {
     }
     if (pm2X != toX || pm2Y != toY) {
        if (pm2X >= 0 && pm2Y >= 0) {
-           damage[0][pm1Y][pm1X] |= 2;
+           damage[0][pm2Y][pm2X] |= 2;
        }
     }
     pm1X = fromX;
        }
     }
     pm1X = fromX;
@@ -1043,7 +1043,7 @@ DrawPosition (int repaint, Board board)
                        SquareExpose(i, j, lineGap);
                    else
                        SquareExpose(i, j, 0);
                        SquareExpose(i, j, lineGap);
                    else
                        SquareExpose(i, j, 0);
-                   damage[nr][i][j] = 0;
+                   if(nr == 0) damage[nr][i][j] = 0; // on auxiliary board we retain arrow damage
                }
     }
 
                }
     }
 
@@ -1059,7 +1059,7 @@ DrawPosition (int repaint, Board board)
                q = strchr(p, '\n');
                if(q) *q = NULLCHAR;
                if(!strstr(appData.suppress, p)) {
                q = strchr(p, '\n');
                if(q) *q = NULLCHAR;
                if(!strstr(appData.suppress, p)) {
-                   if(i == 0) DrawSeekBackground(2*squareSize, 3*squareSize, 6*squareSize, 5*squareSize);
+                   if(i == 0) DrawSeekBackground(2*squareSize, 3*squareSize, 6.5*squareSize, 5*squareSize);
                    DrawText(p, 2*squareSize + 5, (int) ((3 + 0.3*i++)*squareSize) + 5, 2);
                }
                if(q) *q++ = '\n'; else q = "";
                    DrawText(p, 2*squareSize + 5, (int) ((3 + 0.3*i++)*squareSize) + 5, 2);
                }
                if(q) *q++ = '\n'; else q = "";