File indexing completed on 2024-11-24 03:44:59

0001 /*
0002  * Copyright (C) 2006-2009 Stephan Kulow <coolo@kde.org>
0003  *
0004  * This program is free software; you can redistribute it and/or
0005  * modify it under the terms of the GNU General Public License as
0006  * published by the Free Software Foundation; either version 2 of
0007  * the License, or (at your option) any later version.
0008  *
0009  * This program is distributed in the hope that it will be useful,
0010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
0011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
0012  * GNU General Public License for more details.
0013  *
0014  * You should have received a copy of the GNU General Public License
0015  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
0016  */
0017 
0018 #ifndef KLONDIKESOLVER_H
0019 #define KLONDIKESOLVER_H
0020 
0021 // own
0022 #include "patsolve.h"
0023 
0024 class Klondike;
0025 
0026 class KlondikeSolver : public Solver<9>
0027 {
0028 public:
0029     KlondikeSolver(const Klondike *dealer, int draw);
0030     int good_automove(int o, int r);
0031     int get_possible_moves(int *a, int *numout) override;
0032     bool isWon() override;
0033     void make_move(MOVE *m) override;
0034     void undo_move(MOVE *m) override;
0035     int getOuts() override;
0036     unsigned int getClusterNumber() override;
0037     void translate_layout() override;
0038     void unpack_cluster(unsigned int k) override;
0039     MoveHint translateMove(const MOVE &m) override;
0040 
0041     void print_layout() override;
0042 
0043     /* Names of the cards.  The ordering is defined in pat.h. */
0044 
0045     card_t O[4]; /* output piles store only the rank or NONE */
0046     card_t Osuit[4];
0047 
0048     const Klondike *deal;
0049     int m_draw;
0050 };
0051 
0052 #endif // KLONDIKESOLVER_H