forked from qt-creator/qt-creator
Change-Id: I7009df49f79d8f895c5344f7be3558f7f3d35143 Reviewed-by: Orgad Shaneh <orgads@gmail.com>
99 lines
2.5 KiB
C++
99 lines
2.5 KiB
C++
// Copyright (c) 2008 Roberto Raggi <roberto.raggi@gmail.com>
|
|
//
|
|
// 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;
|
|
}
|
|
|
|
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 *)
|
|
{ }
|
|
|