mailinfo: recycle strbuf in check_header()
handle_message_id() duplicates the contents of the strbuf that is passed to it. Its only caller proceeds to release the strbuf immediately after that. Reuse it instead and make that change of object ownership more obvious by inlining this short function. Signed-off-by: Rene Scharfe <l.s.r@web.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
6ac617a321
commit
ecf30b237c
@ -179,12 +179,6 @@ static void handle_content_type(struct mailinfo *mi, struct strbuf *line)
|
||||
}
|
||||
}
|
||||
|
||||
static void handle_message_id(struct mailinfo *mi, const struct strbuf *line)
|
||||
{
|
||||
if (mi->add_message_id)
|
||||
mi->message_id = strdup(line->buf);
|
||||
}
|
||||
|
||||
static void handle_content_transfer_encoding(struct mailinfo *mi,
|
||||
const struct strbuf *line)
|
||||
{
|
||||
@ -495,7 +489,8 @@ static int check_header(struct mailinfo *mi,
|
||||
len = strlen("Message-Id: ");
|
||||
strbuf_add(&sb, line->buf + len, line->len - len);
|
||||
decode_header(mi, &sb);
|
||||
handle_message_id(mi, &sb);
|
||||
if (mi->add_message_id)
|
||||
mi->message_id = strbuf_detach(&sb, NULL);
|
||||
ret = 1;
|
||||
goto check_header_out;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user