]>
git.ipfire.org Git - thirdparty/sqlite.git/log
drh [Sat, 4 Dec 2021 21:11:18 +0000 (21:11 +0000)]
Miscellaneous cleanup of the new Bloom-filter code.
FossilOrigin-Name:
201b6dd875b0ae2bbc9969b098e88abfc09e37b59e857decd41f2dcbeeb13e01
drh [Sat, 4 Dec 2021 18:45:08 +0000 (18:45 +0000)]
Add VdbeCoverage() macros. Adjust the Bloom-filter hash function so that it
correctly deals with zero-blobs.
FossilOrigin-Name:
629ee2e3e3125bfd2af435c6713d49e46691213ad15db0a5e93a63a77f1130c2
drh [Sat, 4 Dec 2021 14:24:30 +0000 (14:24 +0000)]
Apply the Bloom filter only on those terms of an index that have equality
constraints.
FossilOrigin-Name:
a70429596a3c6a413b03118b0d800521b3526d99dcf88a48acc3189b51518d82
drh [Sat, 4 Dec 2021 13:52:08 +0000 (13:52 +0000)]
Add the "WITH BLOOM FILTER" clause to the EXPLAIN QUERY PLAN output for
cases were a Bloom filter is used.
FossilOrigin-Name:
8e078c0e404fe4b3661dd4a11a992a8914c99e2a144cecc417421cbd68fa08cc
drh [Sat, 4 Dec 2021 13:43:57 +0000 (13:43 +0000)]
First attempt to use Bloom filters to optimize star-schema queries.
FossilOrigin-Name:
28161fba9bcde5ae4b36b22d766c881b795af111a3a323c90f6149d0fea9297d
drh [Fri, 3 Dec 2021 19:10:17 +0000 (19:10 +0000)]
Merge the sqlite3WhereBegin() simplification from trunk.
FossilOrigin-Name:
41ba2dfdd3a18671fc78d60935a16fa50f36af3d6481eff2ca9fba88e7093997
drh [Fri, 3 Dec 2021 18:53:53 +0000 (18:53 +0000)]
Factor the noop-join-elimination optimization out of the sqlite3WhereBegin()
routine and into a separate "no-inline" subroutine, in order to reduce the
complexity of sqlite3WhereBegin() and thereby encourage C compilers to
inline sqlite3WhereCodeOneLoopStart().
FossilOrigin-Name:
6225e9abcb0261fefca4a26530524ffc449f937f8ae1ece718af2c3c3d73d78d
drh [Fri, 3 Dec 2021 16:02:05 +0000 (16:02 +0000)]
Merge recent trunk enhancements into the bloom-filter branch.
FossilOrigin-Name:
11d97fb8be6b5155f38df130d7e828edd0f381e32f651458939b1cb9cb973fff
drh [Fri, 3 Dec 2021 15:48:42 +0000 (15:48 +0000)]
Fix exprAnalyze() after recent performance enhancements so that it is able
to handle IF_NULL_ROW opcode correctly, again.
FossilOrigin-Name:
8029e6bab508bf0b8ec1df00a829c5d4de2a84d66dc56b9ff03da879ceef7788
drh [Fri, 3 Dec 2021 14:57:05 +0000 (14:57 +0000)]
Fix unreachable branches resulting from prior optimizations.
FossilOrigin-Name:
f3d6853ee80be2dc6d7236d98b850beb0e1931a624d4f5b194c8db742cde7ec5
drh [Fri, 3 Dec 2021 14:43:49 +0000 (14:43 +0000)]
Fix an over-length source code line in build.c. No logic changes.
FossilOrigin-Name:
b9db5c5fc618a36d70ea2aced9c96094d665935b5c15a987013334f1bd79eb00
drh [Fri, 3 Dec 2021 13:42:41 +0000 (13:42 +0000)]
Performance optimization in the B-Tree cursor allocator btreeCursor(), making
it about 800K CPU cycles faster in speedtest1, and reducing the executable
size by about 100 bytes.
FossilOrigin-Name:
9df939716ace8cfe60340bbe83fc52d452ea40c29c856c588f9a1b8973282391
drh [Thu, 2 Dec 2021 18:15:16 +0000 (18:15 +0000)]
Optimizations to exprAnalyze() and sqlite3WhereExprUsage() save about 1.5
million CPU cycles for speedtest1, and result in a smaller binary.
FossilOrigin-Name:
1f2252e65dc5847c82246fab87dcad035bf594ba7c45362de87a009b7ebcf2d6
drh [Thu, 2 Dec 2021 14:28:36 +0000 (14:28 +0000)]
Move the TK_IS token so that it is adjacent to the TK_IN token, as this
allows the C compiler to optimize better, resulting in a slightly smaller
and faster executable.
FossilOrigin-Name:
8832fa9088414a8d285a457a4effad0b7d610a87ca73cfb5c5812e784649761e
dan [Thu, 2 Dec 2021 14:16:30 +0000 (14:16 +0000)]
In the shell tool, avoid modifying internal data structures until after the arguments to ".open" have been parsed.
FossilOrigin-Name:
fcc509d325dabe06275e7804183bb8b4ba6470a45b443bc8292eecd0974e6367
drh [Thu, 2 Dec 2021 13:45:10 +0000 (13:45 +0000)]
Remove an unnecessary branch from exprAnalyze(), resulting in a small
performance gain.
FossilOrigin-Name:
3312be1db3519074393573265459f6a1eeabce541a9ef4d93689529ea2b8f739
drh [Thu, 2 Dec 2021 12:55:05 +0000 (12:55 +0000)]
Small performance optimization in sqlite3WhereClauseClear().
FossilOrigin-Name:
080b35e62e5c6bb4ea162bc75232b81e54da5e3e01e762127e228400e8afef1d
drh [Thu, 2 Dec 2021 12:34:05 +0000 (12:34 +0000)]
More small performance optimizations for sqlite3WhereGetMask().
FossilOrigin-Name:
3de2c557d915d1b4a9b0e540d5e80ffb243e7123d0ec65c5052f4d6f1cce56b2
drh [Thu, 2 Dec 2021 04:00:45 +0000 (04:00 +0000)]
Small performance optimization in sqlite3WhereGetMask().
FossilOrigin-Name:
7edec54ab045c0493fc5d27d47d7bf0e08d3b0b298f428646fd3f0ee24dfcade
drh [Thu, 2 Dec 2021 02:22:35 +0000 (02:22 +0000)]
Small performance enhancement for whereScanInit().
FossilOrigin-Name:
ed84e124c6097b756ca687ac64df7ee801d14b16c835f1a9e8b336f785157d85
drh [Thu, 2 Dec 2021 01:30:16 +0000 (01:30 +0000)]
drh [Wed, 1 Dec 2021 21:07:05 +0000 (21:07 +0000)]
Merge trunk fixes into the bloom-filter branch.
FossilOrigin-Name:
0864bfbf079a98beaa484911edb17c3dc728e78eca231d4247b282fd824cc098
drh [Wed, 1 Dec 2021 19:17:14 +0000 (19:17 +0000)]
Check for foreign key constraint errors prior to returning the results from
a RETURNING clause. See [forum:/forumpost/
793beaf322 |forum post
793beaf322 ].
FossilOrigin-Name:
a818ba2ed635b91e279dde44236fc7446a33db2b46c9409b67021248c01bf4e5
drh [Wed, 1 Dec 2021 16:31:02 +0000 (16:31 +0000)]
Add a Bloom filter to the automatic-index mechanism.
FossilOrigin-Name:
50ac4de1d7cbb586ea7969e1ae80ea8b021e194edc2fa7db19374b4ee9369bee
dan [Wed, 1 Dec 2021 11:03:50 +0000 (11:03 +0000)]
Add the "static" qualifier to some internal functions in code for various SQLite extensions.
FossilOrigin-Name:
8c986782547211098eb0e4e722eda0097421223af279381373d0055211b5e9d2
drh [Tue, 30 Nov 2021 14:07:58 +0000 (14:07 +0000)]
In the automatic index generator logic, be more precise about when a
partial automatic index is allowed in order to capture more cases where it
is legal to use a partial automatic index.
FossilOrigin-Name:
664b461bb5063d98047fc2e51a3827235cd9f55ca2e23cb66e719eac53fb5437
drh [Mon, 29 Nov 2021 18:09:54 +0000 (18:09 +0000)]
Merge in the proposed date/time function enhancements: (1) Add the
unixepoch() function, (2) the 'auto' modifier and (3) the 'julianday' modifier.
FossilOrigin-Name:
19c51b46e4095ee28badb10f4e08bbd330bda320c9a8806e93b8fc60ba211a2e
drh [Mon, 29 Nov 2021 17:55:12 +0000 (17:55 +0000)]
Bump the version number up to 3.38.0 in order to begin the next development
cycle.
FossilOrigin-Name:
8ad1fcaa1b734e32d8d67c4cca7a23d2b9717ae5c7c2c5ad5a3411a503ee23ae
drh [Mon, 29 Nov 2021 17:23:27 +0000 (17:23 +0000)]
Add the unixepoch() function and the 'auto' and 'julianday' modifiers.
FossilOrigin-Name:
559fdc0aa76f4c207f99f7b0cee42043b402dc388165817529d9963b115a798c
drh [Sun, 28 Nov 2021 19:54:38 +0000 (19:54 +0000)]
Following a prior error, an ALWAYS() in sqlite3ExprCanBeNull() might be false.
dbsqlfuzz
5dbec6678a20e7595a34dfdd869a3b9722b3ca43 .
FossilOrigin-Name:
4e207401acce1bdc17025f2d55bd94234b435e286cd43e1eda03b6949a2a91d3
drh [Sat, 27 Nov 2021 14:13:22 +0000 (14:13 +0000)]
drh [Sat, 27 Nov 2021 12:03:51 +0000 (12:03 +0000)]
drh [Fri, 26 Nov 2021 20:26:37 +0000 (20:26 +0000)]
Add platform "Darwin-arm64" to test/releasetest_data.tcl.
FossilOrigin-Name:
1d5c9aacb8ab6349935561cc12734cf348c12c86e4663ddc7af113b3ed0f6186
drh [Fri, 26 Nov 2021 17:10:18 +0000 (17:10 +0000)]
Improved defenses against integer overflow when computing the size of a
memory allocations. No bugs were fixed here. But perhaps future bugs will
be prevented.
FossilOrigin-Name:
eb878c01f317f09e8ef6b1bd2ec8d6d5cd6ce0bdfe9da7fa7d92d2047cc9d9e4
drh [Fri, 26 Nov 2021 15:08:55 +0000 (15:08 +0000)]
Fixes to internal comments. No changes to code or documentation.
FossilOrigin-Name:
1489b196ce82cddf7360aff6c89219ca25e666187f0f5ff6419ba3b504cdef8d
dan [Wed, 24 Nov 2021 21:16:32 +0000 (21:16 +0000)]
Avoid splitting Failure-Detection test cases in wapptest.tcl.
FossilOrigin-Name:
654e6cf8ab493d48b1827bb8100d4e4366a8e889e647c233a9b1b1278a7133d0
dan [Wed, 24 Nov 2021 11:33:01 +0000 (11:33 +0000)]
Update Makefile.msc to support target "tcltest" in the same way as the autoconf build system.
FossilOrigin-Name:
0f131b92252afc95c8c2d160d4be9ac2a737a610ee355efcd819f1af3bae3c56
drh [Tue, 23 Nov 2021 22:28:09 +0000 (22:28 +0000)]
Changes a test pattern for RBU so that it works regardless of whether newer
TCL versions are used.
FossilOrigin-Name:
5a9921c92ade9e13c3e49c50325c96e3264f3ad352a187387a960783a68bc9d3
drh [Tue, 23 Nov 2021 12:59:25 +0000 (12:59 +0000)]
Fix a compiler warning in the dbserialize method of the TCL interface.
FossilOrigin-Name:
ba71d030fef4cd4251dc882acc6897dbf9aaba498652900c491b082add87404f
dan [Tue, 23 Nov 2021 11:34:43 +0000 (11:34 +0000)]
Exclude two recently added tests in where.test from valgrind runs. They fail due to the subtly different handling of real numbers under valgrind.
FossilOrigin-Name:
e842d2085b295ef1c927611f5d3b211fb6b513ca2676c074fe90331da81734eb
dan [Mon, 22 Nov 2021 16:50:41 +0000 (16:50 +0000)]
Omit wal mode tests in memdb1.test for builds and configurations that do not support wal mode.
FossilOrigin-Name:
0f13c0d9fd7757c6e0b845a285c0047d2c60293354335660d19d80ad799646fc
dan [Mon, 22 Nov 2021 16:48:42 +0000 (16:48 +0000)]
Omit wal mode tests in vacuum-into.test for builds and configurations that do not support wal mode.
FossilOrigin-Name:
65de17635468791678b9d205552a4faec2d6c3b7d330c559b6f81ab072254533
dan [Mon, 22 Nov 2021 16:43:53 +0000 (16:43 +0000)]
Do not attempt to run the tests in alterfault.est with SQLITE_OMIT_ALTERTABLE builds.
FossilOrigin-Name:
6f6f31c7df6831af28a24e69f744beeade739bb7bbb0810d5bbe592e4cd75e3d
dan [Mon, 22 Nov 2021 16:27:36 +0000 (16:27 +0000)]
Fix a typo in memdb1.test preventing tests from passing with -DSQLITE_DEFAULT_AUTOVACUUM=1 builds.
FossilOrigin-Name:
eff4187c50790827d05bb28867cc6546196e7eee3b4c4de54b4e68bfb4e2830e
drh [Mon, 22 Nov 2021 16:06:57 +0000 (16:06 +0000)]
There are two possible error messages from stat-9.1, depending on
compile-time options. Adjust the test case to accept either one.
FossilOrigin-Name:
0f567b61072e214c40cae1441889f83622a975f429b41803dfbed687718731c8
drh [Mon, 22 Nov 2021 13:59:06 +0000 (13:59 +0000)]
In fuzzcheck, improve the defense against long delays due to
rogue busy_timeout macros in fuzzer-generated scripts.
FossilOrigin-Name:
3024d7ca03541a6fe3d264fdc82dd49f8f6b51d2fbeec4dfc9c6dd72806b271a
drh [Mon, 22 Nov 2021 13:35:40 +0000 (13:35 +0000)]
drh [Mon, 22 Nov 2021 12:59:44 +0000 (12:59 +0000)]
In the previous check-in, do not overwrite the SQLITE_CORRUPT signal with
an SQLITE_OK before exiting fts3auxNextMethod().
FossilOrigin-Name:
396688ae5c10b9e7df1c76a3c6f548abf7a7ddad50c25fb23e194201dbb2e857
dan [Mon, 22 Nov 2021 08:12:14 +0000 (08:12 +0000)]
Fix a crash in the fts3aux code that could occur handling corrupt records.
FossilOrigin-Name:
cdcd65b89ecffd380483404f5b1379beffd7ff107acaa5bc1185651cfacaa220
drh [Sat, 20 Nov 2021 13:30:03 +0000 (13:30 +0000)]
New test cases for STRICT and NOT NULL in PRIMARY KEY.
FossilOrigin-Name:
0eafbc2f31b83f48833b19894ff3252a63c319ff501506ef9f744cca813a3a24
drh [Fri, 19 Nov 2021 19:11:58 +0000 (19:11 +0000)]
Small performance increase and size reduction for sqlite3ExprCompare().
This change also handles some corner cases without the need for ALWAYS().
FossilOrigin-Name:
d814ba6effc7c5b021ff625b57371627f3ee326687c508da99f78bc164386b7e
dan [Fri, 19 Nov 2021 14:02:43 +0000 (14:02 +0000)]
Fix a benign data race in os_unix.c that might trouble tsan and similar tools.
FossilOrigin-Name:
95806ac1dabe4598170061d903ae30f09bafac149ff6696963a7e056ac846cdb
drh [Thu, 18 Nov 2021 20:56:59 +0000 (20:56 +0000)]
Minor tweaks to the way auxiliary tools are built, to make it easier to
customize the builds without having to alter the code.
FossilOrigin-Name:
90b06b6f42918852cfb15258be462c6bed260c6a618b86fa9084bac72fa2f58f
dan [Thu, 18 Nov 2021 20:11:31 +0000 (20:11 +0000)]
Fix a performance regression in rtree introduced by the previous commit.
FossilOrigin-Name:
7f42b8e1a25c0830fe81e4668318998af595826784a50780a5c1c0b4d95a2482
dan [Thu, 18 Nov 2021 19:15:40 +0000 (19:15 +0000)]
Fix a problem slowing down the handling of == constraints in the rtree module.
FossilOrigin-Name:
509027e964f28efca088a41fe32f01c38316f7a919de63a8835e3bc7c3fb0787
drh [Thu, 18 Nov 2021 15:40:05 +0000 (15:40 +0000)]
Improve CSV quoting in the CLI using the strstr() function.
FossilOrigin-Name:
b7927bf91049c903730a280484bbcdcdedc259a31fbcc3d3b0c7d046ec321633
drh [Thu, 18 Nov 2021 13:25:31 +0000 (13:25 +0000)]
Fix an obscure problem associated with quoting of CSV output in the CLI.
FossilOrigin-Name:
38a9b660214c06aa6650c6bb11a429a8c74c09f1e0e5c18d691e36de4af7af71
dan [Tue, 16 Nov 2021 13:36:50 +0000 (13:36 +0000)]
Fix a problem causing an OOM within an ALTER TABLE ADD COLUMN command that adds a column with a CHECK constraint to go unreported.
FossilOrigin-Name:
a33f5e93ecb7d84291f6fecc7b60f0c555034aa47e24584c63c78d8a94710d82
drh [Mon, 15 Nov 2021 19:10:13 +0000 (19:10 +0000)]
Strengthen the sticky-CORRUPT idea of check-in [
3feb0f1c3840904d ] by
automatically changing the first COMMIT after an SQLITE_CORRUPT error into
a ROLLBACK.
FossilOrigin-Name:
bd66ab8a1bc3c43a57c7caff5f54545b0feb0177f1f51492f30d308c123c43ba
drh [Mon, 15 Nov 2021 18:50:02 +0000 (18:50 +0000)]
Small performance optimization in sqlite3VdbeHalt().
FossilOrigin-Name:
9e1ecf438cb01d3d76950bcce1b3e4df29bedbb8176c8cede27e66f8e53e2098
dan [Mon, 15 Nov 2021 14:11:23 +0000 (14:11 +0000)]
Fix a problem causing the count(*) optimization to be misapplied in some cases where an aggregate sub-query uses a count() expression that is aggregated against the outer query.
FossilOrigin-Name:
e30917278c0ec750b1756ddc5e32d65c55464531d6ef64d2e72a412dfe634f58
drh [Mon, 15 Nov 2021 13:22:42 +0000 (13:22 +0000)]
Improved context shown for the "ABORT-due-to-error" output line when using
"PRAGMA vdbe_debug=on" in an SQLITE_DEBUG build.
FossilOrigin-Name:
c7776369bcd0dbeb418b14d5dc681a81ee426234cc3f4f79a3c899d7892e1560
drh [Mon, 15 Nov 2021 01:45:11 +0000 (01:45 +0000)]
drh [Fri, 12 Nov 2021 14:39:49 +0000 (14:39 +0000)]
Improved handling of OOM while reallocating a column name to add type
information. dbsqlfuzz
5a195b4233649e49e0aa34f1b743ca192d85b198
FossilOrigin-Name:
5995dd4de4997c43b43befc1281ef6378f33f781134c7f368299d64db2344f1d
drh [Thu, 11 Nov 2021 23:52:44 +0000 (23:52 +0000)]
Make sure the rowid value returned by the VUpdate opcode is always initialized.
FossilOrigin-Name:
150b5be5d5771485f521e3a58312596ecdcd35f3a0ae9d42d88bb99348a197c4
drh [Thu, 11 Nov 2021 16:26:46 +0000 (16:26 +0000)]
Remove a NEVER() that was add yesterday. The fuzzer found a new test case
to make it happen.
FossilOrigin-Name:
83e6ac71073edfa0cd73788c30bdd5f09cb04c8a6a7d5123123dbcd354f430b8
drh [Thu, 11 Nov 2021 11:23:08 +0000 (11:23 +0000)]
New assert() statements to help prove correct usage of VdbeCursor objects.
FossilOrigin-Name:
7cee62f77a9e7c3cf886f136e75a93c3bbbb88e48b66035883bea5503d9fc03c
drh [Wed, 10 Nov 2021 15:23:00 +0000 (15:23 +0000)]
drh [Wed, 10 Nov 2021 10:59:10 +0000 (10:59 +0000)]
Make SQLITE_CORRUPT sticky: If a CORRUPT error is returned, all subsequent
write statements within the same transaction also fail early with
SQLITE_CORRUPT.
FossilOrigin-Name:
3feb0f1c3840904d28fc9a61262820e2b9b764addc1dd178aecc2cd0f952042c
drh [Tue, 9 Nov 2021 13:31:42 +0000 (13:31 +0000)]
Change test case error message text to match the current implementation.
FossilOrigin-Name:
de10795a1cf70925088e9652998e813665b2e147ffa4a4edab18c7e2c66bf5ae
drh [Tue, 9 Nov 2021 01:48:15 +0000 (01:48 +0000)]
Fix lempar.c so that Lemon can compile with NDEBUG defined.
[forum:/forumpost/
f331adca0b |Forum post
f331adca0b ]
FossilOrigin-Name:
ba4fb51853fbcb8c142a350b4db0d59153f28ba0a63ad9a2d6fea7096d3dd544
drh [Mon, 8 Nov 2021 23:24:00 +0000 (23:24 +0000)]
Refactor the code that figures out which SELECT in a cascade of nested queries
a particular aggregate function belongs to. This fixes the problem
reported by [forum:/forumpost/
c7cc2aa3546e39c1 |forum post
c7cc2aa3546e39c1 ].
New test cases in dbsqlfuzz and th3.
FossilOrigin-Name:
74aec5dd1df95b5635f4da1f13753f113ea1d61de3dc3a1523ba51089c1900e4
dan [Mon, 8 Nov 2021 19:35:26 +0000 (19:35 +0000)]
Fix the zeroblob() function and related APIs so that they work with SQLITE_OMIT_INCRBLOB builds.
FossilOrigin-Name:
bc401a75dd9f3c29c5969ae36264e68ccefc0937e44e232ca1f6b550f7fd6e22
dan [Mon, 8 Nov 2021 15:46:08 +0000 (15:46 +0000)]
Fix an assert() in memdbTruncate() that could fail when processing a corrupt database.
FossilOrigin-Name:
b1e2929860557cf88f98f0a4f2472e1a16be126bbb8050f0d728350f0cfe987a
drh [Sun, 7 Nov 2021 23:33:01 +0000 (23:33 +0000)]
Ensure that the window function rewrite does not leave the parse tree
in an invalid state that might cause problems downstream before the
error is recognized and unwinds the stack. Also take steps such that
an invalid parse tree does not cause problems even if it goes
unrecognized.
[forum:/forumpost/
398e9d5aa9 |Forum post
398e9d5aa9 ].
FossilOrigin-Name:
0f9fc6b6073365d5159cd71e7fe08f8dadbc7b42abd324361e809502f4359155
drh [Sat, 6 Nov 2021 20:25:29 +0000 (20:25 +0000)]
Add ALWAYS() to a branch made unreachable by the previous check-in.
FossilOrigin-Name:
0dc963f63aebc42960125f96865029f16b3f6867126aab350da12882505edb82
dan [Sat, 6 Nov 2021 18:22:50 +0000 (18:22 +0000)]
Return an error if an attempt is made to drop an eponymous virtual table.
FossilOrigin-Name:
889dea52de874cd3bda9e811ef1e4ca53ab794ecabc65e9c780d9fb01eff3b2c
drh [Sat, 6 Nov 2021 10:59:27 +0000 (10:59 +0000)]
Avoid accessing the sqlite3_module.xShadowName field if (sqlite3_module.iVersion<3).
FossilOrigin-Name:
a024764cef955099b498ea120d4127144880db6da411f074cf0fd1276989204e
drh [Fri, 5 Nov 2021 22:35:09 +0000 (22:35 +0000)]
Add the rbu_exclusive_checkpoint query parameter to RBU.
FossilOrigin-Name:
c2d33ea9d81975b27fe157d698033e7c01569cc0aa6178b7f0c43afbfba4a9e2
drh [Fri, 5 Nov 2021 22:23:17 +0000 (22:23 +0000)]
New test cases for rbu_exclusive_checkpoint query parameter.
FossilOrigin-Name:
00285ff10c771066876896b28cd5185ec3792166b00702326954ef6678f19da8
drh [Fri, 5 Nov 2021 19:52:27 +0000 (19:52 +0000)]
Update an assert() statement to conform to the changes of the previous check-in.
FossilOrigin-Name:
b5c668cac831425fd3e370142f9ea501bf2ca1c77c3eb0c5b8f0a574f7667b3c
drh [Fri, 5 Nov 2021 19:36:26 +0000 (19:36 +0000)]
Add the SQLITE_OPEN_EXRESCODE flag for sqlite3_open_v2().
FossilOrigin-Name:
ff9373f42d8479be5cae6cc15dc7fe0cc125c6c0157f5375bf7e1e77c624655d
dan [Fri, 5 Nov 2021 19:04:01 +0000 (19:04 +0000)]
If the target database URI passed to sqlite3rbu_open() is contains the option "rbu_exclusive_checkpoint=1", hold an exclusive lock for the duration of any incremental checkpoint operation.
FossilOrigin-Name:
7cb77296a22a87e7ed4c3544792f0204f704f01f384590c32c256bec4517c9bc
dan [Fri, 5 Nov 2021 14:13:12 +0000 (14:13 +0000)]
Update sqllimits1.test to account for recent changes to SQL function strftime().
FossilOrigin-Name:
7bba415f91884a20f665e982376c2c5e91a4431e218c8eefe275be3684f2e59a
drh [Fri, 5 Nov 2021 12:34:06 +0000 (12:34 +0000)]
Use the FTS_CORRUPT_VTAB macro rather than a direct call to
sqlite3Fts3Corrupt() in [
2fad2a89527757b3 ] so that the build works
in all cases.
FossilOrigin-Name:
029c59cdf9e7dbb431f5d110bc69c3597458edc9b6b009b2e91422de705a19fa
drh [Fri, 5 Nov 2021 11:52:33 +0000 (11:52 +0000)]
Remove an incorrect NEVER() reported at
[forum:/forumpost/
5bbabfb7ce |forum post
5bbabfb7ce ]. Also use this
opportunity to improve the isSimpleCount() function with better formatting,
an expanded header comment, and some extra assert() and textcase() macros.
FossilOrigin-Name:
2927185be81a5aa0dce70dd06040d05c2816a4d18b5094a6f709732cfd6968dc
dan [Fri, 5 Nov 2021 11:26:00 +0000 (11:26 +0000)]
Fix vacuum3.test so that it works with SQLITE_OMIT_ALTERTABLE builds.
FossilOrigin-Name:
07cca2fa891e9a60ea128a4b96ee407e9dd0f2b9e31fcffbfc2ac594a0e1ffe6
dan [Fri, 5 Nov 2021 11:18:31 +0000 (11:18 +0000)]
Update a test case in sqllimits1.test to account for the updated implementation of SQL function strftime().
FossilOrigin-Name:
f474ac370accc5c780e7cb3e11c35f2b6104df929d3394a27db00c6b995e71b3
dan [Fri, 5 Nov 2021 10:43:14 +0000 (10:43 +0000)]
Fix a couple of problems with test scripts and SQLITE_OMIT_ALTERTABLE builds.
FossilOrigin-Name:
3ab5414d337536acad5675a3f1ca10e1ca925f0e7182def604b8b7a8fb53bf5a
dan [Thu, 4 Nov 2021 18:04:55 +0000 (18:04 +0000)]
Fix a crash that could occur in fts3 when processing a corrupt database.
FossilOrigin-Name:
2fad2a89527757b3956538a6bf91ebebe9c483f22f94e889e8b50c58f5100c5c
dan [Thu, 4 Nov 2021 16:25:47 +0000 (16:25 +0000)]
Fix corruptN.test so that it works with SQLITE_DEFAULT_AUTOVACUUM=1 builds.
FossilOrigin-Name:
f60e05bdbabe0449e5a12275b254ca9da39a2a5fdbff078ce28007a23044749e
dan [Thu, 4 Nov 2021 16:15:46 +0000 (16:15 +0000)]
Update a test case in corruptN.test to account for the fact that if writable_schema=1 is set, no error is raised if a DELETE statement finds that an index entry is missing ([
19e56291a7344c7a ]).
FossilOrigin-Name:
a90c5f0b5ba1ef0f41449cee10a65beb8b55b09fd1976e0e35814b1848979416
dan [Thu, 4 Nov 2021 16:03:24 +0000 (16:03 +0000)]
Have wapptest.tcl avoid attempting to build fuzztest for SQLITE_OMIT_VIRTUALTABLE configurations.
FossilOrigin-Name:
53ee208d4ee8db1499a63b6652a8c5269e8fe85a75376adffdb912094ac1a681
drh [Thu, 4 Nov 2021 15:17:42 +0000 (15:17 +0000)]
Fix typo in the sqlite3ext.h file.
[forum:/forumpost/
63802db4ce |forum post
63802db4ce ]
FossilOrigin-Name:
d4a48ee0c28def416f75eb7840ba6462389e3f97e0dc02287bf1a726c8642f04
drh [Thu, 4 Nov 2021 14:04:20 +0000 (14:04 +0000)]
Show the preferred schema table names in the output of "PRAGMA table_list".
FossilOrigin-Name:
9147390d9885a37a62edc1058f313434627f1b59965c890877d2cb119e355c78
drh [Thu, 4 Nov 2021 11:34:04 +0000 (11:34 +0000)]
Change a branch made unreachable by the previous check-in into an assert().
FossilOrigin-Name:
685a987c9afd1c30629c36f1ffb5e349eb2e26182837523036b916c6f81632c4
drh [Thu, 4 Nov 2021 00:51:53 +0000 (00:51 +0000)]
First the shadow table mechanism so that it works even if the shadow table
comes before the virtual table in the sqlite_schema table, as can happen
after a VACUUM.
FossilOrigin-Name:
005a8642773556825fe4c5d0b2c12517d35289308a30df0151ef7f080acb0172
drh [Wed, 3 Nov 2021 16:35:23 +0000 (16:35 +0000)]
Remove two incorrect assert() statements added by a check-in from earlier
today.
FossilOrigin-Name:
3206edff947b9edb485466f05b2baadf725d798229630c7e83e88c0b9ae278ca
drh [Wed, 3 Nov 2021 15:59:17 +0000 (15:59 +0000)]
Improved the error message that results when a schema parse fails after
ALTER TABLE ADD COLUMN.
FossilOrigin-Name:
b007a39dd3a46d13fe06f2a1eeb4e3fd4cad1a77892be6d175b31db1edd6f6a8
drh [Wed, 3 Nov 2021 14:02:48 +0000 (14:02 +0000)]
Fix INSERT into STRICT table with STATIC generated columns.
FossilOrigin-Name:
24285d913678853213532d61aba077d576e3cd7629159e0a75dc3c16e54e2662