Mercurial > sdl-ios-xcode
view src/main/symbian/EKA2/vectorbuffer.cpp @ 4543:d7cdc25af9a2 SDL-1.2
Better fix for bug 936
author | Sam Lantinga <slouken@libsdl.org> |
---|---|
date | Sun, 18 Jul 2010 10:28:57 -0700 |
parents | e85e65aec22f |
children |
line wrap: on
line source
/* vectorbuffer.cpp yet another circle buffer Markus Mertama */ #include"vectorbuffer.h" void VectorPanic(TInt aErr, TInt aLine) { TBuf<64> b; b.Format(_L("vector buffer at % d "), aLine); User::Panic(b, aErr); } void TNodeBuffer::TNode::Terminator(TNodeBuffer::TNode* aNode) { Mem::Copy(iSucc, &aNode, sizeof(TNode*)); } TInt TNodeBuffer::TNode::Size() const { return reinterpret_cast<const TUint8*>(iSucc) - Ptr(); } const TUint8* TNodeBuffer::TNode::Ptr() const { return reinterpret_cast<const TUint8*>(this) + sizeof(TNode); } TNodeBuffer::TNode* TNodeBuffer::TNode::Empty(TUint8* aBuffer) { TNode* node = reinterpret_cast<TNode*>(aBuffer); node->iSucc = node + 1; return node; } TNodeBuffer::TNode* TNodeBuffer::TNode::New(TNode* aPred, const TDesC8& aData) { TNode* node = aPred->Size() == 0 ? aPred : aPred->iSucc; TUint8* start = reinterpret_cast<TUint8*>(node) + sizeof(TNode); node->iSucc = reinterpret_cast<TNode*>(start + aData.Size()); node->iSucc->iSucc = NULL; //terminator __ASSERT_DEBUG(node->Size() == aData.Size(), VECPANIC(KErrCorrupt)); Mem::Copy(start, aData.Ptr(), aData.Size()); return node; }