Compare commits

..

No commits in common. "0c40eba66fe49e2de4fd0c33cf31385ff1c3b646" and "419d33bc884fe81eb002a722a86c9833a9d701e1" have entirely different histories.

3 changed files with 6 additions and 35 deletions

View file

@ -131,11 +131,9 @@ public class Board {
// White pieces disappear if new move isn't created, don't know why // White pieces disappear if new move isn't created, don't know why
Move copiedMove = new Move(new BoardCoordinate(move.from.x, move.from.y), new BoardCoordinate(move.to.x, move.to.y), get(move.to.x, move.to.y)); Move copiedMove = new Move(new BoardCoordinate(move.from.x, move.from.y), new BoardCoordinate(move.to.x, move.to.y), get(move.to.x, move.to.y));
copiedMove.submove = move.submove; copiedMove.submove = move.submove;
copiedMove.isPromotion = move.isPromotion;
moveHistory.add(copiedMove); moveHistory.add(copiedMove);
// moveHistory.add(move); // moveHistory.add(move);
Piece movedPiece = get(move.from); set(move.to, get(move.from));
set(move.to, move.isPromotion ? new Queen(movedPiece.black, panel) : movedPiece);
set(move.from, null); set(move.from, null);
move(move.submove); move(move.submove);
if (move.submove != null) moveHistory.pop(); if (move.submove != null) moveHistory.pop();
@ -150,8 +148,7 @@ public class Board {
void undoMove(Move move) { void undoMove(Move move) {
if (move == null) return; if (move == null) return;
Piece movedPiece = get(move.to); set(move.from, get(move.to));
set(move.from, move.isPromotion ? new Pawn(movedPiece.black, panel) : movedPiece);
set(move.to, move.captured); set(move.to, move.captured);
} }

View file

@ -6,7 +6,6 @@ public class Move {
public Piece captured; public Piece captured;
// e.g. castling, castle move. Done after. // e.g. castling, castle move. Done after.
public Move submove; public Move submove;
public boolean isPromotion;
public Move(BoardCoordinate from, BoardCoordinate to) { public Move(BoardCoordinate from, BoardCoordinate to) {
this.from = from; this.from = from;

View file

@ -12,36 +12,11 @@ public class Pawn extends Piece {
public ArrayList<Move> getPossibleMoves(BoardCoordinate position, Board board) { public ArrayList<Move> getPossibleMoves(BoardCoordinate position, Board board) {
ArrayList<Move> possibleMoves = new ArrayList<>(); ArrayList<Move> possibleMoves = new ArrayList<>();
if (this.black) { if (this.black) {
if (board.get(position.x, position.y + 1) == null) { possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y + 1)));
Move oneForward = new Move(position, new BoardCoordinate(position.x, position.y + 1)); if (!moved && board.get(position.x, position.y + 1) == null) possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y + 2)));
oneForward.isPromotion = position.y + 1 == Board.BOARD_SIZE - 1;
possibleMoves.add(oneForward);
if (!moved && board.get(position.x, position.y + 2) == null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y + 2)));
}
}
if (board.get(position.x - 1, position.y + 1) != null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x - 1,position.y + 1)));
}
if (board.get(position.x + 1, position.y + 1) != null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x + 1,position.y + 1)));
}
} else { } else {
if (board.get(position.x, position.y - 1) == null) { possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y - 1)));
Move oneForward = new Move(position, new BoardCoordinate(position.x, position.y - 1)); if (!moved && board.get(position.x, position.y - 1) == null) possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y - 2)));
oneForward.isPromotion = position.y - 1 == 0;
possibleMoves.add(oneForward);
if (!moved && board.get(position.x, position.y - 2) == null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x, position.y - 2)));
}
}
if (board.get(position.x - 1, position.y - 1) != null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x - 1,position.y - 1)));
}
if (board.get(position.x + 1, position.y - 1) != null) {
possibleMoves.add(new Move(position, new BoardCoordinate(position.x + 1,position.y - 1)));
}
} }
return possibleMoves; return possibleMoves;
} }