]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Schema modifications are committed internally when a statement transaction
authordanielk1977 <danielk1977@noemail.net>
Mon, 14 Jun 2004 13:14:59 +0000 (13:14 +0000)
committerdanielk1977 <danielk1977@noemail.net>
Mon, 14 Jun 2004 13:14:59 +0000 (13:14 +0000)
is committed. (CVS 1592)

FossilOrigin-Name: 4cfc5a36e9891a9b69209f94194fc492e203ab75

manifest
manifest.uuid
src/vdbe.c
src/vdbeaux.c
test/quick.test

index be883b237a19fcff1ec3b6f355dedea2b2b1e194..9b45ef502b5061b2c96f6644713ef07d24dd11d9 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Fix\sa\sbug\sin\sthe\sauth.test\sscript.\s(CVS\s1590)
-D 2004-06-14T11:54:18
+C Schema\smodifications\sare\scommitted\sinternally\swhen\sa\sstatement\stransaction\nis\scommitted.\s(CVS\s1592)
+D 2004-06-14T13:14:59
 F Makefile.in ab7b0d5118e2da97bac66be8684a1034e3500f5a
 F Makefile.linux-gcc a9e5a0d309fa7c38e7c14d3ecf7690879d3a5457
 F README f1de682fbbd94899d50aca13d387d1b3fd3be2dd
@@ -71,11 +71,11 @@ F src/update.c 6133c876aa126e1771cda165fd992bb0d2f8eb38
 F src/utf.c e16737b3fc4201bf7ce9bd8ced5250596aa31b76
 F src/util.c 90375fa253137562d536ccdd40b297f0fd7413fc
 F src/vacuum.c b921eb778842592e1fb48a9d4cef7e861103878f
-F src/vdbe.c e6b6702fb2c2e2702e312f52c2cc08353c580736
+F src/vdbe.c afbffe8d238004cf940f8844ecbec921fbeb2996
 F src/vdbe.h 46f74444a213129bc4b5ce40124dd8ed613b0cde
 F src/vdbeInt.h ffc7b8ed911c5bf804796a768fdb6f0568010fa2
 F src/vdbeapi.c ee350b552fc4c1c695b760f914f69e9c5556e829
-F src/vdbeaux.c 79b0dc52fc950c6e66c6259504796350ea5c5964
+F src/vdbeaux.c 9484c890b9dab6ee94705d1ca8072b33c202e3ca
 F src/vdbemem.c 34f59988831ea032b7f526c2c73175f9f4c0f3ad
 F src/where.c 7fee7aeb9278f27324f228c55ab453b5f183b486
 F test/all.test 569a92a8ee88f5300c057cc4a8f50fbbc69a3242
@@ -140,7 +140,7 @@ F test/pager2.test 55469c7c1c1a54d6b32d7b3cc99001e90101a1ce
 F test/pragma.test 1b6792d4af550ca4973096d77fc278dd6c32c4dd
 F test/printf.test 46b3d07d59d871d0831b4a657f6dfcafe0574850
 F test/progress.test 7542a6ac7894a1b7730c1f9a27f3f8b9388a4d25 x
-F test/quick.test 8800cd2f6b45ce2cafadb0e3d5161688c61c946a
+F test/quick.test 10c5fdbee91ef440d6adefa8e5844796c5764bfb
 F test/quote.test 08f23385c685d3dc7914ec760d492cacea7f6e3d
 F test/rowid.test 863e6e75878cccf03d166fe52023f20e09508683
 F test/select1.test 2f161f9cdf9fb577336bc8c930edade538567123
@@ -223,7 +223,7 @@ F www/support.tcl 1801397edd271cc39a2aadd54e701184b5181248
 F www/tclsqlite.tcl 19191cf2a1010eaeff74c51d83fd5f5a4d899075
 F www/vdbe.tcl 59288db1ac5c0616296b26dce071c36cb611dfe9
 F www/whentouse.tcl a8335bce47cc2fddb07f19052cb0cb4d9129a8e4
-P f4b4df6514c19b0c23b399142749a7e4a20d0f70
-R 276f7a5870a912eac65482d1c432e28e
+P 1fa97dd81d349e448171a78f69e463e7fa364daa
+R e2df8a58e6722e61f1dd53384723fd2e
 U danielk1977
-Z 928c748f2a9ec89b583d30c2c73e50ae
+Z 699e2d26d511fd198a645a9fe1c7342b
index 0af183292cac2e75c5f09b010c0571c008ec1760..e5e6f47ae80bebdb5dfdb590529d2f7e30b2eb9e 100644 (file)
@@ -1 +1 @@
-1fa97dd81d349e448171a78f69e463e7fa364daa
\ No newline at end of file
+4cfc5a36e9891a9b69209f94194fc492e203ab75
\ No newline at end of file
index 9cba2007762d32be9ed8aac9c9698496f35e4a5d..14f620a01170621190265b249a4c34f0972b3fe6 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.371 2004/06/14 05:10:43 danielk1977 Exp $
+** $Id: vdbe.c,v 1.372 2004/06/14 13:14:59 danielk1977 Exp $
 */
 #include "sqliteInt.h"
 #include "os.h"
@@ -4711,6 +4711,7 @@ abort_due_to_interrupt:
   }else{
     rc = SQLITE_INTERRUPT;
   }
+  p->rc = rc;
   sqlite3SetString(&p->zErrMsg, sqlite3ErrStr(rc), (char*)0);
   goto vdbe_halt;
 }
index 73a0d8564d27a5d0b7d766b9d8ca15c805cb6886..e282a0f7ce50a09c8a9ed9422262adca485e7346 100644 (file)
@@ -1151,6 +1151,7 @@ static int vdbeCommit(sqlite *db){
       }
     }
   }
+
   return rc;
 }
 
@@ -1275,6 +1276,8 @@ int sqlite3VdbeReset(Vdbe *p, char **pzErrMsg){
 
   if( p->rc!=SQLITE_OK ){
     sqlite3RollbackInternalChanges(db);
+  }else if( db->flags & SQLITE_InternChanges ){
+    db->flags &= ~SQLITE_InternChanges;
   }
 
   if( (p->magic==VDBE_MAGIC_RUN && p->pc>=0) || p->magic==VDBE_MAGIC_HALT ){
index 0c349ecb6860ebd768e225ce1c19b80d27479835..009e8356a30e8146cf770be0b483246d2a28f065 100644 (file)
@@ -10,7 +10,7 @@
 #***********************************************************************
 # This file runs all tests.
 #
-# $Id: quick.test,v 1.19 2004/05/24 07:34:49 danielk1977 Exp $
+# $Id: quick.test,v 1.20 2004/06/14 13:14:59 danielk1977 Exp $
 
 set testdir [file dirname $argv0]
 source $testdir/tester.tcl
@@ -28,12 +28,10 @@ set EXCLUDE {
   format3.test
 }
 
-lappend EXCLUDE interrupt.test    ;# assert() fails in btree
 lappend EXCLUDE ioerr.test        ;# seg-faults (?)
 lappend EXCLUDE memdb.test        ;# fails - malformed database
 
 lappend EXCLUDE printf.test       ;# sqlite3_XX vs sqlite_XX problem
-lappend EXCLUDE auth.test         ;# Cannot attach empty databases.
 lappend EXCLUDE tableapi.test     ;# sqlite3_XX vs sqlite_XX problem
 lappend EXCLUDE version.test      ;# uses the btree_meta API (not updated)