Merge branch 'js/ci-ghwf-dedup-tests'
[git] / Documentation / mailmap.txt
1 If the file `.mailmap` exists at the toplevel of the repository, or at
2 the location pointed to by the mailmap.file or mailmap.blob
3 configuration options, it
4 is used to map author and committer names and email addresses to
5 canonical real names and email addresses.
6
7 In the simple form, each line in the file consists of the canonical
8 real name of an author, whitespace, and an email address used in the
9 commit (enclosed by '<' and '>') to map to the name. For example:
10 --
11         Proper Name <commit@email.xx>
12 --
13
14 The more complex forms are:
15 --
16         <proper@email.xx> <commit@email.xx>
17 --
18 which allows mailmap to replace only the email part of a commit, and:
19 --
20         Proper Name <proper@email.xx> <commit@email.xx>
21 --
22 which allows mailmap to replace both the name and the email of a
23 commit matching the specified commit email address, and:
24 --
25         Proper Name <proper@email.xx> Commit Name <commit@email.xx>
26 --
27 which allows mailmap to replace both the name and the email of a
28 commit matching both the specified commit name and email address.
29
30 Example 1: Your history contains commits by two authors, Jane
31 and Joe, whose names appear in the repository under several forms:
32
33 ------------
34 Joe Developer <joe@example.com>
35 Joe R. Developer <joe@example.com>
36 Jane Doe <jane@example.com>
37 Jane Doe <jane@laptop.(none)>
38 Jane D. <jane@desktop.(none)>
39 ------------
40
41 Now suppose that Joe wants his middle name initial used, and Jane
42 prefers her family name fully spelled out. A proper `.mailmap` file
43 would look like:
44
45 ------------
46 Jane Doe         <jane@desktop.(none)>
47 Joe R. Developer <joe@example.com>
48 ------------
49
50 Note how there is no need for an entry for `<jane@laptop.(none)>`, because the
51 real name of that author is already correct.
52
53 Example 2: Your repository contains commits from the following
54 authors:
55
56 ------------
57 nick1 <bugs@company.xx>
58 nick2 <bugs@company.xx>
59 nick2 <nick2@company.xx>
60 santa <me@company.xx>
61 claus <me@company.xx>
62 CTO <cto@coompany.xx>
63 ------------
64
65 Then you might want a `.mailmap` file that looks like:
66 ------------
67 <cto@company.xx>                       <cto@coompany.xx>
68 Some Dude <some@dude.xx>         nick1 <bugs@company.xx>
69 Other Author <other@author.xx>   nick2 <bugs@company.xx>
70 Other Author <other@author.xx>         <nick2@company.xx>
71 Santa Claus <santa.claus@northpole.xx> <me@company.xx>
72 ------------
73
74 Use hash '#' for comments that are either on their own line, or after
75 the email address.