Invert the sense of the -s flag (local addition). Instead of compiling
in the behavior via the previously default #define DONT_FSYNC, use the -s flag to turn the fsync() behavior on. This can be configured in sendmail.cf without recompiling mail.local.
This commit is contained in:
parent
50094ad9a7
commit
04a0df2514
@ -40,11 +40,12 @@ Turn off the attempts to notify the
|
||||
.Dq biff
|
||||
service.
|
||||
.It Fl s
|
||||
Turn off the
|
||||
Turn on the
|
||||
.Xr fsync 2
|
||||
call that forces the mailbox to be committed to disk before returning a
|
||||
.Dq success
|
||||
status.
|
||||
status. (This can configured in the flags passed through from
|
||||
.Xr sendmail 8 ).
|
||||
.El
|
||||
.Pp
|
||||
Individual mail messages in the mailbox are delimited by an empty
|
||||
|
@ -239,7 +239,7 @@ main(argc, argv)
|
||||
char *argv[];
|
||||
{
|
||||
struct passwd *pw;
|
||||
int ch, fd, nobiff, nofsync;
|
||||
int ch, fd, nobiff, dofsync;
|
||||
uid_t uid;
|
||||
char *from;
|
||||
extern char *optarg;
|
||||
@ -260,7 +260,7 @@ main(argc, argv)
|
||||
|
||||
from = NULL;
|
||||
nobiff = 0;
|
||||
nofsync = 0;
|
||||
dofsync = 0;
|
||||
while ((ch = getopt(argc, argv, "bdf:r:ls")) != -1)
|
||||
switch(ch) {
|
||||
case 'b':
|
||||
@ -280,7 +280,7 @@ main(argc, argv)
|
||||
lmtpmode++;
|
||||
break;
|
||||
case 's':
|
||||
nofsync++;
|
||||
dofsync++;
|
||||
break;
|
||||
case '?':
|
||||
default:
|
||||
@ -290,7 +290,7 @@ main(argc, argv)
|
||||
argv += optind;
|
||||
|
||||
if (lmtpmode)
|
||||
dolmtp(nobiff, nofsync);
|
||||
dolmtp(nobiff, dofsync);
|
||||
|
||||
if (!*argv)
|
||||
usage();
|
||||
@ -315,7 +315,7 @@ main(argc, argv)
|
||||
* at the expense of repeated failures and multiple deliveries.
|
||||
*/
|
||||
for (fd = store(from, 0); *argv; ++argv)
|
||||
deliver(fd, *argv, nobiff, nofsync);
|
||||
deliver(fd, *argv, nobiff, dofsync);
|
||||
exit(eval);
|
||||
}
|
||||
|
||||
@ -431,8 +431,8 @@ process_recipient(addr)
|
||||
#define RCPT_GROW 30
|
||||
|
||||
void
|
||||
dolmtp(nobiff, nofsync)
|
||||
int nobiff, nofsync;
|
||||
dolmtp(nobiff, dofsync)
|
||||
int nobiff, dofsync;
|
||||
{
|
||||
char *return_path = NULL;
|
||||
char **rcpt_addr = NULL;
|
||||
@ -477,7 +477,7 @@ dolmtp(nobiff, nofsync)
|
||||
if (p != NULL)
|
||||
*p++ = '\0';
|
||||
deliver(msgfd, rcpt_addr[i], nobiff,
|
||||
nofsync);
|
||||
dofsync);
|
||||
}
|
||||
close(msgfd);
|
||||
goto rset;
|
||||
@ -680,10 +680,10 @@ store(from, lmtprcpts)
|
||||
}
|
||||
|
||||
void
|
||||
deliver(fd, name, nobiff, nofsync)
|
||||
deliver(fd, name, nobiff, dofsync)
|
||||
int fd;
|
||||
char *name;
|
||||
int nobiff, nofsync;
|
||||
int nobiff, dofsync;
|
||||
{
|
||||
struct stat fsb, sb;
|
||||
struct passwd *pw;
|
||||
@ -851,7 +851,7 @@ tryagain:
|
||||
}
|
||||
|
||||
/* Flush to disk, don't wait for update. */
|
||||
if (!nofsync && fsync(mbfd)) {
|
||||
if (dofsync && fsync(mbfd)) {
|
||||
mailerr("450 4.2.0", "%s: %s", path, strerror(errno));
|
||||
err3:
|
||||
if (setreuid(0, 0) < 0) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user