Files correlati : sqlite Ricompilazione Demo : [ ] Commento : Passaggio da Sqlite 2 a Sqlite 3.3.5 git-svn-id: svn://10.65.10.50/trunk@13902 c028cbd2-c16b-5b4b-a496-9718f37d4682
		
			
				
	
	
		
			115 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
/*
 | 
						|
** 2005 June 16
 | 
						|
**
 | 
						|
** The author disclaims copyright to this source code.  In place of
 | 
						|
** a legal notice, here is a blessing:
 | 
						|
**
 | 
						|
**    May you do good and not evil.
 | 
						|
**    May you find forgiveness for yourself and forgive others.
 | 
						|
**    May you share freely, never taking more than you give.
 | 
						|
**
 | 
						|
*************************************************************************
 | 
						|
** This file implements a FIFO queue of rowids used for processing
 | 
						|
** UPDATE and DELETE statements.
 | 
						|
*/
 | 
						|
#include "sqliteInt.h"
 | 
						|
#include "vdbeInt.h"
 | 
						|
 | 
						|
/*
 | 
						|
** Allocate a new FifoPage and return a pointer to it.  Return NULL if
 | 
						|
** we run out of memory.  Leave space on the page for nEntry entries.
 | 
						|
*/
 | 
						|
static FifoPage *allocatePage(int nEntry){
 | 
						|
  FifoPage *pPage;
 | 
						|
  if( nEntry>32767 ){
 | 
						|
    nEntry = 32767;
 | 
						|
  }
 | 
						|
  pPage = sqliteMallocRaw( sizeof(FifoPage) + sizeof(i64)*(nEntry-1) );
 | 
						|
  if( pPage ){
 | 
						|
    pPage->nSlot = nEntry;
 | 
						|
    pPage->iWrite = 0;
 | 
						|
    pPage->iRead = 0;
 | 
						|
    pPage->pNext = 0;
 | 
						|
  }
 | 
						|
  return pPage;
 | 
						|
}
 | 
						|
 | 
						|
/*
 | 
						|
** Initialize a Fifo structure.
 | 
						|
*/
 | 
						|
void sqlite3VdbeFifoInit(Fifo *pFifo){
 | 
						|
  memset(pFifo, 0, sizeof(*pFifo));
 | 
						|
}
 | 
						|
 | 
						|
/*
 | 
						|
** Push a single 64-bit integer value into the Fifo.  Return SQLITE_OK
 | 
						|
** normally.   SQLITE_NOMEM is returned if we are unable to allocate
 | 
						|
** memory.
 | 
						|
*/
 | 
						|
int sqlite3VdbeFifoPush(Fifo *pFifo, i64 val){
 | 
						|
  FifoPage *pPage;
 | 
						|
  pPage = pFifo->pLast;
 | 
						|
  if( pPage==0 ){
 | 
						|
    pPage = pFifo->pLast = pFifo->pFirst = allocatePage(20);
 | 
						|
    if( pPage==0 ){
 | 
						|
      return SQLITE_NOMEM;
 | 
						|
    }
 | 
						|
  }else if( pPage->iWrite>=pPage->nSlot ){
 | 
						|
    pPage->pNext = allocatePage(pFifo->nEntry);
 | 
						|
    if( pPage->pNext==0 ){
 | 
						|
      return SQLITE_NOMEM;
 | 
						|
    }
 | 
						|
    pPage = pFifo->pLast = pPage->pNext;
 | 
						|
  }
 | 
						|
  pPage->aSlot[pPage->iWrite++] = val;
 | 
						|
  pFifo->nEntry++;
 | 
						|
  return SQLITE_OK;
 | 
						|
}
 | 
						|
 | 
						|
/*
 | 
						|
** Extract a single 64-bit integer value from the Fifo.  The integer
 | 
						|
** extracted is the one least recently inserted.  If the Fifo is empty
 | 
						|
** return SQLITE_DONE.
 | 
						|
*/
 | 
						|
int sqlite3VdbeFifoPop(Fifo *pFifo, i64 *pVal){
 | 
						|
  FifoPage *pPage;
 | 
						|
  if( pFifo->nEntry==0 ){
 | 
						|
    return SQLITE_DONE;
 | 
						|
  }
 | 
						|
  assert( pFifo->nEntry>0 );
 | 
						|
  pPage = pFifo->pFirst;
 | 
						|
  assert( pPage!=0 );
 | 
						|
  assert( pPage->iWrite>pPage->iRead );
 | 
						|
  assert( pPage->iWrite<=pPage->nSlot );
 | 
						|
  assert( pPage->iRead<pPage->nSlot );
 | 
						|
  assert( pPage->iRead>=0 );
 | 
						|
  *pVal = pPage->aSlot[pPage->iRead++];
 | 
						|
  pFifo->nEntry--;
 | 
						|
  if( pPage->iRead>=pPage->iWrite ){
 | 
						|
    pFifo->pFirst = pPage->pNext;
 | 
						|
    sqliteFree(pPage);
 | 
						|
    if( pFifo->nEntry==0 ){
 | 
						|
      assert( pFifo->pLast==pPage );
 | 
						|
      pFifo->pLast = 0;
 | 
						|
    }else{
 | 
						|
      assert( pFifo->pFirst!=0 );
 | 
						|
    }
 | 
						|
  }else{
 | 
						|
    assert( pFifo->nEntry>0 );
 | 
						|
  }
 | 
						|
  return SQLITE_OK;
 | 
						|
}
 | 
						|
 | 
						|
/*
 | 
						|
** Delete all information from a Fifo object.   Free all memory held
 | 
						|
** by the Fifo.
 | 
						|
*/
 | 
						|
void sqlite3VdbeFifoClear(Fifo *pFifo){
 | 
						|
  FifoPage *pPage, *pNextPage;
 | 
						|
  for(pPage=pFifo->pFirst; pPage; pPage=pNextPage){
 | 
						|
    pNextPage = pPage->pNext;
 | 
						|
    sqliteFree(pPage);
 | 
						|
  }
 | 
						|
  sqlite3VdbeFifoInit(pFifo);
 | 
						|
}
 |