dovecot-2.0: Use eacces_get_error() in more places for handling ...
dovecot at dovecot.org
dovecot at dovecot.org
Sun Jun 28 01:51:55 EEST 2009
details: http://hg.dovecot.org/dovecot-2.0/rev/bbe4c24faf21
changeset: 9535:bbe4c24faf21
user: Timo Sirainen <tss at iki.fi>
date: Sat Jun 27 18:51:42 2009 -0400
description:
Use eacces_get_error() in more places for handling EACCES errors.
diffstat:
2 files changed, 17 insertions(+), 4 deletions(-)
src/lib-index/mail-index.c | 10 ++++++++--
src/lib-storage/index/maildir/maildir-uidlist.c | 11 +++++++++--
diffs (55 lines):
diff -r 8760bc0b1c3a -r bbe4c24faf21 src/lib-index/mail-index.c
--- a/src/lib-index/mail-index.c Sat Jun 27 18:51:06 2009 -0400
+++ b/src/lib-index/mail-index.c Sat Jun 27 18:51:42 2009 -0400
@@ -4,6 +4,7 @@
#include "ioloop.h"
#include "array.h"
#include "buffer.h"
+#include "eacces-error.h"
#include "hash.h"
#include "str-sanitize.h"
#include "mmap-util.h"
@@ -700,8 +701,13 @@ int mail_index_file_set_syscall_error(st
return -1;
}
- return mail_index_set_error(index, "%s failed with file %s: %m",
- function, filepath);
+ if (errno == EACCES) {
+ return mail_index_set_error(index, "%s",
+ eacces_error_get(t_strcut(function, '('), filepath));
+ } else {
+ return mail_index_set_error(index, "%s failed with file %s: %m",
+ function, filepath);
+ }
}
const char *mail_index_get_error_message(struct mail_index *index)
diff -r 8760bc0b1c3a -r bbe4c24faf21 src/lib-storage/index/maildir/maildir-uidlist.c
--- a/src/lib-storage/index/maildir/maildir-uidlist.c Sat Jun 27 18:51:06 2009 -0400
+++ b/src/lib-storage/index/maildir/maildir-uidlist.c Sat Jun 27 18:51:42 2009 -0400
@@ -34,6 +34,7 @@
#include "file-dotlock.h"
#include "close-keep-errno.h"
#include "nfs-workarounds.h"
+#include "eacces-error.h"
#include "maildir-storage.h"
#include "maildir-sync.h"
#include "maildir-filename.h"
@@ -172,8 +173,14 @@ static int maildir_uidlist_lock_timeout(
}
if (errno != ENOENT || i == MAILDIR_DELETE_RETRY_COUNT ||
uidlist->mbox == NULL) {
- mail_storage_set_critical(box->storage,
- "file_dotlock_create(%s) failed: %m", path);
+ if (errno == EACCES) {
+ mail_storage_set_critical(box->storage, "%s",
+ eacces_error_get_creating("file_dotlock_create", path));
+ } else {
+ mail_storage_set_critical(box->storage,
+ "file_dotlock_create(%s) failed: %m",
+ path);
+ }
return -1;
}
/* the control dir doesn't exist. create it unless the whole
More information about the dovecot-cvs
mailing list