aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2001-08-01 14:46:39 +0800
committerMichael Zucci <zucchi@src.gnome.org>2001-08-01 14:46:39 +0800
commit0ff44374fd277fe0663550bf7dc8348680bd5731 (patch)
tree11a9ddef98cb36fcc2169343b40e08d1017bc34d
parent6f22eb642b794def699ce9341219f56d793a50fb (diff)
downloadgsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar.gz
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar.bz2
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar.lz
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar.xz
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.tar.zst
gsoc2013-evolution-0ff44374fd277fe0663550bf7dc8348680bd5731.zip
If we fail to get the lock, make sure we close our locking fd, and reset
2001-08-01 Not Zed <NotZed@Ximian.com> * providers/local/camel-mbox-folder.c (mbox_lock): If we fail to get the lock, make sure we close our locking fd, and reset it. Fixes the crash part of 5095. svn path=/trunk/; revision=11538
-rw-r--r--camel/ChangeLog4
-rw-r--r--camel/providers/local/camel-mbox-folder.c8
2 files changed, 11 insertions, 1 deletions
diff --git a/camel/ChangeLog b/camel/ChangeLog
index 3adfa5ad7c..cf15b16eb5 100644
--- a/camel/ChangeLog
+++ b/camel/ChangeLog
@@ -1,5 +1,9 @@
2001-08-01 Not Zed <NotZed@Ximian.com>
+ * providers/local/camel-mbox-folder.c (mbox_lock): If we fail to
+ get the lock, make sure we close our locking fd, and reset it.
+ Fixes the crash part of 5095.
+
* providers/imap/camel-imap-folder.c (camel_imap_folder_changed):
Slightly re-arranged filter/change notification logic. If we;re
filtering, freeze the folder till we're finished to smooth the ui
diff --git a/camel/providers/local/camel-mbox-folder.c b/camel/providers/local/camel-mbox-folder.c
index 1bab553ecf..ccdce9c61e 100644
--- a/camel/providers/local/camel-mbox-folder.c
+++ b/camel/providers/local/camel-mbox-folder.c
@@ -153,7 +153,13 @@ static int mbox_lock(CamelLocalFolder *lf, CamelLockType type, CamelException *e
return -1;
}
- return camel_lock_folder(lf->folder_path, mf->lockfd, type, ex);
+ if (camel_lock_folder(lf->folder_path, mf->lockfd, type, ex) == -1) {
+ close(mf->lockfd);
+ mf->lockfd = -1;
+ return -1;
+ }
+
+ return 0;
}
static void mbox_unlock(CamelLocalFolder *lf)