Skip to content

Commit

Permalink
git-imap-send: Convert LF to CRLF before storing patch to draft box
Browse files Browse the repository at this point in the history
When storing a message over IMAP (RFC 3501 6.3.11), the message should be
in the format of an RFC 2822 message; most notably, CRLF must be used as
a line terminator.

Convert "\n" line endings in the payload to CRLF before feeding it to
IMAP APPEND command.

Signed-off-by: Hitoshi Mitake <mitake@dcl.info.waseda.ac.jp>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Hitoshi Mitake authored and Junio C Hamano committed Feb 12, 2010
1 parent 902f235 commit 67d1763
Showing 1 changed file with 39 additions and 1 deletion.
40 changes: 39 additions & 1 deletion imap-send.c
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,6 @@ struct msg_data {
char *data;
int len;
unsigned char flags;
unsigned int crlf:1;
};

static const char imap_send_usage[] = "git imap-send < <mbox>";
Expand Down Expand Up @@ -1166,6 +1165,44 @@ static int imap_make_flags(int flags, char *buf)
return d;
}

static void lf_to_crlf(struct msg_data *msg)
{
char *new;
int i, j, lfnum = 0;

if (msg->data[0] == '\n')
lfnum++;
for (i = 1; i < msg->len; i++) {
if (msg->data[i - 1] != '\r' && msg->data[i] == '\n')
lfnum++;
}

new = xmalloc(msg->len + lfnum);
if (msg->data[0] == '\n') {
new[0] = '\r';
new[1] = '\n';
i = 1;
j = 2;
} else {
new[0] = msg->data[0];
i = 1;
j = 1;
}
for ( ; i < msg->len; i++) {
if (msg->data[i] != '\n') {
new[j++] = msg->data[i];
continue;
}
if (msg->data[i - 1] != '\r')
new[j++] = '\r';
/* otherwise it already had CR before */
new[j++] = '\n';
}
msg->len += lfnum;
free(msg->data);
msg->data = new;
}

static int imap_store_msg(struct store *gctx, struct msg_data *data)
{
struct imap_store *ctx = (struct imap_store *)gctx;
Expand All @@ -1175,6 +1212,7 @@ static int imap_store_msg(struct store *gctx, struct msg_data *data)
int ret, d;
char flagstr[128];

lf_to_crlf(data);
memset(&cb, 0, sizeof(cb));

cb.dlen = data->len;
Expand Down

0 comments on commit 67d1763

Please sign in to comment.