]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Resolve a condition which could cause an is-interrupted db to call its progress callback.
authorstephan <stephan@noemail.net>
Mon, 28 Aug 2023 12:06:38 +0000 (12:06 +0000)
committerstephan <stephan@noemail.net>
Mon, 28 Aug 2023 12:06:38 +0000 (12:06 +0000)
FossilOrigin-Name: a0d0f1aafc6086726131dff5e6628f2771c20db3122a53bdbb82945ab5d326d1

manifest
manifest.uuid
src/util.c

index 48f883fc4840a0874d3367fa3dd83a22361ba6b7..68551f75a7a37de70315d19a438025aa63d4d416 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Further\sJNI\scleanups\sand\sjavadoc\sadditions.
-D 2023-08-28T11:10:13.491
+C Resolve\sa\scondition\swhich\scould\scause\san\sis-interrupted\sdb\sto\scall\sits\sprogress\scallback.
+D 2023-08-28T12:06:38.596
 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
 F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
@@ -766,7 +766,7 @@ F src/trigger.c ad6ab9452715fa9a8075442e15196022275b414b9141b566af8cdb7a1605f2b0
 F src/update.c 6904814dd62a7a93bbb86d9f1419c7f134a9119582645854ab02b36b676d9f92
 F src/upsert.c fa125a8d3410ce9a97b02cb50f7ae68a2476c405c76aa692d3acf6b8586e9242
 F src/utf.c ee39565f0843775cc2c81135751ddd93eceb91a673ea2c57f61c76f288b041a0
-F src/util.c 278b81c3b33db1b5a5f3859adf8905c165b910080043061d44d3c5a25b4b406d
+F src/util.c 81f6d47ecda50b87e87f86d0bf87aac213698b3eec0d95d4cbaea971794e2e25
 F src/vacuum.c 604fcdaebe76f3497c855afcbf91b8fa5046b32de3045bab89cc008d68e40104
 F src/vdbe.c 346d848a0bf8128e3e3722c5406f4bde6c32d7093b93402c6f8e0718d19305c3
 F src/vdbe.h 41485521f68e9437fdb7ec4a90f9d86ab294e9bb8281e33b235915e29122cfc0
@@ -2106,8 +2106,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
 F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
 F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
 F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P cfe06f90e2c0231efded98767ef3cc646d3a7daa34d77b62b7c04b5aae9448fd
-R d8657bd6950439669ea385ca4259469a
+P c393b1c9f5639c259406e587b3e08efdc1962203001823747681379ffc54fc10
+R 8d931a50e177b7d6e53f54c42fcaa391
 U stephan
-Z 33c0cfaa6b6aa55ee1261a4aa78cec86
+Z bab39be70eb99e3f7bbba492a0a8edda
 # Remove this line to create a well-formed Fossil manifest.
index efd91396c69c8ef1508c4424476cda4dd2247bdb..f47ed03299df6b4bea5c9f63b68d64fdf15a990e 100644 (file)
@@ -1 +1 @@
-c393b1c9f5639c259406e587b3e08efdc1962203001823747681379ffc54fc10
\ No newline at end of file
+a0d0f1aafc6086726131dff5e6628f2771c20db3122a53bdbb82945ab5d326d1
\ No newline at end of file
index 97deb64cfd8b6934cdfaf658da990bc69bdb2228..7f8a33f9cc574f996443c9531597424a7445bae1 100644 (file)
@@ -202,12 +202,16 @@ void sqlite3ProgressCheck(Parse *p){
     p->rc = SQLITE_INTERRUPT;
   }
 #ifndef SQLITE_OMIT_PROGRESS_CALLBACK
-  if( db->xProgress && (++p->nProgressSteps)>=db->nProgressOps ){
-    if( db->xProgress(db->pProgressArg) ){
-      p->nErr++;
-      p->rc = SQLITE_INTERRUPT;
+  if( db->xProgress ){
+    if( p->rc==SQLITE_INTERRUPT ){
+      p->nProgressSteps = 0;
+    }else if( (++p->nProgressSteps)>=db->nProgressOps ){
+      if( db->xProgress(db->pProgressArg) ){
+        p->nErr++;
+        p->rc = SQLITE_INTERRUPT;
+      }
+      p->nProgressSteps = 0;
     }
-    p->nProgressSteps = 0;
   }
 #endif
 }