Currently you can use mailmap to display log authors and committers
but you can't use the mailmap to find commits with mapped values.

This commit allows you to run:

    git log --use-mailmap --author mapped_name_or_email
    git log --use-mailmap --committer mapped_name_or_email

Of course it only works if the --use-mailmap option is used.

Signed-off-by: Antoine Pelisse <apeli...@gmail.com>
---
 revision.c         |   54 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 t/t4203-mailmap.sh |   18 ++++++++++++++++++
 2 files changed, 72 insertions(+)

diff --git a/revision.c b/revision.c
index 95d21e6..fa16b9d 100644
--- a/revision.c
+++ b/revision.c
@@ -13,6 +13,7 @@
 #include "decorate.h"
 #include "log-tree.h"
 #include "string-list.h"
+#include "mailmap.h"
 
 volatile show_early_output_fn_t show_early_output;
 
@@ -2219,6 +2220,51 @@ static int rewrite_parents(struct rev_info *revs, struct 
commit *commit)
        return 0;
 }
 
+static int commit_rewrite_person(struct strbuf *buf, const char *what, struct 
string_list *mailmap)
+{
+       char *person, *endp;
+       size_t len;
+       struct strbuf name = STRBUF_INIT;
+       struct strbuf mail = STRBUF_INIT;
+       struct ident_split ident;
+
+       person = strstr(buf->buf, what);
+       if (!person)
+               goto left_intact;
+
+       person += strlen(what);
+       endp = strchr(person, '\n');
+       if (!endp)
+               goto left_intact;
+
+       len = endp - person;
+
+       if (split_ident_line(&ident, person, len))
+               goto left_intact;
+
+       strbuf_add(&name, ident.name_begin, ident.name_end - ident.name_begin);
+       strbuf_add(&mail, ident.mail_begin, ident.mail_end - ident.mail_begin);
+
+       if (map_user(mailmap, &mail, &name)) {
+               strbuf_addf(&name, " <%s>", mail.buf);
+
+               strbuf_splice(buf, ident.name_begin - buf->buf,
+                             ident.mail_end - ident.name_begin + 1,
+                             name.buf, name.len);
+
+               strbuf_release(&name);
+               strbuf_release(&mail);
+
+               return 1;
+       }
+
+left_intact:
+       strbuf_release(&name);
+       strbuf_release(&mail);
+
+       return 0;
+}
+
 static int commit_match(struct commit *commit, struct rev_info *opt)
 {
        int retval;
@@ -2237,6 +2283,14 @@ static int commit_match(struct commit *commit, struct 
rev_info *opt)
        if (buf.len)
                strbuf_addstr(&buf, commit->buffer);
 
+       if (opt->mailmap) {
+               if (!buf.len)
+                       strbuf_addstr(&buf, commit->buffer);
+
+               commit_rewrite_person(&buf, "\nauthor ", opt->mailmap);
+               commit_rewrite_person(&buf, "\ncommitter ", opt->mailmap);
+       }
+
        /* Append "fake" message parts as needed */
        if (opt->show_notes) {
                if (!buf.len)
diff --git a/t/t4203-mailmap.sh b/t/t4203-mailmap.sh
index db043dc..e16187f 100755
--- a/t/t4203-mailmap.sh
+++ b/t/t4203-mailmap.sh
@@ -248,11 +248,29 @@ Author: Other Author <ot...@author.xx>
 Author: Some Dude <s...@dude.xx>
 Author: A U Thor <aut...@example.com>
 EOF
+
 test_expect_success 'Log output with --use-mailmap' '
        git log --use-mailmap | grep Author >actual &&
        test_cmp expect actual
 '
 
+cat >expect <<\EOF
+Author: Santa Claus <santa.cl...@northpole.xx>
+Author: Santa Claus <santa.cl...@northpole.xx>
+EOF
+
+test_expect_success 'Grep author with --use-mailmap' '
+       git log --use-mailmap --author Santa | grep Author >actual &&
+       test_cmp expect actual
+'
+
+>expect
+
+test_expect_success 'Only grep replaced author with --use-mailmap' '
+       git log --use-mailmap --author "<c...@coompany.xx>" >actual &&
+       test_cmp expect actual
+'
+
 # git blame
 cat >expect <<\EOF
 ^OBJI (A U Thor     DATE 1) one
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to