/* * This file is part of rasdaman community. * * Rasdaman community is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Rasdaman community is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with rasdaman community. If not, see . * * Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann / rasdaman GmbH. * * For more information please see * or contact Peter Baumann via . / /** * INCLUDE: memblockvec.hh * * MODULE: raslib * CLASS: r_Memory_Block_Vector * * COMMENTS: * */ #ifndef _MEMORY_BLOCK_VECTOR_H_ #define _MEMORY_BLOCK_VECTOR_H_ #include "raslib/mddtypes.hh" //@ManMemo: Module {\bf raslib} /*@Doc: Auxiliary class, realizes a set of memory blocks of equal size that can be extended to any size. Used by some children of r_LinCompStream. */ class r_Memory_Block_Vector { public: /// constructor, receiving the size of each memory block and the granularity /// for extending the number of blocks. r_Memory_Block_Vector( r_Bytes bsize=4096, unsigned int gran=8 ); /// destructor ~r_Memory_Block_Vector( void ); /// return number of blocks inline unsigned int get_number( void ) const {return numBlocks;} /// return block size inline r_Bytes get_block_size( void ) const {return blockSize;} /// return granularity inline unsigned int get_granularity( void ) const {return granularity;} /// get a block void* operator[]( unsigned int idx ) const; /// add a new block and return a pointer to it void* add( void ); /// free all blocks (but not the vector, call the destructor for that) void free_data( void ); /// get number of bytes stored. lastFill is the number of bytes used /// in the last block r_Bytes get_size( r_Bytes lastFill ) const; /// Copy the data stored in blocks into linear memory. lastFill is the /// number of bytes in the last block void copy_data( void* dest, r_Bytes lastFill ) const; protected: /// the array of memory block pointers void** blocks; unsigned int numBlocks; unsigned int maxBlocks; /// the size of the blocks r_Bytes blockSize; /// the granularity unsigned int granularity; }; #endif