]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Make sure changes to virtual tables are counted the same as real tables.
authordrh <drh@noemail.net>
Thu, 10 Apr 2008 14:00:09 +0000 (14:00 +0000)
committerdrh <drh@noemail.net>
Thu, 10 Apr 2008 14:00:09 +0000 (14:00 +0000)
Ticket #3038. (CVS 4976)

FossilOrigin-Name: 55591fc49c8ab8146c1f3eff733e637501bff627

manifest
manifest.uuid
src/vdbe.c
test/vtab1.test

index 3d89725c050929cede75d230cf7773522715e2a5..5e05359d6ea652fa6eedd7a0011ac5255e45396c 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Fix\sto\sthe\s"copy"\smethod\sin\sthe\sTCL\sinterface.\s\sTicket\s#3039.\s(CVS\s4975)
-D 2008-04-10T13:42:56
+C Make\ssure\schanges\sto\svirtual\stables\sare\scounted\sthe\ssame\sas\sreal\stables.\nTicket\s#3038.\s(CVS\s4976)
+D 2008-04-10T14:00:10
 F Makefile.arm-wince-mingw32ce-gcc ac5f7b2cef0cd850d6f755ba6ee4ab961b1fadf7
 F Makefile.in b861627d91df5ee422c54237aa38296954dc0151
 F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
@@ -174,7 +174,7 @@ F src/update.c d6f214aad7eab5aaec5f966058b0828b3f7d6706
 F src/utf.c 8c94fa10efc78c2568d08d436acc59df4df7191b
 F src/util.c 02c57c302ef738ff5b554953c12d8f919e501583
 F src/vacuum.c 3524411bfb58aac0d87eadd3e5b7cd532772af30
-F src/vdbe.c edee197463d2505e38e4bf23adca8306e919dd18
+F src/vdbe.c 444ab9ecc91f3c04b2b29ae604458426aa674fa6
 F src/vdbe.h f72201a0657d5f3d6cc008d1f8d9cc65768518c9
 F src/vdbeInt.h 0b96efdeecb0803e504bf1c16b198f87c91d6019
 F src/vdbeapi.c ab6e99f8a6b7fcb82c2c698da7a36762a7593f0a
@@ -524,7 +524,7 @@ F test/vacuum3.test 72fbc903b085cd5f8b3a513b23f8ce44f7e0b06f
 F test/varint.test ab7b110089a08b9926ed7390e7e97bdefeb74102
 F test/veryquick.test 93fd0500c367e6c03ea757071cfe4ca749533946
 F test/view.test 4864e3841ab3213a95297718b94d5d6a8d3bc78b
-F test/vtab1.test bd905d1d43637a700308da6ffcc4e014c27e2f0a
+F test/vtab1.test 4a2015dbf875112dacd96ab3fdaf6ff514d68e4c
 F test/vtab2.test 1da49b015582965a8fc386aa23d051a5a622b08e
 F test/vtab3.test f38d6d7d19f08bffdadce4d5b8cba078f8118587
 F test/vtab4.test a9d7104d41a787754a734740d7aa61c807a69f87
@@ -625,7 +625,7 @@ F www/tclsqlite.tcl 8be95ee6dba05eabcd27a9d91331c803f2ce2130
 F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0
 F www/version3.tcl 890248cf7b70e60c383b0e84d77d5132b3ead42b
 F www/whentouse.tcl fc46eae081251c3c181bd79c5faef8195d7991a5
-P b390e1f7f8d2b530a6765f2ab6804335c5550870
-R 05691c706afc7be18825eef92254ef73
+P 6f07968ec4c9d773a852ecc8343df416d17af2a4
+R bd0175fc475a5bdf6485d3176fb40c11
 U drh
-Z 9d91ed872ad230ff656f02026d9d6051
+Z 0137cb2b33b517f6dae0cbba0b9baee6
index 528e19eed88a32665ee869c386e051c016e92eba..4470063800eaa68f0d44f78100db83cfd5afe8dc 100644 (file)
@@ -1 +1 @@
-6f07968ec4c9d773a852ecc8343df416d17af2a4
\ No newline at end of file
+55591fc49c8ab8146c1f3eff733e637501bff627
\ No newline at end of file
index 793e1211943fd2c7bd39da15b237e05f808197a5..7a45f6416340241e80c05d2a74e3df44d1df799c 100644 (file)
@@ -43,7 +43,7 @@
 ** in this file for details.  If in doubt, do not deviate from existing
 ** commenting and indentation practices when changing or adding code.
 **
-** $Id: vdbe.c,v 1.728 2008/04/05 18:41:43 drh Exp $
+** $Id: vdbe.c,v 1.729 2008/04/10 14:00:10 drh Exp $
 */
 #include "sqliteInt.h"
 #include <ctype.h>
@@ -4768,6 +4768,7 @@ case OP_VUpdate: {
       assert( nArg>1 && apArg[0] && (apArg[0]->flags&MEM_Null) );
       db->lastRowid = rowid;
     }
+    p->nChange++;
   }
   break;
 }
index c07248636c7274deba0e2cff48e1558e915aa046..e1915452055bb1d1a13d999073fe1943b2888faa 100644 (file)
@@ -11,7 +11,7 @@
 # This file implements regression tests for SQLite library.  The
 # focus of this file is creating and dropping virtual tables.
 #
-# $Id: vtab1.test,v 1.50 2007/12/13 21:54:11 drh Exp $
+# $Id: vtab1.test,v 1.51 2008/04/10 14:00:10 drh Exp $
 
 set testdir [file dirname $argv0]
 source $testdir/tester.tcl
@@ -608,41 +608,111 @@ do_test vtab1-6-2 {
     SELECT name FROM sqlite_master WHERE type = 'table';
   }
 } {treal techo}
-do_test vtab1-6-3 {
+do_test vtab1-6-3.1 {
   execsql {
     INSERT INTO techo VALUES(1, 2, 3);
+  }
+  db changes
+} {1}
+do_test vtab1-6-3.2 {
+  execsql {
     SELECT * FROM techo;
   }
 } {1 2 3}
-do_test vtab1-6-4 {
+do_test vtab1-6-4.1 {
   execsql {
     UPDATE techo SET a = 5;
+  }
+  db changes
+} {1}
+do_test vtab1-6-4.2 {
+  execsql {
+    SELECT * FROM techo;
+  }
+} {5 2 3}
+do_test vtab1-6-4.3 {
+  execsql {
+    UPDATE techo SET a=6 WHERE a<0;
+  }
+  db changes
+} {0}
+do_test vtab1-6-4.4 {
+  execsql {
     SELECT * FROM techo;
   }
 } {5 2 3}
 
-do_test vtab1-6-5 {
+do_test vtab1-6-5.1 {
  execsql {
    UPDATE techo set a = a||b||c;
+ }
+ db changes
+} {1}
+do_test vtab1-6-5.2 {
+ execsql {
    SELECT * FROM techo;
  }
 } {523 2 3}
 
-do_test vtab1-6-6 {
+do_test vtab1-6-6.1 {
   execsql {
     UPDATE techo set rowid = 10;
+  }
+  db changes
+} {1}
+do_test vtab1-6-6.2 {
+  execsql {
     SELECT rowid FROM techo;
   }
 } {10}
 
-do_test vtab1-6-7 {
+do_test vtab1-6-7.1 {
+  execsql {
+    INSERT INTO techo VALUES(11,12,13);
+  }
+  db changes
+} {1}
+do_test vtab1-6-7.2 {
+  execsql {
+    SELECT * FROM techo ORDER BY a;
+  }
+} {11 12 13 523 2 3}
+do_test vtab1-6-7.3 {
+  execsql {
+    UPDATE techo SET b=b+1000
+  }
+  db changes
+} {2}
+do_test vtab1-6-7.4 {
+  execsql {
+    SELECT * FROM techo ORDER BY a;
+  }
+} {11 1012 13 523 1002 3}
+
+
+do_test vtab1-6-8.1 {
+  execsql {
+    DELETE FROM techo WHERE a=5;
+  }
+  db changes
+} {0}
+do_test vtab1-6-8.2 {
+  execsql {
+    SELECT * FROM techo ORDER BY a;
+  }
+} {11 1012 13 523 1002 3}
+do_test vtab1-6-8.3 {
   execsql {
     DELETE FROM techo;
-    SELECT * FROM techo;
+  }
+  db changes
+} {2}
+do_test vtab1-6-8.4 {
+  execsql {
+    SELECT * FROM techo ORDER BY a;
   }
 } {}
 
-
 file delete -force test2.db
 file delete -force test2.db-journal
 sqlite3 db2 test2.db