47#ifdef KICAD_GAL_PROFILE
68 assert( aItem !=
nullptr );
70 unsigned int itemSize = aItem->
GetSize();
81 assert(
m_item !=
nullptr );
105#if CACHED_CONTAINER_TEST > 1
113 assert(
m_item !=
nullptr );
120 unsigned int newSize = itemSize + aSize;
140#if CACHED_CONTAINER_TEST > 0
143#if CACHED_CONTAINER_TEST > 2
154 assert( aItem !=
nullptr );
172#if CACHED_CONTAINER_TEST > 0
201 for( ITEMS::iterator it =
m_items.begin(); it !=
m_items.end(); ++it )
202 ( *it )->setSize( 0 );
220 FREE_CHUNK_MAP::iterator newChunk =
m_freeChunks.lower_bound( aSize );
250 assert( newChunkSize >= aSize );
279 ITEMS::iterator it, it_end;
295 int itemOffset = item->GetOffset();
296 int itemSize = item->GetSize();
302 item->setOffset( newOffset );
305 newOffset += itemSize;
322 __except( GetExceptionCode() == STATUS_ACCESS_VIOLATION ? EXCEPTION_EXECUTE_HANDLER
323 : EXCEPTION_CONTINUE_SEARCH )
325 throw std::runtime_error(
326 "Access violation in defragment. This is usually an indicator of "
327 "system or GPU memory running low." );
342#ifdef KICAD_GAL_PROFILE
347 std::list<CHUNK> freeChunks;
349 FREE_CHUNK_MAP::const_iterator it, it_end;
353 freeChunks.emplace_back( it->second, it->first );
359 std::list<CHUNK>::const_iterator itf, itf_end;
360 unsigned int offset = freeChunks.front().first;
361 unsigned int size = freeChunks.front().second;
362 freeChunks.pop_front();
364 for( itf = freeChunks.begin(), itf_end = freeChunks.end(); itf != itf_end; ++itf )
366 if( itf->first == offset + size )
385#if CACHED_CONTAINER_TEST > 0
396 m_freeChunks.insert( std::make_pair( aSize, aOffset ) );
413#ifdef KICAD_GAL_PROFILE
415 unsigned int freeSpace = 0;
416 FREE_CHUNK_MAP::iterator itf;
424 unsigned int used_space = 0;
428 used_space += ( *itr )->GetSize();
unsigned int m_chunkOffset
Maximal vertex index number stored in the container.
void addFreeChunk(unsigned int aOffset, unsigned int aSize)
Add a chunk marked as a free space.
int getChunkSize(const CHUNK &aChunk) const
Return the size of a chunk.
void mergeFreeChunks()
Look for consecutive free memory chunks and merges them, decreasing fragmentation of memory.
void showFreeChunks()
Debug & test functions.
VERTEX_ITEM * m_item
Properties of currently modified chunk & item.
FREE_CHUNK_MAP m_freeChunks
Stored VERTEX_ITEMs.
void defragment(VERTEX *aTarget)
Transfer all stored data to a new buffer, removing empty spaces between the data chunks in the contai...
virtual void FinishItem() override
Clean up after adding an item.
virtual void Delete(VERTEX_ITEM *aItem) override
Remove all data stored in the container and restores its original state.
unsigned int getChunkOffset(const CHUNK &aChunk) const
Return the offset of a chunk.
virtual VERTEX * Allocate(unsigned int aSize) override
Return allocated space for the requested number of vertices associated with the current item (set wit...
virtual void Clear() override
Remove all data stored in the container and restores its original state.
virtual bool defragmentResize(unsigned int aNewSize)=0
Remove empty spaces between chunks and optionally resizes the container.
virtual void SetItem(VERTEX_ITEM *aItem) override
Clean up after adding an item.
CACHED_CONTAINER(unsigned int aSize=DEFAULT_SIZE)
virtual bool IsMapped() const =0
Return true if vertex buffer is currently mapped.
ITEMS m_items
Currently modified item.
bool reallocate(unsigned int aSize)
Resize the chunk that stores the current item to the given size.
unsigned int m_initialSize
Actual storage memory.
unsigned int m_currentSize
Store the initial size, so it can be resized to this on Clear()
unsigned int m_freeSpace
Current container size, expressed in vertices.
unsigned int usedSpace() const
Return size of the used memory space.
bool m_dirty
Default initial size of a container (expressed in vertices)
void setSize(unsigned int aSize)
Set data size in the container.
void setOffset(unsigned int aOffset)
Set data offset in the container.
unsigned int GetOffset() const
Return data offset in the container.
unsigned int GetSize() const
Return information about number of vertices stored.
A small class to help profiling.
The Cairo implementation of the graphics abstraction layer.
static constexpr size_t VERTEX_SIZE
Class to handle an item held in a container.