mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-27 20:03:03 +01:00
91 lines
2.8 KiB
C++
91 lines
2.8 KiB
C++
#ifndef INCLUDE_FB_BLK
|
|
#define INCLUDE_FB_BLK
|
|
|
|
//#include <vector>
|
|
#include "../common/classes/alloc.h"
|
|
|
|
struct blk
|
|
{
|
|
};
|
|
typedef blk* BLK;
|
|
|
|
|
|
//typedef PtrWrapper<BLK> BlkPtr;
|
|
typedef blk* BlkPtr;
|
|
|
|
template<SSHORT BLOCK_TYPE = 0>
|
|
class pool_alloc : public blk
|
|
{
|
|
public:
|
|
#ifdef DEBUG_GDS_ALLOC
|
|
void* operator new(size_t s, MemoryPool& p, char* file, int line)
|
|
{ return p.calloc(s, BLOCK_TYPE, file, line); }
|
|
void* operator new[](size_t s, MemoryPool& p, char* file, int line)
|
|
{ return p.calloc(s, BLOCK_TYPE, file, line); }
|
|
#else
|
|
void* operator new(size_t s, MemoryPool& p )
|
|
{ return p.calloc(s, BLOCK_TYPE); }
|
|
void* operator new[](size_t s, MemoryPool& p)
|
|
{ return p.calloc(s, BLOCK_TYPE); }
|
|
#endif
|
|
|
|
void operator delete(void* mem, MemoryPool& p)
|
|
{ if (mem) p.deallocate(mem); }
|
|
void operator delete[](void* mem, MemoryPool& p)
|
|
{ if (mem) p.deallocate(mem); }
|
|
|
|
void operator delete(void* mem) { if (mem) MemoryPool::globalFree(mem); }
|
|
void operator delete[](void* mem) { if (mem) MemoryPool::globalFree(mem); }
|
|
|
|
private:
|
|
/* These operators are off-limits */
|
|
void* operator new(size_t s) { return 0; }
|
|
void* operator new[](size_t s) { return 0; }
|
|
};
|
|
|
|
template<class RPT, SSHORT BLOCK_TYPE = 0>
|
|
class pool_alloc_rpt : public blk
|
|
{
|
|
public:
|
|
#ifdef DEBUG_GDS_ALLOC
|
|
void* operator new(size_t s, MemoryPool& p, int rpt, char *file, int line)
|
|
{ return p.calloc(s + sizeof(RPT)*rpt, BLOCK_TYPE, file, line); }
|
|
#else
|
|
void* operator new(size_t s, MemoryPool& p, int rpt)
|
|
{ return p.calloc(s + sizeof(RPT)*rpt, BLOCK_TYPE); }
|
|
#endif
|
|
void operator delete(void* mem, MemoryPool& p,int rpt)
|
|
{ if (mem) p.deallocate(mem); }
|
|
void operator delete(void* mem) { if (mem) MemoryPool::globalFree(mem); }
|
|
|
|
private:
|
|
// These operations are not supported on static repeat-base objects
|
|
void* operator new[](size_t s, MemoryPool& p)
|
|
{ return 0; }
|
|
void operator delete[](void* mem, MemoryPool& p)
|
|
{ }
|
|
void operator delete[](void* mem) { }
|
|
|
|
private:
|
|
/* These operators are off-limits */
|
|
void* operator new(size_t s) { return 0; }
|
|
void* operator new[](size_t s) { return 0; }
|
|
};
|
|
|
|
/* template<class BASE, class RPT, UCHAR BLOCK_TYPE>
|
|
class vector_rpt : public BASE
|
|
{
|
|
private:
|
|
MemoryPool::allocator<RPT> rptAllocator;
|
|
vector_rpt(int size, MemoryPool& pool)
|
|
: rptAllocator(pool, BLOCK_TYPE), rpt(size, rptAllocator) {}
|
|
|
|
public:
|
|
std::vector<RPT> rpt;
|
|
|
|
static vector_rpt<BASE,RPT,BLOCK_TYPE>* allocate(int size, MemoryPool& p)
|
|
{ return new(p) vector_rpt<BASE,RPT,BLOCK_TYPE>(size,p); }
|
|
}; */
|
|
|
|
#endif /* INCLUDE_FB_BLK */
|