aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRené Scharfe <l.s.r@web.de>2016-08-13 11:05:42 +0200
committerJunio C Hamano <gitster@pobox.com>2016-08-13 19:45:24 -0700
commitecf30b237cb278040f18c597c1dbdbc49793094d (patch)
tree9b64ad559e899fd13d933b6e1856e38e8cccc863
parent6ac617a321383b2e3a0f0537e3224ec6229e6500 (diff)
downloadgit-ecf30b237cb278040f18c597c1dbdbc49793094d.tar.gz
git-ecf30b237cb278040f18c597c1dbdbc49793094d.tar.xz
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>
-rw-r--r--mailinfo.c9
1 files changed, 2 insertions, 7 deletions
diff --git a/mailinfo.c b/mailinfo.c
index e157ca6eb..44ea8638f 100644
--- a/mailinfo.c
+++ b/mailinfo.c
@@ -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;
}