| Index: third_party/sqlite/src/src/journal.c
|
| diff --git a/third_party/sqlite/src/src/journal.c b/third_party/sqlite/src/src/journal.c
|
| deleted file mode 100644
|
| index fed27be3e38055d2204395cde6ffc94589fbf5e8..0000000000000000000000000000000000000000
|
| --- a/third_party/sqlite/src/src/journal.c
|
| +++ /dev/null
|
| @@ -1,256 +0,0 @@
|
| -/*
|
| -** 2007 August 22
|
| -**
|
| -** 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 special kind of sqlite3_file object used
|
| -** by SQLite to create journal files if the atomic-write optimization
|
| -** is enabled.
|
| -**
|
| -** The distinctive characteristic of this sqlite3_file is that the
|
| -** actual on disk file is created lazily. When the file is created,
|
| -** the caller specifies a buffer size for an in-memory buffer to
|
| -** be used to service read() and write() requests. The actual file
|
| -** on disk is not created or populated until either:
|
| -**
|
| -** 1) The in-memory representation grows too large for the allocated
|
| -** buffer, or
|
| -** 2) The sqlite3JournalCreate() function is called.
|
| -*/
|
| -#ifdef SQLITE_ENABLE_ATOMIC_WRITE
|
| -#include "sqliteInt.h"
|
| -
|
| -
|
| -/*
|
| -** A JournalFile object is a subclass of sqlite3_file used by
|
| -** as an open file handle for journal files.
|
| -*/
|
| -struct JournalFile {
|
| - sqlite3_io_methods *pMethod; /* I/O methods on journal files */
|
| - int nBuf; /* Size of zBuf[] in bytes */
|
| - char *zBuf; /* Space to buffer journal writes */
|
| - int iSize; /* Amount of zBuf[] currently used */
|
| - int flags; /* xOpen flags */
|
| - sqlite3_vfs *pVfs; /* The "real" underlying VFS */
|
| - sqlite3_file *pReal; /* The "real" underlying file descriptor */
|
| - const char *zJournal; /* Name of the journal file */
|
| -};
|
| -typedef struct JournalFile JournalFile;
|
| -
|
| -/*
|
| -** If it does not already exists, create and populate the on-disk file
|
| -** for JournalFile p.
|
| -*/
|
| -static int createFile(JournalFile *p){
|
| - int rc = SQLITE_OK;
|
| - if( !p->pReal ){
|
| - sqlite3_file *pReal = (sqlite3_file *)&p[1];
|
| - rc = sqlite3OsOpen(p->pVfs, p->zJournal, pReal, p->flags, 0);
|
| - if( rc==SQLITE_OK ){
|
| - p->pReal = pReal;
|
| - if( p->iSize>0 ){
|
| - assert(p->iSize<=p->nBuf);
|
| - rc = sqlite3OsWrite(p->pReal, p->zBuf, p->iSize, 0);
|
| - }
|
| - if( rc!=SQLITE_OK ){
|
| - /* If an error occurred while writing to the file, close it before
|
| - ** returning. This way, SQLite uses the in-memory journal data to
|
| - ** roll back changes made to the internal page-cache before this
|
| - ** function was called. */
|
| - sqlite3OsClose(pReal);
|
| - p->pReal = 0;
|
| - }
|
| - }
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Close the file.
|
| -*/
|
| -static int jrnlClose(sqlite3_file *pJfd){
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( p->pReal ){
|
| - sqlite3OsClose(p->pReal);
|
| - }
|
| - sqlite3_free(p->zBuf);
|
| - return SQLITE_OK;
|
| -}
|
| -
|
| -/*
|
| -** Read data from the file.
|
| -*/
|
| -static int jrnlRead(
|
| - sqlite3_file *pJfd, /* The journal file from which to read */
|
| - void *zBuf, /* Put the results here */
|
| - int iAmt, /* Number of bytes to read */
|
| - sqlite_int64 iOfst /* Begin reading at this offset */
|
| -){
|
| - int rc = SQLITE_OK;
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( p->pReal ){
|
| - rc = sqlite3OsRead(p->pReal, zBuf, iAmt, iOfst);
|
| - }else if( (iAmt+iOfst)>p->iSize ){
|
| - rc = SQLITE_IOERR_SHORT_READ;
|
| - }else{
|
| - memcpy(zBuf, &p->zBuf[iOfst], iAmt);
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Write data to the file.
|
| -*/
|
| -static int jrnlWrite(
|
| - sqlite3_file *pJfd, /* The journal file into which to write */
|
| - const void *zBuf, /* Take data to be written from here */
|
| - int iAmt, /* Number of bytes to write */
|
| - sqlite_int64 iOfst /* Begin writing at this offset into the file */
|
| -){
|
| - int rc = SQLITE_OK;
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( !p->pReal && (iOfst+iAmt)>p->nBuf ){
|
| - rc = createFile(p);
|
| - }
|
| - if( rc==SQLITE_OK ){
|
| - if( p->pReal ){
|
| - rc = sqlite3OsWrite(p->pReal, zBuf, iAmt, iOfst);
|
| - }else{
|
| - memcpy(&p->zBuf[iOfst], zBuf, iAmt);
|
| - if( p->iSize<(iOfst+iAmt) ){
|
| - p->iSize = (iOfst+iAmt);
|
| - }
|
| - }
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Truncate the file.
|
| -*/
|
| -static int jrnlTruncate(sqlite3_file *pJfd, sqlite_int64 size){
|
| - int rc = SQLITE_OK;
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( p->pReal ){
|
| - rc = sqlite3OsTruncate(p->pReal, size);
|
| - }else if( size<p->iSize ){
|
| - p->iSize = size;
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Sync the file.
|
| -*/
|
| -static int jrnlSync(sqlite3_file *pJfd, int flags){
|
| - int rc;
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( p->pReal ){
|
| - rc = sqlite3OsSync(p->pReal, flags);
|
| - }else{
|
| - rc = SQLITE_OK;
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Query the size of the file in bytes.
|
| -*/
|
| -static int jrnlFileSize(sqlite3_file *pJfd, sqlite_int64 *pSize){
|
| - int rc = SQLITE_OK;
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - if( p->pReal ){
|
| - rc = sqlite3OsFileSize(p->pReal, pSize);
|
| - }else{
|
| - *pSize = (sqlite_int64) p->iSize;
|
| - }
|
| - return rc;
|
| -}
|
| -
|
| -/*
|
| -** Table of methods for JournalFile sqlite3_file object.
|
| -*/
|
| -static struct sqlite3_io_methods JournalFileMethods = {
|
| - 1, /* iVersion */
|
| - jrnlClose, /* xClose */
|
| - jrnlRead, /* xRead */
|
| - jrnlWrite, /* xWrite */
|
| - jrnlTruncate, /* xTruncate */
|
| - jrnlSync, /* xSync */
|
| - jrnlFileSize, /* xFileSize */
|
| - 0, /* xLock */
|
| - 0, /* xUnlock */
|
| - 0, /* xCheckReservedLock */
|
| - 0, /* xFileControl */
|
| - 0, /* xSectorSize */
|
| - 0, /* xDeviceCharacteristics */
|
| - 0, /* xShmMap */
|
| - 0, /* xShmLock */
|
| - 0, /* xShmBarrier */
|
| - 0 /* xShmUnmap */
|
| -};
|
| -
|
| -/*
|
| -** Open a journal file.
|
| -*/
|
| -int sqlite3JournalOpen(
|
| - sqlite3_vfs *pVfs, /* The VFS to use for actual file I/O */
|
| - const char *zName, /* Name of the journal file */
|
| - sqlite3_file *pJfd, /* Preallocated, blank file handle */
|
| - int flags, /* Opening flags */
|
| - int nBuf /* Bytes buffered before opening the file */
|
| -){
|
| - JournalFile *p = (JournalFile *)pJfd;
|
| - memset(p, 0, sqlite3JournalSize(pVfs));
|
| - if( nBuf>0 ){
|
| - p->zBuf = sqlite3MallocZero(nBuf);
|
| - if( !p->zBuf ){
|
| - return SQLITE_NOMEM;
|
| - }
|
| - }else{
|
| - return sqlite3OsOpen(pVfs, zName, pJfd, flags, 0);
|
| - }
|
| - p->pMethod = &JournalFileMethods;
|
| - p->nBuf = nBuf;
|
| - p->flags = flags;
|
| - p->zJournal = zName;
|
| - p->pVfs = pVfs;
|
| - return SQLITE_OK;
|
| -}
|
| -
|
| -/*
|
| -** If the argument p points to a JournalFile structure, and the underlying
|
| -** file has not yet been created, create it now.
|
| -*/
|
| -int sqlite3JournalCreate(sqlite3_file *p){
|
| - if( p->pMethods!=&JournalFileMethods ){
|
| - return SQLITE_OK;
|
| - }
|
| - return createFile((JournalFile *)p);
|
| -}
|
| -
|
| -/*
|
| -** The file-handle passed as the only argument is guaranteed to be an open
|
| -** file. It may or may not be of class JournalFile. If the file is a
|
| -** JournalFile, and the underlying file on disk has not yet been opened,
|
| -** return 0. Otherwise, return 1.
|
| -*/
|
| -int sqlite3JournalExists(sqlite3_file *p){
|
| - return (p->pMethods!=&JournalFileMethods || ((JournalFile *)p)->pReal!=0);
|
| -}
|
| -
|
| -/*
|
| -** Return the number of bytes required to store a JournalFile that uses vfs
|
| -** pVfs to create the underlying on-disk files.
|
| -*/
|
| -int sqlite3JournalSize(sqlite3_vfs *pVfs){
|
| - return (pVfs->szOsFile+sizeof(JournalFile));
|
| -}
|
| -#endif
|
|
|