#if !defined hString_H #define hString_H #pragma warning (push, 3) //go back down to 3 for the stl include #include #include #include #include #pragma warning (pop) using namespace std; class hstring { int mId; void Init(const char *str); public: hstring() { mId=0; } hstring(const char *str) { Init(str); } hstring(const string &str) { Init(str.c_str()); } hstring(const hstring &str) { mId=str.mId; } operator string () const { return str(); } const char *c_str(void) const; string str(void) const; hstring& operator= (const char *str) { Init(str); return *this; } hstring& operator= (const string &str) { Init(str.c_str()); return *this; } hstring& operator= (const hstring &str) { mId=str.mId; return *this; } bool operator== (const hstring &str) const { return((mId==str.mId)?true:false); } int compare(const hstring &str) const { return strcmp(c_str(),str.c_str()); } bool operator< (const hstring &str) const { return((mId mMapBlocks; vector mFreeList; int mLastBlockNum; public: CMapPoolLow(); ~CMapPoolLow(); void *Alloc(); void Free(void *p); void TouchMem(); }; CMapPoolLow &GetMapPool(); template class CMapPool { CMapPoolLow &mPool; public: CMapPool() : mPool(GetMapPool()) { } template CMapPool(const U&) : mPool(GetMapPool()) { } ~CMapPool() { } typedef T value_type; typedef T* pointer; typedef const T* const_pointer; typedef T& reference; typedef const T& const_reference; typedef size_t size_type; typedef ptrdiff_t difference_type; template struct rebind { typedef CMapPool other; }; // return address of values pointer address (reference value) const { return &value; } const_pointer address (const_reference value) const { return &value; } // return maximum number of elements that can be allocated size_type max_size () const { return mMaxSize; } // allocate but don't initialize num elements of type T pointer allocate (size_type num, const void* = 0) { assert(sizeof(T)<=(MAP_NODE_SIZE-2)); // to big for this pool assert(num==1); //allocator not design for this return (T*)mPool.Alloc(); } void *_Charalloc(size_type size) { assert(size<=(MAP_NODE_SIZE-2)); // to big for this pool return mPool.Alloc(); } // initialize elements of allocated storage p with value value void construct (pointer p, const T& value) { // initialize memory with placement new new((void*)p)T(value); } // destroy elements of initialized storage p void destroy (pointer p) { // destroy objects by calling their destructor p->~T(); } // deallocate storage p of deleted elements template void deallocate (U *p, size_type num) { assert(num==1); //allocator not design for this mPool.Free(p); } }; template bool operator== (const CMapPool&, const CMapPool&) { return false; } template bool operator!= (const CMapPool&, const CMapPool&) { return true; } template > class hmap : public map >{}; template > class hmultimap : public multimap >{}; template > class hset : public set >{}; template > class hmultiset : public multiset >{}; template class hlist : public list >{}; #endif // hString_H