aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.Client/Common/C4JMemoryPoolAllocator.h
blob: a46cc76dbc215e291bf0a52ba53e23643c3abe15 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#pragma once
#include "..\Minecraft.Client\Common\C4JMemoryPool.h"

// Custom allocator, takes a C4JMemoryPool class, which can be one of a number of pool implementations.

template <class T>
class C4JPoolAllocator
{
public:
    typedef T          value_type;
    typedef size_t     size_type;
    typedef ptrdiff_t  difference_type;
 
    typedef T*         pointer;
    typedef const T*   const_pointer;
 
    typedef T&         reference;
    typedef const T&   const_reference;
 
	//! A struct to construct an allocator for a different type.
	template<typename U> 
	struct rebind { typedef C4JPoolAllocator<U> other; };


	C4JMemoryPool*	m_pPool;
	bool			m_selfAllocated;

	C4JPoolAllocator( C4JMemoryPool* pool = new C4JMemoryPoolFixed(32, 4096 )) : m_pPool( pool ), m_selfAllocated(true) 
	{
		printf("allocated mempool\n");
	}

	template<typename U>
	C4JPoolAllocator(C4JPoolAllocator<U> const& obj) : m_pPool( obj.m_pPool ), m_selfAllocated(false) // copy constructor
    {
		printf("C4JPoolAllocator constructed from 0x%08x\n", &obj);
		assert(obj.m_pPool);
    }
private:

public:
  
    ~C4JPoolAllocator()
    {
		if(m_selfAllocated)
			delete m_pPool;
    }
 
    pointer address( reference r ) const				{ return &r; }
    const_pointer address( const_reference r ) const    { return &r; }
 
    pointer allocate( size_type n, const void* /*hint*/=0 )
    {
		assert(m_pPool);
        return (pointer)m_pPool->Alloc(n * sizeof(T));
    }
 
    void deallocate( pointer p, size_type /*n*/ )
    {
		assert(m_pPool);
		m_pPool->Free(p);
    }
 
    void construct( pointer p, const T& val )
    {
        new (p) T(val);
    }
 
    void destroy( pointer p )
    {
        p->~T();
    }
 
    size_type max_size() const
    {
        return ULONG_MAX / sizeof(T);
    }
 
};
 
 
template <class T>
bool
operator==( const C4JPoolAllocator<T>& left, const C4JPoolAllocator<T>& right )
{
	if (left.m_pPool == right.m_pPool)
    {
        return true;
    }
	return false;
}
 
template <class T>
bool
operator!=( const C4JPoolAllocator<T>& left, const C4JPoolAllocator<T>& right)
{
     if (left.m_pPool != right.m_pPool)
     {
         return true;
     }
    return false;
}