/* $Id$ Copyright (C) 2006-2007 by David Cotton This program 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 2 of the License, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package fr.free.jchecs.core; import java.io.Serializable; /** * Interface mise à disposition par les classes décrivant une état instantanné de la partie. * <p> * Les instances de descriptions d'état doivent être immuables. Les comparaisons et la méthode de * calcul des clés de hachage sont supposées compatibles entre les différentes implémentations. * </p> * * @author David Cotton */ public interface Board extends Comparable<Board>, Serializable { /** * Renvoi l'état du droit de roquer côté roi (petit roque) pour une couleur. * * @param pBlanc Positionné à "true" pour obtenir l'état des blancs. * @return Etat du droit de roquer côté roi pour la couleur. */ boolean canCastleLong(final boolean pBlanc); /** * Renvoi l'état du droit de roquer côté reine (grand roque) pour une couleur. * * @param pBlanc Positionné à "true" pour obtenir l'état des blancs. * @return Etat du droit de roquer côté reine pour la couleur. */ boolean canCastleShort(final boolean pBlanc); /** * Renvoi l'éventuelle case cible de la prise "en passant" en cours. * * @return Case cible de la price "en passant" (peut être à null). */ Square getEnPassant(); /** * Renvoi le numéro du coup. * * @return Numéro de coup (> 0). */ int getFullmoveNumber(); /** * Renvoi la valeur du compteur de demi-coups depuis la dernière prise ou le dernier mouvement de * pion. * * @return Nombre de demi-coups (>= 0). */ int getHalfmoveCount(); /** * Renvoi l'éventuelle pièce présente sur la case indiquée. * * @param pCase Case à tester. * @return Pièce présente sur la case (ou null si aucune). */ Piece getPieceAt(final Square pCase); /** * Renvoi l'éventuelle pièce présente sur la case dont les coordonnées sont indiquées. * * @param pColonne Colonne de la case à tester (de 0 à 7). * @param pLigne Ligne de la case à tester (de 0 à 7). * @return Pièce présente sur la case (ou null). */ Piece getPieceAt(final int pColonne, final int pLigne); /** * Indique si le trait est aux blancs. * * @return "true" si le trait est aux blancs, "false" s'il est aux noirs. */ boolean isWhiteActive(); }