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?


2
Czy to repozytorium tylko dla Ciebie, dla kilku osób czy dla dużego projektu?
thejh



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 GIT_AUTHOR_EMAIL=hobo@example.com;
  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
        GIT_AUTHOR_EMAIL=john@example.com
    fi
    if test "$GIT_COMMITTER_EMAIL" = "root@localhost"
    then
        GIT_COMMITTER_EMAIL=john@example.com
    fi
' -- --all

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 GIT_AUTHOR_EMAIL=authorEmail@example.com;\
export GIT_COMMITTER_NAME="Commmiter Name";\
export GIT_COMMITTER_EMAIL=commiterEmail@example.com;\
fi;\
git commit-tree "$@"'

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 GIT_AUTHOR_EMAIL=mail@example.com; git commit-tree "$@"'

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" "johnsmith@example.com"

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)


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.


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

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.