summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiles Bader <miles@gnu.org>1996-10-17 15:09:08 +0000
committerMiles Bader <miles@gnu.org>1996-10-17 15:09:08 +0000
commitfb4e73eefd7cdd47629c8c3cf8b65fa76268acd0 (patch)
tree73374e56bb4449c49295fe733728bb6f3c84146b
parentda747fac6bd794f1dba06a58ab4c67ed7ff1308f (diff)
(deliver):
fsync the user's mailbox after delivery.
-rw-r--r--daemons/lmail.c18
1 files changed, 11 insertions, 7 deletions
diff --git a/daemons/lmail.c b/daemons/lmail.c
index 5b6d7d63..2c1c161a 100644
--- a/daemons/lmail.c
+++ b/daemons/lmail.c
@@ -308,7 +308,7 @@ process (int in, char *in_name, int out, char *out_name, struct params *params)
}
while (blk_len > 0);
- if (ex == 0)
+ if (! ex)
ex = bwrite (out, out_name, "\n", 1); /* Append a blank line. */
bfree (blk, blk_len);
@@ -382,8 +382,12 @@ deliver (int msg, char *msg_name, char *rcpt, int flags, struct params *params)
}
if (fd >= 0)
- if (close (fd) < 0 && !ex)
- ex = SYSERR ("%s", mbox);
+ {
+ if (fsync (fd) < 0 && !ex)
+ ex = SYSERR ("%s", mbox);
+ if (close (fd) < 0 && !ex)
+ ex = SYSERR ("%s", mbox);
+ }
free (mbox);
return ex;
@@ -415,7 +419,7 @@ cache (int in, char *in_name, struct params *params, int *cached)
return SYSERR ("%s", _PATH_TMP);
ex = process (in, in_name, fd, _PATH_TMP, params);
- if (ex == 0)
+ if (! ex)
*cached = fd;
else
close (fd);
@@ -498,7 +502,7 @@ main (int argc, char **argv)
int cached; /* Temporary processed input file. */
ex = cache (in, file ?: "-", &params, &cached);
- if (ex == 0)
+ if (! ex)
while (rcpt < argc)
{
/* Deliver to one recipient. */
@@ -513,12 +517,12 @@ main (int argc, char **argv)
if (ex != EX_TEMPFAIL)
if (rex == EX_TEMPFAIL)
ex = EX_TEMPFAIL;
- else if (ex == 0)
+ else if (! ex)
ex = rex;
}
}
- if (file && remove && ex == 0)
+ if (file && remove && !ex)
unlink (file);
exit (ex);