summaryrefslogtreecommitdiff
path: root/tableau.h
blob: 003d9bb569a43c638a96bfbe02fc6be27ee51ab2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
 * Spider-Arachnid: A plugin for the Video Disk Recorder
 *
 * See the README file for copyright information and how to reach the author.
 *
 * $Id: tableau.h 2 2005-05-14 22:25:56Z tom $
 */

#ifndef VDR_SPIDER_TABLEAU_H
#define VDR_SPIDER_TABLEAU_H

#include "spider.h"
class Deck;
class Card;
class Pack;
class Pile;
typedef Array<Pile*> Piles;
class FinalHeap;
typedef Array<FinalHeap*> Finals;
class History;


/** --- class Tableau ------------------------------------------------------ **/

class Tableau
{
private:
  int dealCount;
  int cardsToOpen;
  Deck& deck;

public:
  Pack* pack;
  Piles piles;
  Finals finals;
  Pile* selected;
  bool changed;
  History* history;

  /** Constructor */
  Tableau(Deck& deck, int pileCount, int finalCount, int deals);

  /** Destructor */
  ~Tableau();

  /** Current count of deals */
  int deals();

  /** Current count of points */
  int points();

  /** Is no pile empty? */
  bool noPileEmpty();

  /** Matches all cards in all piles? */
  bool allCardsMatches();

  /** Is the game over? */
  bool gameOver();

  /** Select p-th pile by selecting up to max matching cards on its end */
  void select(int p, int max = 0);

  /** Unselect the selected pile */
  void unselect();

  /** Move cards from selected pile to p-th pile */
  void move(int p);

  /** Search move from p-th pile to the next left pile, return destination */
  int autoMoveLeft(int p);

  /** Search move from p-th pile to the next right pile, return destination */
  int autoMoveRight(int p);

  /** Search best move from p-th pile, return destination */
  int autoMove(int p);

  /** Deal one row */
  void deal();

  /** Remove one suit of cards from selected pile to the final heaps */
  void remove();

  /** Go one move backward in the history */
  void backward();

  /** Go one move forward in the history */
  void forward();
};

#endif // VDR_SPIDER_TABLEAU_H