Merge recent trunk changes into the statvfs branch.
FossilOrigin-Name: 995ec8a41a7d091d9d87cb8f18f62102c8fda7d7
This commit is contained in:
commit
3a7df358ab
21
manifest
21
manifest
@ -1,5 +1,5 @@
|
|||||||
C Remove\sa\sredundant\sassignment\soperator.
|
C Merge\srecent\strunk\schanges\sinto\sthe\sstatvfs\sbranch.
|
||||||
D 2011-12-22T01:46:04.520
|
D 2011-12-22T02:10:57.625
|
||||||
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
||||||
F Makefile.in 5b4a3e12a850b021547e43daf886b25133b44c07
|
F Makefile.in 5b4a3e12a850b021547e43daf886b25133b44c07
|
||||||
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
||||||
@ -125,7 +125,7 @@ F src/auth.c 523da7fb4979469955d822ff9298352d6b31de34
|
|||||||
F src/backup.c 4368158da74d4711888e03264105c5c527d76caf
|
F src/backup.c 4368158da74d4711888e03264105c5c527d76caf
|
||||||
F src/bitvec.c af50f1c8c0ff54d6bdb7a80e2fceca5a93670bef
|
F src/bitvec.c af50f1c8c0ff54d6bdb7a80e2fceca5a93670bef
|
||||||
F src/btmutex.c 976f45a12e37293e32cae0281b15a21d48a8aaa7
|
F src/btmutex.c 976f45a12e37293e32cae0281b15a21d48a8aaa7
|
||||||
F src/btree.c 80ea65224512884bb72976c93810d2dcaecc1353
|
F src/btree.c 2fdde7d16c80bd4e8a0913038e766c4297818f6f
|
||||||
F src/btree.h f5d775cd6cfc7ac32a2535b70e8d2af48ef5f2ce
|
F src/btree.h f5d775cd6cfc7ac32a2535b70e8d2af48ef5f2ce
|
||||||
F src/btreeInt.h ea863a819224d3e6845ad1e39954d41558b8cd8b
|
F src/btreeInt.h ea863a819224d3e6845ad1e39954d41558b8cd8b
|
||||||
F src/build.c 8915bb6d72ead998f94c2756ea8d143c77709b70
|
F src/build.c 8915bb6d72ead998f94c2756ea8d143c77709b70
|
||||||
@ -168,7 +168,7 @@ F src/os_common.h 92815ed65f805560b66166e3583470ff94478f04
|
|||||||
F src/os_os2.c 4a75888ba3dfc820ad5e8177025972d74d7f2440
|
F src/os_os2.c 4a75888ba3dfc820ad5e8177025972d74d7f2440
|
||||||
F src/os_unix.c 3e630701efd54ecbdba237c5a3cb3c55d83d8a2e
|
F src/os_unix.c 3e630701efd54ecbdba237c5a3cb3c55d83d8a2e
|
||||||
F src/os_win.c 4fc4aa8aecb334c64a250a4b36cff6a798704da4
|
F src/os_win.c 4fc4aa8aecb334c64a250a4b36cff6a798704da4
|
||||||
F src/pager.c c9bd2f7183edba480bea1dd49361a02d0c3d8f43
|
F src/pager.c fb35a2c33667dd568b8df30fc11a4516e9889057
|
||||||
F src/pager.h 5cd760857707529b403837d813d86b68938d6183
|
F src/pager.h 5cd760857707529b403837d813d86b68938d6183
|
||||||
F src/parse.y fabb2e7047417d840e6fdb3ef0988a86849a08ba
|
F src/parse.y fabb2e7047417d840e6fdb3ef0988a86849a08ba
|
||||||
F src/pcache.c 1fdd77978c1525d1ca4b9ef48eb80abca710cb4c
|
F src/pcache.c 1fdd77978c1525d1ca4b9ef48eb80abca710cb4c
|
||||||
@ -211,7 +211,7 @@ F src/test_hexio.c c4773049603151704a6ab25ac5e936b5109caf5a
|
|||||||
F src/test_init.c 3cbad7ce525aec925f8fda2192d576d47f0d478a
|
F src/test_init.c 3cbad7ce525aec925f8fda2192d576d47f0d478a
|
||||||
F src/test_intarray.c d879bbf8e4ce085ab966d1f3c896a7c8b4f5fc99
|
F src/test_intarray.c d879bbf8e4ce085ab966d1f3c896a7c8b4f5fc99
|
||||||
F src/test_intarray.h 489edb9068bb926583445cb02589344961054207
|
F src/test_intarray.h 489edb9068bb926583445cb02589344961054207
|
||||||
F src/test_journal.c 03313c693cca72959dcaaf79f8d76f21c01e19ff
|
F src/test_journal.c 2c06e4be6584d51b935dc8b353980a9388de62ef
|
||||||
F src/test_loadext.c df586c27176e3c2cb2e099c78da67bf14379a56e
|
F src/test_loadext.c df586c27176e3c2cb2e099c78da67bf14379a56e
|
||||||
F src/test_malloc.c 8d416f29ad8573f32601f6056c9d2b17472e9ad5
|
F src/test_malloc.c 8d416f29ad8573f32601f6056c9d2b17472e9ad5
|
||||||
F src/test_multiplex.c 6e07b94e2fe430f7f4f0d7d67b5e58f504dea655
|
F src/test_multiplex.c 6e07b94e2fe430f7f4f0d7d67b5e58f504dea655
|
||||||
@ -225,7 +225,7 @@ F src/test_quota.h 9ffa1d3ad6d0a6a24e8670ea64b909c717ec3358
|
|||||||
F src/test_rtree.c 6d06306e29946dc36f528a3a2cdc3add794656f1
|
F src/test_rtree.c 6d06306e29946dc36f528a3a2cdc3add794656f1
|
||||||
F src/test_schema.c 8c06ef9ddb240c7a0fcd31bc221a6a2aade58bf0
|
F src/test_schema.c 8c06ef9ddb240c7a0fcd31bc221a6a2aade58bf0
|
||||||
F src/test_server.c 2f99eb2837dfa06a4aacf24af24c6affdf66a84f
|
F src/test_server.c 2f99eb2837dfa06a4aacf24af24c6affdf66a84f
|
||||||
F src/test_stat.c 69de4361c7a69fc1136d31ab7144408cd00805c7
|
F src/test_stat.c 80271ad7d776a79babe0e025bb3a1bfcd3a3cfb1
|
||||||
F src/test_superlock.c 2b97936ca127d13962c3605dbc9a4ef269c424cd
|
F src/test_superlock.c 2b97936ca127d13962c3605dbc9a4ef269c424cd
|
||||||
F src/test_syscall.c a992d8c80ea91fbf21fb2dd570db40e77dd7e6ae
|
F src/test_syscall.c a992d8c80ea91fbf21fb2dd570db40e77dd7e6ae
|
||||||
F src/test_tclvar.c f4dc67d5f780707210d6bb0eb6016a431c04c7fa
|
F src/test_tclvar.c f4dc67d5f780707210d6bb0eb6016a431c04c7fa
|
||||||
@ -297,6 +297,7 @@ F test/badutf.test d5360fc31f643d37a973ab0d8b4fb85799c3169f
|
|||||||
F test/badutf2.test f5bc7f2d280670ecd79b9cf4f0f1760c607fe51f
|
F test/badutf2.test f5bc7f2d280670ecd79b9cf4f0f1760c607fe51f
|
||||||
F test/between.test 16b1776c6323faadb097a52d673e8e3d8be7d070
|
F test/between.test 16b1776c6323faadb097a52d673e8e3d8be7d070
|
||||||
F test/bigfile.test a8ec8073a20207456dab01a29ad9cde42b0dd103
|
F test/bigfile.test a8ec8073a20207456dab01a29ad9cde42b0dd103
|
||||||
|
F test/bigfile2.test f8e83eca9abef60692a34255a2ebcb96aff897fc
|
||||||
F test/bigrow.test f0aeb7573dcb8caaafea76454be3ade29b7fc747
|
F test/bigrow.test f0aeb7573dcb8caaafea76454be3ade29b7fc747
|
||||||
F test/bind.test 3c7b320969000c441a70952b0b15938fbb66237c
|
F test/bind.test 3c7b320969000c441a70952b0b15938fbb66237c
|
||||||
F test/bindxfer.test efecd12c580c14df5f4ad3b3e83c667744a4f7e0
|
F test/bindxfer.test efecd12c580c14df5f4ad3b3e83c667744a4f7e0
|
||||||
@ -871,7 +872,7 @@ F test/types.test bf816ce73c7dfcfe26b700c19f97ef4050d194ff
|
|||||||
F test/types2.test 3555aacf8ed8dc883356e59efc314707e6247a84
|
F test/types2.test 3555aacf8ed8dc883356e59efc314707e6247a84
|
||||||
F test/types3.test 99e009491a54f4dc02c06bdbc0c5eea56ae3e25a
|
F test/types3.test 99e009491a54f4dc02c06bdbc0c5eea56ae3e25a
|
||||||
F test/unique.test 083c7fff74695bcc27a71d75699deba3595bc9c2
|
F test/unique.test 083c7fff74695bcc27a71d75699deba3595bc9c2
|
||||||
F test/unixexcl.test 9d80a54d86d2261f660758928959368ffc36151e
|
F test/unixexcl.test 892937c53d0c16e76631674e38a0fce052ae5e9c
|
||||||
F test/unordered.test f53095cee37851bf30130fa1bf299a8845e837bb
|
F test/unordered.test f53095cee37851bf30130fa1bf299a8845e837bb
|
||||||
F test/update.test 8bc86fd7ef1a00014f76dc6a6a7c974df4aef172
|
F test/update.test 8bc86fd7ef1a00014f76dc6a6a7c974df4aef172
|
||||||
F test/uri.test 0d289d32396bdbc491e9dc845f1a52e13f861e0b
|
F test/uri.test 0d289d32396bdbc491e9dc845f1a52e13f861e0b
|
||||||
@ -985,7 +986,7 @@ F tool/tostr.awk e75472c2f98dd76e06b8c9c1367f4ab07e122d06
|
|||||||
F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
|
F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
|
||||||
F tool/warnings-clang.sh 9f406d66e750e8ac031c63a9ef3248aaa347ef2a
|
F tool/warnings-clang.sh 9f406d66e750e8ac031c63a9ef3248aaa347ef2a
|
||||||
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
|
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
|
||||||
P c83627b73285f883719845c1b9fe85f378f28dd2
|
P 19a6852a1e5905b35bc69b309951c5ec8ecd0bef c723e3e18a008922281d8d6e8e3aba07941eb173
|
||||||
R f1e5c3d8040d152c5fcb2f4a7615b662
|
R 0d94bcf8f6066e5974e9f53b64f5faa2
|
||||||
U drh
|
U drh
|
||||||
Z 2c78a3c6c37d41190b48f488942db024
|
Z 112a2eaccff16ef2315b6fa4c08d4e3f
|
||||||
|
@ -1 +1 @@
|
|||||||
19a6852a1e5905b35bc69b309951c5ec8ecd0bef
|
995ec8a41a7d091d9d87cb8f18f62102c8fda7d7
|
@ -3979,7 +3979,7 @@ static int accessPayload(
|
|||||||
u8 aSave[4];
|
u8 aSave[4];
|
||||||
u8 *aWrite = &pBuf[-4];
|
u8 *aWrite = &pBuf[-4];
|
||||||
memcpy(aSave, aWrite, 4);
|
memcpy(aSave, aWrite, 4);
|
||||||
rc = sqlite3OsRead(fd, aWrite, a+4, pBt->pageSize * (nextPage-1));
|
rc = sqlite3OsRead(fd, aWrite, a+4, (i64)pBt->pageSize*(nextPage-1));
|
||||||
nextPage = get4byte(aWrite);
|
nextPage = get4byte(aWrite);
|
||||||
memcpy(aWrite, aSave, 4);
|
memcpy(aWrite, aSave, 4);
|
||||||
}else
|
}else
|
||||||
|
@ -3279,13 +3279,13 @@ static int pagerPlaybackSavepoint(Pager *pPager, PagerSavepoint *pSavepoint){
|
|||||||
*/
|
*/
|
||||||
if( pSavepoint ){
|
if( pSavepoint ){
|
||||||
u32 ii; /* Loop counter */
|
u32 ii; /* Loop counter */
|
||||||
i64 offset = pSavepoint->iSubRec*(4+pPager->pageSize);
|
i64 offset = (i64)pSavepoint->iSubRec*(4+pPager->pageSize);
|
||||||
|
|
||||||
if( pagerUseWal(pPager) ){
|
if( pagerUseWal(pPager) ){
|
||||||
rc = sqlite3WalSavepointUndo(pPager->pWal, pSavepoint->aWalData);
|
rc = sqlite3WalSavepointUndo(pPager->pWal, pSavepoint->aWalData);
|
||||||
}
|
}
|
||||||
for(ii=pSavepoint->iSubRec; rc==SQLITE_OK && ii<pPager->nSubRec; ii++){
|
for(ii=pSavepoint->iSubRec; rc==SQLITE_OK && ii<pPager->nSubRec; ii++){
|
||||||
assert( offset==ii*(4+pPager->pageSize) );
|
assert( offset==(i64)ii*(4+pPager->pageSize) );
|
||||||
rc = pager_playback_one_page(pPager, &offset, pDone, 0, 1);
|
rc = pager_playback_one_page(pPager, &offset, pDone, 0, 1);
|
||||||
}
|
}
|
||||||
assert( rc!=SQLITE_DONE );
|
assert( rc!=SQLITE_DONE );
|
||||||
@ -4137,7 +4137,7 @@ static int subjournalPage(PgHdr *pPg){
|
|||||||
** write the journal record into the file. */
|
** write the journal record into the file. */
|
||||||
if( rc==SQLITE_OK ){
|
if( rc==SQLITE_OK ){
|
||||||
void *pData = pPg->pData;
|
void *pData = pPg->pData;
|
||||||
i64 offset = pPager->nSubRec*(4+pPager->pageSize);
|
i64 offset = (i64)pPager->nSubRec*(4+pPager->pageSize);
|
||||||
char *pData2;
|
char *pData2;
|
||||||
|
|
||||||
CODEC2(pPager, pData, pPg->pgno, 7, return SQLITE_NOMEM, pData2);
|
CODEC2(pPager, pData, pPg->pgno, 7, return SQLITE_NOMEM, pData2);
|
||||||
|
@ -391,7 +391,7 @@ static int openTransaction(jt_file *pMain, jt_file *pJournal){
|
|||||||
while( rc==SQLITE_OK && iTrunk>0 ){
|
while( rc==SQLITE_OK && iTrunk>0 ){
|
||||||
u32 nLeaf;
|
u32 nLeaf;
|
||||||
u32 iLeaf;
|
u32 iLeaf;
|
||||||
sqlite3_int64 iOff = (iTrunk-1)*pMain->nPagesize;
|
sqlite3_int64 iOff = (i64)(iTrunk-1)*pMain->nPagesize;
|
||||||
rc = sqlite3OsRead(p, aData, pMain->nPagesize, iOff);
|
rc = sqlite3OsRead(p, aData, pMain->nPagesize, iOff);
|
||||||
nLeaf = decodeUint32(&aData[4]);
|
nLeaf = decodeUint32(&aData[4]);
|
||||||
for(iLeaf=0; rc==SQLITE_OK && iLeaf<nLeaf; iLeaf++){
|
for(iLeaf=0; rc==SQLITE_OK && iLeaf<nLeaf; iLeaf++){
|
||||||
|
@ -369,7 +369,7 @@ static void statSizeAndOffset(StatCursor *pCsr){
|
|||||||
|
|
||||||
/* The default page size and offset */
|
/* The default page size and offset */
|
||||||
pCsr->szPage = sqlite3BtreeGetPageSize(pBt);
|
pCsr->szPage = sqlite3BtreeGetPageSize(pBt);
|
||||||
pCsr->iOffset = pCsr->szPage * (pCsr->iPageno - 1);
|
pCsr->iOffset = (i64)pCsr->szPage * (pCsr->iPageno - 1);
|
||||||
|
|
||||||
/* If connected to a ZIPVFS backend, override the page size and
|
/* If connected to a ZIPVFS backend, override the page size and
|
||||||
** offset with actual values obtained from ZIPVFS.
|
** offset with actual values obtained from ZIPVFS.
|
||||||
|
59
test/bigfile2.test
Normal file
59
test/bigfile2.test
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
# 2011 December 20
|
||||||
|
#
|
||||||
|
# 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 regression tests for SQLite library. The
|
||||||
|
# focus of this script testing the ability of SQLite to handle database
|
||||||
|
# files larger than 4GB.
|
||||||
|
#
|
||||||
|
|
||||||
|
set testdir [file dirname $argv0]
|
||||||
|
source $testdir/tester.tcl
|
||||||
|
set testprefix bigfile2
|
||||||
|
|
||||||
|
# Create a small database.
|
||||||
|
#
|
||||||
|
do_execsql_test 1.1 {
|
||||||
|
CREATE TABLE t1(a, b);
|
||||||
|
INSERT INTO t1 VALUES(1, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
# Pad the file out to 4GB in size. Then clear the file-size field in the
|
||||||
|
# db header. This will cause SQLite to assume that the first 4GB of pages
|
||||||
|
# are actually in use and new pages will be appended to the file.
|
||||||
|
#
|
||||||
|
db close
|
||||||
|
if {[catch {fake_big_file 4096 [pwd]/test.db} msg]} {
|
||||||
|
puts "**** Unable to create a file larger than 4096 MB. *****"
|
||||||
|
finish_test
|
||||||
|
return
|
||||||
|
}
|
||||||
|
hexio_write test.db 28 00000000
|
||||||
|
|
||||||
|
do_test 1.2 {
|
||||||
|
file size test.db
|
||||||
|
} [expr 14 + 4096 * (1<<20)]
|
||||||
|
|
||||||
|
# Now insert a large row. The overflow pages will be located past the 4GB
|
||||||
|
# boundary. Then, after opening and closing the database, test that the row
|
||||||
|
# can be read back in.
|
||||||
|
#
|
||||||
|
set str [string repeat k 30000]
|
||||||
|
do_test 1.3 {
|
||||||
|
sqlite3 db test.db
|
||||||
|
execsql { INSERT INTO t1 VALUES(3, $str) }
|
||||||
|
db close
|
||||||
|
sqlite3 db test.db
|
||||||
|
db one { SELECT b FROM t1 WHERE a = 3 }
|
||||||
|
} $str
|
||||||
|
|
||||||
|
db close
|
||||||
|
file delete test.db
|
||||||
|
|
||||||
|
finish_test
|
@ -80,4 +80,48 @@ do_multiclient_test tn {
|
|||||||
} {0 {hello world}}
|
} {0 {hello world}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
do_multiclient_test tn {
|
||||||
|
do_test unixexcl-3.$tn.1 {
|
||||||
|
code1 { db close; sqlite3 db test.db -vfs unix-excl }
|
||||||
|
code2 { db2 close; sqlite3 db2 test.db -vfs unix-excl }
|
||||||
|
sql1 {
|
||||||
|
PRAGMA journal_mode = WAL;
|
||||||
|
CREATE TABLE t1(a, b);
|
||||||
|
INSERT INTO t1 VALUES(1, 2);
|
||||||
|
}
|
||||||
|
} {wal}
|
||||||
|
|
||||||
|
if {$tn==1} {
|
||||||
|
do_test unixexcl-3.$tn.1.multiproc {
|
||||||
|
csql2 { SELECT * FROM t1; }
|
||||||
|
} {1 {database is locked}}
|
||||||
|
} else {
|
||||||
|
do_test unixexcl-3.$tn.1.singleproc {
|
||||||
|
sql2 { SELECT * FROM t1; }
|
||||||
|
} {1 2}
|
||||||
|
|
||||||
|
do_test unixexcl-3.$tn.2 {
|
||||||
|
sql2 {
|
||||||
|
BEGIN;
|
||||||
|
SELECT * FROM t1;
|
||||||
|
}
|
||||||
|
} {1 2}
|
||||||
|
do_test unixexcl-3.$tn.3 {
|
||||||
|
sql1 { PRAGMA wal_checkpoint; INSERT INTO t1 VALUES(3, 4); }
|
||||||
|
} {0 5 5}
|
||||||
|
do_test unixexcl-3.$tn.4 {
|
||||||
|
sql2 { SELECT * FROM t1; }
|
||||||
|
} {1 2}
|
||||||
|
do_test unixexcl-3.$tn.5 {
|
||||||
|
sql1 { SELECT * FROM t1; }
|
||||||
|
} {1 2 3 4}
|
||||||
|
do_test unixexcl-3.$tn.6 {
|
||||||
|
sql2 { COMMIT; SELECT * FROM t1; }
|
||||||
|
} {1 2 3 4}
|
||||||
|
do_test unixexcl-3.$tn.7 {
|
||||||
|
sql1 { PRAGMA wal_checkpoint; }
|
||||||
|
} {0 7 7}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
finish_test
|
finish_test
|
||||||
|
Loading…
Reference in New Issue
Block a user