summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsmatz <smatz@openttd.org>2011-02-19 18:23:45 +0000
committersmatz <smatz@openttd.org>2011-02-19 18:23:45 +0000
commit5fd13843f7ada744d221ea473ba781809cd97a85 (patch)
tree9fd77646595456e84a019e400a7de191017da811
parent68bc93f95074702fde2876904198f585969201cc (diff)
downloadopenttd-5fd13843f7ada744d221ea473ba781809cd97a85.tar.xz
(svn r22112) -Codechange: register all pools in a pool vector
-rw-r--r--projects/openttd_vs100.vcxproj1
-rw-r--r--projects/openttd_vs100.vcxproj.filters3
-rw-r--r--projects/openttd_vs80.vcproj4
-rw-r--r--projects/openttd_vs90.vcproj4
-rw-r--r--source.list1
-rw-r--r--src/core/pool_func.cpp30
-rw-r--r--src/core/pool_type.hpp45
7 files changed, 86 insertions, 2 deletions
diff --git a/projects/openttd_vs100.vcxproj b/projects/openttd_vs100.vcxproj
index 98a1be706..c1bb317d3 100644
--- a/projects/openttd_vs100.vcxproj
+++ b/projects/openttd_vs100.vcxproj
@@ -619,6 +619,7 @@
<ClInclude Include="..\src\core\math_func.hpp" />
<ClInclude Include="..\src\core\mem_func.hpp" />
<ClInclude Include="..\src\core\overflowsafe_type.hpp" />
+ <ClCompile Include="..\src\core\pool_func.cpp" />
<ClInclude Include="..\src\core\pool_func.hpp" />
<ClInclude Include="..\src\core\pool_type.hpp" />
<ClCompile Include="..\src\core\random_func.cpp" />
diff --git a/projects/openttd_vs100.vcxproj.filters b/projects/openttd_vs100.vcxproj.filters
index dece30451..16031fa6c 100644
--- a/projects/openttd_vs100.vcxproj.filters
+++ b/projects/openttd_vs100.vcxproj.filters
@@ -1077,6 +1077,9 @@
<ClInclude Include="..\src\core\overflowsafe_type.hpp">
<Filter>Core Source Code</Filter>
</ClInclude>
+ <ClCompile Include="..\src\core\pool_func.cpp">
+ <Filter>Core Source Code</Filter>
+ </ClCompile>
<ClInclude Include="..\src\core\pool_func.hpp">
<Filter>Core Source Code</Filter>
</ClInclude>
diff --git a/projects/openttd_vs80.vcproj b/projects/openttd_vs80.vcproj
index ca82ba786..33701798d 100644
--- a/projects/openttd_vs80.vcproj
+++ b/projects/openttd_vs80.vcproj
@@ -1755,6 +1755,10 @@
>
</File>
<File
+ RelativePath=".\..\src\core\pool_func.cpp"
+ >
+ </File>
+ <File
RelativePath=".\..\src\core\pool_func.hpp"
>
</File>
diff --git a/projects/openttd_vs90.vcproj b/projects/openttd_vs90.vcproj
index 634330007..4d6671c20 100644
--- a/projects/openttd_vs90.vcproj
+++ b/projects/openttd_vs90.vcproj
@@ -1752,6 +1752,10 @@
>
</File>
<File
+ RelativePath=".\..\src\core\pool_func.cpp"
+ >
+ </File>
+ <File
RelativePath=".\..\src\core\pool_func.hpp"
>
</File>
diff --git a/source.list b/source.list
index aa56688bd..5dfb06adb 100644
--- a/source.list
+++ b/source.list
@@ -369,6 +369,7 @@ core/math_func.cpp
core/math_func.hpp
core/mem_func.hpp
core/overflowsafe_type.hpp
+core/pool_func.cpp
core/pool_func.hpp
core/pool_type.hpp
core/random_func.cpp
diff --git a/src/core/pool_func.cpp b/src/core/pool_func.cpp
new file mode 100644
index 000000000..4c55293eb
--- /dev/null
+++ b/src/core/pool_func.cpp
@@ -0,0 +1,30 @@
+/* $Id$ */
+
+/*
+ * This file is part of OpenTTD.
+ * OpenTTD 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, version 2.
+ * OpenTTD 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 OpenTTD. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+/** @file pool_func.cpp Implementation of PoolBase methods. */
+
+#include "../stdafx.h"
+#include "pool_type.hpp"
+
+PoolBase::~PoolBase()
+{
+ PoolVector *pools = PoolBase::GetPools();
+ pools->Erase(pools->Find(this));
+ if (pools->Length() == 0) delete pools;
+}
+
+/* static */ void PoolBase::CleanAll()
+{
+ PoolVector *pools = PoolBase::GetPools();
+ PoolBase **end = pools->End();
+ for (PoolBase **ppool = pools->Begin(); ppool != end; ppool++) {
+ PoolBase *pool = *ppool;
+ pool->CleanPool();
+ }
+}
diff --git a/src/core/pool_type.hpp b/src/core/pool_type.hpp
index 395aa8438..e96608bdb 100644
--- a/src/core/pool_type.hpp
+++ b/src/core/pool_type.hpp
@@ -12,6 +12,47 @@
#ifndef POOL_TYPE_HPP
#define POOL_TYPE_HPP
+#include "smallvec_type.hpp"
+
+typedef SmallVector<struct PoolBase *, 4> PoolVector; ///< Vector of pointers to PoolBase
+
+/** Base class for base of all pools. */
+struct PoolBase {
+ /**
+ * Function used to access the vector of all pools.
+ * @return pointer to vector of all pools
+ */
+ static PoolVector *GetPools()
+ {
+ static PoolVector *pools = new PoolVector();
+ return pools;
+ }
+
+ /**
+ * Clean all pools - calls Pool::CleanPool()
+ */
+ static void CleanAll();
+
+ /**
+ * Contructor registers this object in the pool vector.
+ */
+ PoolBase()
+ {
+ *PoolBase::GetPools()->Append() = this;
+ }
+
+ /**
+ * Destructor removes this object from the pool vector and
+ * deletes the vector itself if this was the last item removed.
+ */
+ ~PoolBase();
+
+ /**
+ * Virtual method that deletes all items in the pool.
+ */
+ virtual void CleanPool() = 0;
+};
+
/**
* Base class for all pools.
* @tparam Titem Type of the class/struct that is going to be pooled
@@ -23,7 +64,7 @@
* @warning when Tcache is enabled *all* instances of this pool's item must be of the same size.
*/
template <class Titem, typename Tindex, size_t Tgrowth_step, size_t Tmax_size, bool Tcache = false, bool Tzero = true>
-struct Pool {
+struct Pool : PoolBase {
static const size_t MAX_SIZE = Tmax_size; ///< Make template parameter accessible from outside
const char * const name; ///< Name of this pool
@@ -40,7 +81,7 @@ struct Pool {
Titem **data; ///< Pointer to array of pointers to Titem
Pool(const char *name);
- void CleanPool();
+ virtual void CleanPool();
/**
* Returs Titem with given index