mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-17 01:46:58 +02:00
bump(dev-db/sqlite): sync with upstream
This commit is contained in:
parent
001e63779b
commit
a0bb13a47e
@ -1,6 +1,9 @@
|
|||||||
DIST sqlite-autoconf-3280000.tar.gz 2810415 BLAKE2B e1af03476d97f96ef78d4e0a9df6ae69a06fb08e48046c843ed668b3f8c00c58263df07a4e8a22a1c7cfc920fd005fa6c2525dceeec4f724b43df7589ca3f777 SHA512 e800c0d9e6c8c01ccf1d714c6c4da4b98e9610c4c06557dda6393d0792a8ae09788703d4a74dcb21844c49b3629ff7ed95a4a86ff79872aafd2b49c672c7a570
|
|
||||||
DIST sqlite-autoconf-3290000.tar.gz 2833613 BLAKE2B b68a4f9bfe90653f5ce9dbf94b44cecc843fbb639883a7be9dd40150749f8d2eca0c231b215137d2f8da78d33356d72640a943ba06516c6d7c10ebd04cae4766 SHA512 85dcaa72cc2476c628e801d4ce46cf10ed8997f56cb0334062df5553f18c29d607883a1049bf75258204f2f53a29a02a01f014dcca383b05dfac1e2123778024
|
DIST sqlite-autoconf-3290000.tar.gz 2833613 BLAKE2B b68a4f9bfe90653f5ce9dbf94b44cecc843fbb639883a7be9dd40150749f8d2eca0c231b215137d2f8da78d33356d72640a943ba06516c6d7c10ebd04cae4766 SHA512 85dcaa72cc2476c628e801d4ce46cf10ed8997f56cb0334062df5553f18c29d607883a1049bf75258204f2f53a29a02a01f014dcca383b05dfac1e2123778024
|
||||||
DIST sqlite-doc-3280000.zip 9421770 BLAKE2B 695eab96f718307a7aff8a171d9e416ddb4b17039ef7230a458dc7d256e2f07a5b41d3aa1a3f085e5e418c297b5dd1d2ba5e4827434329d1ed61d3dd1f618f3d SHA512 83e23dff00614d31d501c66c29d8d4aa780b38859242b58937243235d185fe3db2f9f3c1accf9bf2df0b457a6e32612a00e82f503a8665aad4f19602e2b36396
|
DIST sqlite-autoconf-3300100.tar.gz 2848951 BLAKE2B 3a541a2b07ebbaf7ddca4693b71765e2ecd11974dd64b4a7a19eaee4eea8a17a6004c69f3b2163213fe7568480152709745e029107711813d4bdd41052763cd1 SHA512 9ec0283c417fb0323b0e43550af2a49e9a63988e4212c27ea62cc9da3534caa6faf5bdc7e051b6772c4ce61560a433b3d3288b68e05e9ba8495f61a3bcebda3e
|
||||||
|
DIST sqlite-autoconf-3310100.tar.gz 2887243 BLAKE2B ef5d40b6e6c59a51ae95368eb9f6a938188813f89d5328ea1c1180ef35f124c14b3e83b0832ae5c2fa24cc2df352f1b0ea5f20b64d0762d50a700d9895f9a12e SHA512 d85250ba5f78f0c918880f663741709aba662192f04888b2324a0df17affdf5b8540e8428c6c7315119806e7adad758ea281c9b403c0ad94ac6a9bd1b93fd617
|
||||||
DIST sqlite-doc-3290000.zip 9415641 BLAKE2B 97fef1f01d3e7730e5220541ad9ccdf9f8538aa43939c0f513919c8505b3a4f4b4c89eb2e04fddae80b7eeed440eb0f06f7cfd93cd56f0539bd6fdd5f47e1ff7 SHA512 ca856cf250e395d9c7e9817337adb5a16b1d96a20548a4010f5137188d35bb9d49a4a6da47bf2a696deffa68d2976dbb35a036adce19b8320e0e286876ac094f
|
DIST sqlite-doc-3290000.zip 9415641 BLAKE2B 97fef1f01d3e7730e5220541ad9ccdf9f8538aa43939c0f513919c8505b3a4f4b4c89eb2e04fddae80b7eeed440eb0f06f7cfd93cd56f0539bd6fdd5f47e1ff7 SHA512 ca856cf250e395d9c7e9817337adb5a16b1d96a20548a4010f5137188d35bb9d49a4a6da47bf2a696deffa68d2976dbb35a036adce19b8320e0e286876ac094f
|
||||||
DIST sqlite-src-3280000.zip 12477204 BLAKE2B e62e0f36f0bebf89990f8ec91cb1e508a5ebc92bb212eaf9c80eb0febecb5623f5938ecd31c210837314f1f9aab19a18189824f82a106799384d8184ca5f65ab SHA512 49c35c65fa686a2326e13218db583c54fa5fe8f48f0caddd11a942601803b3023f7d32ffbab16641e0d72dc9ed288ad26eaa7226c865ac54e1f181859125651f
|
DIST sqlite-doc-3300100.zip 9485342 BLAKE2B bf5e3909a327c773106d4990b3e3be5dd63db2dbc1a7f8a7c1bd16f39bec83a6b2a98c4c56ded3b58f4087dcdcc934e542db36e142bf338a411ed7115d67d6b3 SHA512 373e843015307071443a0db5fb930f9120718f6118cc2e21b506fdc8535fbe6996e9889e8b5809ffb91257addfe778bdf3412a81e11f6bced2c5e0330337d00d
|
||||||
|
DIST sqlite-doc-3310100.zip 9600405 BLAKE2B 324fb7a0a38bc56476e41504c14996e9d5d83ac659403991515413d49f5ee3aad064ccece25f52b6041ef26bf23f320a9be1b6b02c5fbe96c36372107f54fc2e SHA512 5572e2c2dac30c014ef9cd60a620b7a7bb610f91a47e2890c0641540d39b9d5ce0e914ee697583130317633918b7827e2612a7cbc024f5bd6aa22ad28a78b56b
|
||||||
DIST sqlite-src-3290000.zip 12557725 BLAKE2B b1aeb80734a2cb7d45c6f2e278bad2996b56ecaf792a8f26322bf50aeaa430eea267f23edb1721bb80ecb6e0c8e14c7a5d8f26178d056fd23efb52f496cc03e1 SHA512 575398fbe20c6471ee2abcbde170b8d48efbb3cb2716a65f42f05c52429a45d14e8046e50c59bbf75bfe2d8f151c34abd50b440c50af571f19e19f3290b230df
|
DIST sqlite-src-3290000.zip 12557725 BLAKE2B b1aeb80734a2cb7d45c6f2e278bad2996b56ecaf792a8f26322bf50aeaa430eea267f23edb1721bb80ecb6e0c8e14c7a5d8f26178d056fd23efb52f496cc03e1 SHA512 575398fbe20c6471ee2abcbde170b8d48efbb3cb2716a65f42f05c52429a45d14e8046e50c59bbf75bfe2d8f151c34abd50b440c50af571f19e19f3290b230df
|
||||||
|
DIST sqlite-src-3300100.zip 12648162 BLAKE2B bb239bac9115c74778de0347b4f4e24a82f149f55fe7dea8b89eb859bfe4cf6f6c2f065f5e1741c40624bb88ecd395140064a41d475a1c64a0188990fd6248e7 SHA512 f40236d0bb25f3ea01a1192dace3b6732fb671fbdabb7cfa8d0cc2b99d21aef00ae380999fdee904501cb03304644cddfb2506951f36a2f6a83693f311c3c11d
|
||||||
|
DIST sqlite-src-3310100.zip 12510166 BLAKE2B a856695e8552b8b4dcb28452fdbd48305fdb9072f9d6587f4b1f4445daf386e920eb936dcb50fdfe41a49f84b26a7c5fedcffea5acf3ba3fa935c36695d4b8ee SHA512 af92a00877bcd90372d6f83a27fea12b4fe8d1155b223a6bccbccc31bb8e3d2269cd9e68f329bc55f70d1068ccbf220ff5abccea6f593fd7a3a4bdd732d1cdbe
|
||||||
|
@ -1,954 +0,0 @@
|
|||||||
https://sqlite.org/src/info/b2ce5ed175cb5029
|
|
||||||
https://sqlite.org/src/info/6e4a5f22811bcd14
|
|
||||||
https://sqlite.org/src/info/516ca8945150bdc1
|
|
||||||
https://sqlite.org/src/info/e1724f1d618cfbcf
|
|
||||||
https://sqlite.org/src/info/c621fc668c6538f9
|
|
||||||
https://sqlite.org/src/info/c509d8a8aebe0da4
|
|
||||||
https://sqlite.org/src/info/a9b90aa12eecdd9f
|
|
||||||
|
|
||||||
--- /ext/fts3/fts3_write.c
|
|
||||||
+++ /ext/fts3/fts3_write.c
|
|
||||||
@@ -3754,7 +3754,7 @@
|
|
||||||
}
|
|
||||||
p->iOff += fts3GetVarint32(&p->aNode[p->iOff], &nSuffix);
|
|
||||||
|
|
||||||
- if( nPrefix>p->iOff || nSuffix>p->nNode-p->iOff ){
|
|
||||||
+ if( nPrefix>p->term.n || nSuffix>p->nNode-p->iOff || nSuffix==0 ){
|
|
||||||
return FTS_CORRUPT_VTAB;
|
|
||||||
}
|
|
||||||
blobGrowBuffer(&p->term, nPrefix+nSuffix, &rc);
|
|
||||||
@@ -3773,7 +3773,7 @@
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- assert( p->iOff<=p->nNode );
|
|
||||||
+ assert_fts3_nc( p->iOff<=p->nNode );
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
--- /ext/fts5/fts5_buffer.c
|
|
||||||
+++ /ext/fts5/fts5_buffer.c
|
|
||||||
@@ -178,7 +178,11 @@
|
|
||||||
i64 iOff = *piOff;
|
|
||||||
int iVal;
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
||||||
- if( iVal==1 ){
|
|
||||||
+ if( iVal<=1 ){
|
|
||||||
+ if( iVal==0 ){
|
|
||||||
+ *pi = i;
|
|
||||||
+ return 0;
|
|
||||||
+ }
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
||||||
iOff = ((i64)iVal) << 32;
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
||||||
--- /ext/fts5/test/fts5corrupt3.test
|
|
||||||
+++ /ext/fts5/test/fts5corrupt3.test
|
|
||||||
@@ -8128,6 +8128,215 @@
|
|
||||||
INSERT INTO t1(t1) VALUES('optimize')
|
|
||||||
} {1 {database disk image is malformed}}
|
|
||||||
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+reset_db
|
|
||||||
+do_test 58.0 {
|
|
||||||
+ sqlite3 db {}
|
|
||||||
+ db deserialize [decode_hexdb {
|
|
||||||
+.open --hexdb
|
|
||||||
+| size 24576 pagesize 4096 filename crash-5a5acd0ab42d31.db
|
|
||||||
+| page 1 offset 0
|
|
||||||
+| 0: 53 51 4c 69 74 65 20 66 6f 72 6d 61 74 20 33 00 SQLite format 3.
|
|
||||||
+| 16: 10 00 01 01 00 40 20 20 00 00 00 00 00 00 00 00 .....@ ........
|
|
||||||
+| 96: 00 00 00 00 0d 00 00 00 06 0e 0f 00 0f aa 0f 53 ...............S
|
|
||||||
+| 112: 0e e8 0e 8b 0e 33 0e 0f 00 00 00 00 00 00 00 00 .....3..........
|
|
||||||
+| 3584: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 22 ................
|
|
||||||
+| 3600: 06 06 17 11 11 01 31 74 61 62 6c 65 62 62 62 62 ......1tablebbbb
|
|
||||||
+| 3616: 06 43 52 45 41 54 45 20 54 41 42 4c 45 20 62 62 .CREATE TABLE bb
|
|
||||||
+| 3632: 28 61 29 56 05 06 17 1f 1f 01 7d 74 61 62 6c 65 (a)V.......table
|
|
||||||
+| 3648: 74 31 5f 63 2a 6e 66 69 68 74 31 5f 63 6f 6e 66 t1_c*nfiht1_conf
|
|
||||||
+| 3664: 69 67 05 43 52 45 41 54 45 20 54 41 42 4c 45 20 ig.CREATE TABLE
|
|
||||||
+| 3680: 27 74 31 5f 63 6f 6e 66 69 67 27 28 6b 20 50 52 't1_config'(k PR
|
|
||||||
+| 3696: 49 4d 41 52 59 20 4b 45 59 2c 20 76 29 20 57 49 IMARY KEY, v) WI
|
|
||||||
+| 3712: 54 48 4f 55 54 20 52 4f 57 49 44 5b 04 07 17 21 THOUT ROWID[...!
|
|
||||||
+| 3728: 21 01 81 01 74 61 62 6c 65 74 31 5f 64 6f 73 73 !...tablet1_doss
|
|
||||||
+| 3744: 69 7a 65 74 31 5f 64 6f 63 73 69 7a 65 04 43 52 izet1_docsize.CR
|
|
||||||
+| 3760: 45 41 54 45 20 54 41 42 4c 45 20 27 74 31 5f 64 EATE TABLE 't1_d
|
|
||||||
+| 3776: 6f 63 73 69 7a 65 27 28 69 64 20 49 4e 54 45 47 ocsize'(id INTEG
|
|
||||||
+| 3792: 45 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 ER PRIMARY KEY,
|
|
||||||
+| 3808: 73 7a 20 42 4c 4f 42 29 69 03 07 17 19 19 01 81 sz BLOB)i.......
|
|
||||||
+| 3824: 2d 74 61 62 6c 65 74 31 5f 69 64 78 74 31 5f 69 -tablet1_idxt1_i
|
|
||||||
+| 3840: 64 78 03 43 52 45 41 54 45 20 54 41 42 4c 45 20 dx.CREATE TABLE
|
|
||||||
+| 3856: 27 74 31 5f 69 64 78 27 28 73 65 67 69 64 2c 20 't1_idx'(segid,
|
|
||||||
+| 3872: 74 65 72 6d 2c 20 70 67 6e 6f 2c 20 50 52 49 4d term, pgno, PRIM
|
|
||||||
+| 3888: 41 52 59 20 4b 45 59 28 73 65 67 69 64 2c 20 74 ARY KEY(segid, t
|
|
||||||
+| 3904: 65 72 6d 29 29 20 57 49 54 48 4f 55 54 20 52 4f erm)) WITHOUT RO
|
|
||||||
+| 3920: 57 49 44 55 02 07 17 1b 1b 01 81 01 74 61 62 6c WIDU........tabl
|
|
||||||
+| 3936: 65 74 31 5f 64 61 74 61 74 31 5f 64 61 74 61 02 et1_datat1_data.
|
|
||||||
+| 3952: 43 52 45 41 54 45 20 54 41 42 4c 45 20 27 74 31 CREATE TABLE 't1
|
|
||||||
+| 3968: 5f 64 61 74 61 27 28 69 64 20 49 4e 54 45 47 45 _data'(id INTEGE
|
|
||||||
+| 3984: 52 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 20 62 R PRIMARY KEY, b
|
|
||||||
+| 4000: 6c 6f 63 6b 20 42 4c 4f 42 29 54 01 07 17 11 11 lock BLOB)T.....
|
|
||||||
+| 4016: 08 81 15 74 61 62 6c 65 74 31 74 31 43 52 45 41 ...tablet1t1CREA
|
|
||||||
+| 4032: 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45 TE VIRTUAL TABLE
|
|
||||||
+| 4048: 20 74 31 20 55 53 49 4e 47 20 66 74 73 35 28 61 t1 USING fts5(a
|
|
||||||
+| 4064: 2c 62 2c 70 72 65 66 69 78 3d 22 32 2c 32 2c 33 ,b,prefix=.2,2,3
|
|
||||||
+| 4080: 2c 34 22 2c 20 63 6f 6e 74 65 6e 74 3d 22 22 29 ,4., content=..)
|
|
||||||
+| page 2 offset 4096
|
|
||||||
+| 0: 0d 0b 6a 00 37 09 4c 02 0f e7 09 4c 0f c6 0f a4 ..j.7.L....L....
|
|
||||||
+| 16: 0f 88 0f 6d 0f 4b 0f 2c 0f 0e 0e ec 0e cd 0e ae ...m.K.,........
|
|
||||||
+| 32: 0e 8e 0e 6c 0e 4b 0e 29 0e 08 0d e6 0d c4 0d b5 ...l.K.)........
|
|
||||||
+| 48: 0d 97 0d 76 0d 54 0d 30 fd 15 0c f3 0c d3 0c b5 ...v.T.0........
|
|
||||||
+| 64: 0c 95 0c 73 0c 54 0c 32 0c 10 0b ee 0b cc 0b b0 ...s.T.2........
|
|
||||||
+| 80: 0b 8d 0b 7e 0b 48 0b 2e 0b 0b 0a ef 0a cc 0a ad ...~.H..........
|
|
||||||
+| 96: 0a 8c 0a 6d 0a 4d 0a 2b 0a 0c 00 00 00 00 00 00 ...m.M.+........
|
|
||||||
+| 2368: 00 00 00 00 00 00 00 00 00 00 00 00 15 0a 03 00 ................
|
|
||||||
+| 2384: 30 00 00 00 9c 01 03 35 00 03 01 01 12 02 01 12 0......5........
|
|
||||||
+| 2400: 03 01 11 1c 8c 80 80 80 80 10 03 00 3e 00 00 00 ............>...
|
|
||||||
+| 2416: 17 01 05 05 34 74 61 62 6c 03 02 03 01 04 77 68 ....4tabl.....wh
|
|
||||||
+| 2432: 65 72 03 02 06 09 1b 8c 80 80 80 80 0f 03 00 3c er.............<
|
|
||||||
+| 2448: 00 00 00 16 05 34 66 74 73 34 03 02 02 01 04 6e .....4fts4.....n
|
|
||||||
+| 2464: 75 6d 62 03 06 01 04 09 1b 8c 80 80 80 80 0e 03 umb.............
|
|
||||||
+| 2480: 00 3c 00 00 00 16 04 33 74 68 65 03 06 01 01 04 .<.....3the.....
|
|
||||||
+| 2496: 01 03 77 68 65 03 02 04 04 0a 1b 8c 80 80 80 80 ..whe...........
|
|
||||||
+| 2512: 0d 03 00 3c 00 00 00 16 04 33 6e 75 6d 03 06 01 ...<.....3num...
|
|
||||||
+| 2528: 01 05 01 03 74 61 62 05 62 03 04 0a 19 8c 80 80 ....tab.b.......
|
|
||||||
+| 2544: 80 80 0c 03 00 38 00 00 00 14 03 39 a7 68 03 02 .....8.....9.h..
|
|
||||||
+| 2560: 04 10 04 33 66 74 73 03 02 02 04 07 18 8c 80 80 ...3fts.........
|
|
||||||
+| 2576: 80 80 0b 03 00 36 00 00 00 13 03 32 74 61 03 02 .....6.....2ta..
|
|
||||||
+| 2592: 03 02 01 68 03 06 01 01 04 04 07 1b 8c 80 80 80 ...h............
|
|
||||||
+| 2608: 80 0a 03 00 3c 00 00 00 16 03 32 6e 75 03 06 01 ....<.....2nu...
|
|
||||||
+| 2624: 01 05 01 02 6f 66 03 06 01 01 06 04 09 19 8c 80 ....of..........
|
|
||||||
+| 2640: 80 80 80 09 03 00 38 00 00 00 14 03 32 66 74 03 ......8.....2ft.
|
|
||||||
+| 2656: 02 02 01 02 69 73 03 06 01 01 03 04 07 18 8c 80 ....is..........
|
|
||||||
+| 2672: 80 80 80 08 03 00 36 00 00 00 13 02 31 74 03 08 ......6.....1t..
|
|
||||||
+| 2688: 03 01 01 04 01 01 77 03 02 04 04 09 1a 8c 80 80 ......w.........
|
|
||||||
+| 2704: 80 80 07 03 00 3a ff 00 00 15 02 31 6e 03 08 01 .....:.....1n...
|
|
||||||
+| 2720: 01 02 05 01 01 6f 03 06 01 01 06 04 09 18 8c 80 .....o..........
|
|
||||||
+| 2736: 80 80 80 06 03 00 36 00 00 00 13 04 02 31 66 03 ......6......1f.
|
|
||||||
+| 2752: 02 01 f1 01 69 03 06 01 01 03 05 06 1c 8c 80 80 ....i...........
|
|
||||||
+| 2768: 80 80 05 03 00 3e 00 00 00 17 04 30 74 68 65 03 .....>.....0the.
|
|
||||||
+| 2784: 06 01 01 14 01 05 77 68 65 72 65 03 02 04 0a 15 ......where.....
|
|
||||||
+| 2800: 8c 80 80 80 80 04 03 00 30 00 00 00 11 01 01 06 ........0.......
|
|
||||||
+| 2816: 06 30 74 61 62 6c cc 03 02 03 07 1c 8c 80 80 80 .0tabl..........
|
|
||||||
+| 2832: 80 03 03 00 3e 00 00 00 17 07 30 6e 75 6d 62 65 ....>.....0numbe
|
|
||||||
+| 2848: 72 03 06 01 01 05 01 02 6f 66 02 06 04 0d 13 8c r.......of......
|
|
||||||
+| 2864: 80 80 80 80 02 03 00 2c 00 00 00 0f 01 01 03 02 .......,........
|
|
||||||
+| 2880: 30 6e 03 06 01 01 02 07 1b 8c 80 80 80 80 01 03 0n..............
|
|
||||||
+| 2896: 00 3c 00 00 00 16 08 30 66 74 73 34 61 75 78 03 .<.....0fts4aux.
|
|
||||||
+| 2912: 02 02 01 02 69 73 03 06 04 0c 00 00 00 14 2a 00 ....is........*.
|
|
||||||
+| 2928: 00 00 01 01 02 24 00 02 01 01 12 02 01 12 08 88 .....$..........
|
|
||||||
+| 2944: 80 80 80 80 12 03 00 16 00 00 00 05 02 1c 88 80 ................
|
|
||||||
+| 2960: 80 80 80 11 03 00 3e 00 00 00 17 05 34 72 6f 77 ......>.....4row
|
|
||||||
+| 2976: 73 02 06 01 01 05 01 04 74 68 65 72 02 02 04 0b s.......ther....
|
|
||||||
+| 2992: 15 88 80 80 80 80 10 03 00 3e 10 00 00 11 02 01 .........>......
|
|
||||||
+| 3008: 01 07 05 34 62 65 74 77 02 02 04 08 1b 88 80 80 ...4betw........
|
|
||||||
+| 3024: 80 80 0f 03 00 3c 00 00 00 16 04 04 33 72 6f 77 .....<......3row
|
|
||||||
+| 3040: 02 06 01 01 05 01 03 74 68 65 02 08 05 0a 1b 88 .......the......
|
|
||||||
+| 3056: 80 80 80 80 0e 03 05 0c 00 00 00 16 01 01 02 04 ................
|
|
||||||
+| 3072: 33 61 72 65 02 02 03 01 03 62 65 74 02 02 07 08 3are.....bet....
|
|
||||||
+| 3088: 1b 88 80 80 80 80 0d 03 00 3c 00 00 00 16 03 32 .........<.....2
|
|
||||||
+| 3104: 74 68 02 08 02 01 01 07 00 04 33 61 6e 64 02 06 th........3and..
|
|
||||||
+| 3120: 04 01 1b 88 80 80 80 80 0c 03 00 3c 00 00 00 16 ...........<....
|
|
||||||
+| 3136: 03 32 69 6e 02 06 01 01 06 01 02 72 6f 02 06 01 .2in.......ro...
|
|
||||||
+| 3152: 01 05 04 09 18 88 80 80 80 80 0b 03 00 36 00 00 .............6..
|
|
||||||
+| 3168: 00 13 02 03 32 61 72 02 02 03 01 02 62 65 02 02 ....2ar.....be..
|
|
||||||
+| 3184: 04 05 07 1b 88 80 bf 80 80 0a 03 00 3c 00 00 00 ............<...
|
|
||||||
+| 3200: 16 02 31 74 02 08 02 01 01 07 00 03 32 61 6e 02 ..1t........2an.
|
|
||||||
+| 3216: 06 01 01 04 09 19 88 80 80 80 80 09 03 00 38 00 ..............8.
|
|
||||||
+| 3232: 00 00 14 02 31 6e 02 06 01 01 03 01 01 72 02 06 ....1n.......r..
|
|
||||||
+| 3248: 01 01 05 03 08 17 88 80 80 80 80 08 03 00 34 00 ..............4.
|
|
||||||
+| 3264: 01 00 12 02 31 62 02 02 04 01 01 69 02 06 01 01 ....1b.....i....
|
|
||||||
+| 3280: 06 04 06 19 88 80 80 80 80 07 03 00 38 00 00 00 ............8...
|
|
||||||
+| 3296: 14 04 02 31 32 02 02 05 01 01 61 02 08 03 01 01 ...12.....a.....
|
|
||||||
+| 3312: 02 05 06 1b 88 80 80 80 80 06 03 00 3c 00 00 00 ............<...
|
|
||||||
+| 3328: 16 06 30 74 68 65 72 65 02 12 02 00 02 31 31 02 ..0there.....11.
|
|
||||||
+| 3344: 06 01 01 04 0a 15 88 80 80 80 80 05 03 00 30 00 ..............0.
|
|
||||||
+| 3360: 00 00 11 01 01 05 04 30 74 68 65 02 06 71 01 07 .......0the..q..
|
|
||||||
+| 3376: 07 1c 88 80 80 80 80 04 03 00 3e 00 00 00 17 01 ..........>.....
|
|
||||||
+| 3392: 01 06 02 30 6e 02 06 01 01 03 01 04 72 6f 77 73 ...0n.......rows
|
|
||||||
+| 3408: 02 06 07 08 1b 88 80 80 80 80 03 03 00 3c 00 00 .............<..
|
|
||||||
+| 3424: 00 16 08 30 62 65 74 77 65 65 6e 02 02 04 01 02 ...0between.....
|
|
||||||
+| 3440: 69 6e 02 06 04 0c 1a 88 80 80 80 80 02 03 00 3a in.............:
|
|
||||||
+| 3456: 08 f0 00 15 04 30 61 6e 64 02 06 01 01 02 02 02 .....0and.......
|
|
||||||
+| 3472: 72 65 02 02 03 04 0a 17 88 80 80 80 80 01 03 00 re..............
|
|
||||||
+| 3488: 34 00 00 00 12 02 30 31 02 06 01 01 04 01 01 32 4.....01.......2
|
|
||||||
+| 3504: 02 02 07 04 08 08 84 80 80 80 80 12 03 00 16 00 ................
|
|
||||||
+| 3520: 00 00 05 04 1b 84 80 80 80 80 11 03 00 3c 00 00 .............<..
|
|
||||||
+| 3536: 00 16 05 34 74 61 62 6c 01 06 01 01 05 02 03 65 ...4tabl.......e
|
|
||||||
+| 3552: 72 6d 01 02 04 0b 1b 84 80 80 80 80 10 03 00 3c rm.............<
|
|
||||||
+| 3568: 00 00 00 16 05 34 65 61 63 68 01 02 03 01 04 70 .....4each.....p
|
|
||||||
+| 3584: 72 65 73 01 02 05 04 09 1a 84 80 80 80 80 0f 03 res.............
|
|
||||||
+| 3600: 00 3a 00 00 00 15 04 33 74 65 72 01 02 04 02 02 .:.....3ter.....
|
|
||||||
+| 3616: 68 65 01 06 01 01 03 04 08 1b 84 80 80 80 80 0e he..............
|
|
||||||
+| 3632: 03 00 3c 00 00 00 16 04 33 70 72 65 01 02 05 01 ..<.....3pre....
|
|
||||||
+| 3648: 03 74 61 62 01 06 01 01 05 04 08 1a 84 80 80 80 .tab............
|
|
||||||
+| 3664: 80 0d 03 00 3a 00 00 00 15 04 33 66 6f 72 01 02 ....:.....3for..
|
|
||||||
+| 3680: 02 02 02 74 73 01 06 01 01 04 03 f8 1b 84 80 80 ...ts...........
|
|
||||||
+| 3696: 80 80 0c 03 00 3c 00 00 00 16 03 32 74 68 01 06 .....<.....2th..
|
|
||||||
+| 3712: 01 01 03 00 04 33 65 61 63 01 02 03 04 09 18 84 .....3eac.......
|
|
||||||
+| 3728: 80 80 80 80 0b 03 00 36 00 00 00 13 03 32 74 61 .......6.....2ta
|
|
||||||
+| 3744: 01 06 01 01 05 02 01 65 00 02 04 04 09 19 84 80 .......e........
|
|
||||||
+| 3760: 80 80 80 0a 03 10 38 00 00 00 14 03 32 69 6e 01 ......8.....2in.
|
|
||||||
+| 3776: 06 01 01 02 01 02 70 72 01 02 05 04 09 18 84 80 ......pr........
|
|
||||||
+| 3792: 80 80 80 09 03 00 36 00 00 00 13 03 32 66 6f 01 ......6.....2fo.
|
|
||||||
+| 3808: 02 02 02 01 74 01 06 01 01 04 04 07 1b 84 80 80 ....t...........
|
|
||||||
+| 3824: 80 80 08 03 00 3c 00 00 00 16 02 31 74 01 0a 04 .....<.....1t...
|
|
||||||
+| 3840: 01 00 03 04 00 03 32 65 61 01 02 03 04 0a 17 84 ......2ea.......
|
|
||||||
+| 3856: 80 80 80 80 07 03 00 34 00 00 00 12 02 31 69 01 .......4.....1i.
|
|
||||||
+| 3872: 06 01 01 02 de 01 70 01 02 05 04 08 18 84 80 80 ......p.........
|
|
||||||
+| 3888: 80 80 06 03 00 36 00 00 00 13 02 31 65 01 02 03 .....6.....1e...
|
|
||||||
+| 3904: 01 01 66 01 08 02 01 01 04 04 06 1b 84 80 80 80 ..f.............
|
|
||||||
+| 3920: 80 05 03 00 3c 00 00 00 16 05 30 74 65 72 6d 01 ....<.....0term.
|
|
||||||
+| 3936: 02 04 02 02 68 65 01 06 01 01 03 04 09 14 84 80 ....he..........
|
|
||||||
+| 3952: 80 80 80 04 03 00 2e 00 00 00 10 06 30 74 61 62 ............0tab
|
|
||||||
+| 3968: 6c 65 01 06 01 01 05 04 15 84 80 80 80 80 03 03 le..............
|
|
||||||
+| 3984: 00 30 00 00 00 11 02 08 30 70 72 65 73 65 6e 74 .0......0present
|
|
||||||
+| 4000: 01 02 05 05 1b 84 80 80 80 80 02 03 00 3c 00 00 .............<..
|
|
||||||
+| 4016: 00 16 04 30 66 74 73 01 06 01 01 04 01 02 69 6e ...0fts.......in
|
|
||||||
+| 4032: 01 06 01 01 04 0a 1a 84 80 80 80 80 01 03 00 3a ...............:
|
|
||||||
+| 4048: 00 00 00 15 05 30 65 61 63 68 00 f2 03 01 03 66 .....0each.....f
|
|
||||||
+| 4064: 6f 72 01 02 02 04 09 06 01 03 00 12 03 0b 0f 00 or..............
|
|
||||||
+| 4080: 00 08 8c 80 80 80 80 11 03 00 16 00 00 00 05 04 ................
|
|
||||||
+| page 3 offset 8192
|
|
||||||
+| 0: 0a 00 00 00 32 0e 4f 00 0f fa 0f f1 0f e9 0f e1 ....2.O.........
|
|
||||||
+| 16: 0f d8 0f d1 0f c9 0f c1 0f b9 0f c1 0f a9 0f a0 ................
|
|
||||||
+| 32: 0f 98 0f 90 0f 87 0f 80 0f 78 0f 71 0f 68 0f 5f .........x.q.h._
|
|
||||||
+| 48: 0f 56 0f 4d 0f 41 0f 38 0f 2f 0f 26 0f 1d 0f 13 .V.M.A.8./.&....
|
|
||||||
+| 64: 0f 0a 0f 01 0e f7 0e ee 0e e6 0e dd 0e d7 0e cd ................
|
|
||||||
+| 80: 0e c3 0e ba 0e b0 0e a8 0e 9f 0e 96 0e 8e 0e 85 ................
|
|
||||||
+| 3648: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 08 ................
|
|
||||||
+| 3664: 04 01 10 01 03 34 74 20 07 04 01 0e 01 03 34 1e .....4t ......4.
|
|
||||||
+| 3680: 09 04 01 12 34 03 33 74 68 1c 08 04 01 10 01 03 ....4.3th.......
|
|
||||||
+| 3696: 33 6e 1a 08 04 01 10 01 03 32 77 18 08 04 01 10 3n.......2w.....
|
|
||||||
+| 3712: 01 03 32 74 16 08 04 01 10 01 03 32 6e 14 07 04 ..2t.......2n...
|
|
||||||
+| 3728: 01 0e 01 03 32 12 08 04 01 0f f1 03 31 74 10 08 ....2.......1t..
|
|
||||||
+| 3744: 04 01 10 01 03 31 6e 0e 07 04 01 0e 01 03 30 fc .....1n.......0.
|
|
||||||
+| 3760: 09 04 01 12 01 03 30 74 68 0a 08 04 01 10 01 03 ......0th.......
|
|
||||||
+| 3776: 30 74 08 09 04 01 12 01 03 30 6e 75 06 08 04 01 0t.......0nu....
|
|
||||||
+| 3792: 10 01 03 30 6e 04 06 04 01 0c 01 05 52 08 04 01 ...0n.......R...
|
|
||||||
+| 3808: 10 01 02 34 72 22 07 04 01 0e 01 02 34 20 08 04 ...4r.......4 ..
|
|
||||||
+| 3824: 01 10 01 02 33 72 1e 09 04 01 12 01 02 33 61 72 ....3r.......3ar
|
|
||||||
+| 3840: 1c 08 04 01 10 01 02 32 74 1a 08 04 01 10 b3 02 .......2t.......
|
|
||||||
+| 3856: 32 69 18 09 04 01 12 01 02 32 61 72 16 08 04 01 2i.......2ar....
|
|
||||||
+| 3872: 10 01 02 31 74 14 08 04 01 10 01 02 31 6e 12 08 ...1t.......1n..
|
|
||||||
+| 3888: 04 01 10 01 02 31 62 10 08 04 01 10 01 02 31 32 .....1b.......12
|
|
||||||
+| 3904: 0e 0b 04 01 16 01 02 30 74 68 65 72 0c 08 04 01 .......0ther....
|
|
||||||
+| 3920: 10 01 02 30 74 0a 08 04 01 10 01 02 30 6e 08 08 ...0t.......0n..
|
|
||||||
+| 3936: 04 01 10 01 02 30 62 06 09 04 01 10 01 02 30 61 .....0b.......0a
|
|
||||||
+| 3952: 04 06 04 01 0c 01 02 02 07 04 09 10 01 34 74 22 .............4t.
|
|
||||||
+| 3968: 06 04 09 0e 01 34 20 08 04 09 12 01 33 74 65 1e .....4 .....3te.
|
|
||||||
+| 3984: 07 04 09 10 01 33 70 1c 07 f4 09 11 01 33 66 1a .....3p......3f.
|
|
||||||
+| 4000: 08 04 09 12 01 32 74 68 18 07 04 09 10 01 32 e4 .....2th......2.
|
|
||||||
+| 4016: 16 07 04 09 10 01 32 69 14 07 04 09 10 01 32 66 ......2i......2f
|
|
||||||
+| 4032: 12 07 04 09 10 01 31 74 10 07 04 09 10 01 31 69 ......1t......1i
|
|
||||||
+| 4048: 0e 06 04 09 0e 01 31 0c 08 04 09 12 01 30 74 65 ......1......0te
|
|
||||||
+| 4064: 0a 07 04 09 10 01 30 74 08 00 00 00 00 00 00 00 ......0t........
|
|
||||||
+| page 4 offset 12288
|
|
||||||
+| 4064: 00 00 00 00 00 00 00 00 00 00 00 05 03 03 00 10 ................
|
|
||||||
+| 4080: 03 05 05 02 03 00 10 04 06 05 01 03 00 10 04 04 ................
|
|
||||||
+| page 5 offset 16384
|
|
||||||
+| 0: 0a 00 00 00 02 0f eb 00 0f eb 0f f4 00 00 00 00 ................
|
|
||||||
+| 4064: 00 00 00 00 00 00 00 00 00 00 00 08 03 15 01 70 ...............p
|
|
||||||
+| 4080: 67 73 7a 18 0b 03 1b 01 76 65 72 73 69 6f 6e 04 gsz.....version.
|
|
||||||
+| page 6 offset 20480
|
|
||||||
+| 4080: 00 00 23 03 02 01 03 03 02 00 00 00 00 00 00 00 ..#.............
|
|
||||||
+| end crash-5a5acd0ab42d31.db
|
|
||||||
+}]} {}
|
|
||||||
+
|
|
||||||
+do_execsql_test 58.1 {
|
|
||||||
+ SELECT * FROM t1('t*');
|
|
||||||
+} {{} {} {} {} {} {}}
|
|
||||||
|
|
||||||
sqlite3_fts5_may_be_corrupt 0
|
|
||||||
finish_test
|
|
||||||
--- /src/btree.c
|
|
||||||
+++ /src/btree.c
|
|
||||||
@@ -4284,10 +4284,9 @@
|
|
||||||
rc = newDatabase(pBt);
|
|
||||||
pBt->nPage = get4byte(28 + pBt->pPage1->aData);
|
|
||||||
|
|
||||||
- /* The database size was written into the offset 28 of the header
|
|
||||||
- ** when the transaction started, so we know that the value at offset
|
|
||||||
- ** 28 is nonzero. */
|
|
||||||
- assert( pBt->nPage>0 );
|
|
||||||
+ /* pBt->nPage might be zero if the database was corrupt when
|
|
||||||
+ ** the transaction was started. Otherwise, it must be at least 1. */
|
|
||||||
+ assert( CORRUPT_DB || pBt->nPage>0 );
|
|
||||||
}
|
|
||||||
sqlite3BtreeLeave(p);
|
|
||||||
}
|
|
||||||
@@ -7637,6 +7636,7 @@
|
|
||||||
u16 maskPage = pOld->maskPage;
|
|
||||||
u8 *piCell = aData + pOld->cellOffset;
|
|
||||||
u8 *piEnd;
|
|
||||||
+ VVA_ONLY( int nCellAtStart = b.nCell; )
|
|
||||||
|
|
||||||
/* Verify that all sibling pages are of the same "type" (table-leaf,
|
|
||||||
** table-interior, index-leaf, or index-interior).
|
|
||||||
@@ -7665,6 +7665,10 @@
|
|
||||||
*/
|
|
||||||
memset(&b.szCell[b.nCell], 0, sizeof(b.szCell[0])*(limit+pOld->nOverflow));
|
|
||||||
if( pOld->nOverflow>0 ){
|
|
||||||
+ if( limit<pOld->aiOvfl[0] ){
|
|
||||||
+ rc = SQLITE_CORRUPT_BKPT;
|
|
||||||
+ goto balance_cleanup;
|
|
||||||
+ }
|
|
||||||
limit = pOld->aiOvfl[0];
|
|
||||||
for(j=0; j<limit; j++){
|
|
||||||
b.apCell[b.nCell] = aData + (maskPage & get2byteAligned(piCell));
|
|
||||||
@@ -7684,6 +7688,7 @@
|
|
||||||
piCell += 2;
|
|
||||||
b.nCell++;
|
|
||||||
}
|
|
||||||
+ assert( (b.nCell-nCellAtStart)==(pOld->nCell+pOld->nOverflow) );
|
|
||||||
|
|
||||||
cntOld[i] = b.nCell;
|
|
||||||
if( i<nOld-1 && !leafData){
|
|
||||||
--- /src/resolve.c
|
|
||||||
+++ /src/resolve.c
|
|
||||||
@@ -866,7 +866,9 @@
|
|
||||||
#ifndef SQLITE_OMIT_WINDOWFUNC
|
|
||||||
if( pExpr->y.pWin ){
|
|
||||||
Select *pSel = pNC->pWinSelect;
|
|
||||||
- sqlite3WindowUpdate(pParse, pSel->pWinDefn, pExpr->y.pWin, pDef);
|
|
||||||
+ if( IN_RENAME_OBJECT==0 ){
|
|
||||||
+ sqlite3WindowUpdate(pParse, pSel->pWinDefn, pExpr->y.pWin, pDef);
|
|
||||||
+ }
|
|
||||||
sqlite3WalkExprList(pWalker, pExpr->y.pWin->pPartition);
|
|
||||||
sqlite3WalkExprList(pWalker, pExpr->y.pWin->pOrderBy);
|
|
||||||
sqlite3WalkExpr(pWalker, pExpr->y.pWin->pFilter);
|
|
||||||
--- /src/vdbe.c
|
|
||||||
+++ /src/vdbe.c
|
|
||||||
@@ -264,7 +264,7 @@
|
|
||||||
** is clear. Otherwise, if this is an ephemeral cursor created by
|
|
||||||
** OP_OpenDup, the cursor will not be closed and will still be part
|
|
||||||
** of a BtShared.pCursor list. */
|
|
||||||
- p->apCsr[iCur]->isEphemeral = 0;
|
|
||||||
+ if( p->apCsr[iCur]->pBtx==0 ) p->apCsr[iCur]->isEphemeral = 0;
|
|
||||||
sqlite3VdbeFreeCursor(p, p->apCsr[iCur]);
|
|
||||||
p->apCsr[iCur] = 0;
|
|
||||||
}
|
|
||||||
@@ -3686,7 +3686,10 @@
|
|
||||||
if( pCx ){
|
|
||||||
/* If the ephermeral table is already open, erase all existing content
|
|
||||||
** so that the table is empty again, rather than creating a new table. */
|
|
||||||
- rc = sqlite3BtreeClearTable(pCx->pBtx, pCx->pgnoRoot, 0);
|
|
||||||
+ assert( pCx->isEphemeral );
|
|
||||||
+ if( pCx->pBtx ){
|
|
||||||
+ rc = sqlite3BtreeClearTable(pCx->pBtx, pCx->pgnoRoot, 0);
|
|
||||||
+ }
|
|
||||||
}else{
|
|
||||||
pCx = allocateCursor(p, pOp->p1, pOp->p2, -1, CURTYPE_BTREE);
|
|
||||||
if( pCx==0 ) goto no_mem;
|
|
||||||
--- /test/altertab3.test
|
|
||||||
+++ /test/altertab3.test
|
|
||||||
@@ -142,6 +142,39 @@
|
|
||||||
ALTER TABLE Table0 RENAME Col0 TO Col0;
|
|
||||||
}
|
|
||||||
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+reset_db
|
|
||||||
+do_execsql_test 7.1.0 {
|
|
||||||
+ CREATE TABLE t1(a,b,c);
|
|
||||||
+ CREATE TRIGGER AFTER INSERT ON t1 BEGIN
|
|
||||||
+ SELECT a, rank() OVER w1 FROM t1
|
|
||||||
+ WINDOW w1 AS (PARTITION BY b, percent_rank() OVER w1);
|
|
||||||
+ END;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+do_execsql_test 7.1.2 {
|
|
||||||
+ ALTER TABLE t1 RENAME TO t1x;
|
|
||||||
+ SELECT sql FROM sqlite_master;
|
|
||||||
+} {
|
|
||||||
+ {CREATE TABLE "t1x"(a,b,c)}
|
|
||||||
+ {CREATE TRIGGER AFTER INSERT ON "t1x" BEGIN
|
|
||||||
+ SELECT a, rank() OVER w1 FROM "t1x"
|
|
||||||
+ WINDOW w1 AS (PARTITION BY b, percent_rank() OVER w1);
|
|
||||||
+ END}
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+do_execsql_test 7.2.1 {
|
|
||||||
+ DROP TRIGGER after;
|
|
||||||
+ CREATE TRIGGER AFTER INSERT ON t1x BEGIN
|
|
||||||
+ SELECT a, rank() OVER w1 FROM t1x
|
|
||||||
+ WINDOW w1 AS (PARTITION BY b, percent_rank() OVER w1 ORDER BY d);
|
|
||||||
+ END;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 7.2.2 {
|
|
||||||
+ ALTER TABLE t1x RENAME TO t1;
|
|
||||||
+} {1 {error in trigger AFTER: no such column: d}}
|
|
||||||
+
|
|
||||||
finish_test
|
|
||||||
|
|
||||||
|
|
||||||
--- /test/corruptL.test
|
|
||||||
+++ /test/corruptL.test
|
|
||||||
@@ -838,4 +838,32 @@
|
|
||||||
INSERT INTO t3 SELECT * FROM t2;
|
|
||||||
} {1 {database disk image is malformed}}
|
|
||||||
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+reset_db
|
|
||||||
+do_test 9.0 {
|
|
||||||
+ sqlite3 db {}
|
|
||||||
+ db deserialize [decode_hexdb {
|
|
||||||
+| size 8192 pagesize 4096 filename crash-ab10597e4e1c32.db
|
|
||||||
+| page 1 offset 0
|
|
||||||
+| 0: 53 51 4c 69 74 65 20 66 6f 72 6d 61 74 20 33 00 SQLite format 3.
|
|
||||||
+| 16: 10 00 01 01 00 40 20 20 00 00 00 00 00 00 00 00 .....@ ........
|
|
||||||
+| 96: 00 00 00 00 0d 00 00 00 01 0f d6 00 0f d6 00 00 ................
|
|
||||||
+| 4048: 00 00 00 00 00 00 28 01 06 17 11 11 01 3d 74 61 ......(......=ta
|
|
||||||
+| 4064: 62 6c 65 74 31 74 31 02 43 52 45 41 54 45 20 54 blet1t1.CREATE T
|
|
||||||
+| 4080: 41 42 4c 45 20 74 31 28 61 2c 62 2c 63 2c 64 29 ABLE t1(a,b,c,d)
|
|
||||||
+| page 2 offset 4096
|
|
||||||
+| 0: 0d 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
|
|
||||||
+| end crash-ab10597e4e1c32.db
|
|
||||||
+}]} {}
|
|
||||||
+
|
|
||||||
+do_execsql_test 9.1 {
|
|
||||||
+ SAVEPOINT one;
|
|
||||||
+}
|
|
||||||
+do_catchsql_test 9.3 {
|
|
||||||
+ INSERT INTO t1(b,c) VALUES(5,6);
|
|
||||||
+} {1 {database disk image is malformed}}
|
|
||||||
+do_execsql_test 9.3 {
|
|
||||||
+ ROLLBACK TO one;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
finish_test
|
|
||||||
--- /test/fts3corrupt4.test
|
|
||||||
+++ /test/fts3corrupt4.test
|
|
||||||
@@ -3915,5 +3915,491 @@
|
|
||||||
SELECT 'FyzLy'FROM t1 WHERE t1 MATCH 'j';
|
|
||||||
} {1 {database disk image is malformed}}
|
|
||||||
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+reset_db
|
|
||||||
+do_test 24.0 {
|
|
||||||
+ sqlite3 db {}
|
|
||||||
+ db deserialize [decode_hexdb {
|
|
||||||
+.open --hexdb
|
|
||||||
+| size 28672 pagesize 4096 filename crash-369d042958c29b.db
|
|
||||||
+| page 1 offset 0
|
|
||||||
+| 0: 53 51 4c 69 74 65 20 66 6f 72 6d 61 74 20 33 00 SQLite format 3.
|
|
||||||
+| 16: 10 00 01 01 00 40 20 20 00 00 03 10 00 00 00 00 .....@ ........
|
|
||||||
+| 96: 00 00 00 00 0d 0e b1 00 06 0d a4 00 0f 8d 0f 21 ...............!
|
|
||||||
+| 112: 0e b9 0d c8 0e 7e 0d a4 00 00 00 00 00 00 00 00 .....~..........
|
|
||||||
+| 3488: 00 00 00 00 22 07 06 17 11 11 01 31 74 61 62 6c ...........1tabl
|
|
||||||
+| 3504: 65 74 32 74 32 07 43 52 45 41 54 45 20 54 41 42 et2t2.CREATE TAB
|
|
||||||
+| 3520: 4c 45 20 74 32 28 78 29 81 33 05 07 17 1f 1f 01 LE t2(x).3......
|
|
||||||
+| 3536: 82 35 74 61 62 6c 65 74 31 5f 73 65 67 64 69 72 .5tablet1_segdir
|
|
||||||
+| 3552: 74 31 5f 73 65 67 64 69 72 05 43 52 45 41 54 45 t1_segdir.CREATE
|
|
||||||
+| 3568: 20 54 41 42 4c 45 20 27 74 31 5f 73 65 67 64 69 TABLE 't1_segdi
|
|
||||||
+| 3584: 72 27 28 6c 65 76 65 6c 20 49 4e 54 45 47 45 52 r'(level INTEGER
|
|
||||||
+| 3600: 2c 69 64 78 20 49 4e 54 45 47 45 52 2c 73 74 61 ,idx INTEGER,sta
|
|
||||||
+| 3616: 72 74 5f 62 6c 6f 63 6b 20 49 4e 54 45 47 45 52 rt_block INTEGER
|
|
||||||
+| 3632: 2c 6c 65 61 76 65 73 5f 65 6e 64 5f 62 6c 6f 63 ,leaves_end_bloc
|
|
||||||
+| 3648: 6b 20 49 4e 54 45 47 45 52 2c 65 6e 64 5f 62 6c k INTEGER,end_bl
|
|
||||||
+| 3664: 6f 63 6b 20 49 4e 54 45 47 45 52 2c 72 6f 6f 74 ock INTEGER,root
|
|
||||||
+| 3680: 20 42 4c 4f 42 2c 50 52 49 4d 41 52 59 20 4b 45 BLOB,PRIMARY KE
|
|
||||||
+| 3696: 59 28 6c 65 76 65 6c 2c 20 69 64 78 29 29 31 06 Y(level, idx))1.
|
|
||||||
+| 3712: 06 17 45 1f 01 00 69 6e 64 65 78 73 71 6c 69 74 ..E...indexsqlit
|
|
||||||
+| 3728: 65 5f 61 75 74 6f 69 6e 64 65 78 5f 74 31 5f 73 e_autoindex_t1_s
|
|
||||||
+| 3744: 65 67 64 69 72 5f 31 74 31 5f 73 65 67 64 69 72 egdir_1t1_segdir
|
|
||||||
+| 3760: 06 0f c7 00 08 00 10 00 00 66 04 07 17 23 23 01 .........f...##.
|
|
||||||
+| 3776: 81 13 74 61 62 6c 65 74 31 5f 73 65 67 6d 65 6e ..tablet1_segmen
|
|
||||||
+| 3792: 64 73 74 31 5f 73 65 67 6d 65 6e 74 73 04 43 52 dst1_segments.CR
|
|
||||||
+| 3808: 45 41 54 45 20 54 41 42 4c 45 20 27 74 31 5f 73 EATE TABLE 't1_s
|
|
||||||
+| 3824: 65 67 6d 65 6e 74 73 27 28 62 6c 6f 63 6b 69 64 egments'(blockid
|
|
||||||
+| 3840: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 INTEGER PRIMARY
|
|
||||||
+| 3856: 20 4b 45 59 2c 20 62 6c 6f 63 6b 20 42 4c 4f 42 KEY, block BLOB
|
|
||||||
+| 3872: 29 6a 03 07 17 21 21 01 81 1f 74 61 62 6c 65 74 )j...!!...tablet
|
|
||||||
+| 3888: 31 4f 63 6f 6e 74 65 6e 74 74 31 5f 63 6f 6e 74 1Ocontentt1_cont
|
|
||||||
+| 3904: 65 6e 74 03 43 52 45 41 54 45 20 54 41 42 4c 45 ent.CREATE TABLE
|
|
||||||
+| 3920: 20 27 74 31 5f 63 6f 6e 74 65 6e 74 27 28 64 6f 't1_content'(do
|
|
||||||
+| 3936: 63 69 64 20 49 4e 54 45 47 45 52 20 50 52 39 4d cid INTEGER PR9M
|
|
||||||
+| 3952: 41 52 59 20 4b 45 59 2c 20 27 63 30 61 27 2c 20 ARY KEY, 'c0a',
|
|
||||||
+| 3968: 27 63 31 62 27 2c 20 27 63 32 63 27 29 38 02 06 'c1b', 'c2c')8..
|
|
||||||
+| 3984: 17 11 11 08 5f 74 61 62 6c 65 74 31 74 31 43 52 ...._tablet1t1CR
|
|
||||||
+| 4000: 45 41 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 EATE VIRTUAL TAB
|
|
||||||
+| 4016: 4c 45 20 74 31 20 55 53 49 4e 47 20 66 74 73 33 LE t1 USING fts3
|
|
||||||
+| 4032: 28 61 2c 62 2c 63 29 00 00 00 00 00 00 00 00 00 (a,b,c).........
|
|
||||||
+| page 3 offset 8192
|
|
||||||
+| 0: 0d 00 00 00 26 0b 48 0e 0f d8 0f af 0f 86 0f 74 ....&.H........t
|
|
||||||
+| 16: 0f 61 0f 4e 0f 2f 0f 0f 0e ef 0e d7 0e be 0e a5 .a.N./..........
|
|
||||||
+| 32: 0e 8d 0e 74 0e 5b 0e 40 0e 24 0e 08 0d ef 0d d5 ...t.[.@.$......
|
|
||||||
+| 48: 0d bb 0d a0 0e 94 03 28 0d 4f 0d 35 0d 1b 05 0b .......(.O.5....
|
|
||||||
+| 64: 0c da 0c b9 0c 99 0c 78 0c 57 0c 3e 0c 24 0c 0a .......x.W.>.$..
|
|
||||||
+| 2880: 00 00 00 00 00 00 00 00 81 3f 25 06 00 72 7f 00 .........?%..r..
|
|
||||||
+| 2896: 00 43 4f 4d 50 49 4c 45 52 3d 67 63 63 2d 35 2e .COMPILER=gcc-5.
|
|
||||||
+| 2912: 34 2e 30 20 32 30 31 36 30 36 30 39 20 44 55 42 4.0 20160609 DUB
|
|
||||||
+| 2928: 55 47 20 45 4e 41 e4 7c 45 20 44 42 53 54 41 54 UG ENA.|E DBSTAT
|
|
||||||
+| 2944: e4 d1 54 41 42 20 45 4e 41 42 4c 45 20 46 54 53 ..TAB ENABLE FTS
|
|
||||||
+| 2960: 34 20 45 4e 41 42 4c 45 20 46 54 53 35 20 45 4e 4 ENABLE FTS5 EN
|
|
||||||
+| 2976: 41 42 4c 45 20 47 45 4f 50 4f 4c 59 20 45 4e 41 ABLE GEOPOLY ENA
|
|
||||||
+| 2992: 42 4c 45 20 4a 53 4f 4e 31 20 45 4e 41 42 4c 45 BLE JSON1 ENABLE
|
|
||||||
+| 3008: 20 4d 45 4d 53 59 53 35 20 45 4e 41 42 4c 45 20 MEMSYS5 ENABLE
|
|
||||||
+| 3024: 42 54 52 45 45 20 4d 41 58 20 4d 45 4d 4f 52 59 BTREE MAX MEMORY
|
|
||||||
+| 3040: 3d 35 30 30 30 30 30 30 30 20 4f 4c 49 54 20 4c =50000000 OLIT L
|
|
||||||
+| 3056: 4f 41 43 20 45 58 54 45 4e 53 49 4f 4e 21 54 48 OAC EXTENSION!TH
|
|
||||||
+| 3072: 52 45 41 44 53 41 46 45 3d 30 18 24 05 00 25 0f READSAFE=0.$..%.
|
|
||||||
+| 3088: 19 54 48 52 45 41 44 53 41 46 45 3d 30 58 42 49 .THREADSAFE=0XBI
|
|
||||||
+| 3104: 4e 41 52 59 18 23 05 00 25 0f 19 54 48 52 45 41 NARY.#..%..THREA
|
|
||||||
+| 3120: 44 53 41 4b 75 3d 30 58 4d 4f 43 41 53 45 17 22 DSAKu=0XMOCASE..
|
|
||||||
+| 3136: 05 00 25 0f 17 54 48 52 45 41 44 53 41 46 46 3d ..%..THREADSAFF=
|
|
||||||
+| 3152: 30 58 52 54 52 49 4d 1f 21 05 00 33 0f 19 4f 4d 0XRTRIM.!..3..OM
|
|
||||||
+| 3168: 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 52 49 4f IT LOAD EXTENRIO
|
|
||||||
+| 3184: 4e 58 42 49 4e 41 52 59 1f 20 05 00 33 0f 19 4f NXBINARY. ..3..O
|
|
||||||
+| 3200: 4d 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 53 49 MIT LOAD EXTENSI
|
|
||||||
+| 3216: 4f 4e 58 4e 4f 43 41 53 45 1e 1f 05 00 33 0f 17 ONXNOCASE....3..
|
|
||||||
+| 3232: 4f 4d 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 53 OMIT LOAD EXTENS
|
|
||||||
+| 3248: 49 4f 4e 58 52 54 52 49 4d 1f 1e 05 00 33 0f 19 IONXRTRIM....3..
|
|
||||||
+| 3264: 4d 41 58 20 4d 45 4d 4f 52 59 3d 35 30 30 30 30 MAX MEMORY=50000
|
|
||||||
+| 3280: 30 30 30 58 42 49 4e 41 52 59 1f 1d 05 00 33 0f 000XBINARY....3.
|
|
||||||
+| 3296: 19 4d 41 58 20 4d 45 4d 4f 52 59 3d 35 30 30 30 .MAX MEMORY=5000
|
|
||||||
+| 3312: 30 30 30 30 58 4e 4f 43 41 53 45 1e 1c 05 00 33 0000XNOCASE....3
|
|
||||||
+| 3328: 0f 17 4d 42 b8 20 4d 45 4d 4f 52 59 3d 35 30 30 ..MB. MEMORY=500
|
|
||||||
+| 3344: 30 30 30 30 30 58 52 54 52 49 4d 18 1b 05 00 25 00000XRTRIM....%
|
|
||||||
+| 3360: 0f 19 45 4e 41 42 4c 45 20 52 54 52 45 45 58 42 ..ENABLE RTREEXB
|
|
||||||
+| 3376: 49 4e 41 52 59 18 1a 05 0d a5 0f 19 45 4e 41 42 INARY.......ENAB
|
|
||||||
+| 3392: 4c 45 20 52 54 52 45 45 58 4e 4f 43 41 53 45 17 LE RTREEXNOCASE.
|
|
||||||
+| 3408: 19 1c 00 25 0f 17 45 4e 41 42 4c 45 20 52 54 52 ...%..ENABLE RTR
|
|
||||||
+| 3424: 45 45 58 52 54 52 49 4d 1a 18 05 00 29 0f 19 45 EEXRTRIM....)..E
|
|
||||||
+| 3440: 4e 41 42 4c 45 20 4d 45 4d 53 59 53 35 58 42 49 NABLE MEMSYS5XBI
|
|
||||||
+| 3456: 4e 41 52 59 1a 17 05 00 29 0f 19 45 4e 41 42 4c NARY....)..ENABL
|
|
||||||
+| 3472: 45 20 4d 45 4d 53 59 53 35 58 4e 4f 43 41 53 45 E MEMSYS5XNOCASE
|
|
||||||
+| 3488: 19 16 05 00 29 0f 17 45 4e 41 42 4c 45 20 4d 45 ....)..ENABLE ME
|
|
||||||
+| 3504: 4d 53 59 53 35 58 52 54 52 49 4d 18 14 05 01 25 MSYS5XRTRIM....%
|
|
||||||
+| 3520: 0f 19 45 4e 12 42 4c 45 20 4a 53 4f 4e 31 58 42 ..EN.BLE JSON1XB
|
|
||||||
+| 3536: 49 4e 41 52 59 18 14 05 00 25 09 d9 45 4e 41 42 INARY....%..ENAB
|
|
||||||
+| 3552: 4c 45 20 4a 53 4f 3e 31 58 4e 4f 43 41 53 45 17 LE JSO>1XNOCASE.
|
|
||||||
+| 3568: 13 05 00 25 0f 17 45 4e 40 42 4c 45 20 4a 53 4f ...%..EN@BLE JSO
|
|
||||||
+| 3584: 4e 31 58 52 54 52 49 4d 1a 12 05 82 29 0f 19 45 N1XRTRIM....)..E
|
|
||||||
+| 3600: 4e 41 42 4c 45 20 47 45 4f 50 4f 4c 59 58 42 49 NABLE GEOPOLYXBI
|
|
||||||
+| 3616: 4e 41 52 59 1a 11 05 c9 29 e8 19 46 4e 41 42 4c NARY....)..FNABL
|
|
||||||
+| 3632: 48 c0 47 45 4f 50 4f 4c 59 58 4e 74 43 41 53 45 H.GEOPOLYXNtCASE
|
|
||||||
+| 3648: 19 10 05 00 29 0f 17 45 4e 41 42 4c 45 20 47 45 ....)..ENABLE GE
|
|
||||||
+| 3664: 4f 50 4f 4c 59 58 52 54 52 49 4d 17 0f 05 00 23 OPOLYXRTRIM....#
|
|
||||||
+| 3680: 0f 19 45 4e 41 42 4c 45 30 46 54 53 35 58 42 49 ..ENABLE0FTS5XBI
|
|
||||||
+| 3696: 4e 41 52 59 17 0e 05 00 23 0f 19 45 4e 41 42 4c NARY....#..ENABL
|
|
||||||
+| 3712: 45 20 46 54 53 35 58 4e 4f 43 41 53 45 16 0e 05 E FTS5XNOCASE...
|
|
||||||
+| 3728: 00 23 0f 17 45 4e 41 42 4c 45 20 46 54 53 35 58 .#..ENABLE FTS5X
|
|
||||||
+| 3744: 52 54 52 49 4d 17 0c 05 00 23 0f 19 45 4e 41 42 RTRIM....#..ENAB
|
|
||||||
+| 3760: 4c 45 20 46 54 53 34 58 42 49 4e 41 52 59 17 0b LE FTS4XBINARY..
|
|
||||||
+| 3776: 05 00 23 0f 19 45 4e 41 42 4c 45 20 46 54 53 34 ..#..ENABLE FTS4
|
|
||||||
+| 3792: 58 4e 4f 43 41 53 45 16 0a 05 00 23 0f 17 45 4e XNOCASE....#..EN
|
|
||||||
+| 3808: 41 42 4c 45 20 46 54 53 34 58 52 54 52 49 4d 1e ABLE FTS4XRTRIM.
|
|
||||||
+| 3824: 09 05 00 31 0f 19 45 4e 42 42 4c 45 20 44 42 53 ...1..ENBBLE DBS
|
|
||||||
+| 3840: 54 41 54 20 56 54 41 42 58 42 49 4e 41 52 59 1e TAT VTABXBINARY.
|
|
||||||
+| 3856: 08 05 00 31 0f 19 45 4e 41 42 4c 45 20 44 42 53 ...1..ENABLE DBS
|
|
||||||
+| 3872: 54 41 54 20 56 54 41 42 58 4e 4f 43 41 53 45 1d TAT VTABXNOCASE.
|
|
||||||
+| 3888: 07 05 00 31 0f 17 45 4e 41 42 4c 45 20 44 42 53 ...1..ENABLE DBS
|
|
||||||
+| 3904: 54 41 54 20 56 54 41 42 58 52 54 52 4a 4d 11 06 TAT VTABXRTRJM..
|
|
||||||
+| 3920: 05 f0 17 0f 19 44 45 42 55 47 58 42 49 4e 41 52 .....DEBUGXBINAR
|
|
||||||
+| 3936: 59 11 05 05 00 17 0e 19 44 45 42 55 47 58 4e 4f Y.......DEBUGXNO
|
|
||||||
+| 3952: 43 41 53 45 10 04 05 00 17 0f 16 44 45 42 55 47 CASE.......DEBUG
|
|
||||||
+| 3968: 58 52 54 52 49 4d 27 03 05 00 43 0f 19 43 4f 4d XRTRIM'...C..COM
|
|
||||||
+| 3984: 50 49 4c 45 52 3d 67 63 63 2d 35 2e 34 2e 30 20 PILER=gcc-5.4.0
|
|
||||||
+| 4000: 32 30 31 36 30 36 30 39 58 42 49 4e 41 52 59 27 20160609XBINARY'
|
|
||||||
+| 4016: 02 05 00 43 0f 19 43 4f 4d 50 49 4c 45 52 3d 67 ...C..COMPILER=g
|
|
||||||
+| 4032: 63 63 2d 35 2e 34 2e 30 20 32 30 31 36 30 36 30 cc-5.4.0 2016060
|
|
||||||
+| 4048: 39 58 4e 4f 43 41 53 45 26 01 06 00 43 0f 17 43 9XNOCASE&...C..C
|
|
||||||
+| 4064: 4f 4d 50 49 4b 45 52 3d 67 63 63 2d 35 2e 34 2e OMPIKER=gcc-5.4.
|
|
||||||
+| 4080: 30 20 32 30 31 36 30 36 40 39 58 29 54 52 49 4d 0 201606@9X)TRIM
|
|
||||||
+| page 4 offset 12288
|
|
||||||
+| 0: 0d 00 10 00 00 10 00 00 00 00 00 00 00 01 00 00 ................
|
|
||||||
+| page 5 offset 16384
|
|
||||||
+| 0: 0d 00 00 00 02 0b a0 00 0c ad 0b a0 00 00 00 00 ................
|
|
||||||
+| 2976: 82 0a 02 08 08 09 08 08 17 84 06 30 20 32 35 33 ...........0 253
|
|
||||||
+| 2992: 00 01 30 04 25 06 1b 00 00 08 32 30 31 36 30 36 ..0.%.....201606
|
|
||||||
+| 3008: 30 39 03 25 07 00 00 01 34 03 25 05 00 00 01 35 09.%....4.%....5
|
|
||||||
+| 3024: 03 25 04 00 01 07 30 30 30 30 30 30 30 03 25 1a .%....0000000.%.
|
|
||||||
+| 3040: 00 00 08 63 6f 6d 70 69 6c 65 72 03 25 02 00 00 ...compiler.%...
|
|
||||||
+| 3056: 06 64 62 73 74 61 74 03 25 0a 00 01 04 65 62 75 .dbstat.%....ebu
|
|
||||||
+| 3072: 67 03 25 08 00 00 06 65 6e 61 62 6c 65 09 25 09 g.%....enable.%.
|
|
||||||
+| 3088: 05 04 04 04 04 04 00 01 08 78 74 65 6e 73 69 6f .........xtensio
|
|
||||||
+| 3104: 6e 03 25 1d 00 00 04 66 74 73 34 03 25 0d 00 03 n.%....fts4.%...
|
|
||||||
+| 3120: 01 35 03 25 0f 00 00 03 67 63 63 03 25 03 00 01 .5.%....gcc.%...
|
|
||||||
+| 3136: 06 65 6f 70 6f 6c 79 03 25 11 00 00 05 6a 73 6f .eopoly.%....jso
|
|
||||||
+| 3152: 6e 31 03 25 13 00 00 04 6c 6f 61 64 03 25 1c 00 n1.%....load.%..
|
|
||||||
+| 3168: 00 03 6d 61 78 03 25 18 00 01 05 65 6e 6f 72 79 ..max.%....enory
|
|
||||||
+| 3184: 03 25 19 00 03 04 ce 79 73 4d 03 25 15 00 00 04 .%.....ysM.%....
|
|
||||||
+| 3200: 6f 6d 69 74 03 25 1b 00 00 05 72 74 72 65 65 03 omit.%....rtree.
|
|
||||||
+| 3216: 25 17 00 00 0a 74 68 72 65 61 64 73 61 66 65 03 %....threadsafe.
|
|
||||||
+| 3232: 25 0e 00 00 04 76 74 61 62 03 25 0b 00 86 50 01 %....vtab.%...P.
|
|
||||||
+| 3248: 08 08 08 08 08 17 8d 12 30 20 38 33 35 00 01 30 ........0 835..0
|
|
||||||
+| 3264: 12 01 06 00 01 06 00 01 06 00 1f 03 00 01 03 09 ................
|
|
||||||
+| 3280: 51 03 00 00 08 32 30 31 36 30 36 30 39 09 01 07 Q....20160609...
|
|
||||||
+| 3296: 00 01 07 00 01 07 00 00 01 34 09 01 05 00 01 05 .........4......
|
|
||||||
+| 3312: 00 01 05 00 00 01 35 09 01 04 00 01 04 00 01 04 ......5.........
|
|
||||||
+| 3328: 00 01 07 30 30 30 30 30 30 30 09 1c 04 00 01 04 ...0000000......
|
|
||||||
+| 3344: 00 01 04 00 00 06 62 69 6e 61 72 79 3c 03 01 02 ......binary<...
|
|
||||||
+| 3360: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3376: 00 03 01 02 02 00 02 f1 02 02 00 03 01 02 02 00 ................
|
|
||||||
+| 3392: 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 03 ................
|
|
||||||
+| 3408: 01 02 02 00 03 01 02 02 00 00 08 63 6f 6d 70 69 ...........compi
|
|
||||||
+| 3424: 6c 65 72 09 01 02 00 01 02 00 01 02 00 00 06 67 ler............g
|
|
||||||
+| 3440: d2 73 74 61 74 09 07 03 00 01 03 00 01 03 00 01 .stat...........
|
|
||||||
+| 3456: 04 65 62 75 67 09 04 02 00 01 02 00 01 02 00 00 .ebug...........
|
|
||||||
+| 3472: 06 65 6e 6f 82 6c 65 3f 07 02 00 01 02 00 01 02 .eno.le?........
|
|
||||||
+| 3488: b0 01 02 00 01 02 00 11 02 00 01 02 00 01 02 00 ................
|
|
||||||
+| 3504: 01 02 00 01 02 00 01 02 00 01 a6 00 01 02 00 01 ................
|
|
||||||
+| 3520: 02 05 51 02 00 01 02 00 01 02 00 01 02 00 01 02 ..Q.............
|
|
||||||
+| 3536: 00 01 02 00 01 02 00 01 08 78 74 65 6e 73 69 6f .........xtensio
|
|
||||||
+| 3552: 6e 09 1f 04 00 01 04 00 00 04 00 00 04 66 74 73 n............fts
|
|
||||||
+| 3568: 34 09 0a 03 00 01 03 00 01 03 00 03 01 35 09 0d 4............5..
|
|
||||||
+| 3584: 03 00 01 03 00 01 03 00 00 03 67 63 63 09 01 03 ..........gcc...
|
|
||||||
+| 3600: 00 01 03 00 01 03 00 01 06 65 6f 70 73 6c 79 09 .........eopsly.
|
|
||||||
+| 3616: 10 03 00 01 03 00 01 03 00 00 05 6a 73 6f 6e 31 ...........json1
|
|
||||||
+| 3632: 09 13 03 00 01 03 00 01 03 00 00 04 6c 6f 61 64 ............load
|
|
||||||
+| 3648: 09 1f 03 00 01 03 00 01 03 00 00 03 6d 61 78 09 ............max.
|
|
||||||
+| 3664: 1c 02 00 01 02 00 01 02 00 01 05 65 6d 6f 72 79 ...........emory
|
|
||||||
+| 3680: 09 1c 03 00 01 03 00 01 03 00 03 04 73 79 73 35 ............sys5
|
|
||||||
+| 3696: 09 16 03 00 01 03 00 01 03 00 00 06 6e 6f 63 61 ............noca
|
|
||||||
+| 3712: 73 65 3c 02 01 02 02 00 03 01 12 02 00 03 01 02 se<.............
|
|
||||||
+| 3728: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3744: 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 ................
|
|
||||||
+| 3760: 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 00 ................
|
|
||||||
+| 3776: 04 6f 6d 69 74 09 1f 02 00 01 02 00 01 02 00 00 .omit...........
|
|
||||||
+| 3792: 05 72 74 72 65 65 09 19 03 00 01 03 00 01 03 00 .rtree..........
|
|
||||||
+| 3808: 03 02 69 6d 3c 01 01 02 02 00 03 01 02 02 00 03 ..im<...........
|
|
||||||
+| 3824: 01 02 02 00 03 01 02 02 00 03 01 02 02 00 03 01 ................
|
|
||||||
+| 3840: 02 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 ................
|
|
||||||
+| 3856: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3872: 00 00 0a 74 68 72 65 61 64 73 61 66 65 09 22 02 ...threadsafe...
|
|
||||||
+| 3888: 00 01 02 00 01 02 00 00 04 76 74 61 62 09 07 04 .........vtab...
|
|
||||||
+| 3904: 00 01 04 00 01 03 ff ff 01 78 b4 01 01 01 01 02 .........x......
|
|
||||||
+| 3920: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| 3936: 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 01 ................
|
|
||||||
+| 3952: 01 01 02 00 01 01 01 07 30 01 01 01 02 00 01 01 ........0.......
|
|
||||||
+| 3968: 01 02 00 11 01 01 02 00 01 01 01 02 00 11 01 01 ................
|
|
||||||
+| 3984: 02 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 ................
|
|
||||||
+| 4000: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| 4016: 01 01 01 01 ff 01 01 01 02 00 01 01 01 02 00 01 ................
|
|
||||||
+| 4032: 01 01 02 00 01 01 01 02 00 01 01 01 02 00 01 01 ................
|
|
||||||
+| 4048: 01 02 00 01 01 09 c2 00 01 01 01 02 00 01 01 01 ................
|
|
||||||
+| 4064: 02 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 ................
|
|
||||||
+| 4080: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| page 6 offset 20480
|
|
||||||
+| 0: 0a 00 00 00 02 0f f5 00 0f fb 0f f5 00 00 00 00 ................
|
|
||||||
+| 4080: 00 00 00 00 00 05 04 08 09 01 02 04 04 08 08 09 ................
|
|
||||||
+| page 7 offset 24576
|
|
||||||
+| 0: 0d 00 00 00 05 0f b8 00 0e f4 0f e9 10 d6 0f c7 ................
|
|
||||||
+| 4016: 00 00 00 00 00 00 00 00 0d 05 02 23 61 75 74 6f ...........#auto
|
|
||||||
+| 4032: 6d 65 72 67 65 3d 35 0d 04 02 23 6d 65 72 67 65 merge=5...#merge
|
|
||||||
+| 4048: 3d 31 00 00 00 00 00 00 00 00 00 00 00 00 00 00 =1..............
|
|
||||||
+| end crash-369d042958c29b.db
|
|
||||||
+}]} {}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.1 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT '4hE'+x FROM c WHERE x<72)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(2829) FROM c;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.2 {
|
|
||||||
+ UPDATE t1 SET b=quote((true) ) WHERE t1 MATCH 'h';
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.3 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT 3+x FROM c WHERE x<72)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(2829) FROM c;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.4 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT null<<x FROM c WHERE x<72)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(2829) FROM c;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.5 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT 3+x FROM c WHERE x<72)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(2829) FROM c;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 24.7 {
|
|
||||||
+ INSERT INTO t1(t1) SELECT x FROM t2;
|
|
||||||
+} {1 {database disk image is malformed}}
|
|
||||||
+
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+#-------------------------------------------------------------------------
|
|
||||||
+reset_db
|
|
||||||
+do_test 25.0 {
|
|
||||||
+ sqlite3 db {}
|
|
||||||
+ db deserialize [decode_hexdb {
|
|
||||||
+.open --hexdb
|
|
||||||
+| size 28672 pagesize 4096 filename crash-dde9e76ed8ab2d.db
|
|
||||||
+| page 1 offset 0
|
|
||||||
+| 0: 53 51 4c 69 74 65 20 66 6f 72 6d 61 74 20 33 00 SQLite format 3.
|
|
||||||
+| 16: 10 00 01 01 00 40 20 20 00 00 03 10 00 00 00 00 .....@ ........
|
|
||||||
+| 96: 00 00 00 00 0d 0e b1 00 06 0d a4 00 0f 8d 0f 21 ...............!
|
|
||||||
+| 112: 0e b9 0d c8 0e 7e 0d a4 00 00 00 00 00 00 00 00 .....~..........
|
|
||||||
+| 3488: 00 00 00 00 22 07 06 17 11 11 01 31 74 61 62 6c ...........1tabl
|
|
||||||
+| 3504: 65 74 32 74 32 07 43 52 45 41 54 45 20 54 41 42 et2t2.CREATE TAB
|
|
||||||
+| 3520: 4c 45 20 74 32 28 78 29 81 33 05 07 17 1f 1f 01 LE t2(x).3......
|
|
||||||
+| 3536: 82 35 74 61 62 6c 65 74 31 5f 73 65 67 64 69 72 .5tablet1_segdir
|
|
||||||
+| 3552: 74 31 5f 73 65 67 64 69 72 05 43 52 45 41 54 45 t1_segdir.CREATE
|
|
||||||
+| 3568: 20 54 41 42 4c 45 20 27 74 31 5f 73 65 67 64 69 TABLE 't1_segdi
|
|
||||||
+| 3584: 72 27 28 6c 65 76 65 6c 20 49 4e 54 45 47 45 52 r'(level INTEGER
|
|
||||||
+| 3600: 2c 69 64 78 20 49 4e 54 45 47 45 52 2c 73 74 61 ,idx INTEGER,sta
|
|
||||||
+| 3616: 72 74 5f 62 6c 6f 63 6b 20 49 4e 54 45 47 45 52 rt_block INTEGER
|
|
||||||
+| 3632: 2c 6c 65 61 76 65 73 5f 65 6e 64 5f 62 6c 6f 63 ,leaves_end_bloc
|
|
||||||
+| 3648: 6b 20 49 4e 54 45 47 45 52 2c 65 6e 64 5f 62 6c k INTEGER,end_bl
|
|
||||||
+| 3664: 6f 63 6b 20 49 4e 54 45 47 45 52 2c 72 6f 6f 74 ock INTEGER,root
|
|
||||||
+| 3680: 20 42 4c 4f 42 2c 50 52 49 4d 41 52 59 20 4b 45 BLOB,PRIMARY KE
|
|
||||||
+| 3696: 59 28 6c 65 76 65 6c 2c 20 69 64 78 29 29 31 06 Y(level, idx))1.
|
|
||||||
+| 3712: 06 17 45 1f 01 00 69 6e 64 65 78 73 71 6c 69 74 ..E...indexsqlit
|
|
||||||
+| 3728: 65 5f 61 75 74 6f 69 6e 64 65 78 5f 74 31 5f 73 e_autoindex_t1_s
|
|
||||||
+| 3744: 65 67 64 69 72 5f 31 74 31 5f 73 65 67 64 69 72 egdir_1t1_segdir
|
|
||||||
+| 3760: 06 0f c7 00 08 00 00 00 00 66 04 07 17 23 23 01 .........f...##.
|
|
||||||
+| 3776: 81 13 74 61 62 6c 65 74 31 5f 73 65 67 6d 65 6e ..tablet1_segmen
|
|
||||||
+| 3792: 64 73 74 31 5f 73 65 67 6d 65 6e 74 73 04 43 52 dst1_segments.CR
|
|
||||||
+| 3808: 45 41 54 45 20 54 41 42 4c 45 20 27 74 31 5f 73 EATE TABLE 't1_s
|
|
||||||
+| 3824: 65 67 6d 65 6e 74 73 27 28 62 6c 6f 63 6b 69 64 egments'(blockid
|
|
||||||
+| 3840: 20 49 4e 54 45 47 45 52 20 50 52 49 4d 41 52 59 INTEGER PRIMARY
|
|
||||||
+| 3856: 20 4b 45 59 2c 20 62 6c 6f 63 6b 20 42 4c 4f 42 KEY, block BLOB
|
|
||||||
+| 3872: 29 6a 03 07 17 21 21 01 81 1f 74 61 62 6c 65 74 )j...!!...tablet
|
|
||||||
+| 3888: 31 5f 63 6f 6e 74 65 6e 74 74 31 5f 63 6f 6e 74 1_contentt1_cont
|
|
||||||
+| 3904: 65 6e 74 03 43 52 45 41 54 45 20 54 41 42 4c 45 ent.CREATE TABLE
|
|
||||||
+| 3920: 20 27 74 31 5f 63 6f 6e 74 65 6e 74 27 28 64 6f 't1_content'(do
|
|
||||||
+| 3936: 63 69 64 20 49 4e 54 45 47 45 52 20 50 52 39 4d cid INTEGER PR9M
|
|
||||||
+| 3952: 41 52 59 20 4b 45 59 2c 20 27 63 30 61 27 2c 20 ARY KEY, 'c0a',
|
|
||||||
+| 3968: 27 63 31 62 27 2c 20 27 63 32 63 27 29 38 02 06 'c1b', 'c2c')8..
|
|
||||||
+| 3984: 17 11 11 08 5f 74 61 62 6c 65 74 31 74 31 43 52 ...._tablet1t1CR
|
|
||||||
+| 4000: 45 41 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 EATE VIRTUAL TAB
|
|
||||||
+| 4016: 4c 45 20 74 31 20 55 53 49 4e 47 20 66 74 73 33 LE t1 USING fts3
|
|
||||||
+| 4032: 28 61 2c 62 2c 63 29 00 00 00 00 00 00 00 00 00 (a,b,c).........
|
|
||||||
+| page 3 offset 8192
|
|
||||||
+| 0: 0d 00 00 00 26 0b 48 0e 0f d8 0f af 0f 86 0f 74 ....&.H........t
|
|
||||||
+| 16: 0f 61 0f 4e 0f 2f 0f 0f 0e ef 0e d7 0e be 0e a5 .a.N./..........
|
|
||||||
+| 32: 0e 8d 0e 74 0e 5b 0e 40 0e 24 0e 08 0d ef 0d d5 ...t.[.@.$......
|
|
||||||
+| 48: 0d bb 0d a0 0e 94 03 28 0d 4f 0d 35 0d 1b 05 0b .......(.O.5....
|
|
||||||
+| 64: 0c da 0c b9 0c 99 0c 78 0c 57 0c 3e 0c 24 0c 0a .......x.W.>.$..
|
|
||||||
+| 2880: 00 00 00 00 00 00 00 00 81 3f 25 06 00 72 7f 00 .........?%..r..
|
|
||||||
+| 2896: 00 43 4f 4d 50 49 4c 45 52 3d 67 63 63 2d 35 2e .COMPILER=gcc-5.
|
|
||||||
+| 2912: 34 2e 30 20 32 30 31 36 30 36 30 39 20 44 55 42 4.0 20160609 DUB
|
|
||||||
+| 2928: 55 47 20 45 4e 41 e4 7c 45 20 44 42 53 54 41 54 UG ENA.|E DBSTAT
|
|
||||||
+| 2944: e4 46 54 41 42 20 45 4e 41 42 4c 45 20 46 54 53 .FTAB ENABLE FTS
|
|
||||||
+| 2960: 34 20 45 4e 41 42 4c 45 20 46 54 53 35 20 45 4e 4 ENABLE FTS5 EN
|
|
||||||
+| 2976: 41 42 4c 45 20 47 45 4f 50 4f 4c 59 20 45 4e 41 ABLE GEOPOLY ENA
|
|
||||||
+| 2992: 42 4c 45 20 4a 53 4f 4e 31 20 45 4e 41 42 4c 45 BLE JSON1 ENABLE
|
|
||||||
+| 3008: 20 4d 45 4d 53 59 53 35 20 45 4e 41 42 4c 45 20 MEMSYS5 ENABLE
|
|
||||||
+| 3024: 42 54 52 45 45 20 4d 41 58 20 4d 45 4d 4f 52 59 BTREE MAX MEMORY
|
|
||||||
+| 3040: 3d 35 30 30 30 30 30 30 30 20 4f 4c 49 54 20 4c =50000000 OLIT L
|
|
||||||
+| 3056: 4f 41 43 20 45 58 54 45 4e 53 49 4f 4e 21 54 48 OAC EXTENSION!TH
|
|
||||||
+| 3072: 52 45 41 44 53 41 46 45 3d 30 18 24 05 00 25 0f READSAFE=0.$..%.
|
|
||||||
+| 3088: 19 54 48 52 45 41 44 53 41 46 45 3d 30 58 42 49 .THREADSAFE=0XBI
|
|
||||||
+| 3104: 4e 41 52 59 18 23 05 00 25 0f 19 54 48 52 45 41 NARY.#..%..THREA
|
|
||||||
+| 3120: 44 53 41 4b 75 3d 30 58 4d 4f 43 41 53 45 17 22 DSAKu=0XMOCASE..
|
|
||||||
+| 3136: 05 00 25 0f 17 54 48 52 45 41 44 53 41 46 46 3d ..%..THREADSAFF=
|
|
||||||
+| 3152: 30 58 52 54 52 49 4d 1f 21 05 00 33 0f 19 4f 4d 0XRTRIM.!..3..OM
|
|
||||||
+| 3168: 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 52 49 4f IT LOAD EXTENRIO
|
|
||||||
+| 3184: 4e 58 42 49 4e 41 52 59 1f 20 05 00 33 0f 19 4f NXBINARY. ..3..O
|
|
||||||
+| 3200: 4d 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 53 49 MIT LOAD EXTENSI
|
|
||||||
+| 3216: 4f 4e 58 4e 4f 43 41 53 45 1e 1f 05 00 33 0f 17 ONXNOCASE....3..
|
|
||||||
+| 3232: 4f 4d 49 54 20 4c 4f 41 44 20 45 58 54 45 4e 53 OMIT LOAD EXTENS
|
|
||||||
+| 3248: 49 4f 4e 58 52 54 52 49 4d 1f 1e 05 00 33 0f 19 IONXRTRIM....3..
|
|
||||||
+| 3264: 4d 41 58 20 4d 45 4d 4f 52 59 3d 35 30 30 30 30 MAX MEMORY=50000
|
|
||||||
+| 3280: 30 30 30 58 42 49 4e 41 52 59 1f 1d 05 00 33 0f 000XBINARY....3.
|
|
||||||
+| 3296: 19 4d 41 58 20 4d 45 4d 4f 52 59 3d 35 30 30 30 .MAX MEMORY=5000
|
|
||||||
+| 3312: 30 30 30 30 58 4e 4f 43 41 53 45 1e 1c 05 00 33 0000XNOCASE....3
|
|
||||||
+| 3328: 0f 17 4d 42 b8 20 4d 45 4d 4f 52 59 3d 35 30 30 ..MB. MEMORY=500
|
|
||||||
+| 3344: 30 30 30 30 30 58 52 54 52 49 4d 18 1b 05 00 25 00000XRTRIM....%
|
|
||||||
+| 3360: 0f 19 45 4e 41 42 4c 45 20 52 54 52 45 45 58 42 ..ENABLE RTREEXB
|
|
||||||
+| 3376: 49 4e 41 52 59 18 1a 05 0d a5 0f 19 45 4e 41 42 INARY.......ENAB
|
|
||||||
+| 3392: 4c 45 20 52 54 52 45 45 58 4e 4f 43 41 53 45 17 LE RTREEXNOCASE.
|
|
||||||
+| 3408: 19 1c 00 25 0f 17 45 4e 41 42 4c 45 20 52 54 52 ...%..ENABLE RTR
|
|
||||||
+| 3424: 45 45 58 52 54 52 49 4d 1a 18 05 00 29 0f 19 45 EEXRTRIM....)..E
|
|
||||||
+| 3440: 4e 41 42 4c 45 20 4d 45 4d 53 59 53 35 58 42 49 NABLE MEMSYS5XBI
|
|
||||||
+| 3456: 4e 41 52 59 1a 17 05 00 29 0f 19 45 4e 41 42 4c NARY....)..ENABL
|
|
||||||
+| 3472: 45 20 4d 45 4d 53 59 53 35 58 4e 4f 43 41 53 45 E MEMSYS5XNOCASE
|
|
||||||
+| 3488: 19 16 05 00 29 0f 17 45 4e 41 42 4c 45 20 4d 45 ....)..ENABLE ME
|
|
||||||
+| 3504: 4d 53 59 53 35 58 52 54 52 49 4d 18 14 05 01 25 MSYS5XRTRIM....%
|
|
||||||
+| 3520: 0f 19 45 4e 12 42 4c 45 20 4a 53 4f 4e 31 58 42 ..EN.BLE JSON1XB
|
|
||||||
+| 3536: 49 4e 41 52 59 18 14 05 00 25 09 d9 45 4e 41 42 INARY....%..ENAB
|
|
||||||
+| 3552: 4c 45 20 4a 53 4f 3e 31 58 4e 4f 43 41 53 45 17 LE JSO>1XNOCASE.
|
|
||||||
+| 3568: 13 05 00 25 0f 17 45 4e 40 42 4c 45 20 4a 53 4f ...%..EN@BLE JSO
|
|
||||||
+| 3584: 4e 31 58 52 54 52 49 4d 1a 12 05 82 29 0f 19 45 N1XRTRIM....)..E
|
|
||||||
+| 3600: 4e 41 42 4c 45 20 47 45 4f 50 4f 4c 59 58 42 49 NABLE GEOPOLYXBI
|
|
||||||
+| 3616: 4e 41 52 59 1a 11 05 c9 29 e8 19 46 4e 41 42 4c NARY....)..FNABL
|
|
||||||
+| 3632: 48 c0 47 45 4f 50 4f 4c 59 58 4e 74 43 41 53 45 H.GEOPOLYXNtCASE
|
|
||||||
+| 3648: 19 10 05 00 29 0f 17 45 4e 41 42 4c 45 20 47 45 ....)..ENABLE GE
|
|
||||||
+| 3664: 4f 50 4f 4c 59 58 52 54 52 49 4d 17 0f 05 00 23 OPOLYXRTRIM....#
|
|
||||||
+| 3680: 0f 19 45 4e 41 42 4c 45 30 46 54 53 35 58 42 49 ..ENABLE0FTS5XBI
|
|
||||||
+| 3696: 4e 41 52 59 17 0e 05 00 23 0f 19 45 4e 41 42 4c NARY....#..ENABL
|
|
||||||
+| 3712: 45 20 46 54 53 35 58 4e 4f 43 41 53 45 16 0e 05 E FTS5XNOCASE...
|
|
||||||
+| 3728: 00 23 0f 17 45 4e 41 42 4c 45 20 46 54 53 35 58 .#..ENABLE FTS5X
|
|
||||||
+| 3744: 52 54 52 49 4d 17 0c 05 00 23 0f 19 45 4e 41 42 RTRIM....#..ENAB
|
|
||||||
+| 3760: 4c 45 20 46 54 53 34 58 42 49 4e 41 52 59 17 0b LE FTS4XBINARY..
|
|
||||||
+| 3776: 05 00 23 0f 19 45 4e 41 42 4c 45 20 46 54 53 34 ..#..ENABLE FTS4
|
|
||||||
+| 3792: 58 4e 4f 43 41 53 45 16 0a 05 00 23 0f 17 45 4e XNOCASE....#..EN
|
|
||||||
+| 3808: 41 42 4c 45 20 46 54 53 34 58 52 54 52 49 4d 1e ABLE FTS4XRTRIM.
|
|
||||||
+| 3824: 09 05 00 31 0f 19 45 4e 42 42 4c 45 20 44 42 53 ...1..ENBBLE DBS
|
|
||||||
+| 3840: 54 41 54 20 56 54 41 42 58 42 49 4e 41 52 59 1e TAT VTABXBINARY.
|
|
||||||
+| 3856: 08 05 00 31 0f 19 45 4e 41 42 4c 45 20 44 42 53 ...1..ENABLE DBS
|
|
||||||
+| 3872: 54 41 54 20 56 54 41 42 58 4e 4f 43 41 53 45 1d TAT VTABXNOCASE.
|
|
||||||
+| 3888: 07 05 00 31 0f 17 45 4e 41 42 4c 45 20 44 42 53 ...1..ENABLE DBS
|
|
||||||
+| 3904: 54 41 54 20 56 54 41 42 58 52 54 52 4a 4d 11 06 TAT VTABXRTRJM..
|
|
||||||
+| 3920: 05 f0 17 0f 19 44 45 42 55 47 58 42 49 4e 41 52 .....DEBUGXBINAR
|
|
||||||
+| 3936: 59 11 05 05 00 17 0e 19 44 45 42 55 47 58 4e 4f Y.......DEBUGXNO
|
|
||||||
+| 3952: 43 41 53 45 10 04 05 00 17 0f 16 44 45 42 55 47 CASE.......DEBUG
|
|
||||||
+| 3968: 58 52 54 52 49 4d 27 03 05 00 43 0f 19 43 4f 4d XRTRIM'...C..COM
|
|
||||||
+| 3984: 50 49 4c 45 52 3d 67 63 63 2d 35 2e 34 2e 30 20 PILER=gcc-5.4.0
|
|
||||||
+| 4000: 32 30 31 36 30 36 30 39 58 42 49 4e 41 52 59 27 20160609XBINARY'
|
|
||||||
+| 4016: 02 05 00 43 0f 19 43 4f 4d 50 49 4c 45 52 3d 67 ...C..COMPILER=g
|
|
||||||
+| 4032: 63 63 2d 35 2e 34 2e 30 20 32 30 31 36 30 36 30 cc-5.4.0 2016060
|
|
||||||
+| 4048: 39 58 4e 4f 43 41 53 45 26 01 06 00 43 0f 17 43 9XNOCASE&...C..C
|
|
||||||
+| 4064: 4f 4d 50 49 4b 45 52 3d 67 63 63 2d 35 2e 34 2e OMPIKER=gcc-5.4.
|
|
||||||
+| 4080: 30 20 32 30 31 36 30 36 40 39 58 29 54 52 49 4d 0 201606@9X)TRIM
|
|
||||||
+| page 4 offset 12288
|
|
||||||
+| 0: 0d 00 10 00 00 10 00 00 00 00 00 00 00 01 00 00 ................
|
|
||||||
+| page 5 offset 16384
|
|
||||||
+| 0: 0d 00 00 00 02 0b a0 00 0c ad 0b a0 00 00 00 00 ................
|
|
||||||
+| 2976: 82 0a 02 08 08 09 08 08 17 84 06 30 20 32 35 33 ...........0 253
|
|
||||||
+| 2992: 00 01 30 04 25 06 1b 00 00 08 32 30 31 36 30 36 ..0.%.....201606
|
|
||||||
+| 3008: 30 39 03 25 07 00 00 01 34 03 25 05 00 00 01 35 09.%....4.%....5
|
|
||||||
+| 3024: 03 25 04 00 01 07 30 30 30 30 30 30 30 03 25 1a .%....0000000.%.
|
|
||||||
+| 3040: 00 00 08 63 6f 6d 70 69 6c 65 72 03 25 02 00 00 ...compiler.%...
|
|
||||||
+| 3056: 06 64 62 73 74 61 74 03 25 0a 00 01 04 65 62 75 .dbstat.%....ebu
|
|
||||||
+| 3072: 67 03 25 08 00 00 06 65 6e 61 62 6c 65 09 25 09 g.%....enable.%.
|
|
||||||
+| 3088: 05 04 04 04 04 04 00 01 08 78 74 65 6e 73 69 6f .........xtensio
|
|
||||||
+| 3104: 6e 03 25 1d 00 00 04 66 74 73 34 03 25 0d 00 03 n.%....fts4.%...
|
|
||||||
+| 3120: 01 35 03 25 0f 00 00 03 67 63 63 03 25 03 00 01 .5.%....gcc.%...
|
|
||||||
+| 3136: 06 65 6f 70 6f 6c 79 03 25 11 00 00 05 6a 73 6f .eopoly.%....jso
|
|
||||||
+| 3152: 6e 31 03 25 13 00 00 04 6c 6f 61 64 03 25 1c 00 n1.%....load.%..
|
|
||||||
+| 3168: 00 03 6d 61 78 03 25 18 00 01 05 65 6e 6f 72 79 ..max.%....enory
|
|
||||||
+| 3184: 03 25 19 00 03 04 ce 79 73 4d 03 25 15 00 00 04 .%.....ysM.%....
|
|
||||||
+| 3200: 6f 6d 69 74 03 25 1b 00 00 05 72 74 72 65 65 03 omit.%....rtree.
|
|
||||||
+| 3216: 25 17 00 00 0a 74 68 72 65 61 64 73 61 66 65 03 %....threadsafe.
|
|
||||||
+| 3232: 25 0e 00 00 04 76 74 61 62 03 25 0b 00 86 50 01 %....vtab.%...P.
|
|
||||||
+| 3248: 08 08 08 08 08 17 8d 12 30 20 38 33 35 00 01 30 ........0 835..0
|
|
||||||
+| 3264: 12 01 06 00 01 06 00 01 06 00 1f 03 00 01 03 09 ................
|
|
||||||
+| 3280: 51 03 00 00 08 32 30 31 36 30 36 30 39 09 01 07 Q....20160609...
|
|
||||||
+| 3296: 00 01 07 00 01 07 00 00 01 34 09 01 05 00 01 05 .........4......
|
|
||||||
+| 3312: 00 01 05 00 00 01 35 09 01 04 00 01 04 00 01 04 ......5.........
|
|
||||||
+| 3328: 00 01 07 30 30 30 30 30 30 30 09 1c 04 00 01 04 ...0000000......
|
|
||||||
+| 3344: 00 01 04 00 00 06 62 69 6e 61 72 79 3c 03 01 02 ......binary<...
|
|
||||||
+| 3360: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3376: 00 03 01 02 02 00 02 f1 02 02 00 03 01 02 02 00 ................
|
|
||||||
+| 3392: 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 03 ................
|
|
||||||
+| 3408: 01 02 02 00 03 01 02 02 00 00 08 63 6f 6d 70 69 ...........compi
|
|
||||||
+| 3424: 6c 65 72 09 01 02 00 01 02 00 01 02 00 00 06 67 ler............g
|
|
||||||
+| 3440: d2 73 74 61 74 09 07 03 00 01 03 00 01 03 00 01 .stat...........
|
|
||||||
+| 3456: 04 65 62 75 67 09 04 02 00 01 02 00 01 02 00 00 .ebug...........
|
|
||||||
+| 3472: 06 65 6e 6f 82 6c 65 3f 07 02 00 01 02 00 01 02 .eno.le?........
|
|
||||||
+| 3488: b0 01 02 00 01 02 00 11 02 00 01 02 00 01 02 00 ................
|
|
||||||
+| 3504: 01 02 00 01 02 00 01 02 00 01 a6 00 01 02 00 01 ................
|
|
||||||
+| 3520: 02 05 51 02 00 01 02 00 01 02 00 01 02 00 01 02 ..Q.............
|
|
||||||
+| 3536: 00 01 02 00 01 02 00 01 08 78 74 65 6e 73 69 6f .........xtensio
|
|
||||||
+| 3552: 6e 09 1f 04 00 01 04 00 00 04 00 00 04 66 74 73 n............fts
|
|
||||||
+| 3568: 34 09 0a 03 00 01 03 00 01 03 00 03 01 35 09 0d 4............5..
|
|
||||||
+| 3584: 03 00 01 03 00 01 03 00 00 03 67 63 63 09 01 03 ..........gcc...
|
|
||||||
+| 3600: 00 01 03 00 01 03 00 01 06 65 6f 70 73 6c 79 09 .........eopsly.
|
|
||||||
+| 3616: 10 03 00 01 03 00 01 03 00 00 05 6a 73 6f 6e 31 ...........json1
|
|
||||||
+| 3632: 09 13 03 00 01 03 00 01 03 00 00 04 6c 6f 61 64 ............load
|
|
||||||
+| 3648: 09 1f 03 00 01 03 00 01 03 00 00 03 6d 61 78 09 ............max.
|
|
||||||
+| 3664: 1c 02 00 01 02 00 01 02 00 01 05 65 6d 6f 72 79 ...........emory
|
|
||||||
+| 3680: 09 1c 03 00 01 03 00 01 03 00 03 04 73 79 73 35 ............sys5
|
|
||||||
+| 3696: 09 16 03 00 01 03 00 01 03 00 00 06 6e 6f 63 61 ............noca
|
|
||||||
+| 3712: 73 65 3c 02 01 02 02 00 03 01 12 02 00 03 01 02 se<.............
|
|
||||||
+| 3728: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3744: 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 ................
|
|
||||||
+| 3760: 03 01 02 02 00 03 01 02 02 00 03 01 02 02 00 00 ................
|
|
||||||
+| 3776: 0e 9f 6d 69 74 09 1f 02 00 01 02 00 01 02 00 00 ..mit...........
|
|
||||||
+| 3792: 05 72 74 72 65 65 09 19 03 00 01 03 00 01 03 00 .rtree..........
|
|
||||||
+| 3808: 03 02 69 6d 3c 01 01 02 02 00 03 01 02 02 00 03 ..im<...........
|
|
||||||
+| 3824: 01 02 02 00 03 01 02 02 00 03 01 02 02 00 03 01 ................
|
|
||||||
+| 3840: 02 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 ................
|
|
||||||
+| 3856: 02 00 03 01 02 02 00 03 01 02 02 00 03 01 02 02 ................
|
|
||||||
+| 3872: 00 00 0a 74 68 72 65 61 64 73 61 66 65 09 22 02 ...threadsafe...
|
|
||||||
+| 3888: 00 01 02 00 01 02 00 00 04 76 74 61 62 09 07 04 .........vtab...
|
|
||||||
+| 3904: 00 01 04 00 01 04 00 00 01 78 b4 01 01 01 01 02 .........x......
|
|
||||||
+| 3920: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| 3936: 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 01 ................
|
|
||||||
+| 3952: 01 01 02 00 01 01 01 07 30 01 01 01 02 00 01 01 ........0.......
|
|
||||||
+| 3968: 01 02 00 11 01 01 02 00 01 01 01 02 00 11 01 01 ................
|
|
||||||
+| 3984: 02 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 ................
|
|
||||||
+| 4000: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| 4016: 01 01 01 01 ff 01 01 01 02 00 01 01 01 02 00 01 ................
|
|
||||||
+| 4032: 01 01 02 00 01 01 01 02 00 01 01 01 02 00 01 01 ................
|
|
||||||
+| 4048: 01 02 00 01 01 01 02 00 01 01 01 02 00 01 01 01 ................
|
|
||||||
+| 4064: 02 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 ................
|
|
||||||
+| 4080: 00 01 01 01 02 00 01 01 01 02 00 01 01 01 02 00 ................
|
|
||||||
+| page 6 offset 20480
|
|
||||||
+| 0: 0a 00 00 00 02 0f f5 00 0f fb 0f f5 00 00 00 00 ................
|
|
||||||
+| 4080: 00 00 00 00 00 05 04 08 09 01 02 04 04 08 08 09 ................
|
|
||||||
+| page 7 offset 24576
|
|
||||||
+| 0: 0d 00 00 00 05 0f b8 00 0e f4 0f e9 10 d6 0f c7 ................
|
|
||||||
+| 4016: 00 00 00 00 00 00 00 00 0d 05 02 23 61 75 74 6f ...........#auto
|
|
||||||
+| 4032: 6d 65 72 67 65 3d 35 0d 04 02 23 6d 65 72 67 65 merge=5...#merge
|
|
||||||
+| 4048: 3d 31 00 00 00 00 00 00 00 00 00 00 00 00 00 00 =1..............
|
|
||||||
+| end crash-dde9e76ed8ab2d.db
|
|
||||||
+}]} {}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.1 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x%1 FROM c WHERE x<599237)
|
|
||||||
+ INSERT INTO t1( a ) SELECT randomblob(3000) FROM t2 ;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.2 {
|
|
||||||
+ UPDATE t1 SET b=quote((true) ) WHERE t1 MATCH 'h*';
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.3 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x +x FROM c WHERE 72<x)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(2829) FROM c;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.4 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x%1 FROM c WHERE 599237<x)
|
|
||||||
+ INSERT INTO t1(a) SELECT randomblob(3000) FROM t2 ;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.5 {
|
|
||||||
+ WITH RECURSIVE c(x) AS (VALUES(1) UNION ALL SELECT x%1 FROM c WHERE x<599237)
|
|
||||||
+ INSERT INTO t1( a ) SELECT randomblob(3000) FROM t2 ;
|
|
||||||
+} {0 {}}
|
|
||||||
+
|
|
||||||
+do_catchsql_test 25.6 {
|
|
||||||
+ INSERT INTO t1(t1) SELECT x FROM t2;
|
|
||||||
+ INSERT INTO t1(t1) SELECT x FROM t2;
|
|
||||||
+} {1 {database disk image is malformed}}
|
|
||||||
+
|
|
||||||
finish_test
|
|
||||||
|
|
||||||
--- /test/with3.test
|
|
||||||
+++ /test/with3.test
|
|
||||||
@@ -130,4 +130,40 @@
|
|
||||||
`--SEARCH TABLE w1 USING INTEGER PRIMARY KEY (rowid=?)
|
|
||||||
}
|
|
||||||
|
|
||||||
+do_execsql_test 4.0 {
|
|
||||||
+ WITH t5(t5col1) AS (
|
|
||||||
+ SELECT (
|
|
||||||
+ WITH t3(t3col1) AS (
|
|
||||||
+ WITH t2 AS (
|
|
||||||
+ WITH t1 AS (SELECT 1 AS c1 GROUP BY 1)
|
|
||||||
+ SELECT a.c1 FROM t1 AS a, t1 AS b
|
|
||||||
+ WHERE anoncol1 = 1
|
|
||||||
+ )
|
|
||||||
+ SELECT (SELECT 1 FROM t2) FROM t2
|
|
||||||
+ )
|
|
||||||
+ SELECT t3col1 FROM t3 WHERE t3col1
|
|
||||||
+ ) FROM (SELECT 1 AS anoncol1)
|
|
||||||
+ )
|
|
||||||
+ SELECT t5col1, t5col1 FROM t5
|
|
||||||
+} {1 1}
|
|
||||||
+do_execsql_test 4.1 {
|
|
||||||
+ SELECT EXISTS (
|
|
||||||
+ WITH RECURSIVE Table0 AS (
|
|
||||||
+ WITH RECURSIVE Table0(Col0) AS (SELECT ALL 1 )
|
|
||||||
+ SELECT ALL (
|
|
||||||
+ WITH RECURSIVE Table0 AS (
|
|
||||||
+ WITH RECURSIVE Table0 AS (
|
|
||||||
+ WITH RECURSIVE Table0 AS (SELECT DISTINCT 1 GROUP BY 1 )
|
|
||||||
+ SELECT DISTINCT * FROM Table0 NATURAL INNER JOIN Table0
|
|
||||||
+ WHERE Col0 = 1
|
|
||||||
+ )
|
|
||||||
+ SELECT ALL (SELECT DISTINCT * FROM Table0) FROM Table0 WHERE Col0 = 1
|
|
||||||
+ )
|
|
||||||
+ SELECT ALL * FROM Table0 NATURAL INNER JOIN Table0
|
|
||||||
+ ) FROM Table0 )
|
|
||||||
+ SELECT DISTINCT * FROM Table0 NATURAL INNER JOIN Table0
|
|
||||||
+ );
|
|
||||||
+} {1}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
finish_test
|
|
@ -1,19 +0,0 @@
|
|||||||
https://sqlite.org/src/info/af53c41a127c314c
|
|
||||||
|
|
||||||
--- /test/like3.test
|
|
||||||
+++ /test/like3.test
|
|
||||||
@@ -182,6 +182,7 @@
|
|
||||||
# Verify that the LIKE optimization works with an ESCAPE clause when
|
|
||||||
# using PRAGMA case_sensitive_like=ON.
|
|
||||||
#
|
|
||||||
+ifcapable !icu {
|
|
||||||
do_execsql_test like3-6.100 {
|
|
||||||
DROP TABLE IF EXISTS t1;
|
|
||||||
CREATE TABLE t1(path TEXT COLLATE nocase PRIMARY KEY,a,b,c) WITHOUT ROWID;
|
|
||||||
@@ -229,5 +230,6 @@
|
|
||||||
QUERY PLAN
|
|
||||||
`--SEARCH TABLE t2 USING INDEX t2path2 (path>? AND path<?)
|
|
||||||
}
|
|
||||||
+}
|
|
||||||
|
|
||||||
finish_test
|
|
@ -1,114 +0,0 @@
|
|||||||
https://sqlite.org/src/info/b2ce5ed175cb5029
|
|
||||||
https://sqlite.org/src/info/6e4a5f22811bcd14
|
|
||||||
https://sqlite.org/src/info/516ca8945150bdc1
|
|
||||||
https://sqlite.org/src/info/e1724f1d618cfbcf
|
|
||||||
https://sqlite.org/src/info/c621fc668c6538f9
|
|
||||||
https://sqlite.org/src/info/c509d8a8aebe0da4
|
|
||||||
https://sqlite.org/src/info/a9b90aa12eecdd9f
|
|
||||||
|
|
||||||
--- /sqlite3.c
|
|
||||||
+++ /sqlite3.c
|
|
||||||
@@ -67472,10 +67472,9 @@
|
|
||||||
rc = newDatabase(pBt);
|
|
||||||
pBt->nPage = get4byte(28 + pBt->pPage1->aData);
|
|
||||||
|
|
||||||
- /* The database size was written into the offset 28 of the header
|
|
||||||
- ** when the transaction started, so we know that the value at offset
|
|
||||||
- ** 28 is nonzero. */
|
|
||||||
- assert( pBt->nPage>0 );
|
|
||||||
+ /* pBt->nPage might be zero if the database was corrupt when
|
|
||||||
+ ** the transaction was started. Otherwise, it must be at least 1. */
|
|
||||||
+ assert( CORRUPT_DB || pBt->nPage>0 );
|
|
||||||
}
|
|
||||||
sqlite3BtreeLeave(p);
|
|
||||||
}
|
|
||||||
@@ -70825,6 +70824,7 @@
|
|
||||||
u16 maskPage = pOld->maskPage;
|
|
||||||
u8 *piCell = aData + pOld->cellOffset;
|
|
||||||
u8 *piEnd;
|
|
||||||
+ VVA_ONLY( int nCellAtStart = b.nCell; )
|
|
||||||
|
|
||||||
/* Verify that all sibling pages are of the same "type" (table-leaf,
|
|
||||||
** table-interior, index-leaf, or index-interior).
|
|
||||||
@@ -70853,6 +70853,10 @@
|
|
||||||
*/
|
|
||||||
memset(&b.szCell[b.nCell], 0, sizeof(b.szCell[0])*(limit+pOld->nOverflow));
|
|
||||||
if( pOld->nOverflow>0 ){
|
|
||||||
+ if( limit<pOld->aiOvfl[0] ){
|
|
||||||
+ rc = SQLITE_CORRUPT_BKPT;
|
|
||||||
+ goto balance_cleanup;
|
|
||||||
+ }
|
|
||||||
limit = pOld->aiOvfl[0];
|
|
||||||
for(j=0; j<limit; j++){
|
|
||||||
b.apCell[b.nCell] = aData + (maskPage & get2byteAligned(piCell));
|
|
||||||
@@ -70872,6 +70876,7 @@
|
|
||||||
piCell += 2;
|
|
||||||
b.nCell++;
|
|
||||||
}
|
|
||||||
+ assert( (b.nCell-nCellAtStart)==(pOld->nCell+pOld->nOverflow) );
|
|
||||||
|
|
||||||
cntOld[i] = b.nCell;
|
|
||||||
if( i<nOld-1 && !leafData){
|
|
||||||
@@ -83747,7 +83752,7 @@
|
|
||||||
** is clear. Otherwise, if this is an ephemeral cursor created by
|
|
||||||
** OP_OpenDup, the cursor will not be closed and will still be part
|
|
||||||
** of a BtShared.pCursor list. */
|
|
||||||
- p->apCsr[iCur]->isEphemeral = 0;
|
|
||||||
+ if( p->apCsr[iCur]->pBtx==0 ) p->apCsr[iCur]->isEphemeral = 0;
|
|
||||||
sqlite3VdbeFreeCursor(p, p->apCsr[iCur]);
|
|
||||||
p->apCsr[iCur] = 0;
|
|
||||||
}
|
|
||||||
@@ -87258,7 +87263,10 @@
|
|
||||||
if( pCx ){
|
|
||||||
/* If the ephermeral table is already open, erase all existing content
|
|
||||||
** so that the table is empty again, rather than creating a new table. */
|
|
||||||
- rc = sqlite3BtreeClearTable(pCx->pBtx, pCx->pgnoRoot, 0);
|
|
||||||
+ assert( pCx->isEphemeral );
|
|
||||||
+ if( pCx->pBtx ){
|
|
||||||
+ rc = sqlite3BtreeClearTable(pCx->pBtx, pCx->pgnoRoot, 0);
|
|
||||||
+ }
|
|
||||||
}else{
|
|
||||||
pCx = allocateCursor(p, pOp->p1, pOp->p2, -1, CURTYPE_BTREE);
|
|
||||||
if( pCx==0 ) goto no_mem;
|
|
||||||
@@ -95979,7 +95987,9 @@
|
|
||||||
#ifndef SQLITE_OMIT_WINDOWFUNC
|
|
||||||
if( pExpr->y.pWin ){
|
|
||||||
Select *pSel = pNC->pWinSelect;
|
|
||||||
- sqlite3WindowUpdate(pParse, pSel->pWinDefn, pExpr->y.pWin, pDef);
|
|
||||||
+ if( IN_RENAME_OBJECT==0 ){
|
|
||||||
+ sqlite3WindowUpdate(pParse, pSel->pWinDefn, pExpr->y.pWin, pDef);
|
|
||||||
+ }
|
|
||||||
sqlite3WalkExprList(pWalker, pExpr->y.pWin->pPartition);
|
|
||||||
sqlite3WalkExprList(pWalker, pExpr->y.pWin->pOrderBy);
|
|
||||||
sqlite3WalkExpr(pWalker, pExpr->y.pWin->pFilter);
|
|
||||||
@@ -174132,7 +174142,7 @@
|
|
||||||
}
|
|
||||||
p->iOff += fts3GetVarint32(&p->aNode[p->iOff], &nSuffix);
|
|
||||||
|
|
||||||
- if( nPrefix>p->iOff || nSuffix>p->nNode-p->iOff ){
|
|
||||||
+ if( nPrefix>p->term.n || nSuffix>p->nNode-p->iOff || nSuffix==0 ){
|
|
||||||
return FTS_CORRUPT_VTAB;
|
|
||||||
}
|
|
||||||
blobGrowBuffer(&p->term, nPrefix+nSuffix, &rc);
|
|
||||||
@@ -174151,7 +174161,7 @@
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- assert( p->iOff<=p->nNode );
|
|
||||||
+ assert_fts3_nc( p->iOff<=p->nNode );
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -204287,7 +204297,11 @@
|
|
||||||
i64 iOff = *piOff;
|
|
||||||
int iVal;
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
||||||
- if( iVal==1 ){
|
|
||||||
+ if( iVal<=1 ){
|
|
||||||
+ if( iVal==0 ){
|
|
||||||
+ *pi = i;
|
|
||||||
+ return 0;
|
|
||||||
+ }
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
||||||
iOff = ((i64)iVal) << 32;
|
|
||||||
fts5FastGetVarint32(a, i, iVal);
|
|
@ -15,11 +15,12 @@ Fix building with dlopen() not available.
|
|||||||
$(TOP)/ext/fts1/fts1.c \
|
$(TOP)/ext/fts1/fts1.c \
|
||||||
$(TOP)/ext/fts1/fts1.h \
|
$(TOP)/ext/fts1/fts1.h \
|
||||||
$(TOP)/ext/fts1/fts1_hash.c \
|
$(TOP)/ext/fts1/fts1_hash.c \
|
||||||
@@ -363,8 +366,11 @@
|
@@ -363,8 +366,12 @@
|
||||||
$(TOP)/ext/rbu/sqlite3rbu.h \
|
$(TOP)/ext/rbu/sqlite3rbu.h \
|
||||||
$(TOP)/ext/rbu/sqlite3rbu.c
|
$(TOP)/ext/rbu/sqlite3rbu.c
|
||||||
SRC += \
|
SRC += \
|
||||||
+ $(TOP)/ext/misc/appendvfs.c \
|
+ $(TOP)/ext/misc/appendvfs.c \
|
||||||
|
+ $(TOP)/ext/misc/dbdata.c \
|
||||||
$(TOP)/ext/misc/json1.c \
|
$(TOP)/ext/misc/json1.c \
|
||||||
- $(TOP)/ext/misc/stmt.c
|
- $(TOP)/ext/misc/stmt.c
|
||||||
+ $(TOP)/ext/misc/sqlar.c \
|
+ $(TOP)/ext/misc/sqlar.c \
|
||||||
@ -28,7 +29,7 @@ Fix building with dlopen() not available.
|
|||||||
|
|
||||||
# Generated source code files
|
# Generated source code files
|
||||||
#
|
#
|
||||||
@@ -435,7 +441,6 @@
|
@@ -435,7 +442,6 @@
|
||||||
# Statically linked extensions
|
# Statically linked extensions
|
||||||
#
|
#
|
||||||
TESTSRC += \
|
TESTSRC += \
|
||||||
@ -36,7 +37,7 @@ Fix building with dlopen() not available.
|
|||||||
$(TOP)/ext/expert/test_expert.c \
|
$(TOP)/ext/expert/test_expert.c \
|
||||||
$(TOP)/ext/misc/amatch.c \
|
$(TOP)/ext/misc/amatch.c \
|
||||||
$(TOP)/ext/misc/carray.c \
|
$(TOP)/ext/misc/carray.c \
|
||||||
@@ -461,7 +466,6 @@
|
@@ -461,7 +467,6 @@
|
||||||
$(TOP)/ext/misc/totype.c \
|
$(TOP)/ext/misc/totype.c \
|
||||||
$(TOP)/ext/misc/unionvtab.c \
|
$(TOP)/ext/misc/unionvtab.c \
|
||||||
$(TOP)/ext/misc/wholenumber.c \
|
$(TOP)/ext/misc/wholenumber.c \
|
||||||
@ -44,7 +45,7 @@ Fix building with dlopen() not available.
|
|||||||
$(TOP)/ext/userauth/userauth.c
|
$(TOP)/ext/userauth/userauth.c
|
||||||
|
|
||||||
# Source code to the library files needed by the test fixture
|
# Source code to the library files needed by the test fixture
|
||||||
@@ -640,25 +644,25 @@
|
@@ -639,25 +644,25 @@
|
||||||
|
|
||||||
libtclsqlite3.la: tclsqlite.lo libsqlite3.la
|
libtclsqlite3.la: tclsqlite.lo libsqlite3.la
|
||||||
$(LTLINK) -no-undefined -o $@ tclsqlite.lo \
|
$(LTLINK) -no-undefined -o $@ tclsqlite.lo \
|
||||||
@ -81,7 +82,7 @@ Fix building with dlopen() not available.
|
|||||||
|
|
||||||
srcck1$(BEXE): $(TOP)/tool/srcck1.c
|
srcck1$(BEXE): $(TOP)/tool/srcck1.c
|
||||||
$(BCC) -o srcck1$(BEXE) $(TOP)/tool/srcck1.c
|
$(BCC) -o srcck1$(BEXE) $(TOP)/tool/srcck1.c
|
||||||
@@ -768,7 +772,7 @@
|
@@ -767,7 +772,7 @@
|
||||||
# Rule to build the amalgamation
|
# Rule to build the amalgamation
|
||||||
#
|
#
|
||||||
sqlite3.lo: sqlite3.c
|
sqlite3.lo: sqlite3.c
|
||||||
@ -90,7 +91,7 @@ Fix building with dlopen() not available.
|
|||||||
|
|
||||||
# Rules to build the LEMON compiler generator
|
# Rules to build the LEMON compiler generator
|
||||||
#
|
#
|
||||||
@@ -1065,14 +1069,9 @@
|
@@ -1064,14 +1069,9 @@
|
||||||
# Source files that go into making shell.c
|
# Source files that go into making shell.c
|
||||||
SHELL_SRC = \
|
SHELL_SRC = \
|
||||||
$(TOP)/src/shell.c.in \
|
$(TOP)/src/shell.c.in \
|
||||||
@ -105,7 +106,7 @@ Fix building with dlopen() not available.
|
|||||||
$(TOP)/ext/misc/memtrace.c \
|
$(TOP)/ext/misc/memtrace.c \
|
||||||
$(TOP)/src/test_windirent.c
|
$(TOP)/src/test_windirent.c
|
||||||
|
|
||||||
@@ -1240,15 +1239,15 @@
|
@@ -1239,11 +1239,11 @@
|
||||||
|
|
||||||
# Fuzz testing
|
# Fuzz testing
|
||||||
fuzztest: fuzzcheck$(TEXE) $(FUZZDATA) sessionfuzz$(TEXE) $(TOP)/test/sessionfuzz-data1.db
|
fuzztest: fuzzcheck$(TEXE) $(FUZZDATA) sessionfuzz$(TEXE) $(TOP)/test/sessionfuzz-data1.db
|
||||||
@ -113,18 +114,13 @@ Fix building with dlopen() not available.
|
|||||||
+ ./fuzzcheck$(TEXE) --timeout 3600 $(FUZZDATA)
|
+ ./fuzzcheck$(TEXE) --timeout 3600 $(FUZZDATA)
|
||||||
./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
|
./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
|
||||||
|
|
||||||
fastfuzztest: fuzzcheck$(TEXE) $(FUZZDATA) sessionfuzz$(TEXE) $(TOP)/test/sessionfuzz-data1.db
|
|
||||||
- ./fuzzcheck$(TEXE) --limit-mem 100M $(FUZZDATA)
|
|
||||||
+ ./fuzzcheck$(TEXE) --limit-mem 100M --timeout 3600 $(FUZZDATA)
|
|
||||||
./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
|
|
||||||
|
|
||||||
valgrindfuzz: fuzzcheck$(TEXT) $(FUZZDATA) sessionfuzz$(TEXE) $(TOP)/test/sessionfuzz-data1.db
|
valgrindfuzz: fuzzcheck$(TEXT) $(FUZZDATA) sessionfuzz$(TEXE) $(TOP)/test/sessionfuzz-data1.db
|
||||||
- valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M --timeout 600 $(FUZZDATA)
|
- valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M --timeout 600 $(FUZZDATA)
|
||||||
+ valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M --timeout 3600 $(FUZZDATA)
|
+ valgrind ./fuzzcheck$(TEXE) --cell-size-check --limit-mem 10M --timeout 3600 $(FUZZDATA)
|
||||||
valgrind ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
|
valgrind ./sessionfuzz$(TEXE) run $(TOP)/test/sessionfuzz-data1.db
|
||||||
|
|
||||||
# The veryquick.test TCL tests.
|
# The veryquick.test TCL tests.
|
||||||
@@ -1279,24 +1278,23 @@
|
@@ -1274,24 +1274,23 @@
|
||||||
smoketest: $(TESTPROGS) fuzzcheck$(TEXE)
|
smoketest: $(TESTPROGS) fuzzcheck$(TEXE)
|
||||||
./testfixture$(TEXE) $(TOP)/test/main.test $(TESTOPTS)
|
./testfixture$(TEXE) $(TOP)/test/main.test $(TESTOPTS)
|
||||||
|
|
||||||
@ -157,7 +153,7 @@ Fix building with dlopen() not available.
|
|||||||
$(TOP)/src/tclsqlite.c \
|
$(TOP)/src/tclsqlite.c \
|
||||||
$(TOP)/ext/repair/sqlite3_checker.tcl \
|
$(TOP)/ext/repair/sqlite3_checker.tcl \
|
||||||
$(TOP)/ext/repair/checkindex.c \
|
$(TOP)/ext/repair/checkindex.c \
|
||||||
@@ -1307,36 +1305,36 @@
|
@@ -1302,36 +1301,36 @@
|
||||||
sqlite3_checker.c: $(CHECKER_DEPS)
|
sqlite3_checker.c: $(CHECKER_DEPS)
|
||||||
$(TCLSH_CMD) $(TOP)/tool/mkccode.tcl $(TOP)/ext/repair/sqlite3_checker.c.in >$@
|
$(TCLSH_CMD) $(TOP)/tool/mkccode.tcl $(TOP)/ext/repair/sqlite3_checker.c.in >$@
|
||||||
|
|
||||||
@ -212,7 +208,7 @@ Fix building with dlopen() not available.
|
|||||||
|
|
||||||
changesetfuzz$(TEXE): $(TOP)/ext/session/changesetfuzz.c sqlite3.lo
|
changesetfuzz$(TEXE): $(TOP)/ext/session/changesetfuzz.c sqlite3.lo
|
||||||
$(LTLINK) -o $@ $(TOP)/ext/session/changesetfuzz.c sqlite3.lo $(TLIBS)
|
$(LTLINK) -o $@ $(TOP)/ext/session/changesetfuzz.c sqlite3.lo $(TLIBS)
|
||||||
@@ -1361,11 +1359,11 @@
|
@@ -1356,11 +1355,11 @@
|
||||||
kvtest$(TEXE): $(TOP)/test/kvtest.c sqlite3.c
|
kvtest$(TEXE): $(TOP)/test/kvtest.c sqlite3.c
|
||||||
$(LTLINK) $(KV_OPT) -o $@ $(TOP)/test/kvtest.c sqlite3.c $(TLIBS)
|
$(LTLINK) $(KV_OPT) -o $@ $(TOP)/test/kvtest.c sqlite3.c $(TLIBS)
|
||||||
|
|
||||||
@ -251,7 +247,7 @@ Fix building with dlopen() not available.
|
|||||||
#include "sqlite3ext.h"
|
#include "sqlite3ext.h"
|
||||||
SQLITE_EXTENSION_INIT1
|
SQLITE_EXTENSION_INIT1
|
||||||
#include <zlib.h>
|
#include <zlib.h>
|
||||||
@@ -119,3 +121,5 @@
|
@@ -121,3 +123,5 @@
|
||||||
}
|
}
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@ -268,7 +264,7 @@ Fix building with dlopen() not available.
|
|||||||
#include "sqlite3ext.h"
|
#include "sqlite3ext.h"
|
||||||
SQLITE_EXTENSION_INIT1
|
SQLITE_EXTENSION_INIT1
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@@ -2176,3 +2178,5 @@
|
@@ -2186,3 +2188,5 @@
|
||||||
(void)pzErrMsg; /* Unused parameter */
|
(void)pzErrMsg; /* Unused parameter */
|
||||||
return zipfileRegister(db);
|
return zipfileRegister(db);
|
||||||
}
|
}
|
||||||
@ -314,7 +310,7 @@ Fix building with dlopen() not available.
|
|||||||
|
|
||||||
#if defined(_WIN32) || defined(WIN32)
|
#if defined(_WIN32) || defined(WIN32)
|
||||||
# include <io.h>
|
# include <io.h>
|
||||||
@@ -939,14 +944,7 @@
|
@@ -939,18 +944,7 @@
|
||||||
INCLUDE ../ext/misc/shathree.c
|
INCLUDE ../ext/misc/shathree.c
|
||||||
INCLUDE ../ext/misc/fileio.c
|
INCLUDE ../ext/misc/fileio.c
|
||||||
INCLUDE ../ext/misc/completion.c
|
INCLUDE ../ext/misc/completion.c
|
||||||
@ -326,12 +322,20 @@ Fix building with dlopen() not available.
|
|||||||
-#endif
|
-#endif
|
||||||
-INCLUDE ../ext/expert/sqlite3expert.h
|
-INCLUDE ../ext/expert/sqlite3expert.h
|
||||||
-INCLUDE ../ext/expert/sqlite3expert.c
|
-INCLUDE ../ext/expert/sqlite3expert.c
|
||||||
|
-
|
||||||
|
-#if !defined(SQLITE_OMIT_VIRTUALTABLE) && defined(SQLITE_ENABLE_DBPAGE_VTAB)
|
||||||
|
-INCLUDE ../ext/misc/dbdata.c
|
||||||
|
-#endif
|
||||||
|
|
||||||
#if defined(SQLITE_ENABLE_SESSION)
|
#if defined(SQLITE_ENABLE_SESSION)
|
||||||
/*
|
/*
|
||||||
@@ -4000,7 +3998,9 @@
|
@@ -4173,10 +4167,13 @@
|
||||||
sqlite3_shathree_init(p->db, 0, 0);
|
sqlite3_shathree_init(p->db, 0, 0);
|
||||||
sqlite3_completion_init(p->db, 0, 0);
|
sqlite3_completion_init(p->db, 0, 0);
|
||||||
|
#if !defined(SQLITE_OMIT_VIRTUALTABLE) && defined(SQLITE_ENABLE_DBPAGE_VTAB)
|
||||||
|
+ extern int sqlite3_dbdata_init(sqlite3 *, char **, const sqlite3_api_routines *);
|
||||||
|
sqlite3_dbdata_init(p->db, 0, 0);
|
||||||
|
#endif
|
||||||
#ifdef SQLITE_HAVE_ZLIB
|
#ifdef SQLITE_HAVE_ZLIB
|
||||||
+ extern int sqlite3_zipfile_init(sqlite3 *, char **, const sqlite3_api_routines *);
|
+ extern int sqlite3_zipfile_init(sqlite3 *, char **, const sqlite3_api_routines *);
|
||||||
sqlite3_zipfile_init(p->db, 0, 0);
|
sqlite3_zipfile_init(p->db, 0, 0);
|
||||||
@ -339,7 +343,7 @@ Fix building with dlopen() not available.
|
|||||||
sqlite3_sqlar_init(p->db, 0, 0);
|
sqlite3_sqlar_init(p->db, 0, 0);
|
||||||
#endif
|
#endif
|
||||||
sqlite3_create_function(p->db, "shell_add_schema", 3, SQLITE_UTF8, 0,
|
sqlite3_create_function(p->db, "shell_add_schema", 3, SQLITE_UTF8, 0,
|
||||||
@@ -5971,6 +5971,7 @@
|
@@ -6176,6 +6173,7 @@
|
||||||
goto end_ar_command;
|
goto end_ar_command;
|
||||||
}
|
}
|
||||||
sqlite3_fileio_init(cmd.db, 0, 0);
|
sqlite3_fileio_init(cmd.db, 0, 0);
|
||||||
@ -347,7 +351,7 @@ Fix building with dlopen() not available.
|
|||||||
sqlite3_sqlar_init(cmd.db, 0, 0);
|
sqlite3_sqlar_init(cmd.db, 0, 0);
|
||||||
sqlite3_create_function(cmd.db, "shell_putsnl", 1, SQLITE_UTF8, cmd.p,
|
sqlite3_create_function(cmd.db, "shell_putsnl", 1, SQLITE_UTF8, cmd.p,
|
||||||
shellPutsFunc, 0, 0);
|
shellPutsFunc, 0, 0);
|
||||||
@@ -9260,6 +9261,7 @@
|
@@ -10354,6 +10352,7 @@
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
data.out = stdout;
|
data.out = stdout;
|
||||||
@ -410,11 +414,12 @@ Fix building with dlopen() not available.
|
|||||||
sqlite3ext.h
|
sqlite3ext.h
|
||||||
sqlite3rbu.h
|
sqlite3rbu.h
|
||||||
sqliteicu.h
|
sqliteicu.h
|
||||||
@@ -403,6 +404,10 @@
|
@@ -403,6 +404,11 @@
|
||||||
sqlite3session.c
|
sqlite3session.c
|
||||||
fts5.c
|
fts5.c
|
||||||
stmt.c
|
stmt.c
|
||||||
+ appendvfs.c
|
+ appendvfs.c
|
||||||
|
+ dbdata.c
|
||||||
+ sqlar.c
|
+ sqlar.c
|
||||||
+ sqlite3expert.c
|
+ sqlite3expert.c
|
||||||
+ zipfile.c
|
+ zipfile.c
|
@ -0,0 +1,72 @@
|
|||||||
|
https://sqlite.org/cgi/src/info/04885763c4cd00cb
|
||||||
|
https://sqlite.org/cgi/src/info/b20503aaf5b6595a
|
||||||
|
|
||||||
|
--- /ext/fts5/test/fts5matchinfo.test
|
||||||
|
+++ /ext/fts5/test/fts5matchinfo.test
|
||||||
|
@@ -500,14 +500,18 @@
|
||||||
|
INSERT INTO t1 VALUES('c', 'd');
|
||||||
|
}
|
||||||
|
|
||||||
|
+if {$tcl_platform(byteOrder)=="littleEndian"} {
|
||||||
|
+ set res {X'02000000'}
|
||||||
|
+} else {
|
||||||
|
+ set res {X'00000002'}
|
||||||
|
+}
|
||||||
|
do_execsql_test 15.1 {
|
||||||
|
SELECT quote(matchinfo(t1, 'n')) FROM t1 LIMIT 1;
|
||||||
|
-} {X'02000000'}
|
||||||
|
-
|
||||||
|
+} $res
|
||||||
|
do_execsql_test 15.2 {
|
||||||
|
DELETE FROM t1_content WHERE rowid=1;
|
||||||
|
SELECT quote(matchinfo(t1, 'n')) FROM t1 LIMIT 1;
|
||||||
|
-} {X'02000000'}
|
||||||
|
+} $res
|
||||||
|
|
||||||
|
fts5_aux_test_functions db
|
||||||
|
do_execsql_test 15.3 {
|
||||||
|
@@ -517,4 +521,3 @@
|
||||||
|
}
|
||||||
|
|
||||||
|
finish_test
|
||||||
|
-
|
||||||
|
--- /src/insert.c
|
||||||
|
+++ /src/insert.c
|
||||||
|
@@ -2170,12 +2170,14 @@
|
||||||
|
x = *sqlite3VdbeGetOp(v, addrConflictCk);
|
||||||
|
if( x.opcode!=OP_IdxRowid ){
|
||||||
|
int p2; /* New P2 value for copied conflict check opcode */
|
||||||
|
+ const char *zP4;
|
||||||
|
if( sqlite3OpcodeProperty[x.opcode]&OPFLG_JUMP ){
|
||||||
|
p2 = lblRecheckOk;
|
||||||
|
}else{
|
||||||
|
p2 = x.p2;
|
||||||
|
}
|
||||||
|
- sqlite3VdbeAddOp4(v, x.opcode, x.p1, p2, x.p3, x.p4.z, x.p4type);
|
||||||
|
+ zP4 = x.p4type==P4_INT32 ? SQLITE_INT_TO_PTR(x.p4.i) : x.p4.z;
|
||||||
|
+ sqlite3VdbeAddOp4(v, x.opcode, x.p1, p2, x.p3, zP4, x.p4type);
|
||||||
|
sqlite3VdbeChangeP5(v, x.p5);
|
||||||
|
VdbeCoverageIf(v, p2!=x.p2);
|
||||||
|
}
|
||||||
|
--- /test/fts4aa.test
|
||||||
|
+++ /test/fts4aa.test
|
||||||
|
@@ -229,13 +229,18 @@
|
||||||
|
# 2019-11-18 https://bugs.chromium.org/p/chromium/issues/detail?id=1025467
|
||||||
|
db close
|
||||||
|
sqlite3 db :memory:
|
||||||
|
+if {$tcl_platform(byteOrder)=="littleEndian"} {
|
||||||
|
+ set res {X'0200000000000000000000000E0000000E00000001000000010000000100000001000000'}
|
||||||
|
+} else {
|
||||||
|
+ set res {X'0000000200000000000000000000000E0000000E00000001000000010000000100000001'}
|
||||||
|
+}
|
||||||
|
do_execsql_test fts4aa-6.10 {
|
||||||
|
CREATE VIRTUAL TABLE f USING fts4();
|
||||||
|
INSERT INTO f_segdir VALUES (77,91,0,0,'255 77',x'0001308000004d5c4ddddddd4d4d7b4d4d4d614d8019ff4d05000001204d4d2e4d6e4d4d4d4b4d6c4d004d4d4d4d4d4d3d000000004d5d4d4d645d4d004d4d4d4d4d4d4d4d4d454d6910004d05ffff054d646c4d004d5d4d4d4d4d3d000000004d4d4d4d4d4d4d4d4d4d4d69624d4d4d04004d4d4d4d4d604d4ce1404d554d45');
|
||||||
|
INSERT INTO f_segdir VALUES (77,108,0,0,'255 77',x'0001310000fa64004d4d4d3c5d4d654d4d4d614d8000ff4d05000001204d4d2e4d6e4d4d4dff4d4d4d4d4d4d00104d4d4d4d000000004d4d4d0400311d4d4d4d4d4d4d4d4d4d684d6910004d05ffff054d4d6c4d004d4d4d4d4d4d3d000000004d4d4d4d644d4d4d4d4d4d69624d4d4d03ed4d4d4d4d4d604d4ce1404d550080');
|
||||||
|
INSERT INTO f_stat VALUES (0,x'80808080100000000064004d4d4d3c4d4d654d4d4d614d8000ff4df6ff1a00204d4d2e4d6e4d4d4d104d4d4d4d4d4d00104d4d4d4d4d4d69574d4d4d000031044d4d4d3e4d4d4c4d05004d6910');
|
||||||
|
SELECT quote(matchinfo(f,'pnax')) from f where f match '0 1';
|
||||||
|
-} {X'0200000000000000000000000E0000000E00000001000000010000000100000001000000'}
|
||||||
|
+} $res
|
||||||
|
|
||||||
|
# 2019-11-18 Detect infinite loop in fts3SelectLeaf()
|
||||||
|
db close
|
@ -0,0 +1,163 @@
|
|||||||
|
https://sqlite.org/cgi/src/info/9d0d4ab95dc0c56e
|
||||||
|
https://sqlite.org/cgi/src/info/abc473fb8fb99900
|
||||||
|
https://sqlite.org/cgi/src/info/5aeb5a2d295e10d5
|
||||||
|
https://sqlite.org/cgi/src/info/a67cf5b7d37d5b14
|
||||||
|
https://sqlite.org/cgi/src/info/14d14eb537075c6a
|
||||||
|
https://sqlite.org/cgi/src/info/c431b3fd8fd0f6a6
|
||||||
|
|
||||||
|
--- /src/expr.c
|
||||||
|
+++ /src/expr.c
|
||||||
|
@@ -5463,19 +5463,25 @@
|
||||||
|
case TK_LT:
|
||||||
|
case TK_LE:
|
||||||
|
case TK_GT:
|
||||||
|
- case TK_GE:
|
||||||
|
+ case TK_GE: {
|
||||||
|
+ Expr *pLeft = pExpr->pLeft;
|
||||||
|
+ Expr *pRight = pExpr->pRight;
|
||||||
|
testcase( pExpr->op==TK_EQ );
|
||||||
|
testcase( pExpr->op==TK_NE );
|
||||||
|
testcase( pExpr->op==TK_LT );
|
||||||
|
testcase( pExpr->op==TK_LE );
|
||||||
|
testcase( pExpr->op==TK_GT );
|
||||||
|
testcase( pExpr->op==TK_GE );
|
||||||
|
- if( (pExpr->pLeft->op==TK_COLUMN && IsVirtual(pExpr->pLeft->y.pTab))
|
||||||
|
- || (pExpr->pRight->op==TK_COLUMN && IsVirtual(pExpr->pRight->y.pTab))
|
||||||
|
+ /* The y.pTab=0 assignment in wherecode.c always happens after the
|
||||||
|
+ ** impliesNotNullRow() test */
|
||||||
|
+ if( (pLeft->op==TK_COLUMN && ALWAYS(pLeft->y.pTab!=0)
|
||||||
|
+ && IsVirtual(pLeft->y.pTab))
|
||||||
|
+ || (pRight->op==TK_COLUMN && ALWAYS(pRight->y.pTab!=0)
|
||||||
|
+ && IsVirtual(pRight->y.pTab))
|
||||||
|
){
|
||||||
|
- return WRC_Prune;
|
||||||
|
+ return WRC_Prune;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
+ }
|
||||||
|
default:
|
||||||
|
return WRC_Continue;
|
||||||
|
}
|
||||||
|
--- /src/resolve.c
|
||||||
|
+++ /src/resolve.c
|
||||||
|
@@ -1051,7 +1051,7 @@
|
||||||
|
assert( !ExprHasProperty(pExpr, EP_Reduced) );
|
||||||
|
/* Handle special cases of "x IS TRUE", "x IS FALSE", "x IS NOT TRUE",
|
||||||
|
** and "x IS NOT FALSE". */
|
||||||
|
- if( pRight->op==TK_ID ){
|
||||||
|
+ if( pRight && pRight->op==TK_ID ){
|
||||||
|
int rc = resolveExprStep(pWalker, pRight);
|
||||||
|
if( rc==WRC_Abort ) return WRC_Abort;
|
||||||
|
if( pRight->op==TK_TRUEFALSE ){
|
||||||
|
--- /src/select.c
|
||||||
|
+++ /src/select.c
|
||||||
|
@@ -2806,6 +2806,7 @@
|
||||||
|
/* Generate code to take the intersection of the two temporary
|
||||||
|
** tables.
|
||||||
|
*/
|
||||||
|
+ if( rc ) break;
|
||||||
|
assert( p->pEList );
|
||||||
|
iBreak = sqlite3VdbeMakeLabel(pParse);
|
||||||
|
iCont = sqlite3VdbeMakeLabel(pParse);
|
||||||
|
@@ -5148,7 +5149,7 @@
|
||||||
|
pNew = sqlite3ExprListAppend(pParse, pNew, pExpr);
|
||||||
|
sqlite3TokenInit(&sColname, zColname);
|
||||||
|
sqlite3ExprListSetName(pParse, pNew, &sColname, 0);
|
||||||
|
- if( pNew && (p->selFlags & SF_NestedFrom)!=0 ){
|
||||||
|
+ if( pNew && (p->selFlags & SF_NestedFrom)!=0 && !IN_RENAME_OBJECT ){
|
||||||
|
struct ExprList_item *pX = &pNew->a[pNew->nExpr-1];
|
||||||
|
sqlite3DbFree(db, pX->zEName);
|
||||||
|
if( pSub ){
|
||||||
|
--- /src/sqliteInt.h
|
||||||
|
+++ /src/sqliteInt.h
|
||||||
|
@@ -2153,8 +2153,11 @@
|
||||||
|
*/
|
||||||
|
#ifndef SQLITE_OMIT_VIRTUALTABLE
|
||||||
|
# define IsVirtual(X) ((X)->nModuleArg)
|
||||||
|
+# define ExprIsVtab(X) \
|
||||||
|
+ ((X)->op==TK_COLUMN && (X)->y.pTab!=0 && (X)->y.pTab->nModuleArg)
|
||||||
|
#else
|
||||||
|
# define IsVirtual(X) 0
|
||||||
|
+# define ExprIsVtab(X) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
--- /src/whereexpr.c
|
||||||
|
+++ /src/whereexpr.c
|
||||||
|
@@ -377,7 +377,8 @@
|
||||||
|
** MATCH(expression,vtab_column)
|
||||||
|
*/
|
||||||
|
pCol = pList->a[1].pExpr;
|
||||||
|
- if( pCol->op==TK_COLUMN && IsVirtual(pCol->y.pTab) ){
|
||||||
|
+ testcase( pCol->op==TK_COLUMN && pCol->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pCol) ){
|
||||||
|
for(i=0; i<ArraySize(aOp); i++){
|
||||||
|
if( sqlite3StrICmp(pExpr->u.zToken, aOp[i].zOp)==0 ){
|
||||||
|
*peOp2 = aOp[i].eOp2;
|
||||||
|
@@ -399,7 +400,8 @@
|
||||||
|
** with function names in an arbitrary case.
|
||||||
|
*/
|
||||||
|
pCol = pList->a[0].pExpr;
|
||||||
|
- if( pCol->op==TK_COLUMN && IsVirtual(pCol->y.pTab) ){
|
||||||
|
+ testcase( pCol->op==TK_COLUMN && pCol->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pCol) ){
|
||||||
|
sqlite3_vtab *pVtab;
|
||||||
|
sqlite3_module *pMod;
|
||||||
|
void (*xNotUsed)(sqlite3_context*,int,sqlite3_value**);
|
||||||
|
@@ -422,10 +424,12 @@
|
||||||
|
int res = 0;
|
||||||
|
Expr *pLeft = pExpr->pLeft;
|
||||||
|
Expr *pRight = pExpr->pRight;
|
||||||
|
- if( pLeft->op==TK_COLUMN && IsVirtual(pLeft->y.pTab) ){
|
||||||
|
+ testcase( pLeft->op==TK_COLUMN && pLeft->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pLeft) ){
|
||||||
|
res++;
|
||||||
|
}
|
||||||
|
- if( pRight && pRight->op==TK_COLUMN && IsVirtual(pRight->y.pTab) ){
|
||||||
|
+ testcase( pRight && pRight->op==TK_COLUMN && pRight->y.pTab==0 );
|
||||||
|
+ if( pRight && ExprIsVtab(pRight) ){
|
||||||
|
res++;
|
||||||
|
SWAP(Expr*, pLeft, pRight);
|
||||||
|
}
|
||||||
|
--- /test/altertab.test
|
||||||
|
+++ /test/altertab.test
|
||||||
|
@@ -613,4 +613,21 @@
|
||||||
|
SELECT sql FROM sqlite_master;
|
||||||
|
} {{CREATE TABLE t0 (c1 INTEGER, PRIMARY KEY(c1))}}
|
||||||
|
|
||||||
|
+# 2020-02-23 ticket f50af3e8a565776b
|
||||||
|
+reset_db
|
||||||
|
+do_execsql_test 19.100 {
|
||||||
|
+ CREATE TABLE t1(x);
|
||||||
|
+ CREATE VIEW t2 AS SELECT 1 FROM t1, (t1 AS a0, t1);
|
||||||
|
+ ALTER TABLE t1 RENAME TO t3;
|
||||||
|
+ SELECT sql FROM sqlite_master;
|
||||||
|
+} {{CREATE TABLE "t3"(x)} {CREATE VIEW t2 AS SELECT 1 FROM "t3", ("t3" AS a0, "t3")}}
|
||||||
|
+do_execsql_test 19.110 {
|
||||||
|
+ INSERT INTO t3(x) VALUES(123);
|
||||||
|
+ SELECT * FROM t2;
|
||||||
|
+} {1}
|
||||||
|
+do_execsql_test 19.120 {
|
||||||
|
+ INSERT INTO t3(x) VALUES('xyz');
|
||||||
|
+ SELECT * FROM t2;
|
||||||
|
+} {1 1 1 1 1 1 1 1}
|
||||||
|
+
|
||||||
|
finish_test
|
||||||
|
--- /test/windowfault.test
|
||||||
|
+++ /test/windowfault.test
|
||||||
|
@@ -263,4 +263,15 @@
|
||||||
|
faultsim_test_result {0 {}}
|
||||||
|
}
|
||||||
|
|
||||||
|
+do_faultsim_test 11 -faults oom* -prep {
|
||||||
|
+} -body {
|
||||||
|
+ execsql {
|
||||||
|
+ VALUES(false),(current_date collate binary)
|
||||||
|
+ intersect
|
||||||
|
+ values(count() not like group_concat(cast(cast(0e00 as text) as integer) <= NULL || 0.4e-0 || 0x8 & true ) over () collate rtrim);
|
||||||
|
+ }
|
||||||
|
+} -test {
|
||||||
|
+ faultsim_test_result {0 {}}
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
finish_test
|
@ -0,0 +1,20 @@
|
|||||||
|
https://sqlite.org/cgi/src/info/04885763c4cd00cb
|
||||||
|
|
||||||
|
--- /sqlite3.c
|
||||||
|
+++ /sqlite3.c
|
||||||
|
@@ -121302,12 +121302,14 @@
|
||||||
|
x = *sqlite3VdbeGetOp(v, addrConflictCk);
|
||||||
|
if( x.opcode!=OP_IdxRowid ){
|
||||||
|
int p2; /* New P2 value for copied conflict check opcode */
|
||||||
|
+ const char *zP4;
|
||||||
|
if( sqlite3OpcodeProperty[x.opcode]&OPFLG_JUMP ){
|
||||||
|
p2 = lblRecheckOk;
|
||||||
|
}else{
|
||||||
|
p2 = x.p2;
|
||||||
|
}
|
||||||
|
- sqlite3VdbeAddOp4(v, x.opcode, x.p1, p2, x.p3, x.p4.z, x.p4type);
|
||||||
|
+ zP4 = x.p4type==P4_INT32 ? SQLITE_INT_TO_PTR(x.p4.i) : x.p4.z;
|
||||||
|
+ sqlite3VdbeAddOp4(v, x.opcode, x.p1, p2, x.p3, zP4, x.p4type);
|
||||||
|
sqlite3VdbeChangeP5(v, x.p5);
|
||||||
|
VdbeCoverageIf(v, p2!=x.p2);
|
||||||
|
}
|
@ -0,0 +1,112 @@
|
|||||||
|
https://sqlite.org/cgi/src/info/9d0d4ab95dc0c56e
|
||||||
|
https://sqlite.org/cgi/src/info/abc473fb8fb99900
|
||||||
|
https://sqlite.org/cgi/src/info/5aeb5a2d295e10d5
|
||||||
|
https://sqlite.org/cgi/src/info/a67cf5b7d37d5b14
|
||||||
|
https://sqlite.org/cgi/src/info/c431b3fd8fd0f6a6
|
||||||
|
|
||||||
|
--- /sqlite3.c
|
||||||
|
+++ /sqlite3.c
|
||||||
|
@@ -17428,8 +17428,11 @@
|
||||||
|
*/
|
||||||
|
#ifndef SQLITE_OMIT_VIRTUALTABLE
|
||||||
|
# define IsVirtual(X) ((X)->nModuleArg)
|
||||||
|
+# define ExprIsVtab(X) \
|
||||||
|
+ ((X)->op==TK_COLUMN && (X)->y.pTab!=0 && (X)->y.pTab->nModuleArg)
|
||||||
|
#else
|
||||||
|
# define IsVirtual(X) 0
|
||||||
|
+# define ExprIsVtab(X) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -97816,7 +97819,7 @@
|
||||||
|
assert( !ExprHasProperty(pExpr, EP_Reduced) );
|
||||||
|
/* Handle special cases of "x IS TRUE", "x IS FALSE", "x IS NOT TRUE",
|
||||||
|
** and "x IS NOT FALSE". */
|
||||||
|
- if( pRight->op==TK_ID ){
|
||||||
|
+ if( pRight && pRight->op==TK_ID ){
|
||||||
|
int rc = resolveExprStep(pWalker, pRight);
|
||||||
|
if( rc==WRC_Abort ) return WRC_Abort;
|
||||||
|
if( pRight->op==TK_TRUEFALSE ){
|
||||||
|
@@ -104133,19 +104136,25 @@
|
||||||
|
case TK_LT:
|
||||||
|
case TK_LE:
|
||||||
|
case TK_GT:
|
||||||
|
- case TK_GE:
|
||||||
|
+ case TK_GE: {
|
||||||
|
+ Expr *pLeft = pExpr->pLeft;
|
||||||
|
+ Expr *pRight = pExpr->pRight;
|
||||||
|
testcase( pExpr->op==TK_EQ );
|
||||||
|
testcase( pExpr->op==TK_NE );
|
||||||
|
testcase( pExpr->op==TK_LT );
|
||||||
|
testcase( pExpr->op==TK_LE );
|
||||||
|
testcase( pExpr->op==TK_GT );
|
||||||
|
testcase( pExpr->op==TK_GE );
|
||||||
|
- if( (pExpr->pLeft->op==TK_COLUMN && IsVirtual(pExpr->pLeft->y.pTab))
|
||||||
|
- || (pExpr->pRight->op==TK_COLUMN && IsVirtual(pExpr->pRight->y.pTab))
|
||||||
|
+ /* The y.pTab=0 assignment in wherecode.c always happens after the
|
||||||
|
+ ** impliesNotNullRow() test */
|
||||||
|
+ if( (pLeft->op==TK_COLUMN && ALWAYS(pLeft->y.pTab!=0)
|
||||||
|
+ && IsVirtual(pLeft->y.pTab))
|
||||||
|
+ || (pRight->op==TK_COLUMN && ALWAYS(pRight->y.pTab!=0)
|
||||||
|
+ && IsVirtual(pRight->y.pTab))
|
||||||
|
){
|
||||||
|
- return WRC_Prune;
|
||||||
|
+ return WRC_Prune;
|
||||||
|
}
|
||||||
|
-
|
||||||
|
+ }
|
||||||
|
default:
|
||||||
|
return WRC_Continue;
|
||||||
|
}
|
||||||
|
@@ -130673,6 +130682,7 @@
|
||||||
|
/* Generate code to take the intersection of the two temporary
|
||||||
|
** tables.
|
||||||
|
*/
|
||||||
|
+ if( rc ) break;
|
||||||
|
assert( p->pEList );
|
||||||
|
iBreak = sqlite3VdbeMakeLabel(pParse);
|
||||||
|
iCont = sqlite3VdbeMakeLabel(pParse);
|
||||||
|
@@ -133015,7 +133025,7 @@
|
||||||
|
pNew = sqlite3ExprListAppend(pParse, pNew, pExpr);
|
||||||
|
sqlite3TokenInit(&sColname, zColname);
|
||||||
|
sqlite3ExprListSetName(pParse, pNew, &sColname, 0);
|
||||||
|
- if( pNew && (p->selFlags & SF_NestedFrom)!=0 ){
|
||||||
|
+ if( pNew && (p->selFlags & SF_NestedFrom)!=0 && !IN_RENAME_OBJECT ){
|
||||||
|
struct ExprList_item *pX = &pNew->a[pNew->nExpr-1];
|
||||||
|
sqlite3DbFree(db, pX->zEName);
|
||||||
|
if( pSub ){
|
||||||
|
@@ -142593,7 +142603,8 @@
|
||||||
|
** MATCH(expression,vtab_column)
|
||||||
|
*/
|
||||||
|
pCol = pList->a[1].pExpr;
|
||||||
|
- if( pCol->op==TK_COLUMN && IsVirtual(pCol->y.pTab) ){
|
||||||
|
+ testcase( pCol->op==TK_COLUMN && pCol->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pCol) ){
|
||||||
|
for(i=0; i<ArraySize(aOp); i++){
|
||||||
|
if( sqlite3StrICmp(pExpr->u.zToken, aOp[i].zOp)==0 ){
|
||||||
|
*peOp2 = aOp[i].eOp2;
|
||||||
|
@@ -142615,7 +142626,8 @@
|
||||||
|
** with function names in an arbitrary case.
|
||||||
|
*/
|
||||||
|
pCol = pList->a[0].pExpr;
|
||||||
|
- if( pCol->op==TK_COLUMN && IsVirtual(pCol->y.pTab) ){
|
||||||
|
+ testcase( pCol->op==TK_COLUMN && pCol->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pCol) ){
|
||||||
|
sqlite3_vtab *pVtab;
|
||||||
|
sqlite3_module *pMod;
|
||||||
|
void (*xNotUsed)(sqlite3_context*,int,sqlite3_value**);
|
||||||
|
@@ -142638,10 +142650,12 @@
|
||||||
|
int res = 0;
|
||||||
|
Expr *pLeft = pExpr->pLeft;
|
||||||
|
Expr *pRight = pExpr->pRight;
|
||||||
|
- if( pLeft->op==TK_COLUMN && IsVirtual(pLeft->y.pTab) ){
|
||||||
|
+ testcase( pLeft->op==TK_COLUMN && pLeft->y.pTab==0 );
|
||||||
|
+ if( ExprIsVtab(pLeft) ){
|
||||||
|
res++;
|
||||||
|
}
|
||||||
|
- if( pRight && pRight->op==TK_COLUMN && IsVirtual(pRight->y.pTab) ){
|
||||||
|
+ testcase( pRight && pRight->op==TK_COLUMN && pRight->y.pTab==0 );
|
||||||
|
+ if( pRight && ExprIsVtab(pRight) ){
|
||||||
|
res++;
|
||||||
|
SWAP(Expr*, pLeft, pRight);
|
||||||
|
}
|
@ -5,6 +5,11 @@
|
|||||||
<email>arfrever.fta@gmail.com</email>
|
<email>arfrever.fta@gmail.com</email>
|
||||||
<name>Arfrever Frehtes Taifersar Arahesis</name>
|
<name>Arfrever Frehtes Taifersar Arahesis</name>
|
||||||
</maintainer>
|
</maintainer>
|
||||||
|
<maintainer type="person">
|
||||||
|
<email>floppym@gentoo.org</email>
|
||||||
|
<name>Mike Gilbert</name>
|
||||||
|
<description>Proxy</description>
|
||||||
|
</maintainer>
|
||||||
<use>
|
<use>
|
||||||
<flag name="secure-delete">Enable overwriting of deleted content with zeros by default (http://sqlite.org/pragma.html#pragma_secure_delete), causing some performance penalty</flag>
|
<flag name="secure-delete">Enable overwriting of deleted content with zeros by default (http://sqlite.org/pragma.html#pragma_secure_delete), causing some performance penalty</flag>
|
||||||
<flag name="tools">Install additional tools</flag>
|
<flag name="tools">Install additional tools</flag>
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Copyright 1999-2019 Gentoo Authors
|
# Copyright 1999-2020 Gentoo Authors
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
EAPI="7"
|
EAPI="7"
|
||||||
@ -25,7 +25,7 @@ fi
|
|||||||
|
|
||||||
LICENSE="public-domain"
|
LICENSE="public-domain"
|
||||||
SLOT="3"
|
SLOT="3"
|
||||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sh ~sparc ~x86 ~ppc-aix ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 m68k ~mips ppc ppc64 ~riscv s390 sparc x86 ~ppc-aix ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
||||||
IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
|
IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
|
||||||
if [[ "${PV}" == "9999" ]]; then
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
PROPERTIES="live"
|
PROPERTIES="live"
|
||||||
|
@ -1,41 +1,55 @@
|
|||||||
# Copyright 1999-2019 Gentoo Authors
|
# Copyright 1999-2020 Gentoo Authors
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
EAPI="7"
|
EAPI="7"
|
||||||
|
|
||||||
inherit autotools flag-o-matic multilib-minimal toolchain-funcs
|
inherit autotools flag-o-matic multilib-minimal toolchain-funcs
|
||||||
|
|
||||||
SRC_PV="$(printf "%u%02u%02u%02u" $(ver_rs 1- " "))"
|
if [[ "${PV}" != "9999" ]]; then
|
||||||
DOC_PV="${SRC_PV}"
|
SRC_PV="$(printf "%u%02u%02u%02u" $(ver_rs 1- " "))"
|
||||||
# DOC_PV="$(printf "%u%02u%02u00" $(ver_rs 1-3 " "))"
|
DOC_PV="${SRC_PV}"
|
||||||
|
# DOC_PV="$(printf "%u%02u%02u00" $(ver_rs 1-3 " "))"
|
||||||
|
fi
|
||||||
|
|
||||||
DESCRIPTION="SQL database engine"
|
DESCRIPTION="SQL database engine"
|
||||||
HOMEPAGE="https://sqlite.org/"
|
HOMEPAGE="https://sqlite.org/"
|
||||||
SRC_URI="doc? ( https://sqlite.org/2019/${PN}-doc-${DOC_PV}.zip )
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
tcl? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
SRC_URI=""
|
||||||
test? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
else
|
||||||
tools? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
SRC_URI="doc? ( https://sqlite.org/2019/${PN}-doc-${DOC_PV}.zip )
|
||||||
!tcl? ( !test? ( !tools? ( https://sqlite.org/2019/${PN}-autoconf-${SRC_PV}.tar.gz ) ) )"
|
tcl? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
||||||
|
test? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
||||||
|
tools? ( https://sqlite.org/2019/${PN}-src-${SRC_PV}.zip )
|
||||||
|
!tcl? ( !test? ( !tools? ( https://sqlite.org/2019/${PN}-autoconf-${SRC_PV}.tar.gz ) ) )"
|
||||||
|
fi
|
||||||
|
|
||||||
LICENSE="public-domain"
|
LICENSE="public-domain"
|
||||||
SLOT="3"
|
SLOT="3"
|
||||||
KEYWORDS="alpha amd64 arm arm64 hppa ia64 ~m68k ~mips ppc ppc64 ~riscv s390 ~sh sparc x86 ~ppc-aix ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 ~m68k ~mips ppc ppc64 ~riscv s390 sparc x86 ~ppc-aix ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
||||||
IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
|
IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
PROPERTIES="live"
|
||||||
|
fi
|
||||||
RESTRICT="!test? ( test )"
|
RESTRICT="!test? ( test )"
|
||||||
|
|
||||||
BDEPEND="doc? ( app-arch/unzip )
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
tcl? (
|
BDEPEND=">=dev-lang/tcl-8.6:0
|
||||||
app-arch/unzip
|
dev-vcs/fossil"
|
||||||
>=dev-lang/tcl-8.6:0
|
else
|
||||||
)
|
BDEPEND="doc? ( app-arch/unzip )
|
||||||
test? (
|
tcl? (
|
||||||
app-arch/unzip
|
app-arch/unzip
|
||||||
>=dev-lang/tcl-8.6:0
|
>=dev-lang/tcl-8.6:0
|
||||||
)
|
)
|
||||||
tools? (
|
test? (
|
||||||
app-arch/unzip
|
app-arch/unzip
|
||||||
>=dev-lang/tcl-8.6:0
|
>=dev-lang/tcl-8.6:0
|
||||||
)"
|
)
|
||||||
|
tools? (
|
||||||
|
app-arch/unzip
|
||||||
|
>=dev-lang/tcl-8.6:0
|
||||||
|
)"
|
||||||
|
fi
|
||||||
RDEPEND="sys-libs/zlib:0=[${MULTILIB_USEDEP}]
|
RDEPEND="sys-libs/zlib:0=[${MULTILIB_USEDEP}]
|
||||||
icu? ( dev-libs/icu:0=[${MULTILIB_USEDEP}] )
|
icu? ( dev-libs/icu:0=[${MULTILIB_USEDEP}] )
|
||||||
readline? ( sys-libs/readline:0=[${MULTILIB_USEDEP}] )
|
readline? ( sys-libs/readline:0=[${MULTILIB_USEDEP}] )
|
||||||
@ -45,22 +59,72 @@ DEPEND="${RDEPEND}
|
|||||||
test? ( >=dev-lang/tcl-8.6:0[${MULTILIB_USEDEP}] )"
|
test? ( >=dev-lang/tcl-8.6:0[${MULTILIB_USEDEP}] )"
|
||||||
|
|
||||||
full_archive() {
|
full_archive() {
|
||||||
use tcl || use test || use tools
|
[[ "${PV}" == "9999" ]] || use tcl || use test || use tools
|
||||||
}
|
}
|
||||||
|
|
||||||
pkg_setup() {
|
pkg_setup() {
|
||||||
if full_archive; then
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
S="${WORKDIR}/${PN}-src-${SRC_PV}"
|
S="${WORKDIR}/${PN}"
|
||||||
else
|
else
|
||||||
S="${WORKDIR}/${PN}-autoconf-${SRC_PV}"
|
if full_archive; then
|
||||||
|
S="${WORKDIR}/${PN}-src-${SRC_PV}"
|
||||||
|
else
|
||||||
|
S="${WORKDIR}/${PN}-autoconf-${SRC_PV}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
src_unpack() {
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
local distdir="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}"
|
||||||
|
addwrite "${distdir}"
|
||||||
|
mkdir -p "${distdir}/fossil-src/${PN}" || die
|
||||||
|
|
||||||
|
mkdir "${WORKDIR}/${PN}" || die
|
||||||
|
pushd "${WORKDIR}/${PN}" > /dev/null || die
|
||||||
|
if [[ ! -f "${distdir}/fossil-src/${PN}/sqlite.fossil" ]]; then
|
||||||
|
einfo fossil clone --verbose https://sqlite.org/src sqlite.fossil
|
||||||
|
fossil clone --verbose https://sqlite.org/src sqlite.fossil || die
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
cp -p "${distdir}/fossil-src/${PN}/sqlite.fossil" . || die
|
||||||
|
einfo fossil pull --repository sqlite.fossil --verbose https://sqlite.org/src
|
||||||
|
fossil pull --repository sqlite.fossil --verbose https://sqlite.org/src || die
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
cp -p sqlite.fossil "${distdir}/fossil-src/${PN}" || die
|
||||||
|
einfo fossil open --quiet sqlite.fossil
|
||||||
|
fossil open --quiet sqlite.fossil || die
|
||||||
|
echo
|
||||||
|
popd > /dev/null || die
|
||||||
|
|
||||||
|
if use doc; then
|
||||||
|
mkdir "${WORKDIR}/${PN}-doc" || die
|
||||||
|
pushd "${WORKDIR}/${PN}-doc" > /dev/null || die
|
||||||
|
if [[ ! -f "${distdir}/fossil-src/${PN}/sqlite-doc.fossil" ]]; then
|
||||||
|
einfo fossil clone --verbose https://sqlite.org/docsrc sqlite-doc.fossil
|
||||||
|
fossil clone --verbose https://sqlite.org/docsrc sqlite-doc.fossil || die
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
cp -p "${distdir}/fossil-src/${PN}/sqlite-doc.fossil" . || die
|
||||||
|
einfo fossil pull --repository sqlite-doc.fossil --verbose https://sqlite.org/docsrc
|
||||||
|
fossil pull --repository sqlite-doc.fossil --verbose https://sqlite.org/docsrc || die
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
cp -p sqlite-doc.fossil "${distdir}/fossil-src/${PN}" || die
|
||||||
|
einfo fossil open --quiet sqlite-doc.fossil
|
||||||
|
fossil open --quiet sqlite-doc.fossil || die
|
||||||
|
echo
|
||||||
|
popd > /dev/null || die
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
default
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
src_prepare() {
|
src_prepare() {
|
||||||
if full_archive; then
|
if full_archive; then
|
||||||
eapply "${FILESDIR}/${PN}-3.28.0-full_archive-build.patch"
|
eapply "${FILESDIR}/${PN}-3.29.0-full_archive-build.patch"
|
||||||
eapply "${FILESDIR}/${PN}-3.28.0-full_archive-segmentation_fault_fixes.patch"
|
|
||||||
eapply "${FILESDIR}/${PN}-3.28.0-full_archive-tests.patch"
|
|
||||||
|
|
||||||
eapply_user
|
eapply_user
|
||||||
|
|
||||||
@ -69,7 +133,6 @@ src_prepare() {
|
|||||||
sed -e "s/AC_CHECK_FUNCS(.*)/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" -i configure.ac || die "sed failed"
|
sed -e "s/AC_CHECK_FUNCS(.*)/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" -i configure.ac || die "sed failed"
|
||||||
else
|
else
|
||||||
eapply "${FILESDIR}/${PN}-3.25.0-nonfull_archive-build.patch"
|
eapply "${FILESDIR}/${PN}-3.25.0-nonfull_archive-build.patch"
|
||||||
eapply "${FILESDIR}/${PN}-3.28.0-nonfull_archive-segmentation_fault_fixes.patch"
|
|
||||||
|
|
||||||
eapply_user
|
eapply_user
|
||||||
|
|
||||||
@ -87,7 +150,8 @@ src_prepare() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
multilib_src_configure() {
|
multilib_src_configure() {
|
||||||
local CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}" options=()
|
local -x CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}"
|
||||||
|
local options=()
|
||||||
|
|
||||||
options+=(
|
options+=(
|
||||||
--enable-$(full_archive && echo load-extension || echo dynamic-extensions)
|
--enable-$(full_archive && echo load-extension || echo dynamic-extensions)
|
||||||
@ -186,12 +250,6 @@ multilib_src_configure() {
|
|||||||
# https://sqlite.org/compile.html#enable_update_delete_limit
|
# https://sqlite.org/compile.html#enable_update_delete_limit
|
||||||
append-cppflags -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT
|
append-cppflags -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT
|
||||||
|
|
||||||
# Support PRAGMA function_list, PRAGMA module_list and PRAGMA pragma_list statements.
|
|
||||||
# https://sqlite.org/pragma.html#pragma_function_list
|
|
||||||
# https://sqlite.org/pragma.html#pragma_module_list
|
|
||||||
# https://sqlite.org/pragma.html#pragma_pragma_list
|
|
||||||
append-cppflags -DSQLITE_INTROSPECTION_PRAGMAS
|
|
||||||
|
|
||||||
# Support soundex() function.
|
# Support soundex() function.
|
||||||
# https://sqlite.org/lang_corefunc.html#soundex
|
# https://sqlite.org/lang_corefunc.html#soundex
|
||||||
append-cppflags -DSQLITE_SOUNDEX
|
append-cppflags -DSQLITE_SOUNDEX
|
||||||
@ -316,12 +374,12 @@ multilib_src_install() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
multilib_src_install_all() {
|
multilib_src_install_all() {
|
||||||
find "${D}" -name "*.la" -delete || die
|
find "${D}" -name "*.la" -type f -delete || die
|
||||||
|
|
||||||
doman sqlite3.1
|
doman sqlite3.1
|
||||||
|
|
||||||
if use doc; then
|
if use doc; then
|
||||||
rm "${WORKDIR}/${PN}-doc-${DOC_PV}/"*.{db,txt}
|
rm "${WORKDIR}/${PN}-doc-${DOC_PV}/"*.{db,txt} || die
|
||||||
(
|
(
|
||||||
docinto html
|
docinto html
|
||||||
dodoc -r "${WORKDIR}/${PN}-doc-${DOC_PV}/"*
|
dodoc -r "${WORKDIR}/${PN}-doc-${DOC_PV}/"*
|
392
sdk_container/src/third_party/portage-stable/dev-db/sqlite/sqlite-3.31.1.ebuild
vendored
Normal file
392
sdk_container/src/third_party/portage-stable/dev-db/sqlite/sqlite-3.31.1.ebuild
vendored
Normal file
@ -0,0 +1,392 @@
|
|||||||
|
# Copyright 1999-2020 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI="7"
|
||||||
|
|
||||||
|
inherit autotools flag-o-matic multilib-minimal toolchain-funcs
|
||||||
|
|
||||||
|
if [[ "${PV}" != "9999" ]]; then
|
||||||
|
SRC_PV="$(printf "%u%02u%02u%02u" $(ver_rs 1- " "))"
|
||||||
|
DOC_PV="${SRC_PV}"
|
||||||
|
# DOC_PV="$(printf "%u%02u%02u00" $(ver_rs 1-3 " "))"
|
||||||
|
fi
|
||||||
|
|
||||||
|
DESCRIPTION="SQL database engine"
|
||||||
|
HOMEPAGE="https://sqlite.org/"
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
SRC_URI=""
|
||||||
|
else
|
||||||
|
SRC_URI="doc? ( https://sqlite.org/2020/${PN}-doc-${DOC_PV}.zip )
|
||||||
|
tcl? ( https://sqlite.org/2020/${PN}-src-${SRC_PV}.zip )
|
||||||
|
test? ( https://sqlite.org/2020/${PN}-src-${SRC_PV}.zip )
|
||||||
|
tools? ( https://sqlite.org/2020/${PN}-src-${SRC_PV}.zip )
|
||||||
|
!tcl? ( !test? ( !tools? ( https://sqlite.org/2020/${PN}-autoconf-${SRC_PV}.tar.gz ) ) )"
|
||||||
|
fi
|
||||||
|
|
||||||
|
LICENSE="public-domain"
|
||||||
|
SLOT="3"
|
||||||
|
KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 ~m68k ~mips ppc ppc64 ~riscv s390 sparc x86 ~ppc-aix ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
|
||||||
|
IUSE="debug doc icu +readline secure-delete static-libs tcl test tools"
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
PROPERTIES="live"
|
||||||
|
fi
|
||||||
|
RESTRICT="!test? ( test )"
|
||||||
|
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
BDEPEND=">=dev-lang/tcl-8.6:0
|
||||||
|
dev-vcs/fossil"
|
||||||
|
else
|
||||||
|
BDEPEND="doc? ( app-arch/unzip )
|
||||||
|
tcl? (
|
||||||
|
app-arch/unzip
|
||||||
|
>=dev-lang/tcl-8.6:0
|
||||||
|
)
|
||||||
|
test? (
|
||||||
|
app-arch/unzip
|
||||||
|
>=dev-lang/tcl-8.6:0
|
||||||
|
)
|
||||||
|
tools? (
|
||||||
|
app-arch/unzip
|
||||||
|
>=dev-lang/tcl-8.6:0
|
||||||
|
)"
|
||||||
|
fi
|
||||||
|
RDEPEND="sys-libs/zlib:0=[${MULTILIB_USEDEP}]
|
||||||
|
icu? ( dev-libs/icu:0=[${MULTILIB_USEDEP}] )
|
||||||
|
readline? ( sys-libs/readline:0=[${MULTILIB_USEDEP}] )
|
||||||
|
tcl? ( dev-lang/tcl:0=[${MULTILIB_USEDEP}] )
|
||||||
|
tools? ( dev-lang/tcl:0=[${MULTILIB_USEDEP}] )"
|
||||||
|
DEPEND="${RDEPEND}
|
||||||
|
test? ( >=dev-lang/tcl-8.6:0[${MULTILIB_USEDEP}] )"
|
||||||
|
|
||||||
|
full_archive() {
|
||||||
|
[[ "${PV}" == "9999" ]] || use tcl || use test || use tools
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_setup() {
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
S="${WORKDIR}/${PN}"
|
||||||
|
else
|
||||||
|
if full_archive; then
|
||||||
|
S="${WORKDIR}/${PN}-src-${SRC_PV}"
|
||||||
|
else
|
||||||
|
S="${WORKDIR}/${PN}-autoconf-${SRC_PV}"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
src_unpack() {
|
||||||
|
if [[ "${PV}" == "9999" ]]; then
|
||||||
|
local distdir="${PORTAGE_ACTUAL_DISTDIR:-${DISTDIR}}"
|
||||||
|
addwrite "${distdir}"
|
||||||
|
mkdir -p "${distdir}/fossil-src/${PN}" || die
|
||||||
|
|
||||||
|
mkdir "${WORKDIR}/${PN}" || die
|
||||||
|
pushd "${WORKDIR}/${PN}" > /dev/null || die
|
||||||
|
if [[ ! -f "${distdir}/fossil-src/${PN}/sqlite.fossil" ]]; then
|
||||||
|
einfo fossil clone --verbose https://sqlite.org/src sqlite.fossil
|
||||||
|
fossil clone --verbose https://sqlite.org/src sqlite.fossil || die
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
cp -p "${distdir}/fossil-src/${PN}/sqlite.fossil" . || die
|
||||||
|
einfo fossil pull --repository sqlite.fossil --verbose https://sqlite.org/src
|
||||||
|
fossil pull --repository sqlite.fossil --verbose https://sqlite.org/src || die
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
cp -p sqlite.fossil "${distdir}/fossil-src/${PN}" || die
|
||||||
|
einfo fossil open --quiet sqlite.fossil
|
||||||
|
fossil open --quiet sqlite.fossil || die
|
||||||
|
echo
|
||||||
|
popd > /dev/null || die
|
||||||
|
|
||||||
|
if use doc; then
|
||||||
|
mkdir "${WORKDIR}/${PN}-doc" || die
|
||||||
|
pushd "${WORKDIR}/${PN}-doc" > /dev/null || die
|
||||||
|
if [[ ! -f "${distdir}/fossil-src/${PN}/sqlite-doc.fossil" ]]; then
|
||||||
|
einfo fossil clone --verbose https://sqlite.org/docsrc sqlite-doc.fossil
|
||||||
|
fossil clone --verbose https://sqlite.org/docsrc sqlite-doc.fossil || die
|
||||||
|
echo
|
||||||
|
else
|
||||||
|
cp -p "${distdir}/fossil-src/${PN}/sqlite-doc.fossil" . || die
|
||||||
|
einfo fossil pull --repository sqlite-doc.fossil --verbose https://sqlite.org/docsrc
|
||||||
|
fossil pull --repository sqlite-doc.fossil --verbose https://sqlite.org/docsrc || die
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
cp -p sqlite-doc.fossil "${distdir}/fossil-src/${PN}" || die
|
||||||
|
einfo fossil open --quiet sqlite-doc.fossil
|
||||||
|
fossil open --quiet sqlite-doc.fossil || die
|
||||||
|
echo
|
||||||
|
popd > /dev/null || die
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
default
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
if full_archive; then
|
||||||
|
eapply "${FILESDIR}/${PN}-3.31.0-full_archive-build.patch"
|
||||||
|
eapply "${FILESDIR}/${PN}-3.31.1-full_archive-architectures.patch"
|
||||||
|
eapply "${FILESDIR}/${PN}-3.31.1-full_archive-security_fixes.patch"
|
||||||
|
|
||||||
|
eapply_user
|
||||||
|
|
||||||
|
# Fix AC_CHECK_FUNCS.
|
||||||
|
# https://mailinglists.sqlite.org/cgi-bin/mailman/private/sqlite-dev/2016-March/002762.html
|
||||||
|
sed -e "s/AC_CHECK_FUNCS(.*)/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" -i configure.ac || die "sed failed"
|
||||||
|
else
|
||||||
|
eapply "${FILESDIR}/${PN}-3.25.0-nonfull_archive-build.patch"
|
||||||
|
eapply "${FILESDIR}/${PN}-3.31.1-nonfull_archive-architectures.patch"
|
||||||
|
eapply "${FILESDIR}/${PN}-3.31.1-nonfull_archive-security_fixes.patch"
|
||||||
|
|
||||||
|
eapply_user
|
||||||
|
|
||||||
|
# Fix AC_CHECK_FUNCS.
|
||||||
|
# https://mailinglists.sqlite.org/cgi-bin/mailman/private/sqlite-dev/2016-March/002762.html
|
||||||
|
sed \
|
||||||
|
-e "s/AC_CHECK_FUNCS(\[fdatasync.*/AC_CHECK_FUNCS([fdatasync fullfsync gmtime_r isnan localtime_r localtime_s malloc_usable_size posix_fallocate pread pread64 pwrite pwrite64 strchrnul usleep utime])/" \
|
||||||
|
-e "/AC_CHECK_FUNCS(posix_fallocate)/d" \
|
||||||
|
-i configure.ac || die "sed failed"
|
||||||
|
fi
|
||||||
|
|
||||||
|
eautoreconf
|
||||||
|
|
||||||
|
multilib_copy_sources
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_configure() {
|
||||||
|
local -x CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}"
|
||||||
|
local options=()
|
||||||
|
|
||||||
|
options+=(
|
||||||
|
--enable-$(full_archive && echo load-extension || echo dynamic-extensions)
|
||||||
|
--enable-threadsafe
|
||||||
|
)
|
||||||
|
if ! full_archive; then
|
||||||
|
options+=(--disable-static-shell)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Support detection of misuse of SQLite API.
|
||||||
|
# https://sqlite.org/compile.html#enable_api_armor
|
||||||
|
append-cppflags -DSQLITE_ENABLE_API_ARMOR
|
||||||
|
|
||||||
|
# Support column metadata functions.
|
||||||
|
# https://sqlite.org/c3ref/column_database_name.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_COLUMN_METADATA
|
||||||
|
|
||||||
|
# Support sqlite_dbpage virtual table.
|
||||||
|
# https://sqlite.org/compile.html#enable_dbpage_vtab
|
||||||
|
append-cppflags -DSQLITE_ENABLE_DBPAGE_VTAB
|
||||||
|
|
||||||
|
# Support dbstat virtual table.
|
||||||
|
# https://sqlite.org/dbstat.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_DBSTAT_VTAB
|
||||||
|
|
||||||
|
# Support sqlite3_serialize() and sqlite3_deserialize() functions.
|
||||||
|
# https://sqlite.org/compile.html#enable_deserialize
|
||||||
|
# https://sqlite.org/c3ref/serialize.html
|
||||||
|
# https://sqlite.org/c3ref/deserialize.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_DESERIALIZE
|
||||||
|
|
||||||
|
# Support comments in output of EXPLAIN.
|
||||||
|
# https://sqlite.org/compile.html#enable_explain_comments
|
||||||
|
append-cppflags -DSQLITE_ENABLE_EXPLAIN_COMMENTS
|
||||||
|
|
||||||
|
# Support Full-Text Search versions 3, 4 and 5.
|
||||||
|
# https://sqlite.org/fts3.html
|
||||||
|
# https://sqlite.org/fts5.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_FTS3 -DSQLITE_ENABLE_FTS3_PARENTHESIS -DSQLITE_ENABLE_FTS4
|
||||||
|
options+=(--enable-fts5)
|
||||||
|
|
||||||
|
# Support hidden columns.
|
||||||
|
append-cppflags -DSQLITE_ENABLE_HIDDEN_COLUMNS
|
||||||
|
|
||||||
|
# Support JSON1 extension.
|
||||||
|
# https://sqlite.org/json1.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_JSON1
|
||||||
|
|
||||||
|
# Support memsys5 memory allocator.
|
||||||
|
# https://sqlite.org/malloc.html#memsys5
|
||||||
|
append-cppflags -DSQLITE_ENABLE_MEMSYS5
|
||||||
|
|
||||||
|
# Support sqlite3_normalized_sql() function.
|
||||||
|
# https://sqlite.org/c3ref/expanded_sql.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_NORMALIZE
|
||||||
|
|
||||||
|
# Support sqlite_offset() function.
|
||||||
|
# https://sqlite.org/lang_corefunc.html#sqlite_offset
|
||||||
|
append-cppflags -DSQLITE_ENABLE_OFFSET_SQL_FUNC
|
||||||
|
|
||||||
|
# Support pre-update hook functions.
|
||||||
|
# https://sqlite.org/c3ref/preupdate_count.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_PREUPDATE_HOOK
|
||||||
|
|
||||||
|
# Support Resumable Bulk Update extension.
|
||||||
|
# https://sqlite.org/rbu.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_RBU
|
||||||
|
|
||||||
|
# Support R*Trees.
|
||||||
|
# https://sqlite.org/rtree.html
|
||||||
|
# https://sqlite.org/geopoly.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_RTREE -DSQLITE_ENABLE_GEOPOLY
|
||||||
|
|
||||||
|
# Support scan status functions.
|
||||||
|
# https://sqlite.org/c3ref/stmt_scanstatus.html
|
||||||
|
# https://sqlite.org/c3ref/stmt_scanstatus_reset.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_STMT_SCANSTATUS
|
||||||
|
|
||||||
|
# Support sqlite_stmt virtual table.
|
||||||
|
# https://sqlite.org/stmt.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_STMTVTAB
|
||||||
|
|
||||||
|
# Support Session extension.
|
||||||
|
# https://sqlite.org/sessionintro.html
|
||||||
|
options+=(--enable-session)
|
||||||
|
|
||||||
|
# Support unknown() function.
|
||||||
|
# https://sqlite.org/compile.html#enable_unknown_sql_function
|
||||||
|
append-cppflags -DSQLITE_ENABLE_UNKNOWN_SQL_FUNCTION
|
||||||
|
|
||||||
|
# Support unlock notification.
|
||||||
|
# https://sqlite.org/unlock_notify.html
|
||||||
|
append-cppflags -DSQLITE_ENABLE_UNLOCK_NOTIFY
|
||||||
|
|
||||||
|
# Support LIMIT and ORDER BY clauses on DELETE and UPDATE statements.
|
||||||
|
# https://sqlite.org/compile.html#enable_update_delete_limit
|
||||||
|
append-cppflags -DSQLITE_ENABLE_UPDATE_DELETE_LIMIT
|
||||||
|
|
||||||
|
# Support soundex() function.
|
||||||
|
# https://sqlite.org/lang_corefunc.html#soundex
|
||||||
|
append-cppflags -DSQLITE_SOUNDEX
|
||||||
|
|
||||||
|
# Support URI filenames.
|
||||||
|
# https://sqlite.org/uri.html
|
||||||
|
append-cppflags -DSQLITE_USE_URI
|
||||||
|
|
||||||
|
# debug USE flag.
|
||||||
|
if full_archive; then
|
||||||
|
options+=($(use_enable debug))
|
||||||
|
else
|
||||||
|
if use debug; then
|
||||||
|
append-cppflags -DSQLITE_DEBUG
|
||||||
|
else
|
||||||
|
append-cppflags -DNDEBUG
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# icu USE flag.
|
||||||
|
if use icu; then
|
||||||
|
# Support ICU extension.
|
||||||
|
# https://sqlite.org/compile.html#enable_icu
|
||||||
|
append-cppflags -DSQLITE_ENABLE_ICU
|
||||||
|
if full_archive; then
|
||||||
|
sed -e "s/^TLIBS = @LIBS@/& -licui18n -licuuc/" -i Makefile.in || die "sed failed"
|
||||||
|
else
|
||||||
|
sed -e "s/^LIBS = @LIBS@/& -licui18n -licuuc/" -i Makefile.in || die "sed failed"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# readline USE flag.
|
||||||
|
options+=(
|
||||||
|
--disable-editline
|
||||||
|
$(use_enable readline)
|
||||||
|
)
|
||||||
|
if full_archive && use readline; then
|
||||||
|
options+=(--with-readline-inc="-I${EPREFIX}/usr/include/readline")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# secure-delete USE flag.
|
||||||
|
if use secure-delete; then
|
||||||
|
# Enable secure_delete pragma by default.
|
||||||
|
# https://sqlite.org/pragma.html#pragma_secure_delete
|
||||||
|
append-cppflags -DSQLITE_SECURE_DELETE
|
||||||
|
fi
|
||||||
|
|
||||||
|
# static-libs USE flag.
|
||||||
|
options+=($(use_enable static-libs static))
|
||||||
|
|
||||||
|
# tcl, test, tools USE flags.
|
||||||
|
if full_archive; then
|
||||||
|
options+=(--enable-tcl)
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${CHOST}" == *-mint* ]]; then
|
||||||
|
append-cppflags -DSQLITE_OMIT_WAL
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "${ABI}" == "x86" ]]; then
|
||||||
|
if $(tc-getCC) ${CPPFLAGS} ${CFLAGS} -E -P -dM - < /dev/null 2> /dev/null | grep -q "^#define __SSE__ 1$"; then
|
||||||
|
append-cflags -mfpmath=sse
|
||||||
|
else
|
||||||
|
append-cflags -ffloat-store
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
econf "${options[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_compile() {
|
||||||
|
emake HAVE_TCL="$(usex tcl 1 "")" TCLLIBDIR="${EPREFIX}/usr/$(get_libdir)/${P}"
|
||||||
|
|
||||||
|
if use tools && multilib_is_native_abi; then
|
||||||
|
emake changeset dbdump dbhash dbtotxt index_usage rbu scrub showdb showjournal showshm showstat4 showwal sqldiff sqlite3_analyzer sqlite3_checker sqlite3_expert sqltclsh
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_test() {
|
||||||
|
if [[ "${EUID}" -eq 0 ]]; then
|
||||||
|
ewarn "Skipping tests due to root permissions"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
local -x SQLITE_HISTORY="${T}/sqlite_history_${ABI}"
|
||||||
|
|
||||||
|
emake HAVE_TCL="$(usex tcl 1 "")" $(use debug && echo fulltest || echo test)
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_install() {
|
||||||
|
emake DESTDIR="${D}" HAVE_TCL="$(usex tcl 1 "")" TCLLIBDIR="${EPREFIX}/usr/$(get_libdir)/${P}" install
|
||||||
|
|
||||||
|
if use tools && multilib_is_native_abi; then
|
||||||
|
install_tool() {
|
||||||
|
if [[ -f ".libs/${1}" ]]; then
|
||||||
|
newbin ".libs/${1}" "${2}"
|
||||||
|
else
|
||||||
|
newbin "${1}" "${2}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
install_tool changeset sqlite3-changeset
|
||||||
|
install_tool dbdump sqlite3-db-dump
|
||||||
|
install_tool dbhash sqlite3-db-hash
|
||||||
|
install_tool dbtotxt sqlite3-db-to-txt
|
||||||
|
install_tool index_usage sqlite3-index-usage
|
||||||
|
install_tool rbu sqlite3-rbu
|
||||||
|
install_tool scrub sqlite3-scrub
|
||||||
|
install_tool showdb sqlite3-show-db
|
||||||
|
install_tool showjournal sqlite3-show-journal
|
||||||
|
install_tool showshm sqlite3-show-shm
|
||||||
|
install_tool showstat4 sqlite3-show-stat4
|
||||||
|
install_tool showwal sqlite3-show-wal
|
||||||
|
install_tool sqldiff sqlite3-diff
|
||||||
|
install_tool sqlite3_analyzer sqlite3-analyzer
|
||||||
|
install_tool sqlite3_checker sqlite3-checker
|
||||||
|
install_tool sqlite3_expert sqlite3-expert
|
||||||
|
install_tool sqltclsh sqlite3-tclsh
|
||||||
|
|
||||||
|
unset -f install_tool
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
multilib_src_install_all() {
|
||||||
|
find "${D}" -name "*.la" -type f -delete || die
|
||||||
|
|
||||||
|
doman sqlite3.1
|
||||||
|
|
||||||
|
if use doc; then
|
||||||
|
rm "${WORKDIR}/${PN}-doc-${DOC_PV}/"*.{db,txt} || die
|
||||||
|
(
|
||||||
|
docinto html
|
||||||
|
dodoc -r "${WORKDIR}/${PN}-doc-${DOC_PV}/"*
|
||||||
|
)
|
||||||
|
fi
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user