From: dan Date: Fri, 19 Jun 2026 11:46:05 +0000 (+0000) Subject: Fix a cast in fts3_write so that it is applied as intended. Bug [bugs:/info/2026... X-Git-Url: http://git.ipfire.org/gitweb/?a=commitdiff_plain;h=593b55cb78250bf3c8e77911f0daf30e9a59dc5a;p=thirdparty%2Fsqlite.git Fix a cast in fts3_write so that it is applied as intended. Bug [bugs:/info/2026-06-19T07:56:23Z | 2026-06-19T07:56:23Z]. FossilOrigin-Name: d6a3272e5592bcfeecf8a06dd8330cce57ff6603b24994b533d1fdcd48b5dc66 --- diff --git a/ext/fts3/fts3_write.c b/ext/fts3/fts3_write.c index 7ae55b38bc..9688393c64 100644 --- a/ext/fts3/fts3_write.c +++ b/ext/fts3/fts3_write.c @@ -4359,7 +4359,7 @@ static int fts3IncrmergeLoad( return FTS_CORRUPT_VTAB; } - pWriter->nLeafEst = (int)((iEnd - iStart) + 1)/FTS_MAX_APPENDABLE_HEIGHT; + pWriter->nLeafEst = (int)(((iEnd - iStart)+1)/FTS_MAX_APPENDABLE_HEIGHT); pWriter->iStart = iStart; pWriter->iEnd = iEnd; pWriter->iAbsLevel = iAbsLevel; diff --git a/manifest b/manifest index 6a82cab05a..4c6006cd5c 100644 --- a/manifest +++ b/manifest @@ -1,5 +1,5 @@ -C Fix\san\sfts5\sproblem\scausing\sattempts\sto\screate\slocale=1\stables\swith\smore\sthan\s115\scolumns\sto\sfail.\sBug\s[bugs:/info/2026-06-19T05:19:08Z\s|\s2026-06-19T05:19:08Z]. -D 2026-06-19T11:14:16.143 +C Fix\sa\scast\sin\sfts3_write\sso\sthat\sit\sis\sapplied\sas\sintended.\sBug\s[bugs:/info/2026-06-19T07:56:23Z\s|\s2026-06-19T07:56:23Z]. +D 2026-06-19T11:46:05.961 F .fossil-settings/binary-glob 61195414528fb3ea9693577e1980230d78a1f8b0a54c78cf1b9b24d0a409ed6a x F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea @@ -98,7 +98,7 @@ F ext/fts3/fts3_tokenizer.h 64c6ef6c5272c51ebe60fc607a896e84288fcbc3 F ext/fts3/fts3_tokenizer1.c c1de4ae28356ad98ccb8b2e3388a7fdcce7607b5523738c9afb6275dab765154 F ext/fts3/fts3_unicode.c de426ff05c1c2e7bce161cf6b706638419c3a1d9c2667de9cb9dc0458c18e226 F ext/fts3/fts3_unicode2.c 416eb7e1e81142703520d284b768ca2751d40e31fa912cae24ba74860532bf0f -F ext/fts3/fts3_write.c b84f9808f6df7b19db34af2397d82a7c5db4d30486c428f4f296d286996cea02 +F ext/fts3/fts3_write.c 3a78030f52747d53ef8c9bdff8ad137957834ce2ff7367db5de2b0fabdbefb5f F ext/fts3/fts3speed.tcl b54caf6a18d38174f1a6e84219950d85e98bb1e9 F ext/fts3/tool/fts3cov.sh c331d006359456cf6f8f953e37f2b9c7d568f3863f00bb5f7eb87fea4ac01b73 F ext/fts3/tool/fts3view.c 413c346399159df81f86c4928b7c4a455caab73bfbc8cd68f950f632e5751674 @@ -1170,7 +1170,7 @@ F test/fts3corrupt2.test e318f0676e5e78d5a4b702637e2bb25265954c08a1b1e4aaf93c788 F test/fts3corrupt3.test 0d5b69a0998b4adf868cc301fc78f3d0707745f1d984ce044c205cdb764b491f F test/fts3corrupt4.test c7f414fe29b97a478d15c90382c4ae077a2bbd2283bf8c63bf66dadaaed3edb8 F test/fts3corrupt5.test 0549f85ec4bd22e992f645f13c59b99d652f2f5e643dac75568bfd23a6db7ed5 -F test/fts3corrupt6.test f417c910254f32c0bc9ead7affa991a1d5aec35b3b32a183ffb05eea78289525 +F test/fts3corrupt6.test 9ea944e3cd17a36c64451059022fabff53bd338a43356d1f49264ce8aa9477ad F test/fts3corrupt7.test 8564d278801a7947d1c74d8819adee7dfed18b81574d0c42f8a1acc6759fc65a F test/fts3cov.test 1e5ecea0e4c1394cea97adcfb9fd3d2d5998fd563dacf465f413e6c7fa5cffb3 F test/fts3d.test 2bd8c97bcb9975f2334147173b4872505b6a41359a4f9068960a36afe07a679f @@ -2208,8 +2208,8 @@ F tool/warnings-clang.sh bbf6a1e685e534c92ec2bfba5b1745f34fb6f0bc2a362850723a9ee F tool/warnings.sh a554d13f6e5cf3760f041b87939e3d616ec6961859c3245e8ef701d1eafc2ca2 F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f F tool/winmain.c 00c8fb88e365c9017db14c73d3c78af62194d9644feaf60e220ab0f411f3604c -P dc4763b14c421710f2a19c19c1cac455c1d0244b27303b6f328c778ac188bb02 -R 53b5c4d6c419375fb8d7eb50058e2698 +P 979229f720e63d0294be14dae3f9fad68f76e4126a0ad63e32573cdfecd0151e +R a53eaa85cfef4414eab52fda02bb530f U dan -Z 149151f57447ce30cac2c573585c047e +Z 181164ac7ba0d87b6bb5ff7ad06933d0 # Remove this line to create a well-formed Fossil manifest. diff --git a/manifest.uuid b/manifest.uuid index bbc1be7d4e..3ae4403856 100644 --- a/manifest.uuid +++ b/manifest.uuid @@ -1 +1 @@ -979229f720e63d0294be14dae3f9fad68f76e4126a0ad63e32573cdfecd0151e +d6a3272e5592bcfeecf8a06dd8330cce57ff6603b24994b533d1fdcd48b5dc66 diff --git a/test/fts3corrupt6.test b/test/fts3corrupt6.test index a3c5fd8da6..cdd99f337d 100644 --- a/test/fts3corrupt6.test +++ b/test/fts3corrupt6.test @@ -64,7 +64,6 @@ do_execsql_test 2.1 { #------------------------------------------------------------------------- reset_db -breakpoint do_catchsql_test 3.0 { CREATE VIRTUAL TABLE main.Table0 USING fts3(); INSERT INTO Table0 VALUES (1), (printf('%8.1280000X') ), (1), (printf('%8.1280000X') ), (1) ; @@ -75,5 +74,43 @@ do_catchsql_test 3.0 { INSERT INTO Table0(Table0) VALUES('merge=6,8'); } {1 {database disk image is malformed}} +#------------------------------------------------------------------------- +reset_db +do_execsql_test 4.0 { + CREATE VIRTUAL TABLE t USING fts4(c); + INSERT INTO t(t) VALUES('nodesize=200'); + INSERT INTO t VALUES('alpha bravo charlie delta echo foxtrot golf hotel india juliet kilo lima mike november'); + INSERT INTO t VALUES('oscar papa quebec romeo sierra tango uniform victor whiskey xray yankee zulu alpha bravo'); + INSERT INTO t(t) VALUES('merge=16,4'); + UPDATE t_segdir SET end_block = start_block + 2147483647 WHERE level=0; + INSERT OR REPLACE INTO t_segments(blockid,block) + SELECT start_block+2147483647, NULL FROM t_segdir WHERE level=0; +} + +do_execsql_test 4.1 { + PRAGMA integrity_check +} {ok} + +do_execsql_test 4.2 { + INSERT INTO t VALUES( + 'mike november oscar papa quebec romeo + sierra tango uniform victor whiskey xray yankee' + ); + INSERT INTO t VALUES( + 'charlie delta echo foxtrot golf hotel india + juliet kilo lima mike november oscar papa' + ); + INSERT INTO t(t) VALUES('merge=16,4'); + SELECT blockid FROM t_segments ORDER BY blockid; +} { + 2147483647 2147483648 2147483649 2147483775 +} + +do_execsql_test 4.3 { + PRAGMA integrity_check +} {ok} + + set sqlite_fts3_enable_parentheses $saved_sqlite_fts3_enable_parentheses finish_test +