#include <pool_type.hpp>
| Public Member Functions | |
| Pool (const char *name) | |
| Constructor. | |
| void | CleanPool () | 
| Destroys all items in the pool and resets all member variables. | |
| FORCEINLINE Titem * | Get (size_t index) | 
| Returs Titem with given index. | |
| FORCEINLINE bool | IsValidID (size_t index) | 
| Tests whether given index can be used to get valid (non-NULL) Titem. | |
| FORCEINLINE bool | CanAllocate (size_t n=1) | 
| Tests whether we can allocate 'n' items. | |
| Data Fields | |
| const char *const | name | 
| Name of this pool. | |
| size_t | size | 
| Current allocated size. | |
| size_t | first_free | 
| No item with index lower than this is free (doesn't say anything about this one!). | |
| size_t | first_unused | 
| This and all higher indexes are free (doesn't say anything about first_unused-1 !). | |
| size_t | items | 
| Number of used indexes (non-NULL). | |
| bool | cleaning | 
| True if cleaning pool (deleting all items). | |
| Titem ** | data | 
| Pointer to array of pointers to Titem. | |
| Static Public Attributes | |
| static const size_t | MAX_SIZE = Tmax_size | 
| Make template parameter accessible from outside. | |
| Private Member Functions | |
| void * | AllocateItem (size_t size, size_t index) | 
| Makes given index valid. | |
| void | ResizeFor (size_t index) | 
| Resizes the pool so 'index' can be addressed. | |
| size_t | FindFirstFree () | 
| Searches for first free index. | |
| void * | GetNew (size_t size) | 
| Allocates new item. | |
| void * | GetNew (size_t size, size_t index) | 
| Allocates new item with given index. | |
| void | FreeItem (size_t index) | 
| Deallocates memory used by this index and marks item as free. | |
| Private Attributes | |
| AllocCache * | alloc_cache | 
| Cache of freed pointers. | |
| Static Private Attributes | |
| static const size_t | NO_FREE_ITEM = MAX_UVALUE(size_t) | 
| Contant to indicate we can't allocate any more items. | |
| Data Structures | |
| struct | AllocCache | 
| Helper struct to cache 'freed' PoolItems so we do not need to allocate them again.  More... | |
| struct | PoolItem | 
| Base class for all PoolItems.  More... | |
| Titem | Type of the class/struct that is going to be pooled | |
| Tindex | Type of the index for this pool | |
| Tgrowth_step | Size of growths; if the pool is full increase the size by this amount | |
| Tmax_size | Maximum size of the pool | |
| Tcache | Whether to perform 'alloc' caching, i.e. don't actually free/malloc just reuse the memory | |
| Tzero | Whether to zero the memory | 
Definition at line 26 of file pool_type.hpp.
| FORCEINLINE Titem* Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::Get | ( | size_t | index | ) |  [inline] | 
Returs Titem with given index.
| index | of item to get | 
Definition at line 51 of file pool_type.hpp.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::data, and Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::first_unused.
Referenced by SpecializedVehicle< RoadVehicle, VEH_ROAD >::Get(), SpecializedVehicle< RoadVehicle, VEH_ROAD >::IsValidID(), and Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::IsValidID().
| FORCEINLINE bool Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::IsValidID | ( | size_t | index | ) |  [inline] | 
Tests whether given index can be used to get valid (non-NULL) Titem.
| index | index to examine | 
Definition at line 62 of file pool_type.hpp.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::first_unused, and Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::Get().
Referenced by SpecializedVehicle< RoadVehicle, VEH_ROAD >::IsValidID().
| FORCEINLINE bool Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::CanAllocate | ( | size_t | n = 1 | ) |  [inline] | 
Tests whether we can allocate 'n' items.
| n | number of items we want to allocate | 
Definition at line 72 of file pool_type.hpp.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::items.
| void* Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::AllocateItem | ( | size_t | size, | |
| size_t | index | |||
| ) |  [private] | 
Makes given index valid.
| size | size of item | |
| index | index of item | 
this->Get(index) == NULL
| void Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::ResizeFor | ( | size_t | index | ) |  [private] | 
Resizes the pool so 'index' can be addressed.
| index | index we will allocate later | 
index < Tmax_size
| size_t Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::FindFirstFree | ( | ) |  [private] | 
Searches for first free index.
| void* Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::GetNew | ( | size_t | size | ) |  [private] | 
Allocates new item.
| size | size of item | 
| void* Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::GetNew | ( | size_t | size, | |
| size_t | index | |||
| ) |  [private] | 
Allocates new item with given index.
| size | size of item | |
| index | index of item | 
| void Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tcache, Tzero >::FreeItem | ( | size_t | index | ) |  [private] | 
Deallocates memory used by this index and marks item as free.
| index | item to deallocate | 
 1.5.6
 1.5.6