diff options
author | Junio C Hamano <gitster@pobox.com> | 2012-05-25 12:06:16 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2012-05-25 12:06:16 -0700 |
commit | 9972c8ea49ea95a841fd35fe847bc1062abe5a44 (patch) | |
tree | 344a6bfdb89aa53b5a56de7ff9d59a019c0f9fbc | |
parent | Merge branch 'jk/pretty-commit-header-incomplete-line' (diff) | |
parent | pretty: avoid buffer overflow in format_person_part (diff) | |
download | tgif-9972c8ea49ea95a841fd35fe847bc1062abe5a44.tar.xz |
Merge branch 'jk/format-person-part-buffer-limit'
Avoid buffer overflow in format_person_part() function
-rw-r--r-- | pretty.c | 6 |
1 files changed, 4 insertions, 2 deletions
@@ -550,8 +550,10 @@ static size_t format_person_part(struct strbuf *sb, char part, mail_end = s.mail_end; if (part == 'N' || part == 'E') { /* mailmap lookup */ - strlcpy(person_name, name_start, name_end - name_start + 1); - strlcpy(person_mail, mail_start, mail_end - mail_start + 1); + snprintf(person_name, sizeof(person_name), "%.*s", + (int)(name_end - name_start), name_start); + snprintf(person_mail, sizeof(person_mail), "%.*s", + (int)(mail_end - mail_start), mail_start); mailmap_name(person_mail, sizeof(person_mail), person_name, sizeof(person_name)); name_start = person_name; name_end = name_start + strlen(person_name); |