aboutsummaryrefslogtreecommitdiffstats
path: root/lock.c
diff options
context:
space:
mode:
authorMatthias Andree <matthias.andree@gmx.de>2005-10-30 18:15:16 +0000
committerMatthias Andree <matthias.andree@gmx.de>2005-10-30 18:15:16 +0000
commit2c32441420fcb5c3ad12d44aea7fea11669a1d08 (patch)
tree362305cffc5d233ea01f1b91b49d93f8c6cae0bd /lock.c
parent6fae1ebc493bd2c9bb3c6be646f9c2de74329952 (diff)
downloadfetchmail-2c32441420fcb5c3ad12d44aea7fea11669a1d08.tar.gz
fetchmail-2c32441420fcb5c3ad12d44aea7fea11669a1d08.tar.bz2
fetchmail-2c32441420fcb5c3ad12d44aea7fea11669a1d08.zip
Exit with error if the lock file cannot be read.
svn path=/trunk/; revision=4374
Diffstat (limited to 'lock.c')
-rw-r--r--lock.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/lock.c b/lock.c
index 89bf896a..f29129d1 100644
--- a/lock.c
+++ b/lock.c
@@ -73,9 +73,11 @@ int lock_state(void)
int args = fscanf(lockfp, "%d %d", &pid, &st);
bkgd = (args == 2);
- if (ferror(lockfp))
+ if (ferror(lockfp)) {
fprintf(stderr, GT_("fetchmail: error reading lockfile \"%s\": %s\n"),
lockfile, strerror(errno));
+ exit(PS_EXCLUDE);
+ }
if (args == 0 || kill(pid, 0) == -1) {
fprintf(stderr,GT_("fetchmail: removing stale lockfile\n"));
@@ -86,9 +88,11 @@ int lock_state(void)
fclose(lockfp); /* not checking should be safe, file mode was "r" */
} else {
pid = 0;
- if (errno != ENOENT)
+ if (errno != ENOENT) {
fprintf(stderr, GT_("fetchmail: error opening lockfile \"%s\": %s\n"),
lockfile, strerror(errno));
+ exit(PS_EXCLUDE);
+ }
}
return(bkgd ? -pid : pid);