/* Yo Emacs, this -*- C++ -*-
 *******************************************************************
 *******************************************************************
 *
 *
 * 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.
 *
 *******************************************************************
 */

// This file defines the two classes SimpleMove and Move.
//
// The class Move is used to represent an Othello move with a player value
// (see class Score) and a pair of coordinates on an 8x8 Othello board.
// Each coordinate can have values between 1 and 8, inclusive.
// 
// The difference between a Move and a SimpleMove is that a SimpleMove
// can be done (performed) in a Position, but a Move can be both done
// and undone.  In addition to the info in SimpleMove, the class Move
// stores information that is used in undoing the move and visualizing
// it.
//
// The reason for the class SimpleMove is that it saves memory.  The
// class Game stores an array of Moves, since the BoardView needs
// information about which pieces were turned by the move.
//


#ifndef __MOVE__H__
#define __MOVE__H__


#include "tqvaluelist.h"
#include "tqstring.h"

#include "Score.h"


class Position;


class SimpleMove
{
public:
  SimpleMove()   { m_color = Nobody; m_x = -1; m_y = -1; }
  SimpleMove(Color color, int x, int y);
  SimpleMove(const SimpleMove &move);

  //Move &operator=(Move &move);

  Color color() const { return m_color; }
  int   x()     const { return m_x; }
  int   y()     const { return m_y; }

  TQString  asString() const;

protected:
  Color  m_color;
  int    m_x;
  int    m_y;
};


// Note: This class is not memory optimized.  The list of turned
//       pieces can surely be made much smaller.

class Move : public SimpleMove
{
  friend class Position;

public:
  Move();
  Move(Color color, int x, int y);
  Move(const Move &move);
  Move(const SimpleMove &move);

  bool   squareModified(uint x, uint y) const;
  bool   wasTurned(uint x, uint y)      const;

private:
  TQValueList<char>  m_turnedPieces;
};


typedef TQValueList<Move>            MoveList;


#endif