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
|
/*---------------------------------------------------------------------------
spider.cpp implements a patience card game
Copyright (C) 2003 Josh Metzler
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted,
* provided that the above copyright notice appear in all copies and that
* both that copyright notice and this permission notice appear in
* supporting documentation.
*
* This file is provided AS IS with no warranties of any kind. The author
* shall have no liability with respect to the infringement of copyrights,
* trade secrets or any patents by this file or any part thereof. In no
* event will the author be liable for any lost revenue or profits or
* other special, indirect and consequential damages.
---------------------------------------------------------------------------*/
#ifndef _SPIDER_H_
#define _SPIDER_H_
#include "dealer.h"
class SpiderPile : public Pile
{
public:
SpiderPile(int _index, Dealer* tqparent = 0) : Pile(_index, tqparent) {}
virtual void moveCards(CardList &c, Pile *to);
CardList getRun();
};
class Spider : public Dealer
{
Q_OBJECT
TQ_OBJECT
public:
Spider(int suits, KMainWindow *tqparent=0, const char *name=0);
void deal();
void dealRow();
void checkPileDeck(Pile *to);
virtual void restart();
virtual bool isGameLost() const;
public slots:
void deckClicked(Card *c);
protected:
virtual bool checkRemove(int /*checkIndex*/, const Pile *p, const Card *c) const;
virtual bool checkAdd(int /*checkIndex*/, const Pile *c1, const CardList &c2) const;
virtual TQString getGameState() const;
virtual void setGameState(const TQString &stream);
virtual void getHints();
virtual MoveHint *chooseHint();
virtual Card *demoNewCards();
private:
CardList getRun(Card *c) const;
SpiderPile *stack[10];
Pile *legs[8];
int m_leg;
Pile *redeals[5];
int m_redeal;
Deck *deck;
};
#endif
//-------------------------------------------------------------------------//
|