summaryrefslogtreecommitdiffstats
path: root/kjumpingcube/cubeboxbase.h
diff options
context:
space:
mode:
Diffstat (limited to 'kjumpingcube/cubeboxbase.h')
-rw-r--r--kjumpingcube/cubeboxbase.h246
1 files changed, 246 insertions, 0 deletions
diff --git a/kjumpingcube/cubeboxbase.h b/kjumpingcube/cubeboxbase.h
new file mode 100644
index 00000000..63bc0529
--- /dev/null
+++ b/kjumpingcube/cubeboxbase.h
@@ -0,0 +1,246 @@
+/* ****************************************************************************
+ This file is part of the game 'KJumpingCube'
+
+ Copyright (C) 1998-2000 by Matthias Kiefer
+
+ This program 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 of the License, or
+ (at your option) any later version.
+
+ This program 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 this program; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
+**************************************************************************** */
+#ifndef CUBEBOXBASE_H
+#define CUBEBOXBASE_H
+
+#ifdef DEBUG
+#include <assert.h>
+#endif
+
+template<class T>
+class CubeBoxBase
+{
+public:
+ enum Player{One=1,Two=2};
+
+ CubeBoxBase(const int dim=1);
+ virtual ~CubeBoxBase();
+
+ T** operator[](const int index);
+ /**
+ * sets number of Cubes in a row/column to 'size'.
+ */
+ virtual void setDim(int dim);
+
+ /**
+ * returns number of Cubes in a row/column
+ */
+ inline int dim() const { return _dim; }
+
+ inline Player player() const { return currentPlayer; }
+
+protected:
+ virtual void deleteCubes();
+ virtual void initCubes();
+
+ /** increases the neighbours of cube at ['row','column'] */
+ //void increaseNeighbours(int forWhom,int row,int column);
+
+ T*** cubes;
+ Player currentPlayer;
+
+private:
+ int _dim;
+
+};
+
+template<class T>
+CubeBoxBase<T>::CubeBoxBase(const int dim)
+{
+#ifdef DEBUG
+ assert(dim>0);
+#endif
+
+ _dim=dim;
+ currentPlayer=One;
+}
+
+template<class T>
+CubeBoxBase<T>::~CubeBoxBase()
+{
+ if(cubes)
+ deleteCubes();
+}
+
+template<class T>
+T** CubeBoxBase<T>::operator[](const int index)
+{
+#ifdef DEBUG
+ assert(index >= 0);
+#endif
+
+ return cubes[index];
+}
+
+template<class T>
+void CubeBoxBase<T>::setDim(int d)
+{
+ if(d != _dim)
+ {
+ deleteCubes();
+
+ _dim=d;
+
+ initCubes();
+ }
+}
+
+
+template<class T>
+void CubeBoxBase<T>::initCubes()
+{
+ const int s=dim();
+
+ int i,j;
+ // create new cubes
+ cubes = new T**[s];
+ for(i=0;i<s;i++)
+ {
+ cubes[i]=new T*[s];
+ }
+ for(i=0;i<s;i++)
+ for(j=0;j<s;j++)
+ {
+ cubes[i][j]=new T();
+ }
+
+ // initialize cubes
+ int max=dim()-1;
+
+ cubes[0][0]->setMax(2);
+ cubes[0][max]->setMax(2);
+ cubes[max][0]->setMax(2);
+ cubes[max][max]->setMax(2);
+
+ for(i=0;i<=max;i++)
+ {
+ cubes[i][0]->setMax(3);
+ cubes[i][max]->setMax(3);
+ cubes[0][i]->setMax(3);
+ cubes[max][i]->setMax(3);
+ }
+
+ for(i=1;i<max;i++)
+ for(j=1;j<max;j++)
+ {
+ cubes[i][j]->setMax(4);
+ }
+}
+
+template<class T>
+void CubeBoxBase<T>::deleteCubes()
+{
+ int i,j;
+ for(i=0;i<dim();i++)
+ for(j=0;j<dim();j++)
+ {
+ delete cubes[i][j];
+ }
+ for(i=0;i<dim();i++)
+ {
+ delete [] cubes[i];
+ }
+
+ delete [] cubes;
+
+ cubes=0;
+}
+/*
+template<class T>
+void CubeBoxBase<T>::increaseNeighbours(int forWhom,int row,int column)
+{
+ int _player = (T::Owner)(forWhom);
+
+ if(row==0)
+ {
+ if(column==0) // linke obere Ecke
+ {
+ cubes[0][1]->increase(_player);
+ cubes[1][0]->increase(_player);
+ return;
+ }
+ else if(column==dim()-1) // rechte obere Ecke
+ {
+ cubes[0][dim()-2]->increase(_player);
+ cubes[1][dim()-1]->increase(_player);
+ return;
+ }
+ else // oberer Rand
+ {
+ cubes[0][column-1]->increase(_player);
+ cubes[0][column+1]->increase(_player);
+ cubes[1][column]->increase(_player);
+ return;
+ }
+ }
+ else if(row==dim()-1)
+ {
+ if(column==0) // linke untere Ecke
+ {
+ cubes[dim()-2][0]->increase(_player);
+ cubes[dim()-1][1]->increase(_player);
+ return;
+ }
+
+ else if(column==dim()-1) // rechte untere Ecke
+ {
+ cubes[dim()-2][dim()-1]->increase(_player);
+ cubes[dim()-1][dim()-2]->increase(_player);
+ return;
+ }
+ else // unterer Rand
+ {
+ cubes[dim()-1][column-1]->increase(_player);
+ cubes[dim()-1][column+1]->increase(_player);
+ cubes[dim()-2][column]->increase(_player);
+ return;
+ }
+ }
+ else if(column==0) // linker Rand
+ {
+ cubes[row-1][0]->increase(_player);
+ cubes[row+1][0]->increase(_player);
+ cubes[row][1]->increase(_player);
+ return;
+ }
+ else if(column==dim()-1) // rechter Rand
+ {
+ cubes[row-1][dim()-1]->increase(_player);
+ cubes[row+1][dim()-1]->increase(_player);
+ cubes[row][dim()-2]->increase(_player);
+ return;
+ }
+ else
+ {
+ cubes[row][column-1]->increase(_player);
+ cubes[row][column+1]->increase(_player);
+ cubes[row-1][column]->increase(_player);
+ cubes[row+1][column]->increase(_player);
+ return;
+ }
+
+
+}
+*/
+
+#endif // CUBEBOXBASE_H
+