00001
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00033
00034 #ifndef GROOVX_RUTZ_FREELIST_H_UTC20050626084020_DEFINED
00035 #define GROOVX_RUTZ_FREELIST_H_UTC20050626084020_DEFINED
00036
00037 #include <cstddef>
00038
00039 namespace rutz
00040 {
00041 class free_list_base;
00042 template <class T> class free_list;
00043 }
00044
00046 class rutz::free_list_base
00047 {
00048 private:
00050 struct node
00051 {
00052 node* next;
00053 };
00054
00055 node* m_node_list;
00056 std::size_t m_num_allocations;
00057 const std::size_t m_size_check;
00058
00059 free_list_base(const free_list_base&);
00060 free_list_base& operator=(const free_list_base&);
00061
00062 public:
00064
00065 free_list_base(std::size_t size_check);
00066
00068
00071 void* allocate(std::size_t bytes);
00072
00074 void deallocate(void* space);
00075
00077 void release_free_nodes();
00078
00080 std::size_t alloc_size() const { return m_size_check; }
00081
00083 std::size_t num_allocations() const { return m_num_allocations; }
00084 };
00085
00087 template <class T>
00088 class rutz::free_list
00089 {
00090 private:
00091 rutz::free_list_base m_base;
00092
00093 public:
00095
00096 free_list() : m_base(sizeof(T)) {}
00097
00098 void* allocate(std::size_t bytes)
00099 {
00100 return m_base.allocate(bytes);
00101 }
00102
00103 void deallocate(void* space)
00104 {
00105 m_base.deallocate(space);
00106 }
00107
00109 void release_free_nodes() { m_base.release_free_nodes(); }
00110 };
00111
00112 static const char __attribute__((used)) vcid_groovx_rutz_freelist_h_utc20050626084020[] = "$Id: freelist.h 10095 2007-08-07 19:07:44Z rjpeters $ $HeadURL: file:
00113 #endif // !GROOVX_RUTZ_FREELIST_H_UTC20050626084020_DEFINED