Blame libmng_read.c

Packit 93f41a
#include "config.h"
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
/* *             For conditions of distribution and use,                    * */
Packit 93f41a
/* *                see copyright notice in libmng.h                        * */
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* * project   : libmng                                                     * */
Packit 93f41a
/* * file      : libmng_read.c             copyright (c) 2000-2007 G.Juyn   * */
Packit 93f41a
/* * version   : 1.0.10                                                     * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* * purpose   : Read logic (implementation)                                * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* * author    : G.Juyn                                                     * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* * comment   : implementation of the high-level read logic                * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* * changes   : 0.5.1 - 05/08/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed strict-ANSI stuff                                * */
Packit 93f41a
/* *             0.5.1 - 05/11/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - added callback error-reporting support                   * */
Packit 93f41a
/* *             0.5.1 - 05/12/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed trace to macro for callback error-reporting      * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.5.2 - 05/19/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - cleaned up some code regarding mixed support             * */
Packit 93f41a
/* *             0.5.2 - 05/20/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - added support for JNG                                    * */
Packit 93f41a
/* *             0.5.2 - 05/31/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - fixed up punctuation (contribution by Tim Rowley)        * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.5.3 - 06/16/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed progressive-display processing                   * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.9.1 - 07/08/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed read-processing for improved I/O-suspension      * */
Packit 93f41a
/* *             0.9.1 - 07/14/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed EOF processing behavior                          * */
Packit 93f41a
/* *             0.9.1 - 07/14/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed default readbuffer size from 1024 to 4200        * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.9.2 - 07/27/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - B110320 - fixed GCC warning about mix-sized pointer math * */
Packit 93f41a
/* *             0.9.2 - 07/31/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - B110546 - fixed for improperly returning UNEXPECTEDEOF   * */
Packit 93f41a
/* *             0.9.2 - 08/04/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - B111096 - fixed large-buffer read-suspension             * */
Packit 93f41a
/* *             0.9.2 - 08/05/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - changed file-prefixes                                    * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.9.3 - 08/26/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - added MAGN chunk                                         * */
Packit 93f41a
/* *             0.9.3 - 10/11/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - removed test-MaGN                                        * */
Packit 93f41a
/* *             0.9.3 - 10/16/2000 - G.Juyn                                * */
Packit 93f41a
/* *             - added support for JDAA                                   * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             0.9.5 - 01/23/2001 - G.Juyn                                * */
Packit 93f41a
/* *             - fixed timing-problem with switching framing_modes        * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.4 - 06/22/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - B495443 - incorrect suspend check in read_databuffer     * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.5 - 07/04/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - added errorcode for extreme chunk-sizes                  * */
Packit 93f41a
/* *             1.0.5 - 07/08/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - B578572 - removed eMNGma hack (thanks Dimitri!)          * */
Packit 93f41a
/* *             1.0.5 - 07/16/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - B581625 - large chunks fail with suspension reads        * */
Packit 93f41a
/* *             1.0.5 - 08/19/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - B597134 - libmng pollutes the linker namespace           * */
Packit 93f41a
/* *             - added HLAPI function to copy chunks                      * */
Packit 93f41a
/* *             1.0.5 - 09/16/2002 - G.Juyn                                * */
Packit 93f41a
/* *             - added event handling for dynamic MNG                     * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.6 - 05/25/2003 - G.R-P                                 * */
Packit 93f41a
/* *             - added MNG_SKIPCHUNK_cHNK footprint optimizations         * */
Packit 93f41a
/* *             1.0.6 - 07/07/2003 - G.R-P                                 * */
Packit 93f41a
/* *             - added MNG_NO_DELTA_PNG reduction                         * */
Packit 93f41a
/* *             - skip additional code when MNG_INCLUDE_JNG is not enabled * */
Packit 93f41a
/* *             1.0.6 - 07/29/2003 - G.R-P                                 * */
Packit 93f41a
/* *             - added conditionals around PAST chunk support             * */
Packit 93f41a
/* *             1.0.6 - 08/17/2003 - G.R-P                                 * */
Packit 93f41a
/* *             - added conditionals around non-VLC chunk support          * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.7 - 03/10/2004 - G.R-P                                 * */
Packit 93f41a
/* *             - added conditionals around openstream/closestream         * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.8 - 04/08/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - added CRC existence & checking flags                     * */
Packit 93f41a
/* *             1.0.8 - 04/11/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - added data-push mechanisms for specialized decoders      * */
Packit 93f41a
/* *             1.0.8 - 07/06/2004 - G.R-P                                 * */
Packit 93f41a
/* *             - defend against using undefined closestream function      * */
Packit 93f41a
/* *             1.0.8 - 07/28/2004 - G.R-P                                 * */
Packit 93f41a
/* *             - added check for extreme chunk-lengths                    * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.9 - 09/16/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - fixed chunk pushing mechanism                            * */
Packit 93f41a
/* *             1.0.9 - 12/05/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - added conditional MNG_OPTIMIZE_CHUNKINITFREE             * */
Packit 93f41a
/* *             1.0.9 - 12/06/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - added conditional MNG_OPTIMIZE_CHUNKASSIGN               * */
Packit 93f41a
/* *             - added conditional MNG_OPTIMIZE_CHUNKREADER               * */
Packit 93f41a
/* *             1.0.9 - 12/20/2004 - G.Juyn                                * */
Packit 93f41a
/* *             - cleaned up macro-invocations (thanks to D. Airlie)       * */
Packit 93f41a
/* *             1.0.9 - 12/31/2004 - G.R-P                                 * */
Packit 93f41a
/* *             - removed stray characters from #ifdef directive           * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* *             1.0.10 - 04/08/2007 - G.Juyn                               * */
Packit 93f41a
/* *             - added support for mPNG proposal                          * */
Packit 93f41a
/* *                                                                        * */
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
#include "libmng.h"
Packit 93f41a
#include "libmng_data.h"
Packit 93f41a
#include "libmng_error.h"
Packit 93f41a
#include "libmng_trace.h"
Packit 93f41a
#ifdef __BORLANDC__
Packit 93f41a
#pragma hdrstop
Packit 93f41a
#endif
Packit 93f41a
#include "libmng_memory.h"
Packit 93f41a
#include "libmng_objects.h"
Packit 93f41a
#include "libmng_object_prc.h"
Packit 93f41a
#include "libmng_chunks.h"
Packit 93f41a
#ifdef MNG_OPTIMIZE_CHUNKREADER
Packit 93f41a
#include "libmng_chunk_descr.h"
Packit 93f41a
#endif
Packit 93f41a
#include "libmng_chunk_prc.h"
Packit 93f41a
#include "libmng_chunk_io.h"
Packit 93f41a
#include "libmng_display.h"
Packit 93f41a
#include "libmng_read.h"
Packit 93f41a
Packit 93f41a
#if defined(__BORLANDC__) && defined(MNG_STRICT_ANSI)
Packit 93f41a
#pragma option -A                      /* force ANSI-C */
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
#ifdef MNG_INCLUDE_READ_PROCS
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
mng_retcode mng_process_eof (mng_datap pData)
Packit 93f41a
{
Packit 93f41a
  if (!pData->bEOF)                    /* haven't closed the stream yet ? */
Packit 93f41a
  {
Packit 93f41a
    pData->bEOF = MNG_TRUE;            /* now we do! */
Packit 93f41a
Packit 93f41a
#ifndef MNG_NO_OPEN_CLOSE_STREAM
Packit 93f41a
    if (pData->fClosestream && !pData->fClosestream ((mng_handle)pData))
Packit 93f41a
    {
Packit 93f41a
      MNG_ERROR (pData, MNG_APPIOERROR);
Packit 93f41a
    }
Packit 93f41a
#endif
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
mng_retcode mng_release_pushdata (mng_datap pData)
Packit 93f41a
{
Packit 93f41a
  mng_pushdatap pFirst  = pData->pFirstpushdata;
Packit 93f41a
  mng_pushdatap pNext   = pFirst->pNext;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_RELEASE_PUSHDATA, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  pData->pFirstpushdata = pNext;       /* next becomes the first */
Packit 93f41a
Packit 93f41a
  if (!pNext)                          /* no next? => no last! */
Packit 93f41a
    pData->pLastpushdata = MNG_NULL;
Packit 93f41a
                                       /* buffer owned and release callback defined? */
Packit 93f41a
  if ((pFirst->bOwned) && (pData->fReleasedata))
Packit 93f41a
    pData->fReleasedata ((mng_handle)pData, pFirst->pData, pFirst->iLength);
Packit 93f41a
  else                                 /* otherwise use internal free mechanism */
Packit 93f41a
    MNG_FREEX (pData, pFirst->pData, pFirst->iLength);
Packit 93f41a
                                       /* and free it */
Packit 93f41a
  MNG_FREEX (pData, pFirst, sizeof(mng_pushdata));
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_RELEASE_PUSHDATA, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
mng_retcode mng_release_pushchunk (mng_datap pData)
Packit 93f41a
{
Packit 93f41a
  mng_pushdatap pFirst  = pData->pFirstpushchunk;
Packit 93f41a
  mng_pushdatap pNext   = pFirst->pNext;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_RELEASE_PUSHCHUNK, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  pData->pFirstpushchunk = pNext;      /* next becomes the first */
Packit 93f41a
Packit 93f41a
  if (!pNext)                          /* no next? => no last! */
Packit 93f41a
    pData->pLastpushchunk = MNG_NULL;
Packit 93f41a
                                       /* buffer owned and release callback defined? */
Packit 93f41a
  if ((pFirst->bOwned) && (pData->fReleasedata))
Packit 93f41a
    pData->fReleasedata ((mng_handle)pData, pFirst->pData, pFirst->iLength);
Packit 93f41a
  else                                 /* otherwise use internal free mechanism */
Packit 93f41a
    MNG_FREEX (pData, pFirst->pData, pFirst->iLength);
Packit 93f41a
                                       /* and free it */
Packit 93f41a
  MNG_FREEX (pData, pFirst, sizeof(mng_pushdata));
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_RELEASE_PUSHCHUNK, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode read_data (mng_datap    pData,
Packit 93f41a
                                 mng_uint8p   pBuf,
Packit 93f41a
                                 mng_uint32   iSize,
Packit 93f41a
                                 mng_uint32 * iRead)
Packit 93f41a
{
Packit 93f41a
  mng_retcode   iRetcode;
Packit 93f41a
  mng_uint32    iTempsize = iSize;
Packit 93f41a
  mng_uint8p    pTempbuf  = pBuf;
Packit 93f41a
  mng_pushdatap pPush     = pData->pFirstpushdata;
Packit 93f41a
  mng_uint32    iPushsize = 0;
Packit 93f41a
  *iRead                  = 0;         /* nothing yet */
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_DATA, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  while (pPush)                        /* calculate size of pushed data */
Packit 93f41a
  {
Packit 93f41a
    iPushsize += pPush->iRemaining;
Packit 93f41a
    pPush      = pPush->pNext;
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  if (iTempsize <= iPushsize)          /* got enough push data? */
Packit 93f41a
  {
Packit 93f41a
    while (iTempsize)
Packit 93f41a
    {
Packit 93f41a
      pPush = pData->pFirstpushdata;
Packit 93f41a
                                       /* enough data remaining in this buffer? */
Packit 93f41a
      if (pPush->iRemaining <= iTempsize)
Packit 93f41a
      {                                /* no: then copy what we've got */
Packit 93f41a
        MNG_COPY (pTempbuf, pPush->pDatanext, pPush->iRemaining);
Packit 93f41a
                                       /* move pointers & lengths */
Packit 93f41a
        pTempbuf  += pPush->iRemaining;
Packit 93f41a
        *iRead    += pPush->iRemaining;
Packit 93f41a
        iTempsize -= pPush->iRemaining;
Packit 93f41a
                                       /* release the depleted buffer */
Packit 93f41a
        iRetcode = mng_release_pushdata (pData);
Packit 93f41a
        if (iRetcode)
Packit 93f41a
          return iRetcode;
Packit 93f41a
      }
Packit 93f41a
      else
Packit 93f41a
      {                                /* copy the needed bytes */
Packit 93f41a
        MNG_COPY (pTempbuf, pPush->pDatanext, iTempsize);
Packit 93f41a
                                       /* move pointers & lengths */
Packit 93f41a
        pPush->iRemaining -= iTempsize;
Packit 93f41a
        pPush->pDatanext  += iTempsize;
Packit 93f41a
        pTempbuf          += iTempsize;
Packit 93f41a
        *iRead            += iTempsize;
Packit 93f41a
        iTempsize         = 0;         /* all done!!! */
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
  else
Packit 93f41a
  {
Packit 93f41a
    mng_uint32 iTempread = 0;
Packit 93f41a
                                       /* get it from the app then */
Packit 93f41a
    if (!pData->fReaddata (((mng_handle)pData), pTempbuf, iTempsize, &iTempread))
Packit 93f41a
      MNG_ERROR (pData, MNG_APPIOERROR);
Packit 93f41a
Packit 93f41a
    *iRead += iTempread;
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_DATA, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode read_databuffer (mng_datap    pData,
Packit 93f41a
                                       mng_uint8p   pBuf,
Packit 93f41a
                                       mng_uint8p * pBufnext,
Packit 93f41a
                                       mng_uint32   iSize,
Packit 93f41a
                                       mng_uint32 * iRead)
Packit 93f41a
{
Packit 93f41a
  mng_retcode iRetcode;
Packit 93f41a
  
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_DATABUFFER, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  if (pData->bSuspensionmode)
Packit 93f41a
  {
Packit 93f41a
    mng_uint8p pTemp;
Packit 93f41a
    mng_uint32 iTemp;
Packit 93f41a
Packit 93f41a
    *iRead = 0;                        /* let's be negative about the outcome */
Packit 93f41a
Packit 93f41a
    if (!pData->pSuspendbuf)           /* need to create a suspension buffer ? */
Packit 93f41a
    {
Packit 93f41a
      pData->iSuspendbufsize = MNG_SUSPENDBUFFERSIZE;
Packit 93f41a
                                       /* so, create it */
Packit 93f41a
      MNG_ALLOC (pData, pData->pSuspendbuf, pData->iSuspendbufsize);
Packit 93f41a
Packit 93f41a
      pData->iSuspendbufleft = 0;      /* make sure to fill it first time */
Packit 93f41a
      pData->pSuspendbufnext = pData->pSuspendbuf;
Packit 93f41a
    }
Packit 93f41a
                                       /* more than our buffer can hold ? */
Packit 93f41a
    if (iSize > pData->iSuspendbufsize)
Packit 93f41a
    {
Packit 93f41a
      mng_uint32 iRemain;
Packit 93f41a
Packit 93f41a
      if (!*pBufnext)                  /* first time ? */
Packit 93f41a
      {
Packit 93f41a
        if (pData->iSuspendbufleft)    /* do we have some data left ? */
Packit 93f41a
        {                              /* then copy it */
Packit 93f41a
          MNG_COPY (pBuf, pData->pSuspendbufnext, pData->iSuspendbufleft);
Packit 93f41a
                                       /* fixup variables */
Packit 93f41a
          *pBufnext              = pBuf + pData->iSuspendbufleft;
Packit 93f41a
          pData->pSuspendbufnext = pData->pSuspendbuf;
Packit 93f41a
          pData->iSuspendbufleft = 0;
Packit 93f41a
        }
Packit 93f41a
        else
Packit 93f41a
        {
Packit 93f41a
          *pBufnext              = pBuf;
Packit 93f41a
        }
Packit 93f41a
      }
Packit 93f41a
                                       /* calculate how much to get */
Packit 93f41a
      iRemain = iSize - (mng_uint32)(*pBufnext - pBuf);
Packit 93f41a
                                       /* let's go get it */
Packit 93f41a
      iRetcode = read_data (pData, *pBufnext, iRemain, &iTemp);
Packit 93f41a
      if (iRetcode)
Packit 93f41a
        return iRetcode;
Packit 93f41a
                                       /* first read after suspension return 0 means EOF */
Packit 93f41a
      if ((pData->iSuspendpoint) && (iTemp == 0))
Packit 93f41a
      {                                /* that makes it final */
Packit 93f41a
        mng_retcode iRetcode = mng_process_eof (pData);
Packit 93f41a
        if (iRetcode)                  /* on error bail out */
Packit 93f41a
          return iRetcode;
Packit 93f41a
                                       /* indicate the source is depleted */
Packit 93f41a
        *iRead = iSize - iRemain + iTemp;
Packit 93f41a
      }
Packit 93f41a
      else
Packit 93f41a
      {
Packit 93f41a
        if (iTemp < iRemain)           /* suspension required ? */
Packit 93f41a
        {
Packit 93f41a
          *pBufnext         = *pBufnext + iTemp;
Packit 93f41a
          pData->bSuspended = MNG_TRUE;
Packit 93f41a
        }
Packit 93f41a
        else
Packit 93f41a
        {
Packit 93f41a
          *iRead = iSize;              /* got it all now ! */
Packit 93f41a
        }
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
    else
Packit 93f41a
    {                                  /* need to read some more ? */
Packit 93f41a
      while ((!pData->bSuspended) && (!pData->bEOF) && (iSize > pData->iSuspendbufleft))
Packit 93f41a
      {                                /* not enough space left in buffer ? */
Packit 93f41a
        if (pData->iSuspendbufsize - pData->iSuspendbufleft -
Packit 93f41a
            (mng_uint32)(pData->pSuspendbufnext - pData->pSuspendbuf) <
Packit 93f41a
                                                          MNG_SUSPENDREQUESTSIZE)
Packit 93f41a
        {
Packit 93f41a
          if (pData->iSuspendbufleft)  /* then lets shift (if there's anything left) */
Packit 93f41a
            MNG_COPY (pData->pSuspendbuf, pData->pSuspendbufnext, pData->iSuspendbufleft);
Packit 93f41a
                                       /* adjust running pointer */
Packit 93f41a
          pData->pSuspendbufnext = pData->pSuspendbuf;
Packit 93f41a
        }
Packit 93f41a
                                       /* still not enough room ? */
Packit 93f41a
        if (pData->iSuspendbufsize - pData->iSuspendbufleft < MNG_SUSPENDREQUESTSIZE)
Packit 93f41a
          MNG_ERROR (pData, MNG_INTERNALERROR);
Packit 93f41a
                                       /* now read some more data */
Packit 93f41a
        pTemp = pData->pSuspendbufnext + pData->iSuspendbufleft;
Packit 93f41a
Packit 93f41a
        iRetcode = read_data (pData, pTemp, MNG_SUSPENDREQUESTSIZE, &iTemp);
Packit 93f41a
        if (iRetcode)
Packit 93f41a
          return iRetcode;
Packit 93f41a
                                       /* adjust fill-counter */
Packit 93f41a
        pData->iSuspendbufleft += iTemp;
Packit 93f41a
                                       /* first read after suspension returning 0 means EOF */
Packit 93f41a
        if ((pData->iSuspendpoint) && (iTemp == 0))
Packit 93f41a
        {                              /* that makes it final */
Packit 93f41a
          mng_retcode iRetcode = mng_process_eof (pData);
Packit 93f41a
          if (iRetcode)                /* on error bail out */
Packit 93f41a
            return iRetcode;
Packit 93f41a
Packit 93f41a
          if (pData->iSuspendbufleft)  /* return the leftover scraps */
Packit 93f41a
            MNG_COPY (pBuf, pData->pSuspendbufnext, pData->iSuspendbufleft);
Packit 93f41a
                                       /* and indicate so */
Packit 93f41a
          *iRead = pData->iSuspendbufleft;
Packit 93f41a
          pData->pSuspendbufnext = pData->pSuspendbuf;
Packit 93f41a
          pData->iSuspendbufleft = 0;
Packit 93f41a
        }
Packit 93f41a
        else
Packit 93f41a
        {                              /* suspension required ? */
Packit 93f41a
          if ((iSize > pData->iSuspendbufleft) && (iTemp < MNG_SUSPENDREQUESTSIZE))
Packit 93f41a
            pData->bSuspended = MNG_TRUE;
Packit 93f41a
Packit 93f41a
        }
Packit 93f41a
Packit 93f41a
        pData->iSuspendpoint = 0;      /* reset it here in case we loop back */
Packit 93f41a
      }
Packit 93f41a
Packit 93f41a
      if ((!pData->bSuspended) && (!pData->bEOF))
Packit 93f41a
      {                                /* return the data ! */
Packit 93f41a
        MNG_COPY (pBuf, pData->pSuspendbufnext, iSize);
Packit 93f41a
Packit 93f41a
        *iRead = iSize;                /* returned it all */
Packit 93f41a
                                       /* adjust suspension-buffer variables */
Packit 93f41a
        pData->pSuspendbufnext += iSize;
Packit 93f41a
        pData->iSuspendbufleft -= iSize;
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
  else
Packit 93f41a
  {
Packit 93f41a
    iRetcode = read_data (pData, (mng_ptr)pBuf, iSize, iRead);
Packit 93f41a
    if (iRetcode)
Packit 93f41a
      return iRetcode;
Packit 93f41a
    if (*iRead == 0)                   /* suspension required ? */
Packit 93f41a
      pData->bSuspended = MNG_TRUE;
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  pData->iSuspendpoint = 0;            /* safely reset it here ! */
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_DATABUFFER, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode process_raw_chunk (mng_datap  pData,
Packit 93f41a
                                         mng_uint8p pBuf,
Packit 93f41a
                                         mng_uint32 iBuflen)
Packit 93f41a
{
Packit 93f41a
Packit 93f41a
#ifndef MNG_OPTIMIZE_CHUNKREADER
Packit 93f41a
  /* the table-idea & binary search code was adapted from
Packit 93f41a
     libpng 1.1.0 (pngread.c) */
Packit 93f41a
  /* NOTE1: the table must remain sorted by chunkname, otherwise the binary
Packit 93f41a
     search will break !!! (ps. watch upper-/lower-case chunknames !!) */
Packit 93f41a
  /* NOTE2: the layout must remain equal to the header part of all the
Packit 93f41a
     chunk-structures (yes, that means even the pNext and pPrev fields;
Packit 93f41a
     it's wasting a bit of space, but hey, the code is a lot easier) */
Packit 93f41a
Packit 93f41a
#ifdef MNG_OPTIMIZE_CHUNKINITFREE
Packit 93f41a
  mng_chunk_header mng_chunk_unknown = {MNG_UINT_HUH, mng_init_general, mng_free_unknown,
Packit 93f41a
                                        mng_read_unknown, mng_write_unknown, mng_assign_unknown, 0, 0, sizeof(mng_unknown_chunk)};
Packit 93f41a
#else
Packit 93f41a
  mng_chunk_header mng_chunk_unknown = {MNG_UINT_HUH, mng_init_unknown, mng_free_unknown,
Packit 93f41a
                                        mng_read_unknown, mng_write_unknown, mng_assign_unknown, 0, 0};
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
#ifdef MNG_OPTIMIZE_CHUNKINITFREE
Packit 93f41a
Packit 93f41a
  mng_chunk_header mng_chunk_table [] =
Packit 93f41a
  {
Packit 93f41a
#ifndef MNG_SKIPCHUNK_BACK
Packit 93f41a
    {MNG_UINT_BACK, mng_init_general, mng_free_general, mng_read_back, mng_write_back, mng_assign_general, 0, 0, sizeof(mng_back)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_BASI
Packit 93f41a
    {MNG_UINT_BASI, mng_init_general, mng_free_general, mng_read_basi, mng_write_basi, mng_assign_general, 0, 0, sizeof(mng_basi)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLIP
Packit 93f41a
    {MNG_UINT_CLIP, mng_init_general, mng_free_general, mng_read_clip, mng_write_clip, mng_assign_general, 0, 0, sizeof(mng_clip)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLON
Packit 93f41a
    {MNG_UINT_CLON, mng_init_general, mng_free_general, mng_read_clon, mng_write_clon, mng_assign_general, 0, 0, sizeof(mng_clon)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DBYK
Packit 93f41a
    {MNG_UINT_DBYK, mng_init_general, mng_free_dbyk,    mng_read_dbyk, mng_write_dbyk, mng_assign_dbyk,    0, 0, sizeof(mng_dbyk)},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DEFI
Packit 93f41a
    {MNG_UINT_DEFI, mng_init_general, mng_free_general, mng_read_defi, mng_write_defi, mng_assign_general, 0, 0, sizeof(mng_defi)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
    {MNG_UINT_DHDR, mng_init_general, mng_free_general, mng_read_dhdr, mng_write_dhdr, mng_assign_general, 0, 0, sizeof(mng_dhdr)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DISC
Packit 93f41a
    {MNG_UINT_DISC, mng_init_general, mng_free_disc,    mng_read_disc, mng_write_disc, mng_assign_disc,    0, 0, sizeof(mng_disc)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DROP
Packit 93f41a
    {MNG_UINT_DROP, mng_init_general, mng_free_drop,    mng_read_drop, mng_write_drop, mng_assign_drop,    0, 0, sizeof(mng_drop)},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_LOOP
Packit 93f41a
    {MNG_UINT_ENDL, mng_init_general, mng_free_general, mng_read_endl, mng_write_endl, mng_assign_general, 0, 0, sizeof(mng_endl)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_FRAM
Packit 93f41a
    {MNG_UINT_FRAM, mng_init_general, mng_free_fram,    mng_read_fram, mng_write_fram, mng_assign_fram,    0, 0, sizeof(mng_fram)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_IDAT, mng_init_general, mng_free_idat,    mng_read_idat, mng_write_idat, mng_assign_idat,    0, 0, sizeof(mng_idat)},  /* 12-th element! */
Packit 93f41a
    {MNG_UINT_IEND, mng_init_general, mng_free_general, mng_read_iend, mng_write_iend, mng_assign_general, 0, 0, sizeof(mng_iend)},
Packit 93f41a
    {MNG_UINT_IHDR, mng_init_general, mng_free_general, mng_read_ihdr, mng_write_ihdr, mng_assign_general, 0, 0, sizeof(mng_ihdr)},
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
    {MNG_UINT_IJNG, mng_init_general, mng_free_general, mng_read_ijng, mng_write_ijng, mng_assign_general, 0, 0, sizeof(mng_ijng)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_IPNG, mng_init_general, mng_free_general, mng_read_ipng, mng_write_ipng, mng_assign_general, 0, 0, sizeof(mng_ipng)},
Packit 93f41a
#endif
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
    {MNG_UINT_JDAA, mng_init_general, mng_free_jdaa,    mng_read_jdaa, mng_write_jdaa, mng_assign_jdaa,    0, 0, sizeof(mng_jdaa)},
Packit 93f41a
    {MNG_UINT_JDAT, mng_init_general, mng_free_jdat,    mng_read_jdat, mng_write_jdat, mng_assign_jdat,    0, 0, sizeof(mng_jdat)},
Packit 93f41a
    {MNG_UINT_JHDR, mng_init_general, mng_free_general, mng_read_jhdr, mng_write_jhdr, mng_assign_general, 0, 0, sizeof(mng_jhdr)},
Packit 93f41a
    {MNG_UINT_JSEP, mng_init_general, mng_free_general, mng_read_jsep, mng_write_jsep, mng_assign_general, 0, 0, sizeof(mng_jsep)},
Packit 93f41a
    {MNG_UINT_JdAA, mng_init_general, mng_free_jdaa,    mng_read_jdaa, mng_write_jdaa, mng_assign_jdaa,    0, 0, sizeof(mng_jdaa)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_LOOP
Packit 93f41a
    {MNG_UINT_LOOP, mng_init_general, mng_free_loop,    mng_read_loop, mng_write_loop, mng_assign_loop,    0, 0, sizeof(mng_loop)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MAGN
Packit 93f41a
    {MNG_UINT_MAGN, mng_init_general, mng_free_general, mng_read_magn, mng_write_magn, mng_assign_general, 0, 0, sizeof(mng_magn)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_MEND, mng_init_general, mng_free_general, mng_read_mend, mng_write_mend, mng_assign_general, 0, 0, sizeof(mng_mend)},
Packit 93f41a
    {MNG_UINT_MHDR, mng_init_general, mng_free_general, mng_read_mhdr, mng_write_mhdr, mng_assign_general, 0, 0, sizeof(mng_mhdr)},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MOVE
Packit 93f41a
    {MNG_UINT_MOVE, mng_init_general, mng_free_general, mng_read_move, mng_write_move, mng_assign_general, 0, 0, sizeof(mng_move)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_ORDR
Packit 93f41a
    {MNG_UINT_ORDR, mng_init_general, mng_free_ordr,    mng_read_ordr, mng_write_ordr, mng_assign_ordr,    0, 0, sizeof(mng_ordr)},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_PAST
Packit 93f41a
    {MNG_UINT_PAST, mng_init_general, mng_free_past,    mng_read_past, mng_write_past, mng_assign_past,    0, 0, sizeof(mng_past)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_PLTE, mng_init_general, mng_free_general, mng_read_plte, mng_write_plte, mng_assign_general, 0, 0, sizeof(mng_plte)},
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
    {MNG_UINT_PPLT, mng_init_general, mng_free_general, mng_read_pplt, mng_write_pplt, mng_assign_general, 0, 0, sizeof(mng_pplt)},
Packit 93f41a
    {MNG_UINT_PROM, mng_init_general, mng_free_general, mng_read_prom, mng_write_prom, mng_assign_general, 0, 0, sizeof(mng_prom)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SAVE
Packit 93f41a
    {MNG_UINT_SAVE, mng_init_general, mng_free_save,    mng_read_save, mng_write_save, mng_assign_save,    0, 0, sizeof(mng_save)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SEEK
Packit 93f41a
    {MNG_UINT_SEEK, mng_init_general, mng_free_seek,    mng_read_seek, mng_write_seek, mng_assign_seek,    0, 0, sizeof(mng_seek)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SHOW
Packit 93f41a
    {MNG_UINT_SHOW, mng_init_general, mng_free_general, mng_read_show, mng_write_show, mng_assign_general, 0, 0, sizeof(mng_show)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_TERM
Packit 93f41a
    {MNG_UINT_TERM, mng_init_general, mng_free_general, mng_read_term, mng_write_term, mng_assign_general, 0, 0, sizeof(mng_term)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_bKGD
Packit 93f41a
    {MNG_UINT_bKGD, mng_init_general, mng_free_general, mng_read_bkgd, mng_write_bkgd, mng_assign_general, 0, 0, sizeof(mng_bkgd)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_cHRM
Packit 93f41a
    {MNG_UINT_cHRM, mng_init_general, mng_free_general, mng_read_chrm, mng_write_chrm, mng_assign_general, 0, 0, sizeof(mng_chrm)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_eXPI
Packit 93f41a
    {MNG_UINT_eXPI, mng_init_general, mng_free_expi,    mng_read_expi, mng_write_expi, mng_assign_expi,    0, 0, sizeof(mng_expi)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_evNT
Packit 93f41a
    {MNG_UINT_evNT, mng_init_general, mng_free_evnt,    mng_read_evnt, mng_write_evnt, mng_assign_evnt,    0, 0, sizeof(mng_evnt)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_fPRI
Packit 93f41a
    {MNG_UINT_fPRI, mng_init_general, mng_free_general, mng_read_fpri, mng_write_fpri, mng_assign_general, 0, 0, sizeof(mng_fpri)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_gAMA
Packit 93f41a
    {MNG_UINT_gAMA, mng_init_general, mng_free_general, mng_read_gama, mng_write_gama, mng_assign_general, 0, 0, sizeof(mng_gama)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_hIST
Packit 93f41a
    {MNG_UINT_hIST, mng_init_general, mng_free_general, mng_read_hist, mng_write_hist, mng_assign_general, 0, 0, sizeof(mng_hist)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_iCCP
Packit 93f41a
    {MNG_UINT_iCCP, mng_init_general, mng_free_iccp,    mng_read_iccp, mng_write_iccp, mng_assign_iccp,    0, 0, sizeof(mng_iccp)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_iTXt
Packit 93f41a
    {MNG_UINT_iTXt, mng_init_general, mng_free_itxt,    mng_read_itxt, mng_write_itxt, mng_assign_itxt,    0, 0, sizeof(mng_itxt)},
Packit 93f41a
#endif
Packit 93f41a
#ifdef MNG_INCLUDE_MPNG_PROPOSAL
Packit 93f41a
    {MNG_UINT_mpNG, mng_init_general, mng_free_mpng,    mng_read_mpng, mng_write_mpng, mng_assign_mpng,    0, 0, sizeof(mng_mpng)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_nEED
Packit 93f41a
    {MNG_UINT_nEED, mng_init_general, mng_free_need,    mng_read_need, mng_write_need, mng_assign_need,    0, 0, sizeof(mng_need)},
Packit 93f41a
#endif
Packit 93f41a
/* TODO:     {MNG_UINT_oFFs, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
/* TODO:     {MNG_UINT_pCAL, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
#ifndef MNG_SKIPCHUNK_pHYg
Packit 93f41a
    {MNG_UINT_pHYg, mng_init_general, mng_free_general, mng_read_phyg, mng_write_phyg, mng_assign_general, 0, 0, sizeof(mng_phyg)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_pHYs
Packit 93f41a
    {MNG_UINT_pHYs, mng_init_general, mng_free_general, mng_read_phys, mng_write_phys, mng_assign_general, 0, 0, sizeof(mng_phys)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_sBIT
Packit 93f41a
    {MNG_UINT_sBIT, mng_init_general, mng_free_general, mng_read_sbit, mng_write_sbit, mng_assign_general, 0, 0, sizeof(mng_sbit)},
Packit 93f41a
#endif
Packit 93f41a
/* TODO:     {MNG_UINT_sCAL, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
#ifndef MNG_SKIPCHUNK_sPLT
Packit 93f41a
    {MNG_UINT_sPLT, mng_init_general, mng_free_splt,    mng_read_splt, mng_write_splt, mng_assign_splt,    0, 0, sizeof(mng_splt)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_sRGB, mng_init_general, mng_free_general, mng_read_srgb, mng_write_srgb, mng_assign_general, 0, 0, sizeof(mng_srgb)},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_tEXt
Packit 93f41a
    {MNG_UINT_tEXt, mng_init_general, mng_free_text,    mng_read_text, mng_write_text, mng_assign_text,    0, 0, sizeof(mng_text)},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_tIME
Packit 93f41a
    {MNG_UINT_tIME, mng_init_general, mng_free_general, mng_read_time, mng_write_time, mng_assign_general, 0, 0, sizeof(mng_time)},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_tRNS, mng_init_general, mng_free_general, mng_read_trns, mng_write_trns, mng_assign_general, 0, 0, sizeof(mng_trns)},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_zTXt
Packit 93f41a
    {MNG_UINT_zTXt, mng_init_general, mng_free_ztxt,    mng_read_ztxt, mng_write_ztxt, mng_assign_ztxt,    0, 0, sizeof(mng_ztxt)},
Packit 93f41a
#endif
Packit 93f41a
  };
Packit 93f41a
Packit 93f41a
#else                        /* MNG_OPTIMIZE_CHUNKINITFREE */
Packit 93f41a
Packit 93f41a
  mng_chunk_header mng_chunk_table [] =
Packit 93f41a
  {
Packit 93f41a
#ifndef MNG_SKIPCHUNK_BACK
Packit 93f41a
    {MNG_UINT_BACK, mng_init_back, mng_free_back, mng_read_back, mng_write_back, mng_assign_back, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_BASI
Packit 93f41a
    {MNG_UINT_BASI, mng_init_basi, mng_free_basi, mng_read_basi, mng_write_basi, mng_assign_basi, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLIP
Packit 93f41a
    {MNG_UINT_CLIP, mng_init_clip, mng_free_clip, mng_read_clip, mng_write_clip, mng_assign_clip, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLON
Packit 93f41a
    {MNG_UINT_CLON, mng_init_clon, mng_free_clon, mng_read_clon, mng_write_clon, mng_assign_clon, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DBYK
Packit 93f41a
    {MNG_UINT_DBYK, mng_init_dbyk, mng_free_dbyk, mng_read_dbyk, mng_write_dbyk, mng_assign_dbyk, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DEFI
Packit 93f41a
    {MNG_UINT_DEFI, mng_init_defi, mng_free_defi, mng_read_defi, mng_write_defi, mng_assign_defi, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
    {MNG_UINT_DHDR, mng_init_dhdr, mng_free_dhdr, mng_read_dhdr, mng_write_dhdr, mng_assign_dhdr, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DISC
Packit 93f41a
    {MNG_UINT_DISC, mng_init_disc, mng_free_disc, mng_read_disc, mng_write_disc, mng_assign_disc, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_DROP
Packit 93f41a
    {MNG_UINT_DROP, mng_init_drop, mng_free_drop, mng_read_drop, mng_write_drop, mng_assign_drop, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_LOOP
Packit 93f41a
    {MNG_UINT_ENDL, mng_init_endl, mng_free_endl, mng_read_endl, mng_write_endl, mng_assign_endl, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_FRAM
Packit 93f41a
    {MNG_UINT_FRAM, mng_init_fram, mng_free_fram, mng_read_fram, mng_write_fram, mng_assign_fram, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_IDAT, mng_init_idat, mng_free_idat, mng_read_idat, mng_write_idat, mng_assign_idat, 0, 0},  /* 12-th element! */
Packit 93f41a
    {MNG_UINT_IEND, mng_init_iend, mng_free_iend, mng_read_iend, mng_write_iend, mng_assign_iend, 0, 0},
Packit 93f41a
    {MNG_UINT_IHDR, mng_init_ihdr, mng_free_ihdr, mng_read_ihdr, mng_write_ihdr, mng_assign_ihdr, 0, 0},
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
    {MNG_UINT_IJNG, mng_init_ijng, mng_free_ijng, mng_read_ijng, mng_write_ijng, mng_assign_ijng, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_IPNG, mng_init_ipng, mng_free_ipng, mng_read_ipng, mng_write_ipng, mng_assign_ipng, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
    {MNG_UINT_JDAA, mng_init_jdaa, mng_free_jdaa, mng_read_jdaa, mng_write_jdaa, mng_assign_jdaa, 0, 0},
Packit 93f41a
    {MNG_UINT_JDAT, mng_init_jdat, mng_free_jdat, mng_read_jdat, mng_write_jdat, mng_assign_jdat, 0, 0},
Packit 93f41a
    {MNG_UINT_JHDR, mng_init_jhdr, mng_free_jhdr, mng_read_jhdr, mng_write_jhdr, mng_assign_jhdr, 0, 0},
Packit 93f41a
    {MNG_UINT_JSEP, mng_init_jsep, mng_free_jsep, mng_read_jsep, mng_write_jsep, mng_assign_jsep, 0, 0},
Packit 93f41a
    {MNG_UINT_JdAA, mng_init_jdaa, mng_free_jdaa, mng_read_jdaa, mng_write_jdaa, mng_assign_jdaa, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_LOOP
Packit 93f41a
    {MNG_UINT_LOOP, mng_init_loop, mng_free_loop, mng_read_loop, mng_write_loop, mng_assign_loop, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MAGN
Packit 93f41a
    {MNG_UINT_MAGN, mng_init_magn, mng_free_magn, mng_read_magn, mng_write_magn, mng_assign_magn, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_MEND, mng_init_mend, mng_free_mend, mng_read_mend, mng_write_mend, mng_assign_mend, 0, 0},
Packit 93f41a
    {MNG_UINT_MHDR, mng_init_mhdr, mng_free_mhdr, mng_read_mhdr, mng_write_mhdr, mng_assign_mhdr, 0, 0},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MOVE
Packit 93f41a
    {MNG_UINT_MOVE, mng_init_move, mng_free_move, mng_read_move, mng_write_move, mng_assign_move, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
#ifndef MNG_SKIPCHUNK_ORDR
Packit 93f41a
    {MNG_UINT_ORDR, mng_init_ordr, mng_free_ordr, mng_read_ordr, mng_write_ordr, mng_assign_ordr, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_PAST
Packit 93f41a
    {MNG_UINT_PAST, mng_init_past, mng_free_past, mng_read_past, mng_write_past, mng_assign_past, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_PLTE, mng_init_plte, mng_free_plte, mng_read_plte, mng_write_plte, mng_assign_plte, 0, 0},
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
    {MNG_UINT_PPLT, mng_init_pplt, mng_free_pplt, mng_read_pplt, mng_write_pplt, mng_assign_pplt, 0, 0},
Packit 93f41a
    {MNG_UINT_PROM, mng_init_prom, mng_free_prom, mng_read_prom, mng_write_prom, mng_assign_prom, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SAVE
Packit 93f41a
    {MNG_UINT_SAVE, mng_init_save, mng_free_save, mng_read_save, mng_write_save, mng_assign_save, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SEEK
Packit 93f41a
    {MNG_UINT_SEEK, mng_init_seek, mng_free_seek, mng_read_seek, mng_write_seek, mng_assign_seek, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SHOW
Packit 93f41a
    {MNG_UINT_SHOW, mng_init_show, mng_free_show, mng_read_show, mng_write_show, mng_assign_show, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_TERM
Packit 93f41a
    {MNG_UINT_TERM, mng_init_term, mng_free_term, mng_read_term, mng_write_term, mng_assign_term, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_bKGD
Packit 93f41a
    {MNG_UINT_bKGD, mng_init_bkgd, mng_free_bkgd, mng_read_bkgd, mng_write_bkgd, mng_assign_bkgd, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_cHRM
Packit 93f41a
    {MNG_UINT_cHRM, mng_init_chrm, mng_free_chrm, mng_read_chrm, mng_write_chrm, mng_assign_chrm, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_eXPI
Packit 93f41a
    {MNG_UINT_eXPI, mng_init_expi, mng_free_expi, mng_read_expi, mng_write_expi, mng_assign_expi, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_evNT
Packit 93f41a
    {MNG_UINT_evNT, mng_init_evnt, mng_free_evnt, mng_read_evnt, mng_write_evnt, mng_assign_evnt, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_fPRI
Packit 93f41a
    {MNG_UINT_fPRI, mng_init_fpri, mng_free_fpri, mng_read_fpri, mng_write_fpri, mng_assign_fpri, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_gAMA
Packit 93f41a
    {MNG_UINT_gAMA, mng_init_gama, mng_free_gama, mng_read_gama, mng_write_gama, mng_assign_gama, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_hIST
Packit 93f41a
    {MNG_UINT_hIST, mng_init_hist, mng_free_hist, mng_read_hist, mng_write_hist, mng_assign_hist, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_iCCP
Packit 93f41a
    {MNG_UINT_iCCP, mng_init_iccp, mng_free_iccp, mng_read_iccp, mng_write_iccp, mng_assign_iccp, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_iTXt
Packit 93f41a
    {MNG_UINT_iTXt, mng_init_itxt, mng_free_itxt, mng_read_itxt, mng_write_itxt, mng_assign_itxt, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_nEED
Packit 93f41a
    {MNG_UINT_nEED, mng_init_need, mng_free_need, mng_read_need, mng_write_need, mng_assign_need, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
/* TODO:     {MNG_UINT_oFFs, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
/* TODO:     {MNG_UINT_pCAL, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
#ifndef MNG_SKIPCHUNK_pHYg
Packit 93f41a
    {MNG_UINT_pHYg, mng_init_phyg, mng_free_phyg, mng_read_phyg, mng_write_phyg, mng_assign_phyg, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_pHYs
Packit 93f41a
    {MNG_UINT_pHYs, mng_init_phys, mng_free_phys, mng_read_phys, mng_write_phys, mng_assign_phys, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_sBIT
Packit 93f41a
    {MNG_UINT_sBIT, mng_init_sbit, mng_free_sbit, mng_read_sbit, mng_write_sbit, mng_assign_sbit, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
/* TODO:     {MNG_UINT_sCAL, 0, 0, 0, 0, 0, 0},  */
Packit 93f41a
#ifndef MNG_SKIPCHUNK_sPLT
Packit 93f41a
    {MNG_UINT_sPLT, mng_init_splt, mng_free_splt, mng_read_splt, mng_write_splt, mng_assign_splt, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_sRGB, mng_init_srgb, mng_free_srgb, mng_read_srgb, mng_write_srgb, mng_assign_srgb, 0, 0},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_tEXt
Packit 93f41a
    {MNG_UINT_tEXt, mng_init_text, mng_free_text, mng_read_text, mng_write_text, mng_assign_text, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_tIME
Packit 93f41a
    {MNG_UINT_tIME, mng_init_time, mng_free_time, mng_read_time, mng_write_time, mng_assign_time, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
    {MNG_UINT_tRNS, mng_init_trns, mng_free_trns, mng_read_trns, mng_write_trns, mng_assign_trns, 0, 0},
Packit 93f41a
#ifndef MNG_SKIPCHUNK_zTXt
Packit 93f41a
    {MNG_UINT_zTXt, mng_init_ztxt, mng_free_ztxt, mng_read_ztxt, mng_write_ztxt, mng_assign_ztxt, 0, 0},
Packit 93f41a
#endif
Packit 93f41a
  };
Packit 93f41a
Packit 93f41a
#endif                       /* MNG_OPTIMIZE_CHUNKINITFREE */
Packit 93f41a
Packit 93f41a
                                       /* binary search variables */
Packit 93f41a
  mng_int32         iTop, iLower, iUpper, iMiddle;
Packit 93f41a
  mng_chunk_headerp pEntry;            /* pointer to found entry */
Packit 93f41a
#else
Packit 93f41a
  mng_chunk_header  sEntry;            /* temp chunk-header */
Packit 93f41a
#endif /* MNG_OPTIMIZE_CHUNKREADER */
Packit 93f41a
Packit 93f41a
  mng_chunkid       iChunkname;        /* the chunk's tag */
Packit 93f41a
  mng_chunkp        pChunk;            /* chunk structure (if #define MNG_STORE_CHUNKS) */
Packit 93f41a
  mng_retcode       iRetcode;          /* temporary error-code */
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_PROCESS_RAW_CHUNK, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
                                       /* reset timer indicator on read-cycle */
Packit 93f41a
  if ((pData->bReading) && (!pData->bDisplaying))
Packit 93f41a
    pData->bTimerset = MNG_FALSE;
Packit 93f41a
                                       /* get the chunkname */
Packit 93f41a
  iChunkname = (mng_chunkid)(mng_get_uint32 (pBuf));
Packit 93f41a
Packit 93f41a
  pBuf += sizeof (mng_chunkid);        /* adjust the buffer */
Packit 93f41a
  iBuflen -= sizeof (mng_chunkid);
Packit 93f41a
  pChunk = 0;
Packit 93f41a
Packit 93f41a
#ifndef MNG_OPTIMIZE_CHUNKREADER
Packit 93f41a
                                       /* determine max index of table */
Packit 93f41a
  iTop = (sizeof (mng_chunk_table) / sizeof (mng_chunk_table [0])) - 1;
Packit 93f41a
Packit 93f41a
  /* binary search; with 54 chunks, worst-case is 7 comparisons */
Packit 93f41a
  iLower  = 0;
Packit 93f41a
#ifndef MNG_NO_DELTA_PNG
Packit 93f41a
  iMiddle = 11;                        /* start with the IDAT entry */
Packit 93f41a
#else
Packit 93f41a
  iMiddle = 8;
Packit 93f41a
#endif
Packit 93f41a
  iUpper  = iTop;
Packit 93f41a
  pEntry  = 0;                         /* no goods yet! */
Packit 93f41a
Packit 93f41a
  do                                   /* the binary search itself */
Packit 93f41a
    {
Packit 93f41a
      if (mng_chunk_table [iMiddle].iChunkname < iChunkname)
Packit 93f41a
        iLower = iMiddle + 1;
Packit 93f41a
      else if (mng_chunk_table [iMiddle].iChunkname > iChunkname)
Packit 93f41a
        iUpper = iMiddle - 1;
Packit 93f41a
      else
Packit 93f41a
      {
Packit 93f41a
        pEntry = &mng_chunk_table [iMiddle];
Packit 93f41a
        break;
Packit 93f41a
      }
Packit 93f41a
Packit 93f41a
      iMiddle = (iLower + iUpper) >> 1;
Packit 93f41a
    }
Packit 93f41a
  while (iLower <= iUpper);
Packit 93f41a
Packit 93f41a
  if (!pEntry)                         /* unknown chunk ? */
Packit 93f41a
    pEntry = &mng_chunk_unknown;       /* make it so! */
Packit 93f41a
Packit 93f41a
#else /* MNG_OPTIMIZE_CHUNKREADER */
Packit 93f41a
Packit 93f41a
  mng_get_chunkheader (iChunkname, &sEntry);
Packit 93f41a
Packit 93f41a
#endif /* MNG_OPTIMIZE_CHUNKREADER */
Packit 93f41a
Packit 93f41a
  pData->iChunkname = iChunkname;      /* keep track of where we are */
Packit 93f41a
  pData->iChunkseq++;
Packit 93f41a
Packit 93f41a
#ifndef MNG_OPTIMIZE_CHUNKREADER
Packit 93f41a
  if (pEntry->fRead)                   /* read-callback available ? */
Packit 93f41a
  {
Packit 93f41a
    iRetcode = pEntry->fRead (pData, pEntry, iBuflen, (mng_ptr)pBuf, &pChunk);
Packit 93f41a
Packit 93f41a
    if (!iRetcode)                     /* everything oke ? */
Packit 93f41a
    {                                  /* remember unknown chunk's id */
Packit 93f41a
      if ((pChunk) && (pEntry->iChunkname == MNG_UINT_HUH))
Packit 93f41a
        ((mng_chunk_headerp)pChunk)->iChunkname = iChunkname;
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
#else /* MNG_OPTIMIZE_CHUNKREADER */
Packit 93f41a
  if (sEntry.fRead)                    /* read-callback available ? */
Packit 93f41a
  {
Packit 93f41a
    iRetcode = sEntry.fRead (pData, &sEntry, iBuflen, (mng_ptr)pBuf, &pChunk);
Packit 93f41a
Packit 93f41a
#ifndef MNG_OPTIMIZE_CHUNKREADER
Packit 93f41a
    if (!iRetcode)                     /* everything oke ? */
Packit 93f41a
    {                                  /* remember unknown chunk's id */
Packit 93f41a
      if ((pChunk) && (sEntry.iChunkname == MNG_UINT_HUH))
Packit 93f41a
        ((mng_chunk_headerp)pChunk)->iChunkname = iChunkname;
Packit 93f41a
    }
Packit 93f41a
#endif
Packit 93f41a
  }
Packit 93f41a
#endif /* MNG_OPTIMIZE_CHUNKREADER */
Packit 93f41a
  else
Packit 93f41a
    iRetcode = MNG_NOERROR;
Packit 93f41a
Packit 93f41a
  if (pChunk)                          /* store this chunk ? */
Packit 93f41a
    mng_add_chunk (pData, pChunk);     /* do it */
Packit 93f41a
Packit 93f41a
#ifdef MNG_INCLUDE_JNG                 /* implicit EOF ? */
Packit 93f41a
  if ((!pData->bHasMHDR) && (!pData->bHasIHDR) && (!pData->bHasJHDR))
Packit 93f41a
#else
Packit 93f41a
  if ((!pData->bHasMHDR) && (!pData->bHasIHDR))
Packit 93f41a
#endif
Packit 93f41a
    iRetcode = mng_process_eof (pData);/* then do some EOF processing */
Packit 93f41a
Packit 93f41a
  if (iRetcode)                        /* on error bail out */
Packit 93f41a
    return iRetcode;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_PROCESS_RAW_CHUNK, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode check_chunk_crc (mng_datap  pData,
Packit 93f41a
                                       mng_uint8p pBuf,
Packit 93f41a
                                       mng_uint32 iBuflen)
Packit 93f41a
{
Packit 93f41a
  mng_uint32  iCrc;                    /* calculated CRC */
Packit 93f41a
  mng_bool    bDiscard = MNG_FALSE;
Packit 93f41a
  mng_retcode iRetcode = MNG_NOERROR;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_CHUNK_CRC, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  if (pData->iCrcmode & MNG_CRC_INPUT) /* crc included ? */
Packit 93f41a
  {
Packit 93f41a
    mng_bool bCritical = (mng_bool)((*pBuf & 0x20) == 0);
Packit 93f41a
    mng_uint32 iL = iBuflen - (mng_uint32)(sizeof (iCrc));
Packit 93f41a
Packit 93f41a
    if (((bCritical ) && (pData->iCrcmode & MNG_CRC_CRITICAL )) ||
Packit 93f41a
        ((!bCritical) && (pData->iCrcmode & MNG_CRC_ANCILLARY)))
Packit 93f41a
    {                                  /* calculate the crc */
Packit 93f41a
      iCrc = mng_crc (pData, pBuf, iL);
Packit 93f41a
                                       /* and check it */
Packit 93f41a
      if (!(iCrc == mng_get_uint32 (pBuf + iL)))
Packit 93f41a
      {
Packit 93f41a
        mng_bool bWarning = MNG_FALSE;
Packit 93f41a
        mng_bool bError   = MNG_FALSE;
Packit 93f41a
Packit 93f41a
        if (bCritical)
Packit 93f41a
        {
Packit 93f41a
          switch (pData->iCrcmode & MNG_CRC_CRITICAL)
Packit 93f41a
          {
Packit 93f41a
            case MNG_CRC_CRITICAL_WARNING  : { bWarning = MNG_TRUE; break; }
Packit 93f41a
            case MNG_CRC_CRITICAL_ERROR    : { bError   = MNG_TRUE; break; }
Packit 93f41a
          }
Packit 93f41a
        }
Packit 93f41a
        else
Packit 93f41a
        {
Packit 93f41a
          switch (pData->iCrcmode & MNG_CRC_ANCILLARY)
Packit 93f41a
          {
Packit 93f41a
            case MNG_CRC_ANCILLARY_DISCARD : { bDiscard = MNG_TRUE; break; }
Packit 93f41a
            case MNG_CRC_ANCILLARY_WARNING : { bWarning = MNG_TRUE; break; }
Packit 93f41a
            case MNG_CRC_ANCILLARY_ERROR   : { bError   = MNG_TRUE; break; }
Packit 93f41a
          }
Packit 93f41a
        }
Packit 93f41a
Packit 93f41a
        if (bWarning)
Packit 93f41a
          MNG_WARNING (pData, MNG_INVALIDCRC);
Packit 93f41a
        if (bError)
Packit 93f41a
          MNG_ERROR (pData, MNG_INVALIDCRC);
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
Packit 93f41a
    if (!bDiscard)                     /* still processing ? */
Packit 93f41a
      iRetcode = process_raw_chunk (pData, pBuf, iL);
Packit 93f41a
  }
Packit 93f41a
  else
Packit 93f41a
  {                                    /* no crc => straight onto processing */
Packit 93f41a
    iRetcode = process_raw_chunk (pData, pBuf, iBuflen);
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_CHUNK_CRC, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return iRetcode;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode read_chunk (mng_datap  pData)
Packit 93f41a
{
Packit 93f41a
  mng_uint32  iBufmax   = pData->iReadbufsize;
Packit 93f41a
  mng_uint8p  pBuf      = pData->pReadbuf;
Packit 93f41a
  mng_uint32  iBuflen   = 0;           /* number of bytes requested */
Packit 93f41a
  mng_uint32  iRead     = 0;           /* number of bytes read */
Packit 93f41a
  mng_retcode iRetcode  = MNG_NOERROR;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_CHUNK, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY
Packit 93f41a
  if (pData->pCurraniobj)              /* processing an animation object ? */
Packit 93f41a
  {
Packit 93f41a
    do                                 /* process it then */
Packit 93f41a
    {
Packit 93f41a
      iRetcode = ((mng_object_headerp)pData->pCurraniobj)->fProcess (pData, pData->pCurraniobj);
Packit 93f41a
                                       /* refresh needed ? */
Packit 93f41a
/*      if ((!iRetcode) && (!pData->bTimerset) && (pData->bNeedrefresh))
Packit 93f41a
        iRetcode = display_progressive_refresh (pData, 1); */
Packit 93f41a
                                       /* can we advance to next object ? */
Packit 93f41a
      if ((!iRetcode) && (pData->pCurraniobj) &&
Packit 93f41a
          (!pData->bTimerset) && (!pData->bSectionwait))
Packit 93f41a
      {                                /* reset timer indicator on read-cycle */
Packit 93f41a
        if ((pData->bReading) && (!pData->bDisplaying))
Packit 93f41a
          pData->bTimerset = MNG_FALSE;
Packit 93f41a
Packit 93f41a
        pData->pCurraniobj = ((mng_object_headerp)pData->pCurraniobj)->pNext;
Packit 93f41a
                                       /* TERM processing to be done ? */
Packit 93f41a
        if ((!pData->pCurraniobj) && (pData->bHasTERM) && (!pData->bHasMHDR))
Packit 93f41a
          iRetcode = mng_process_display_mend (pData);
Packit 93f41a
      }
Packit 93f41a
    }                                  /* until error or a break or no more objects */
Packit 93f41a
    while ((!iRetcode) && (pData->pCurraniobj) &&
Packit 93f41a
           (!pData->bTimerset) && (!pData->bSectionwait) && (!pData->bFreezing));
Packit 93f41a
  }
Packit 93f41a
  else
Packit 93f41a
  {
Packit 93f41a
    if (pData->iBreakpoint)            /* do we need to finish something first ? */
Packit 93f41a
    {
Packit 93f41a
      switch (pData->iBreakpoint)      /* return to broken display routine */
Packit 93f41a
      {
Packit 93f41a
#ifndef MNG_SKIPCHUNK_FRAM
Packit 93f41a
        case  1 : { iRetcode = mng_process_display_fram2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case  2 : { iRetcode = mng_process_display_ihdr  (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SHOW
Packit 93f41a
        case  3 : ;                     /* same as 4 !!! */
Packit 93f41a
        case  4 : { iRetcode = mng_process_display_show  (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLON
Packit 93f41a
        case  5 : { iRetcode = mng_process_display_clon2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
        case  7 : { iRetcode = mng_process_display_jhdr  (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case  6 : ;                     /* same as 8 !!! */
Packit 93f41a
        case  8 : { iRetcode = mng_process_display_iend  (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MAGN
Packit 93f41a
        case  9 : { iRetcode = mng_process_display_magn2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case 10 : { iRetcode = mng_process_display_mend2 (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_PAST
Packit 93f41a
        case 11 : { iRetcode = mng_process_display_past2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  if (iRetcode)                        /* on error bail out */
Packit 93f41a
    return iRetcode;
Packit 93f41a
Packit 93f41a
#endif /* MNG_SUPPORT_DISPLAY */
Packit 93f41a
                                       /* can we continue processing now, or do we */
Packit 93f41a
                                       /* need to wait for the timer to finish (again) ? */
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY
Packit 93f41a
  if ((!pData->bTimerset) && (!pData->bSectionwait) && (!pData->bEOF))
Packit 93f41a
#else
Packit 93f41a
  if (!pData->bEOF)
Packit 93f41a
#endif
Packit 93f41a
  {
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY
Packit 93f41a
                                       /* freezing in progress ? */
Packit 93f41a
    if ((pData->bFreezing) && (pData->iSuspendpoint == 0))
Packit 93f41a
      pData->bRunning = MNG_FALSE;     /* then this is the right moment to do it */
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
    if (pData->iSuspendpoint <= 2)
Packit 93f41a
    {
Packit 93f41a
      iBuflen  = sizeof (mng_uint32);  /* read length */
Packit 93f41a
      iRetcode = read_databuffer (pData, pBuf, &pData->pReadbufnext, iBuflen, &iRead);
Packit 93f41a
Packit 93f41a
      if (iRetcode)                    /* bail on errors */
Packit 93f41a
        return iRetcode;
Packit 93f41a
Packit 93f41a
      if (pData->bSuspended)           /* suspended ? */
Packit 93f41a
        pData->iSuspendpoint = 2;
Packit 93f41a
      else                             /* save the length */
Packit 93f41a
      {
Packit 93f41a
        pData->iChunklen = mng_get_uint32 (pBuf);
Packit 93f41a
        if (pData->iChunklen > 0x7ffffff)
Packit 93f41a
           return MNG_INVALIDLENGTH;
Packit 93f41a
      }
Packit 93f41a
Packit 93f41a
    }
Packit 93f41a
Packit 93f41a
    if (!pData->bSuspended)            /* still going ? */
Packit 93f41a
    {                                  /* previously suspended or not eof ? */
Packit 93f41a
      if ((pData->iSuspendpoint > 2) || (iRead == iBuflen))
Packit 93f41a
      {                                /* determine length chunkname + data (+ crc) */
Packit 93f41a
        if (pData->iCrcmode & MNG_CRC_INPUT)
Packit 93f41a
          iBuflen = pData->iChunklen + (mng_uint32)(sizeof (mng_chunkid) + sizeof (mng_uint32));
Packit 93f41a
        else
Packit 93f41a
          iBuflen = pData->iChunklen + (mng_uint32)(sizeof (mng_chunkid));
Packit 93f41a
Packit 93f41a
                                       /* do we have enough data in the current push buffer ? */
Packit 93f41a
        if ((pData->pFirstpushdata) && (iBuflen <= pData->pFirstpushdata->iRemaining))
Packit 93f41a
        {
Packit 93f41a
          mng_pushdatap pPush  = pData->pFirstpushdata;
Packit 93f41a
          pBuf                 = pPush->pDatanext;
Packit 93f41a
          pPush->pDatanext    += iBuflen;
Packit 93f41a
          pPush->iRemaining   -= iBuflen;
Packit 93f41a
          pData->iSuspendpoint = 0;    /* safely reset this here ! */
Packit 93f41a
Packit 93f41a
          iRetcode = check_chunk_crc (pData, pBuf, iBuflen);
Packit 93f41a
          if (iRetcode)
Packit 93f41a
            return iRetcode;
Packit 93f41a
Packit 93f41a
          if (!pPush->iRemaining)      /* buffer depleted? then release it */
Packit 93f41a
            iRetcode = mng_release_pushdata (pData);
Packit 93f41a
        }
Packit 93f41a
        else
Packit 93f41a
        {
Packit 93f41a
          if (iBuflen < iBufmax)       /* does it fit in default buffer ? */
Packit 93f41a
          {                            /* note that we don't use the full size
Packit 93f41a
                                          so there's always a zero-byte at the
Packit 93f41a
                                          very end !!! */
Packit 93f41a
            iRetcode = read_databuffer (pData, pBuf, &pData->pReadbufnext, iBuflen, &iRead);
Packit 93f41a
            if (iRetcode)              /* bail on errors */
Packit 93f41a
              return iRetcode;
Packit 93f41a
Packit 93f41a
            if (pData->bSuspended)     /* suspended ? */
Packit 93f41a
              pData->iSuspendpoint = 3;
Packit 93f41a
            else
Packit 93f41a
            {
Packit 93f41a
              if (iRead != iBuflen)    /* did we get all the data ? */
Packit 93f41a
                MNG_ERROR (pData, MNG_UNEXPECTEDEOF);
Packit 93f41a
              iRetcode = check_chunk_crc (pData, pBuf, iBuflen);
Packit 93f41a
            }
Packit 93f41a
          }
Packit 93f41a
          else
Packit 93f41a
          {
Packit 93f41a
            if (iBuflen > 16777216)    /* is the length incredible? */
Packit 93f41a
              MNG_ERROR (pData, MNG_IMPROBABLELENGTH);
Packit 93f41a
Packit 93f41a
            if (!pData->iSuspendpoint) /* create additional large buffer ? */
Packit 93f41a
            {                          /* again reserve space for the last zero-byte */
Packit 93f41a
              pData->iLargebufsize = iBuflen + 1;
Packit 93f41a
              pData->pLargebufnext = MNG_NULL;
Packit 93f41a
              MNG_ALLOC (pData, pData->pLargebuf, pData->iLargebufsize);
Packit 93f41a
            }
Packit 93f41a
Packit 93f41a
            iRetcode = read_databuffer (pData, pData->pLargebuf, &pData->pLargebufnext, iBuflen, &iRead);
Packit 93f41a
            if (iRetcode)
Packit 93f41a
              return iRetcode;
Packit 93f41a
Packit 93f41a
            if (pData->bSuspended)     /* suspended ? */
Packit 93f41a
              pData->iSuspendpoint = 4;
Packit 93f41a
            else
Packit 93f41a
            {
Packit 93f41a
              if (iRead != iBuflen)    /* did we get all the data ? */
Packit 93f41a
                MNG_ERROR (pData, MNG_UNEXPECTEDEOF);
Packit 93f41a
              iRetcode = check_chunk_crc (pData, pData->pLargebuf, iBuflen);
Packit 93f41a
                                       /* cleanup additional large buffer */
Packit 93f41a
              MNG_FREE (pData, pData->pLargebuf, pData->iLargebufsize);
Packit 93f41a
            }
Packit 93f41a
          }
Packit 93f41a
        }
Packit 93f41a
Packit 93f41a
        if (iRetcode)                  /* on error bail out */
Packit 93f41a
          return iRetcode;
Packit 93f41a
Packit 93f41a
      }
Packit 93f41a
      else
Packit 93f41a
      {                                /* that's final */
Packit 93f41a
        iRetcode = mng_process_eof (pData);
Packit 93f41a
Packit 93f41a
        if (iRetcode)                  /* on error bail out */
Packit 93f41a
          return iRetcode;
Packit 93f41a
Packit 93f41a
        if ((iRead != 0) ||            /* did we get an unexpected eof ? */
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
            (pData->bHasIHDR || pData->bHasMHDR || pData->bHasJHDR))
Packit 93f41a
#else
Packit 93f41a
            (pData->bHasIHDR || pData->bHasMHDR))
Packit 93f41a
#endif
Packit 93f41a
          MNG_ERROR (pData, MNG_UNEXPECTEDEOF);
Packit 93f41a
      } 
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY             /* refresh needed ? */
Packit 93f41a
  if ((!pData->bTimerset) && (!pData->bSuspended) && (pData->bNeedrefresh))
Packit 93f41a
  {
Packit 93f41a
    iRetcode = mng_display_progressive_refresh (pData, 1);
Packit 93f41a
Packit 93f41a
    if (iRetcode)                      /* on error bail out */
Packit 93f41a
      return iRetcode;
Packit 93f41a
  }
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_CHUNK, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
MNG_LOCAL mng_retcode process_pushedchunk (mng_datap pData)
Packit 93f41a
{
Packit 93f41a
  mng_pushdatap pPush;
Packit 93f41a
  mng_retcode   iRetcode = MNG_NOERROR;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY
Packit 93f41a
  if (pData->pCurraniobj)              /* processing an animation object ? */
Packit 93f41a
  {
Packit 93f41a
    do                                 /* process it then */
Packit 93f41a
    {
Packit 93f41a
      iRetcode = ((mng_object_headerp)pData->pCurraniobj)->fProcess (pData, pData->pCurraniobj);
Packit 93f41a
                                       /* refresh needed ? */
Packit 93f41a
/*      if ((!iRetcode) && (!pData->bTimerset) && (pData->bNeedrefresh))
Packit 93f41a
        iRetcode = display_progressive_refresh (pData, 1); */
Packit 93f41a
                                       /* can we advance to next object ? */
Packit 93f41a
      if ((!iRetcode) && (pData->pCurraniobj) &&
Packit 93f41a
          (!pData->bTimerset) && (!pData->bSectionwait))
Packit 93f41a
      {                                /* reset timer indicator on read-cycle */
Packit 93f41a
        if ((pData->bReading) && (!pData->bDisplaying))
Packit 93f41a
          pData->bTimerset = MNG_FALSE;
Packit 93f41a
Packit 93f41a
        pData->pCurraniobj = ((mng_object_headerp)pData->pCurraniobj)->pNext;
Packit 93f41a
                                       /* TERM processing to be done ? */
Packit 93f41a
        if ((!pData->pCurraniobj) && (pData->bHasTERM) && (!pData->bHasMHDR))
Packit 93f41a
          iRetcode = mng_process_display_mend (pData);
Packit 93f41a
      }
Packit 93f41a
    }                                  /* until error or a break or no more objects */
Packit 93f41a
    while ((!iRetcode) && (pData->pCurraniobj) &&
Packit 93f41a
           (!pData->bTimerset) && (!pData->bSectionwait) && (!pData->bFreezing));
Packit 93f41a
  }
Packit 93f41a
  else
Packit 93f41a
  {
Packit 93f41a
    if (pData->iBreakpoint)            /* do we need to finish something first ? */
Packit 93f41a
    {
Packit 93f41a
      switch (pData->iBreakpoint)      /* return to broken display routine */
Packit 93f41a
      {
Packit 93f41a
#ifndef MNG_SKIPCHUNK_FRAM
Packit 93f41a
        case  1 : { iRetcode = mng_process_display_fram2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case  2 : { iRetcode = mng_process_display_ihdr  (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_SHOW
Packit 93f41a
        case  3 : ;                     /* same as 4 !!! */
Packit 93f41a
        case  4 : { iRetcode = mng_process_display_show  (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
#ifndef MNG_SKIPCHUNK_CLON
Packit 93f41a
        case  5 : { iRetcode = mng_process_display_clon2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
        case  7 : { iRetcode = mng_process_display_jhdr  (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case  6 : ;                     /* same as 8 !!! */
Packit 93f41a
        case  8 : { iRetcode = mng_process_display_iend  (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_MAGN
Packit 93f41a
        case  9 : { iRetcode = mng_process_display_magn2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
        case 10 : { iRetcode = mng_process_display_mend2 (pData); break; }
Packit 93f41a
#ifndef MNG_SKIPCHUNK_PAST
Packit 93f41a
        case 11 : { iRetcode = mng_process_display_past2 (pData); break; }
Packit 93f41a
#endif
Packit 93f41a
      }
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  if (iRetcode)                        /* on error bail out */
Packit 93f41a
    return iRetcode;
Packit 93f41a
Packit 93f41a
#endif /* MNG_SUPPORT_DISPLAY */
Packit 93f41a
                                       /* can we continue processing now, or do we */
Packit 93f41a
                                       /* need to wait for the timer to finish (again) ? */
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY
Packit 93f41a
  if ((!pData->bTimerset) && (!pData->bSectionwait) && (!pData->bEOF))
Packit 93f41a
#else
Packit 93f41a
  if (!pData->bEOF)
Packit 93f41a
#endif
Packit 93f41a
  {
Packit 93f41a
    pData->iSuspendpoint = 0;            /* safely reset it here ! */
Packit 93f41a
    pPush = pData->pFirstpushchunk;
Packit 93f41a
Packit 93f41a
    iRetcode = process_raw_chunk (pData, pPush->pData, pPush->iLength);
Packit 93f41a
    if (iRetcode)
Packit 93f41a
      return iRetcode;
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY             /* refresh needed ? */
Packit 93f41a
    if ((!pData->bTimerset) && (!pData->bSuspended) && (pData->bNeedrefresh))
Packit 93f41a
    {
Packit 93f41a
      iRetcode = mng_display_progressive_refresh (pData, 1);
Packit 93f41a
      if (iRetcode)                      /* on error bail out */
Packit 93f41a
        return iRetcode;
Packit 93f41a
    }
Packit 93f41a
#endif
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  return mng_release_pushchunk (pData);
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
mng_retcode mng_read_graphic (mng_datap pData)
Packit 93f41a
{
Packit 93f41a
  mng_uint32  iBuflen;                 /* number of bytes requested */
Packit 93f41a
  mng_uint32  iRead;                   /* number of bytes read */
Packit 93f41a
  mng_retcode iRetcode;                /* temporary error-code */
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_GRAPHIC, MNG_LC_START);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  if (!pData->pReadbuf)                /* buffer allocated ? */
Packit 93f41a
  {
Packit 93f41a
    pData->iReadbufsize = 4200;        /* allocate a default read buffer */
Packit 93f41a
    MNG_ALLOC (pData, pData->pReadbuf, pData->iReadbufsize);
Packit 93f41a
  }
Packit 93f41a
                                       /* haven't processed the signature ? */
Packit 93f41a
  if ((!pData->bHavesig) || (pData->iSuspendpoint == 1))
Packit 93f41a
  {
Packit 93f41a
    iBuflen = 2 * sizeof (mng_uint32); /* read signature */
Packit 93f41a
Packit 93f41a
    iRetcode = read_databuffer (pData, pData->pReadbuf, &pData->pReadbufnext, iBuflen, &iRead);
Packit 93f41a
Packit 93f41a
    if (iRetcode)
Packit 93f41a
      return iRetcode;
Packit 93f41a
Packit 93f41a
    if (pData->bSuspended)             /* input suspension ? */
Packit 93f41a
      pData->iSuspendpoint = 1;
Packit 93f41a
    else
Packit 93f41a
    {
Packit 93f41a
      if (iRead != iBuflen)            /* full signature received ? */
Packit 93f41a
        MNG_ERROR (pData, MNG_UNEXPECTEDEOF);
Packit 93f41a
                                       /* is it a valid signature ? */
Packit 93f41a
      if (mng_get_uint32 (pData->pReadbuf) == PNG_SIG)
Packit 93f41a
        pData->eSigtype = mng_it_png;
Packit 93f41a
      else
Packit 93f41a
#ifdef MNG_INCLUDE_JNG
Packit 93f41a
      if (mng_get_uint32 (pData->pReadbuf) == JNG_SIG)
Packit 93f41a
        pData->eSigtype = mng_it_jng;
Packit 93f41a
      else
Packit 93f41a
#endif
Packit 93f41a
      if (mng_get_uint32 (pData->pReadbuf) == MNG_SIG)
Packit 93f41a
        pData->eSigtype = mng_it_mng;
Packit 93f41a
      else
Packit 93f41a
        MNG_ERROR (pData, MNG_INVALIDSIG);
Packit 93f41a
                                       /* all of it ? */
Packit 93f41a
      if (mng_get_uint32 (pData->pReadbuf+4) != POST_SIG)
Packit 93f41a
        MNG_ERROR (pData, MNG_INVALIDSIG);
Packit 93f41a
Packit 93f41a
      pData->bHavesig = MNG_TRUE;
Packit 93f41a
    }
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
  if (!pData->bSuspended)              /* still going ? */
Packit 93f41a
  {
Packit 93f41a
    do
Packit 93f41a
    {                                  /* reset timer during mng_read() ? */
Packit 93f41a
      if ((pData->bReading) && (!pData->bDisplaying))
Packit 93f41a
        pData->bTimerset = MNG_FALSE;
Packit 93f41a
Packit 93f41a
      if (pData->pFirstpushchunk)      /* chunks pushed ? */
Packit 93f41a
        iRetcode = process_pushedchunk (pData); /* process the pushed chunk */
Packit 93f41a
      else
Packit 93f41a
        iRetcode = read_chunk (pData); /* read & process a chunk */
Packit 93f41a
Packit 93f41a
      if (iRetcode)                    /* on error bail out */
Packit 93f41a
        return iRetcode;
Packit 93f41a
    }
Packit 93f41a
#ifdef MNG_SUPPORT_DISPLAY             /* until EOF or a break-request */
Packit 93f41a
    while (((!pData->bEOF) || (pData->pCurraniobj)) &&
Packit 93f41a
           (!pData->bSuspended) && (!pData->bSectionwait) &&
Packit 93f41a
           ((!pData->bTimerset) || ((pData->bReading) && (!pData->bDisplaying))));
Packit 93f41a
#else
Packit 93f41a
    while ((!pData->bEOF) && (!pData->bSuspended));
Packit 93f41a
#endif
Packit 93f41a
  }
Packit 93f41a
Packit 93f41a
#ifdef MNG_SUPPORT_TRACE
Packit 93f41a
  MNG_TRACE (pData, MNG_FN_READ_GRAPHIC, MNG_LC_END);
Packit 93f41a
#endif
Packit 93f41a
Packit 93f41a
  return MNG_NOERROR;
Packit 93f41a
}
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
Packit 93f41a
#endif /* MNG_INCLUDE_READ_PROCS */
Packit 93f41a
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a
/* * end of file                                                            * */
Packit 93f41a
/* ************************************************************************** */
Packit 93f41a