aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2015-12-11 20:24:36 +0100
committerKim Alvefur <zash@zash.se>2015-12-11 20:24:36 +0100
commit93304d3439bdf8479bf24971487275432045dd41 (patch)
tree0d3e34d019b95724892a06cee3aafe30564c9b73
parentda98f6463936788e85bff956434c308f6bb66058 (diff)
downloadprosody-93304d3439bdf8479bf24971487275432045dd41.tar.gz
prosody-93304d3439bdf8479bf24971487275432045dd41.zip
util.datamanager: Handle potential issues from fallocate
-rw-r--r--util/datamanager.lua11
1 files changed, 10 insertions, 1 deletions
diff --git a/util/datamanager.lua b/util/datamanager.lua
index 786abd95..3016feed 100644
--- a/util/datamanager.lua
+++ b/util/datamanager.lua
@@ -222,7 +222,16 @@ local function append(username, host, datastore, ext, data)
end
local pos = f:seek("end");
ok, msg = fallocate(f, pos, #data);
- f:seek("set", pos);
+ if not ok then
+ log("warn", "fallocate() failed: %s", tostring(msg));
+ -- This doesn't work on every file system
+ end
+
+ if f:seek() ~= pos then
+ log("debug", "fallocate() changed file position");
+ f:seek("set", pos);
+ end
+
if ok then
f:write(data);
else