]> git.ipfire.org Git - thirdparty/git.git/commitdiff
mailinfo: fix passing wrong address to git_mailinfo_config
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>
Sun, 1 Nov 2015 14:30:30 +0000 (15:30 +0100)
committerJunio C Hamano <gitster@pobox.com>
Sun, 1 Nov 2015 18:29:40 +0000 (10:29 -0800)
git_mailinfo_config() expects "struct mailinfo *". But in
setup_mailinfo(), "mi" is already "struct mailinfo *". &mi would make
it "struct mailinfo **" and git_mailinfo_config() would damage some
other memory when it assigns some value to mi->use_scissors.

This is caught by t4150.20. git_mailinfo_config() breaks
mi->name.alloc and makes strbuf_release() in clear_mailinfo() attempt
to free strbuf_slopbuf.

Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
mailinfo.c

index e157ca6eb5a078f950d9bd6c746698be22fa651c..f289941f7e516be2f6265326188b3d8da70ef3aa 100644 (file)
@@ -1009,7 +1009,7 @@ void setup_mailinfo(struct mailinfo *mi)
        mi->header_stage = 1;
        mi->use_inbody_headers = 1;
        mi->content_top = mi->content;
-       git_config(git_mailinfo_config, &mi);
+       git_config(git_mailinfo_config, mi);
 }
 
 void clear_mailinfo(struct mailinfo *mi)