# HG changeset patch # User Waqas Hussain # Date 1293412235 -18000 # Node ID d3f5c60a72b1267a06f9708b85f84d70335c77fb # Parent 3294f12ea6026e373051fd334cf19c5d18c76355 mod_storage_sql: Call commit() after all SQL statements, including SELECT, to get SQLite to drop its locks. diff -r 3294f12ea602 -r d3f5c60a72b1 plugins/mod_storage_sql.lua --- a/plugins/mod_storage_sql.lua Mon Dec 27 06:10:35 2010 +0500 +++ b/plugins/mod_storage_sql.lua Mon Dec 27 06:10:35 2010 +0500 @@ -55,9 +55,9 @@ if count == 0 then local stmt = assert(connection:prepare("CREATE TABLE `Prosody` (`host` TEXT, `user` TEXT, `store` TEXT, `key` TEXT, `subkey` TEXT, `type` TEXT, `value` TEXT);")); assert(stmt:execute()); - assert(connection:commit()); module:log("debug", "Initialized new SQLite3 database"); end + assert(connection:commit()); --print("===", json.stringify()) end end @@ -132,7 +132,7 @@ end end end - return haveany and result or nil; + return commit(haveany and result or nil); end function keyval_store:set(username, data) user,store = username,self.store; @@ -182,7 +182,7 @@ end end end - return haveany and result or nil; + return commit(haveany and result or nil); end function map_store:set(username, key, data) user,store = username,self.store;