Чи можу я змінити своє ім’я та прізвище у всіх попередніх комісіях?


122

Я хотів би змінити своє ім’я, прізвище та електронну пошту у всіх своїх зобов'язаннях, чи це можливо?


2
Це докори лише для вас, для кількох людей або для великого проекту?
thejh



Відповіді:


212

Використовуйте 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 "$@"'

Це впливає лише на автора, а не на виконавця (який для більшості комісій буде таким самим, як і автор). Якщо ви також хочете їх переписати, встановіть GIT_COMMITTER_NAMEі GIT_COMMITTER_EMAILзмінні.

Застосовується стандартне попередження про історію переписування; робити це лише для історії, яка ще не ділиться.

Оновлення за червень 2018 року

Посібник тепер включає рішення, використовуючи --env-filterу своїх прикладах: 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
Якщо ви користуєтесь msysgit, ви все ще маєте доступ до bash. Інакше я не маю підказки.
Джош Лі

@Joshua, якщо ви використовуєте щось там, де у вас немає bash, ви, ймовірно, можете використовувати Windows-пакетний сценарій, хоча я ще не пробував цього.
MatrixFrog

а що з тегами? це рішення не змінить автора тегів
piotrek

@Joshua ознайомтеся з git repo на вікні linux та виконайте виправлення там
Буде Шеппард

Чи є параметри, які призводять до того, що нова гілка та залишає джерело недоторканим?
Євген Конков

56

Щоб переписати як автора, так і виконавця у всіх вибраних комісіях:

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
Але як застосувати зміни до віддаленого сервера?
vikyd

5
@Viky Trygit push --all origin --force
user11153

2
Це працює для мене! Я використовую GitLab, я повинен видалити гілку перед push командою.
vikyd

37

Якщо інших авторів немає, ви можете зробити:

git filter-branch --commit-filter 'export GIT_AUTHOR_NAME="authorname"; \
export GIT_AUTHOR_EMAIL=mail@example.com; git commit-tree "$@"'

1
Це не переписування інформації "Комітер:".
користувач11153

1
Він не призначений для перезапису інформації про комітента. Якщо ви хочете це зробити, експортуйте також GIT_COMMITTER_NAME та GIT_COMMITTER_EMAIL (див. Прийняту відповідь).
chronospoon

12

Збережіть сценарій нижче як, наприклад, ~/.bin/git-replace-authorта запустіть його, використовуючи, наприклад:

git replace-author "John Ssmith" "John Smith" "johnsmith@example.com"

Без аргументів, він оновлює всі зобов’язання з вашим іменем для використання вашої поточної адреси електронної пошти відповідно до конфігурації 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 (для завантаження)


У короткій замітці ~/.bin/повинна бути всередині користувачів $PATHі потреби файл виконуваним, так працювати: chmod +x ~/.bin/git-replace-author.
Майкл Гехт

І що це робити з аргументами?
Євген Конков

2

Тільки якщо ви не підштовхували свої зобов'язання до світу. Інші мудрі всі інші мають своє старе ім’я у своєму репо, що навряд чи ви зможете змінити.


Щоправда, але в деяких випадках у вас немає вибору. У моєму випадку у моїй конфігурації git було налаштовано неправильну адресу електронної пошти (як я міг бачити з "git config --global -l"). Як результат, у мене не було жодної активності, яка відображалася в моєму власному репортажі Github (оскільки адреса електронної пошти не збігалася з електронною поштою, налаштованою в Github)! Щоб вирішити це, я виправив свої місцеві комісії за допомогою рецепту від stackoverflow.com/a/23564785/2474068 (працював ідеально), а потім я натиснув змінені комісії на Github, використовуючи "git push -u -f origin master" (з силою прапор "-f"). Це суперечить прийнятій практиці, але у мене не було вибору!
лео

1
Так, моя думка полягала в тому, що будь-які вилки цього репо не мали б такої зміни, якщо б вони не прийняли ваш натиск. Буде складно отримати кожен вилок для оновлення :)
EnabrenTane

1

З Git 2.24 (Q4 2019), git filter-branch(і BFG) є застарілим .

Еквівалент буде, використовуючи newren/git-filter-repo, та його приклад розділу :

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

з my-mailmap:

Correct Name <correct@email.com> <old@email.com>

Це замінить ім’я автора та електронну пошту будь-якого вчинення, здійсненого ким-небудь з <old@email.com>

Точний синтаксис див. У git shortlogрозділі авторів карти

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.