]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Fix a segfault that could occur if a query that used a vector comparison contained...
authordan <dan@noemail.net>
Sat, 20 Aug 2016 15:01:24 +0000 (15:01 +0000)
committerdan <dan@noemail.net>
Sat, 20 Aug 2016 15:01:24 +0000 (15:01 +0000)
FossilOrigin-Name: 203f07c5e140e74cf91d0c1e20135c21236f0fc1

manifest
manifest.uuid
src/expr.c
test/rowvalue4.test

index 04b3482aedde96d8c7652096c4cdd60ad28bc5bb..9c5692d52497f96e26254cea52d27f707e4e0f50 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Improvements\sto\sthe\svector\scomparison\ssplitter\sin\sexprAnalyze().
-D 2016-08-20T12:00:05.657
+C Fix\sa\ssegfault\sthat\scould\soccur\sif\sa\squery\sthat\sused\sa\svector\scomparison\scontained\scertain\stypes\sof\ssyntax\serrors.
+D 2016-08-20T15:01:24.921
 F Makefile.in cfd8fb987cd7a6af046daa87daa146d5aad0e088
 F Makefile.linux-gcc 7bc79876b875010e8c8f9502eb935ca92aa3c434
 F Makefile.msc d66d0395c38571aab3804f8db0fa20707ae4609a
@@ -338,7 +338,7 @@ F src/ctime.c e77f3dc297b4b65c96da78b4ae4272fdfae863d7
 F src/date.c 95c9a8d00767e7221a8e9a31f4e913fc8029bf6b
 F src/dbstat.c 19ee7a4e89979d4df8e44cfac7a8f905ec89b77d
 F src/delete.c 76c084f0265f4a3cd1ecf17eee112a94f1ccbc05
-F src/expr.c d5cffb307d4e812c41a6fb1f6bc94e6b0801e3e8
+F src/expr.c f1d9c4374246955b9a93edddfc3abfd3297d1455
 F src/fault.c 160a0c015b6c2629d3899ed2daf63d75754a32bb
 F src/fkey.c e2be0968c1adc679c87e467aa5b4f167588f38a8
 F src/func.c 29cc9acb170ec1387b9f63eb52cd85f8de96c771
@@ -1022,7 +1022,7 @@ F test/rowid.test 5b7509f384f4f6fae1af3c8c104c8ca299fea18d
 F test/rowvalue.test 56b34d31d91340a6e922e753b798880170cc1aa7
 F test/rowvalue2.test 875068299fd4dd50ef0a47786462c8e1f4065f9a
 F test/rowvalue3.test dbe935260851b197dfbbbcb0ac2a15cb5f324fd4
-F test/rowvalue4.test ed3f7974099f0fc508c9f95df55d37c49f43be65
+F test/rowvalue4.test 318cdd40e66dfae686537eea581ae49cbb01195d
 F test/rowvalue5.test 01c7e0bc4048f30b58e6eb27ecd26e5bd312635e
 F test/rowvalue6.test d19b54feb604d5601f8614b15e214e0774c01087
 F test/rowvalue7.test 3c9a127954d3da309a271babdfc43dbcc5c4da7f
@@ -1519,7 +1519,7 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
 F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 4165d20f64d778a4e48f511a37cfced8579d4dbe
-R 29e91d5826d73f7831f4580f57f08037
-U drh
-Z 96272366ac5b1657f908e6772496984c
+P a3ffd283bc931b04170ef737e56bced33d27f06d
+R b7a3d3965778241daed9250312140835
+U dan
+Z 9e9f2920cf64cc9378d276416e2ee3f8
index 72cde1cebca982dcb8328f8119adcf829c0ac44d..6e35ee275b6a8e7ae9fedcb1fd66a32c784f42e9 100644 (file)
@@ -1 +1 @@
-a3ffd283bc931b04170ef737e56bced33d27f06d
\ No newline at end of file
+203f07c5e140e74cf91d0c1e20135c21236f0fc1
\ No newline at end of file
index 5a5afe5ff3840de54d566fea795e3d9bc7ad63aa..0412919a240b9562181750787b9f04053d91755b 100644 (file)
@@ -462,8 +462,8 @@ static int exprVectorRegister(
   int *pRegFree                   /* OUT: Temp register to free */
 ){
   assert( pVector->op==TK_VECTOR || pVector->op==TK_SELECT );
-  assert( (pVector->op==TK_VECTOR)==(regSelect==0) );
-  if( regSelect ){
+  assert( pParse->nErr || (pVector->op==TK_VECTOR)==(regSelect==0) );
+  if( pVector->op==TK_SELECT ){
     *ppExpr = pVector->x.pSelect->pEList->a[iField].pExpr;
      return regSelect+iField;
   }
index 55401aa8a3538847a6657f273af325e07665d1e6..c4581d5562ba37739df57983aed0172fe6dcf820 100644 (file)
@@ -292,5 +292,21 @@ do_catchsql_test 7.4 {
   SELECT * FROM f1 WHERE (?, ? COLLATE nose) > (a, b);
 } {1 {no such collation sequence: nose}}
 
+#-------------------------------------------------------------------------
+drop_all_tables
+do_execsql_test 8.1 {
+  CREATE TABLE c1(x, y);
+  CREATE TABLE c2(a, b, c);
+  CREATE INDEX c2ab ON c2(a, b);
+  CREATE INDEX c2c ON c2(c);
+
+  CREATE TABLE c3(d);
+}
+do_catchsql_test 8.2 {
+  SELECT * FROM c2 CROSS JOIN c3 WHERE 
+    ( (a, b) == (SELECT x, y FROM c1) AND c3.d = c ) OR
+    ( c == (SELECT x, y FROM c1) AND c3.d = c )
+} {1 {sub-select returns 2 columns - expected 1}}
+
 finish_test