Czy mogę zmienić swoje imię i nazwisko we wszystkich poprzednich zatwierdzeniach?

122

Chciałbym zmienić swoje imię, nazwisko i adres e-mail we wszystkich moich zobowiązaniach, czy to możliwe?

Joshua
źródło
2
Czy to repozytorium tylko dla Ciebie, dla kilku osób czy dla dużego projektu?
thejh
3
możliwy duplikat Jak zmienić autora zatwierdzenia w git?
Josh Lee,

Odpowiedzi:

212

Użyj git-filter-branch.

git filter-branch --commit-filter 'if [ "$GIT_AUTHOR_NAME" = "Josh Lee" ];
  then export GIT_AUTHOR_NAME="Hobo Bob"; export [email protected];
  fi; git commit-tree "$@"'

Ma to wpływ tylko na autora, a nie na osobę zatwierdzającą (która dla większości zatwierdzeń będzie taka sama jak autor). Jeśli chcesz je również przepisać, ustaw zmienne GIT_COMMITTER_NAMEi GIT_COMMITTER_EMAIL.

Obowiązuje standardowe ostrzeżenie o przepisywaniu historii; zrób to tylko z historią, która nie została jeszcze udostępniona.

Aktualizacja z czerwca 2018 r

Podręcznik zawiera teraz rozwiązanie, używając --env-filterw przykładach: https://git-scm.com/docs/git-filter-branch#_examples :

git filter-branch --env-filter '
    if test "$GIT_AUTHOR_EMAIL" = "root@localhost"
    then
        [email protected]
    fi
    if test "$GIT_COMMITTER_EMAIL" = "root@localhost"
    then
        [email protected]
    fi
' -- --all
Josh Lee
źródło
4
Jeśli używasz msysgit, nadal masz dostęp do bash. W przeciwnym razie nie mam pojęcia.
Josh Lee,
@Joshua, jeśli używasz czegoś, w którym nie masz basha, prawdopodobnie możesz użyć skryptów wsadowych systemu Windows, chociaż nie próbowałem tego.
MatrixFrog
a co z tagami? to rozwiązanie nie zmieni autora tagów
piotrek
@Joshua sprawdź repozytorium git na komputerze z systemem Linux i wykonaj tam naprawę
Will Sheppard
Czy są opcje, które powodują powstanie nowej gałęzi i pozostawienie zatwierdzeń źródłowych nienaruszonych?
Eugen Konkov
56

Aby przepisać zarówno autora, jak i zatwierdzającego we wszystkich wybranych zatwierdzeniach:

git filter-branch --commit-filter \
'if [ "$GIT_AUTHOR_NAME" = "OldAuthor Name" ]; then \
export GIT_AUTHOR_NAME="Author Name";\
export [email protected];\
export GIT_COMMITTER_NAME="Commmiter Name";\
export [email protected];\
fi;\
git commit-tree "$@"'
user11153
źródło
1
Ale jak wprowadzić zmiany na zdalnym serwerze?
vikyd
5
@Viky Trygit push --all origin --force
user11153
2
Mi to pasuje ! Używam GitLab, muszę wyłączyć ochronę gałęzi przed poleceniem push.
vikyd
37

Jeśli nie ma innych autorów, możesz zrobić:

git filter-branch --commit-filter 'export GIT_AUTHOR_NAME="authorname"; \
export [email protected]; git commit-tree "$@"'
denis.peplin
źródło
1
To nie jest przepisywanie informacji „Committer:”.
user11153
1
Nie ma na celu przepisywania informacji o autorach. Jeśli chcesz to zrobić, wyeksportuj również GIT_COMMITTER_NAME i GIT_COMMITTER_EMAIL (zobacz zaakceptowaną odpowiedź).
chronospoon
12

Zapisz poniższy skrypt jako np. ~/.bin/git-replace-authorI uruchom go używając np .:

git replace-author "John Ssmith" "John Smith" "[email protected]"

Bez argumentów aktualizuje wszystkie zatwierdzenia o Twoje imię i nazwisko, aby używać Twojego obecnego adresu e-mail zgodnie z konfiguracją Git.

DEFAULT_NAME="$(git config user.name)"
DEFAULT_EMAIL="$(git config user.email)"
export OLD_NAME="${1:-$DEFAULT_NAME}"
export NEW_NAME="${2:-$DEFAULT_NAME}"
export NEW_EMAIL="${3:-$DEFAULT_EMAIL}"

echo "Old:" $OLD_NAME "<*>"
echo "New:" "$NEW_NAME <$NEW_EMAIL>"
echo "To undo, use: git reset $(git rev-parse HEAD)"

git filter-branch --env-filter \
'if [ "$GIT_AUTHOR_NAME" = "${OLD_NAME}" ]; then
    export GIT_AUTHOR_NAME="${NEW_NAME}"
    export GIT_AUTHOR_EMAIL="${NEW_EMAIL}"
    export GIT_COMMITTER_NAME="${NEW_NAME}"
    export GIT_COMMITTER_EMAIL="${NEW_EMAIL}"
fi'

Raw (do pobrania)

Zaz
źródło
W krótkiej notatce: ~/.bin/musi być wewnątrz użytkownicy $PATHoraz potrzeby pliku do pliku wykonywalnego, więc uruchomić: chmod +x ~/.bin/git-replace-author.
Michael Gecht,
A co to robi z argumentami?
Eugen Konkov
2

Tylko jeśli nie wypchnąłeś swoich zobowiązań w świat. Poza tym wszyscy inni mają twoje stare imię w swoim repozytorium, co jest mało prawdopodobne, że możesz zmienić każdego.

EnabrenTane
źródło
To prawda, ale w niektórych przypadkach nie masz wyboru. W moim przypadku miałem nieprawidłowy adres e-mail skonfigurowany w mojej konfiguracji git (jak mogłem zobaczyć z "git config --global -l"). W rezultacie, w moim repozytorium Github nie pojawiła się żadna aktywność związana z zatwierdzaniem (ponieważ adres e-mail nie pasował do adresu e-mail skonfigurowanego w Github)! Aby rozwiązać ten problem, naprawiłem moje lokalne zatwierdzenia, używając przepisu ze stackoverflow.com/a/23564785/2474068 (działało idealnie), a następnie wypchnąłem zmienione zatwierdzenia do Github za pomocą "git push -u -f origin master" (z siłą flaga „-f”). Jest to sprzeczne z przyjętą praktyką, ale nie miałem wyboru!
leo
1
Tak, chodziło mi o to, że żadne rozwidlenia tego repozytorium nie miałyby tej zmiany, chyba że zaakceptowałyby twoją siłę. Aktualizacja każdego widelca byłaby trudna :)
EnabrenTane
1

W Git 2.24 (Q4 2019) git filter-branch(i BFG) jest przestarzałe .

Odpowiednikiem byłoby użycie newren/git-filter-repoi jego przykładowa sekcja :

cd repo
git filter-repo --mailmap my-mailmap

z my-mailmap:

Correct Name <[email protected]> <[email protected]>

Spowoduje to zastąpienie nazwiska autora i adresu e-mail każdego zatwierdzenia wykonanego przez kogokolwiek z <[email protected]>

Zobacz git shortlogsekcję dotyczącą autora mapowania, aby uzyskać dokładną składnię

VonC
źródło