-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmem_pool_base.cpp
93 lines (82 loc) · 2.6 KB
/
mem_pool_base.cpp
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
// -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
// vim:tabstop=4:shiftwidth=4:expandtab:
/*
* Copyright (C) 2004-2014 Wu Yongwei <adah at users dot sourceforge dot net>
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event will the authors be held liable for any
* damages arising from the use of this software.
*
* Permission is granted to anyone to use this software for any purpose,
* including commercial applications, and to alter it and redistribute
* it freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you must
* not claim that you wrote the original software. If you use this
* software in a product, an acknowledgement in the product
* documentation would be appreciated but is not required.
* 2. Altered source versions must be plainly marked as such, and must
* not be misrepresented as being the original software.
* 3. This notice may not be removed or altered from any source
* distribution.
*
* This file is part of Stones of Nvwa:
* http://sourceforge.net/projects/nvwa
*
*/
/**
* @file mem_pool_base.cpp
*
* Implementation for the memory pool base.
*
* @date 2014-11-29
*/
#if defined(_MEM_POOL_USE_MALLOC)
#include <stdlib.h> // malloc/free
#else
#include <new> // std::bad_alloc
#endif
#include "_nvwa.h" // NVWA_NAMESPACE_*
#include "mem_pool_base.h" // nvwa::mem_pool_base
NVWA_NAMESPACE_BEGIN
/* Defines macros to abstract system memory routines */
# ifdef _MEM_POOL_USE_MALLOC
# define _MEM_POOL_ALLOCATE(_Sz) malloc(_Sz)
# define _MEM_POOL_DEALLOCATE(_Ptr) free(_Ptr)
# else
# define _MEM_POOL_ALLOCATE(_Sz) ::operator new((_Sz), std::nothrow)
# define _MEM_POOL_DEALLOCATE(_Ptr) ::operator delete(_Ptr)
# endif
/**
* @fn void mem_pool_base::recycle()
*
* Recycles unused memory from memory pools. It is an interface and
* needs to be implemented in subclasses.
*/
/**
* Empty base destructor.
*/
mem_pool_base::~mem_pool_base()
{
}
/**
* Allocates memory from the run-time system.
*
* @param size size of the memory to allocate in bytes
* @return pointer to allocated memory block if successful; or
* null if memory allocation fails
*/
void* mem_pool_base::alloc_sys(size_t size)
{
return _MEM_POOL_ALLOCATE(size);
}
/**
* Frees memory and returns it to the run-time system.
*
* @param ptr pointer to the memory block previously allocated
*/
void mem_pool_base::dealloc_sys(void* ptr)
{
_MEM_POOL_DEALLOCATE(ptr);
}
NVWA_NAMESPACE_END