1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-12-24 14:17:58 +03:00

Fix crashes that can occur when queries are run on an FTS4 table containing zero rows.

FossilOrigin-Name: ed61fd20adef44d0f6b2345e0205b25f3641a15e
This commit is contained in:
dan
2010-11-24 15:02:22 +00:00
parent ad3acbbfb3
commit d6e12384bd
4 changed files with 22 additions and 12 deletions

View File

@@ -2298,8 +2298,9 @@ static int fts3PhraseSelect(
if( pCsr->eEvalmode==FTS3_EVAL_NEXT && pTok->pDeferred ){
rc = fts3DeferredTermSelect(pTok->pDeferred, isTermPos, &nList, &pList);
}else{
assert( pTok->pArray );
rc = fts3TermSelect(p, pTok, iCol, isTermPos, &nList, &pList);
if( pTok->pArray ){
rc = fts3TermSelect(p, pTok, iCol, isTermPos, &nList, &pList);
}
pTok->bFulltext = 1;
}
assert( rc!=SQLITE_OK || pCsr->eEvalmode || pTok->pArray==0 );
@@ -2527,7 +2528,10 @@ static int fts3ExprCost(Fts3Expr *pExpr){
int ii;
nCost = 0;
for(ii=0; ii<pPhrase->nToken; ii++){
nCost += pPhrase->aToken[ii].pArray->nCost;
Fts3SegReaderArray *pArray = pPhrase->aToken[ii].pArray;
if( pArray ){
nCost += pPhrase->aToken[ii].pArray->nCost;
}
}
}else{
nCost = fts3ExprCost(pExpr->pLeft) + fts3ExprCost(pExpr->pRight);
@@ -2555,7 +2559,7 @@ static void fts3ExprAssignCosts(
fts3ExprAssignCosts(pExpr->pRight, ppExprCost);
}else{
(*ppExprCost)->pExpr = pExpr;
(*ppExprCost)->nCost = fts3ExprCost(pExpr);;
(*ppExprCost)->nCost = fts3ExprCost(pExpr);
(*ppExprCost)++;
}
}

View File

@@ -1,5 +1,5 @@
C Remove\ssome\sunused\scode\sfrom\sfts3.\sAdd\stests\sto\sfts3matchinfo.test.
D 2010-11-24T11:51:56
C Fix\scrashes\sthat\scan\soccur\swhen\squeries\sare\srun\son\san\sFTS4\stable\scontaining\szero\srows.
D 2010-11-24T15:02:23
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
F Makefile.in e7a59672eaeb04408d1fa8501618d7501a3c5e39
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -61,7 +61,7 @@ F ext/fts2/mkfts2amal.tcl 974d5d438cb3f7c4a652639262f82418c1e4cff0
F ext/fts3/README.syntax a19711dc5458c20734b8e485e75fb1981ec2427a
F ext/fts3/README.tokenizers 998756696647400de63d5ba60e9655036cb966e9
F ext/fts3/README.txt 8c18f41574404623b76917b9da66fcb0ab38328d
F ext/fts3/fts3.c 916091c7aeeefa8a7017865d97d10d13a5949b52
F ext/fts3/fts3.c 0e207ae8008bb37e5c8a10581da328709b318354
F ext/fts3/fts3.h 3a10a0af180d502cecc50df77b1b22df142817fe
F ext/fts3/fts3Int.h 52c818623c60943bc4ac4a22d77b2e8f28395e78
F ext/fts3/fts3_expr.c ee48b9278b8b2432a05a03320fbcacba151dbaa5
@@ -446,7 +446,7 @@ F test/fts3expr.test 5e745b2b6348499d9ef8d59015de3182072c564c
F test/fts3expr2.test 18da930352e5693eaa163a3eacf96233b7290d1a
F test/fts3fault.test 81fd40ceb12f33f9d16c5637d0f8d95d4556c456
F test/fts3malloc.test 9c8cc3f885bb4dfc66d0460c52f68f45e4710d1b
F test/fts3matchinfo.test cf3d0149f749abdb228c7bfe2350cf799b1809f4
F test/fts3matchinfo.test 2dfdf80a927e3dc02f2e42337e5aa0b835994f6e
F test/fts3near.test 2e318ee434d32babd27c167142e2b94ddbab4844
F test/fts3query.test ef79d31fdb355d094baec1c1b24b60439a1fb8a2
F test/fts3rnd.test 707533ce943f490443ce5e696236bb1675a37635
@@ -889,7 +889,7 @@ F tool/speedtest2.tcl ee2149167303ba8e95af97873c575c3e0fab58ff
F tool/speedtest8.c 2902c46588c40b55661e471d7a86e4dd71a18224
F tool/speedtest8inst1.c 293327bc76823f473684d589a8160bde1f52c14e
F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
P 9cf0f2b76bc68c168e3fa861b7235f384db21d38
R 9d3e5478b917e1cb6e46d1d7c8efa28d
P ae40b34cf7c24c9601bdfb5cbe5b20f05a376ea8
R bf9b07886b7dc4c93620c54d1a7703f7
U dan
Z 2747212062c29415eaa46cf5d82fabf7
Z c507e6c3579e8a599c5f904476d64b95

View File

@@ -1 +1 @@
ae40b34cf7c24c9601bdfb5cbe5b20f05a376ea8
ed61fd20adef44d0f6b2345e0205b25f3641a15e

View File

@@ -66,6 +66,12 @@ do_execsql_test 3.1 {
SELECT mtchinfo FROM t3;
} {{Beside the lake, beneath the trees}}
do_execsql_test 3.2 {
CREATE VIRTUAL TABLE xx USING FTS4;
SELECT * FROM xx WHERE xx MATCH 'abc';
SELECT * FROM xx WHERE xx MATCH 'a b c';
}
#--------------------------------------------------------------------------
# Proc [do_matchinfo_test] is used to test the FTSX matchinfo() function.