Files
@ r11504:4c9004317ccb
Branch filter:
Location: cpp/openttd-patchpack/source/src/oldpool.cpp - annotation
r11504:4c9004317ccb
2.1 KiB
text/x-c
(svn r15870) -Codechange: New widgets for the autoreplace window.
r5584:545d748cc681 r5584:545d748cc681 r9111:983de9c5a848 r6351:0ad6f06c84a9 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r8130:bece2e5c7460 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r7413:3ccdde9800e0 r5584:545d748cc681 r7375:6e8d6e5fb07f r7375:6e8d6e5fb07f r7375:6e8d6e5fb07f r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r7413:3ccdde9800e0 r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r7375:6e8d6e5fb07f r7375:6e8d6e5fb07f r7378:2aebcfdbd3c3 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r11216:1fb6ec55b11b r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r7375:6e8d6e5fb07f r5584:545d748cc681 r7375:6e8d6e5fb07f r7375:6e8d6e5fb07f r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 r5584:545d748cc681 | /* $Id$ */
/** @file oldpool.cpp Implementation of the old pool. */
#include "stdafx.h"
#include "debug.h"
#include "oldpool.h"
#include "core/alloc_func.hpp"
/**
* Clean a pool in a safe way (does free all blocks)
*/
void OldMemoryPoolBase::CleanPool()
{
uint i;
DEBUG(misc, 4, "[Pool] (%s) cleaning pool..", this->name);
this->cleaning_pool = true;
/* Free all blocks */
for (i = 0; i < this->current_blocks; i++) {
if (this->clean_block_proc != NULL) {
this->clean_block_proc(i * (1 << this->block_size_bits), (i + 1) * (1 << this->block_size_bits) - 1);
}
free(this->blocks[i]);
}
this->cleaning_pool = false;
/* Free the block itself */
free(this->blocks);
/* Clear up some critical data */
this->total_items = 0;
this->current_blocks = 0;
this->blocks = NULL;
this->first_free_index = 0;
}
/**
* This function tries to increase the size of array by adding
* 1 block too it
*
* @return Returns false if the pool could not be increased
*/
bool OldMemoryPoolBase::AddBlockToPool()
{
/* Is the pool at his max? */
if (this->max_blocks == this->current_blocks) return false;
this->total_items = (this->current_blocks + 1) * (1 << this->block_size_bits);
DEBUG(misc, 4, "[Pool] (%s) increasing size of pool to %d items (%d bytes)", this->name, this->total_items, this->total_items * this->item_size);
/* Increase the poolsize */
this->blocks = ReallocT(this->blocks, this->current_blocks + 1);
/* Allocate memory to the new block item */
this->blocks[this->current_blocks] = CallocT<byte>(this->item_size * (1 << this->block_size_bits));
/* Call a custom function if defined (e.g. to fill indexes) */
if (this->new_block_proc != NULL) this->new_block_proc(this->current_blocks * (1 << this->block_size_bits));
/* We have a new block */
this->current_blocks++;
return true;
}
/**
* Adds blocks to the pool if needed (and possible) till index fits inside the pool
*
* @return Returns false if adding failed
*/
bool OldMemoryPoolBase::AddBlockIfNeeded(uint index)
{
while (index >= this->total_items) {
if (!this->AddBlockToPool()) return false;
}
return true;
}
|