add missing newlines
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@5011 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -10,7 +10,7 @@ RCSID("$Id$");
|
|||||||
/*
|
/*
|
||||||
* sendline: Send a line of a multi-line response to a client.
|
* sendline: Send a line of a multi-line response to a client.
|
||||||
*/
|
*/
|
||||||
void
|
static int
|
||||||
pop_sendline(POP *p, char *buffer)
|
pop_sendline(POP *p, char *buffer)
|
||||||
{
|
{
|
||||||
char * bp;
|
char * bp;
|
||||||
@@ -34,6 +34,7 @@ pop_sendline(POP *p, char *buffer)
|
|||||||
/* Put a <CR><NL> if a newline was removed from the buffer */
|
/* Put a <CR><NL> if a newline was removed from the buffer */
|
||||||
if (bp)
|
if (bp)
|
||||||
fputs ("\r\n",p->output);
|
fputs ("\r\n",p->output);
|
||||||
|
return bp != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -54,6 +55,7 @@ pop_send(POP *p)
|
|||||||
int return_path_sent;
|
int return_path_sent;
|
||||||
int return_path_linlen;
|
int return_path_linlen;
|
||||||
#endif
|
#endif
|
||||||
|
int sent_nl = 0;
|
||||||
|
|
||||||
/* Convert the first parameter into an integer */
|
/* Convert the first parameter into an integer */
|
||||||
msg_num = atoi(p->pop_parm[1]);
|
msg_num = atoi(p->pop_parm[1]);
|
||||||
@@ -135,7 +137,7 @@ pop_send(POP *p)
|
|||||||
/* Don't send existing Return-Path-header if already sent own */
|
/* Don't send existing Return-Path-header if already sent own */
|
||||||
if (!return_path_sent || strncasecmp(buffer, "Return-Path:", 12) != 0)
|
if (!return_path_sent || strncasecmp(buffer, "Return-Path:", 12) != 0)
|
||||||
#endif
|
#endif
|
||||||
pop_sendline (p,buffer);
|
sent_nl = pop_sendline (p,buffer);
|
||||||
/* A single newline (blank line) signals the
|
/* A single newline (blank line) signals the
|
||||||
end of the header. sendline() converts this to a NULL,
|
end of the header. sendline() converts this to a NULL,
|
||||||
so that's what we look for. */
|
so that's what we look for. */
|
||||||
@@ -146,19 +148,23 @@ pop_send(POP *p)
|
|||||||
/* Send the message body */
|
/* Send the message body */
|
||||||
{
|
{
|
||||||
int blank_line = 0;
|
int blank_line = 0;
|
||||||
while (fgets(buffer, MAXMSGLINELEN, p->drop)) {
|
while (fgets(buffer, MAXMSGLINELEN-1, p->drop)) {
|
||||||
/* Look for the start of the next message */
|
/* Look for the start of the next message */
|
||||||
if (!IS_MAILDIR(p) && blank_line && strncmp(buffer,"From ",5) == 0)
|
if (!IS_MAILDIR(p) && blank_line && strncmp(buffer,"From ",5) == 0)
|
||||||
break;
|
break;
|
||||||
blank_line = (strncmp(buffer, "\n", 1) == 0);
|
blank_line = (strncmp(buffer, "\n", 1) == 0);
|
||||||
/* Decrement the lines sent (for a TOP command) */
|
/* Decrement the lines sent (for a TOP command) */
|
||||||
if (msg_lines >= 0 && msg_lines-- == 0) break;
|
if (msg_lines >= 0 && msg_lines-- == 0) break;
|
||||||
pop_sendline(p,buffer);
|
sent_nl = pop_sendline(p,buffer);
|
||||||
if (hangup)
|
if (hangup)
|
||||||
return (pop_msg (p,POP_FAILURE,"SIGHUP or SIGPIPE flagged"));
|
return (pop_msg (p,POP_FAILURE,"SIGHUP or SIGPIPE flagged"));
|
||||||
}
|
}
|
||||||
/* some braindamaged pop-clients need a blank line at the end
|
/* add missing newline at end */
|
||||||
of the message */
|
if(!sent_nl)
|
||||||
|
fputs("\r\n", p->output);
|
||||||
|
/* some pop-clients want a blank line at the end of the
|
||||||
|
message, we always add one here, but what the heck -- in
|
||||||
|
outer (white) space, no one can hear you scream */
|
||||||
if(IS_MAILDIR(p))
|
if(IS_MAILDIR(p))
|
||||||
fputs("\r\n", p->output);
|
fputs("\r\n", p->output);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user