8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-27 20:03:03 +01:00
firebird-mirror/src/include/fb_blk.h

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 */