| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- // Copyright (c) 2008 Roberto Raggi <[email protected]>
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- #include "MemoryPool.h"
- #include "cppassert.h"
- #include <cstring>
- using namespace CPlusPlus;
- MemoryPool::MemoryPool()
- : _blocks(0),
- _allocatedBlocks(0),
- _blockCount(-1),
- _ptr(0),
- _end(0)
- { }
- MemoryPool::~MemoryPool()
- {
- if (_blocks) {
- for (int i = 0; i < _allocatedBlocks; ++i) {
- if (char *b = _blocks[i])
- std::free(b);
- }
- std::free(_blocks);
- }
- }
- void MemoryPool::reset()
- {
- _blockCount = -1;
- _ptr = _end = 0;
- }
- void *MemoryPool::allocate_helper(size_t size)
- {
- CPP_CHECK(size < BLOCK_SIZE);
- if (++_blockCount == _allocatedBlocks) {
- if (! _allocatedBlocks)
- _allocatedBlocks = DEFAULT_BLOCK_COUNT;
- else
- _allocatedBlocks *= 2;
- _blocks = (char **) realloc(_blocks, sizeof(char *) * _allocatedBlocks);
- for (int index = _blockCount; index < _allocatedBlocks; ++index)
- _blocks[index] = 0;
- }
- char *&block = _blocks[_blockCount];
- if (! block)
- block = (char *) std::malloc(BLOCK_SIZE);
- _ptr = block;
- _end = _ptr + BLOCK_SIZE;
- void *addr = _ptr;
- _ptr += size;
- return addr;
- }
- RecursiveMemoryPool::RecursiveMemoryPool(MemoryPool *pool)
- : _pool(pool),
- _blockCount(pool->_blockCount),
- _ptr(pool->_ptr),
- _end(pool->_end)
- {
- }
- RecursiveMemoryPool::~RecursiveMemoryPool()
- {
- _pool->_blockCount = _blockCount;
- _pool->_ptr = _ptr;
- _pool->_end = _end;
- }
- Managed::Managed()
- { }
- Managed::~Managed()
- { }
- void *Managed::operator new(size_t size, MemoryPool *pool)
- { return pool->allocate(size); }
- void Managed::operator delete(void *)
- { }
- void Managed::operator delete(void *, MemoryPool *)
- { }
|