]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Detect a corrupt UnpackedRecord and return SQLITE_CORRUPT prior to calling
authordrh <drh@noemail.net>
Sat, 30 Nov 2013 12:49:28 +0000 (12:49 +0000)
committerdrh <drh@noemail.net>
Sat, 30 Nov 2013 12:49:28 +0000 (12:49 +0000)
sqlite3BtreeMovetoUnpacked().

FossilOrigin-Name: 55ec474db8935ef36fae30da5d11f5701c60c088

manifest
manifest.uuid
src/btree.c

index 8b8ce602365f40fde582d1b18d60e1096e2445f1..940dfe002275039c011ec22762ce4eae1e423c64 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Change\sthe\sname\sof\sthe\sCORRUPTIBLE\smacro\sto\sCORRUPT_DB.
-D 2013-11-29T15:39:36.814
+C Detect\sa\scorrupt\sUnpackedRecord\sand\sreturn\sSQLITE_CORRUPT\sprior\sto\scalling\nsqlite3BtreeMovetoUnpacked().
+D 2013-11-30T12:49:28.537
 F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
 F Makefile.in e1a9b4258bbde53f5636f4e238c65b7e11459e2b
 F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -166,7 +166,7 @@ F src/auth.c 523da7fb4979469955d822ff9298352d6b31de34
 F src/backup.c 1809a7caa2504233bdddd12f5018422421789537
 F src/bitvec.c 19a4ba637bd85f8f63fc8c9bae5ade9fb05ec1cb
 F src/btmutex.c 976f45a12e37293e32cae0281b15a21d48a8aaa7
-F src/btree.c ec8a4dcac5c1ec1ba9705b8c5a13e62167958317
+F src/btree.c fe6c95c57fd14ed4b3329f4b5bb08132fe7c322d
 F src/btree.h a61ddebc78c66795a2b93181321a116746302cc9
 F src/btreeInt.h f038e818bfadf75afbd09819ed93c26a333d39e0
 F src/build.c 07054d45319953e54a89d726e589a423e9c1c590
@@ -1145,7 +1145,7 @@ F tool/vdbe-compress.tcl f12c884766bd14277f4fcedcae07078011717381
 F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
 F tool/warnings.sh d1a6de74685f360ab718efda6265994b99bbea01
 F tool/win/sqlite.vsix 030f3eeaf2cb811a3692ab9c14d021a75ce41fff
-P 15e4f63d1f3cbcd0aa789fd3e460cd6e4d3338f9
-R 962cc490e8fc3a8042a30112d4f3290d
+P f865be10e85a4063394a21827db2d854fc25960c
+R b4c7c44fd7f9f4c41a202ec1f5d2e636
 U drh
-Z d6583fce3162aa40a5f7e6ad518960af
+Z 430bb09012d5a037af5177ecb970e2fe
index a0b1398f2fcfdfe3082f52afdc89666fa21e6519..4da7a7d3de392c89ed099f0de043d467255b18cf 100644 (file)
@@ -1 +1 @@
-f865be10e85a4063394a21827db2d854fc25960c
\ No newline at end of file
+55ec474db8935ef36fae30da5d11f5701c60c088
\ No newline at end of file
index 27e7146893303af707c4cd0656d0c8eff1d94811..30fdf4256fa7b726af1e1b1323a387e687fd7997 100644 (file)
@@ -694,6 +694,10 @@ static int btreeMoveto(
     );
     if( pIdxKey==0 ) return SQLITE_NOMEM;
     sqlite3VdbeRecordUnpack(pCur->pKeyInfo, (int)nKey, pKey, pIdxKey);
+    if( pIdxKey->nField==0 ){
+      sqlite3DbFree(pCur->pKeyInfo->db, pFree);
+      return SQLITE_CORRUPT_BKPT;
+    }
   }else{
     pIdxKey = 0;
   }