/*
 *******************************************************************
 *******************************************************************
 *
 *
 * KREVERSI
 *
 *
 *******************************************************************
 *
 * A Reversi (or sometimes called Othello) game
 *
 *******************************************************************
 *
 * Created 1997 by Mario Weilguni <mweilguni@sime.com>. This file
 * is ported from Mats Luthman's <Mats.Luthman@sylog.se> JAVA applet.
 * Many thanks to Mr. Luthman who has allowed me to put this port
 * under the GNU GPL. Without his wonderful game engine kreversi
 * would be just another of those Reversi programs a five year old
 * child could beat easily. But with it it's a worthy opponent!
 *
 * If you are interested on the JAVA applet of Mr. Luthman take a
 * look at http://www.sylog.se/~mats/
 *
 *******************************************************************
 *
 * This file is part of the KDE project "KREVERSI"
 *
 * KREVERSI 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, or (at your option)
 * any later version.
 *
 * KREVERSI 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 KREVERSI; see the file COPYING.  If not, write to
 * the Free Software Foundation, 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA.
 *
 *******************************************************************
 */

#include "Move.h"


SimpleMove::SimpleMove(Color color, int x, int y)
{
  m_color = color;
  m_x     = x;
  m_y     = y;
}


SimpleMove::SimpleMove(const SimpleMove &move)
{
  *this = move;
}


TQString SimpleMove::asString() const
{
  if (m_x == -1)
    return TQString("pass");
  else
    return TQString("%1%2").arg(" ABCDEFGH"[m_x]).arg(" 12345678"[m_y]);
}


// ================================================================


Move::Move()
  : SimpleMove()
{
  m_turnedPieces.clear();
}


Move::Move(Color color, int x, int y)
  : SimpleMove(color, x, y)
{
  m_turnedPieces.clear();
}


Move::Move(const Move &move)
  : SimpleMove((SimpleMove&) move)
{
  m_turnedPieces.clear();
}


Move::Move(const SimpleMove &move)
  : SimpleMove(move)
{
  m_turnedPieces.clear();
}


// ----------------------------------------------------------------


bool Move::squareModified(uint x, uint y) const
{
  return (m_x == (int) x && m_y == (int) y) || wasTurned(x, y);
}


bool Move::wasTurned(uint x, uint y) const
{
  // findIndex returns the first index where the item is found, or -1
  // if not found.
  return (m_turnedPieces.findIndex(10 * x + y) != -1);
}