Return TypeFunction nameArguments
unsigned inthzChain::Append(const void*,unsigned int,)

Declared in file: hzChain.h
Defined in file : hzChain.cpp

Function Logic:

0:START 1:!nBytes 2:Return nBytes 3:!mx 4:mx mx 5:!mx->m_Begin 6:_zblk_alloc mx mx 7:curBlk 8:!curBlk 9:hzexit 10:i 11:nWritten 12:curBlk->m_nUsage==ZBLKSIZE 13:_zblk_alloc newBlk _zblk::Prev _zblk::Next curBlk mx 14:nCan 15:(nWritten+nCan)>nBytes 16:nCan 17:memcpy curBlk i mx nWritten 18:Return nWritten

Function body:

unsigned int hzChain::Append (const void* vpStr, unsigned int nBytes)
{
   _hzfunc("hzChain::Append(1)") ;
   _zblk*      curBlk ;
   _zblk*      newBlk ;
   const char* i ;
   uint32_t    nCan ;
   uint32_t    nWritten = 0;
   if (!nBytes)
       return nBytes ;
   if (!mx)
       { mx = new _chain() ; mx->m_Test = mx ; }
   if (!mx->m_Begin)
       mx->m_Begin = mx->m_End = _zblk_alloc() ;
   curBlk = (_zblk*) mx->m_End ;
   if (!curBlk)
       hzexit(E_MEMORY, "Chain %p has no end block\n", this) ;
   i = (char*) vpStr ;
   for (; nWritten < nBytes ;)
   {
       if (curBlk->m_nUsage == ZBLKSIZE)
       {
           newBlk = _zblk_alloc() ;
           newBlk->Prev(curBlk) ;
           curBlk->Next(newBlk) ;
           mx->m_End = curBlk = newBlk ;
       }
       nCan = ZBLKSIZE - curBlk->m_nUsage ;
       if ((nWritten + nCan) > nBytes)
           nCan = nBytes - nWritten ;
       memcpy(curBlk->m_Data + curBlk->m_nUsage, i, nCan) ;
       curBlk->m_nUsage += nCan ;
       i += nCan ;
       mx->m_nSize += nCan ;
       nWritten += nCan ;
   }
   return nWritten ;
}