1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-08-07 02:42:48 +03:00

Add NEVER macros to error-detection branches that were made unreachable

(as far as I can tell) by check-in [ceacc28b03580334].

FossilOrigin-Name: 7b62555e285f32d354df7746ef8dce16856c6d9d53a02d895b74ba02362d2968
This commit is contained in:
drh
2020-01-03 17:40:30 +00:00
parent 0d21eae099
commit 3b76c45a7f
3 changed files with 22 additions and 20 deletions

View File

@@ -1,5 +1,5 @@
C Improvement\sto\scheck-in\s[7405e98225761180]\sso\sthat\smissing\sor\snull\sfilenames\ngiven\sto\sthe\szipfile\sextension\sthrow\san\simmediate\serror. C Add\sNEVER\smacros\sto\serror-detection\sbranches\sthat\swere\smade\sunreachable\n(as\sfar\sas\sI\scan\stell)\sby\scheck-in\s[ceacc28b03580334].
D 2020-01-03T16:38:54.215 D 2020-01-03T17:40:30.845
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
@@ -469,7 +469,7 @@ F src/auth.c a3d5bfdba83d25abed1013a8c7a5f204e2e29b0c25242a56bc02bb0c07bf1e06
F src/backup.c f70077d40c08b7787bfe934e4d1da8030cb0cc57d46b345fba2294b7d1be23ab F src/backup.c f70077d40c08b7787bfe934e4d1da8030cb0cc57d46b345fba2294b7d1be23ab
F src/bitvec.c 17ea48eff8ba979f1f5b04cc484c7bb2be632f33 F src/bitvec.c 17ea48eff8ba979f1f5b04cc484c7bb2be632f33
F src/btmutex.c 8acc2f464ee76324bf13310df5692a262b801808984c1b79defb2503bbafadb6 F src/btmutex.c 8acc2f464ee76324bf13310df5692a262b801808984c1b79defb2503bbafadb6
F src/btree.c 0eb5d02aac9a6f6029904060db1986550bc99b40c5f8d9374d9bbcca0543164d F src/btree.c df0ec5541fa5662a90082faea44322c5143db61f2e806375f4e3f5ab35d6cc41
F src/btree.h 6111552f19ed7a40f029cf4b33badc6fef9880314fffd80a945f0b7f43ab7471 F src/btree.h 6111552f19ed7a40f029cf4b33badc6fef9880314fffd80a945f0b7f43ab7471
F src/btreeInt.h 6794084fad08c9750b45145743c0e3e5c27c94dee89f26dd8df7073314934fd2 F src/btreeInt.h 6794084fad08c9750b45145743c0e3e5c27c94dee89f26dd8df7073314934fd2
F src/build.c 67b1a8d3ac700747687dbdc49ded847a3c17fef450a8c919ac0399b44cbd4215 F src/build.c 67b1a8d3ac700747687dbdc49ded847a3c17fef450a8c919ac0399b44cbd4215
@@ -1853,7 +1853,7 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
P ceacc28b035803342764f9b696c1e80edcd259b87ea4fb46f92963d6cb33de3e P 523e09bd228750fb7be1d4e68d18f6c1bf9db19293d66fbf30b86409321e9814
R b1b114b0553a0e4f445e7455b465ab9e R 9db325677ae78118554163eac3ed2eae
U drh U drh
Z 0a4493657ad671889aa7ad8712c9a995 Z e0ea28a1a8dedd28fad05208e3f0151a

View File

@@ -1 +1 @@
523e09bd228750fb7be1d4e68d18f6c1bf9db19293d66fbf30b86409321e9814 7b62555e285f32d354df7746ef8dce16856c6d9d53a02d895b74ba02362d2968

View File

@@ -1449,7 +1449,7 @@ static int defragmentPage(MemPage *pPage, int nMaxFrag){
int sz2 = 0; int sz2 = 0;
int sz = get2byte(&data[iFree+2]); int sz = get2byte(&data[iFree+2]);
int top = get2byte(&data[hdr+5]); int top = get2byte(&data[hdr+5]);
if( top>=iFree ){ if( NEVER(top>=iFree) ){
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
} }
if( iFree2 ){ if( iFree2 ){
@@ -1458,7 +1458,7 @@ static int defragmentPage(MemPage *pPage, int nMaxFrag){
if( iFree2+sz2 > usableSize ) return SQLITE_CORRUPT_PAGE(pPage); if( iFree2+sz2 > usableSize ) return SQLITE_CORRUPT_PAGE(pPage);
memmove(&data[iFree+sz+sz2], &data[iFree+sz], iFree2-(iFree+sz)); memmove(&data[iFree+sz+sz2], &data[iFree+sz], iFree2-(iFree+sz));
sz += sz2; sz += sz2;
}else if( iFree+sz>usableSize ){ }else if( NEVER(iFree+sz>usableSize) ){
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
} }
@@ -1650,8 +1650,10 @@ static int allocateSpace(MemPage *pPage, int nByte, int *pIdx){
if( (data[hdr+2] || data[hdr+1]) && gap+2<=top ){ if( (data[hdr+2] || data[hdr+1]) && gap+2<=top ){
u8 *pSpace = pageFindSlot(pPage, nByte, &rc); u8 *pSpace = pageFindSlot(pPage, nByte, &rc);
if( pSpace ){ if( pSpace ){
int g2;
assert( pSpace+nByte<=data+pPage->pBt->usableSize ); assert( pSpace+nByte<=data+pPage->pBt->usableSize );
if( (*pIdx = (int)(pSpace-data))<=gap ){ *pIdx = g2 = (int)(pSpace-data);
if( NEVER(g2<=gap) ){
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
}else{ }else{
return SQLITE_OK; return SQLITE_OK;
@@ -1729,12 +1731,12 @@ static int freeSpace(MemPage *pPage, u16 iStart, u16 iSize){
}else{ }else{
while( (iFreeBlk = get2byte(&data[iPtr]))<iStart ){ while( (iFreeBlk = get2byte(&data[iPtr]))<iStart ){
if( iFreeBlk<iPtr+4 ){ if( iFreeBlk<iPtr+4 ){
if( iFreeBlk==0 ) break; if( ALWAYS(iFreeBlk==0) ) break;
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
} }
iPtr = iFreeBlk; iPtr = iFreeBlk;
} }
if( iFreeBlk>pPage->pBt->usableSize-4 ){ if( NEVER(iFreeBlk>pPage->pBt->usableSize-4) ){
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
} }
assert( iFreeBlk>iPtr || iFreeBlk==0 ); assert( iFreeBlk>iPtr || iFreeBlk==0 );
@@ -1749,7 +1751,7 @@ static int freeSpace(MemPage *pPage, u16 iStart, u16 iSize){
nFrag = iFreeBlk - iEnd; nFrag = iFreeBlk - iEnd;
if( iEnd>iFreeBlk ) return SQLITE_CORRUPT_PAGE(pPage); if( iEnd>iFreeBlk ) return SQLITE_CORRUPT_PAGE(pPage);
iEnd = iFreeBlk + get2byte(&data[iFreeBlk+2]); iEnd = iFreeBlk + get2byte(&data[iFreeBlk+2]);
if( iEnd > pPage->pBt->usableSize ){ if( NEVER(iEnd > pPage->pBt->usableSize) ){
return SQLITE_CORRUPT_PAGE(pPage); return SQLITE_CORRUPT_PAGE(pPage);
} }
iSize = iEnd - iStart; iSize = iEnd - iStart;
@@ -1777,7 +1779,8 @@ static int freeSpace(MemPage *pPage, u16 iStart, u16 iSize){
/* The new freeblock is at the beginning of the cell content area, /* The new freeblock is at the beginning of the cell content area,
** so just extend the cell content area rather than create another ** so just extend the cell content area rather than create another
** freelist entry */ ** freelist entry */
if( iStart<x || iPtr!=hdr+1 ) return SQLITE_CORRUPT_PAGE(pPage); if( iStart<x ) return SQLITE_CORRUPT_PAGE(pPage);
if( NEVER(iPtr!=hdr+1) ) return SQLITE_CORRUPT_PAGE(pPage);
put2byte(&data[hdr+1], iFreeBlk); put2byte(&data[hdr+1], iFreeBlk);
put2byte(&data[hdr+5], iEnd); put2byte(&data[hdr+5], iEnd);
}else{ }else{
@@ -6936,7 +6939,7 @@ static int rebuildPage(
assert( i<iEnd ); assert( i<iEnd );
j = get2byte(&aData[hdr+5]); j = get2byte(&aData[hdr+5]);
if( j>(u32)usableSize ){ j = 0; } if( NEVER(j>(u32)usableSize) ){ j = 0; }
memcpy(&pTmp[j], &aData[j], usableSize - j); memcpy(&pTmp[j], &aData[j], usableSize - j);
for(k=0; pCArray->ixNx[k]<=i && ALWAYS(k<NB*2); k++){} for(k=0; pCArray->ixNx[k]<=i && ALWAYS(k<NB*2); k++){}
@@ -6948,7 +6951,7 @@ static int rebuildPage(
u16 sz = pCArray->szCell[i]; u16 sz = pCArray->szCell[i];
assert( sz>0 ); assert( sz>0 );
if( SQLITE_WITHIN(pCell,aData,pEnd) ){ if( SQLITE_WITHIN(pCell,aData,pEnd) ){
if( ((uptr)(pCell+sz))>(uptr)pEnd ) return SQLITE_CORRUPT_BKPT; if( NEVER(((uptr)(pCell+sz))>(uptr)pEnd) ) return SQLITE_CORRUPT_BKPT;
pCell = &pTmp[pCell - aData]; pCell = &pTmp[pCell - aData];
}else if( (uptr)(pCell+sz)>(uptr)pSrcEnd }else if( (uptr)(pCell+sz)>(uptr)pSrcEnd
&& (uptr)(pCell)<(uptr)pSrcEnd && (uptr)(pCell)<(uptr)pSrcEnd
@@ -6959,10 +6962,9 @@ static int rebuildPage(
pData -= sz; pData -= sz;
put2byte(pCellptr, (pData - aData)); put2byte(pCellptr, (pData - aData));
pCellptr += 2; pCellptr += 2;
if( pData < pCellptr ) return SQLITE_CORRUPT_BKPT; if( NEVER(pData < pCellptr) ) return SQLITE_CORRUPT_BKPT;
memcpy(pData, pCell, sz); memcpy(pData, pCell, sz);
assert( sz==pPg->xCellSize(pPg, pCell) || CORRUPT_DB ); assert( sz==pPg->xCellSize(pPg, pCell) );
testcase( sz!=pPg->xCellSize(pPg,pCell) );
i++; i++;
if( i>=iEnd ) break; if( i>=iEnd ) break;
if( pCArray->ixNx[k]<=i ){ if( pCArray->ixNx[k]<=i ){
@@ -7101,7 +7103,7 @@ static int pageFreeArray(
} }
pFree = pCell; pFree = pCell;
szFree = sz; szFree = sz;
if( pFree+sz>pEnd ) return 0; if( NEVER(pFree+sz>pEnd) ) return 0;
}else{ }else{
pFree = pCell; pFree = pCell;
szFree += sz; szFree += sz;