Eu quero mudar o autor de um compromisso específico na história. It'não é o último compromisso.
Eu sei sobre esta questão - Como eu mudo o autor de um commit in git?
Mas estou a pensar em algo, onde identifico o compromisso por haxixe ou fascículo curto.
Rebase interativo de um ponto mais cedo na história do que o compromisso que você precisa modificar (git rebase -i <earliercommit>
). Na lista de commits sendo rebaseados, altere o texto de pick
para edit
ao lado do hash do que você quer modificar. Então quando o git pedir que você altere o commit, use isto:
git commit --amend --author="Author Name <[email protected]>"
Por exemplo, se o seu histórico de commit é A-B-C-D-E-F
com F
como HEAD
, e você quer mudar o autor de C
e D
, então você...
git rebase -i B
(aqui está um exemplo do que você verá após executar o comando git rebase -i B
)A
, utilize git rebase -i --root
.C
e D
de pick
para edit
.git commit --amend --author="Author Name <[email protected]>"
git commit --amend --author="Author Name <[email protected]>"
novamentegit push -f
para actualizar a sua origem com os commits actualizados.As respostas na pergunta a que se ligou são boas respostas e cobrem a sua situação (a outra pergunta é mais geral uma vez que envolve a reescrita de múltiplos compromissos).
Como uma desculpa para experimentar o git filter-branch
, escrevi um script para reescrever o nome do autor e/ou e-mail do autor para um determinado compromisso:
#!/bin/sh
#
# Change the author name and/or email of a single commit.
#
# change-author [-f] commit-to-change [branch-to-rewrite [new-name [new-email]]]
#
# If -f is supplied it is passed to "git filter-branch".
#
# If <branch-to-rewrite> is not provided or is empty HEAD will be used.
# Use "--all" or a space separated list (e.g. "master next") to rewrite
# multiple branches.
#
# If <new-name> (or <new-email>) is not provided or is empty, the normal
# user.name (user.email) Git configuration value will be used.
#
force=''
if test "x$1" = "x-f"; then
force='-f'
shift
fi
die() {
printf '%s\n' "$@"
exit 128
}
targ="$(git rev-parse --verify "$1" 2>/dev/null)" || die "$1 is not a commit"
br="${2:-HEAD}"
TARG_COMMIT="$targ"
TARG_NAME="${3-}"
TARG_EMAIL="${4-}"
export TARG_COMMIT TARG_NAME TARG_EMAIL
filt='
if test "$GIT_COMMIT" = "$TARG_COMMIT"; then
if test -n "$TARG_EMAIL"; then
GIT_AUTHOR_EMAIL="$TARG_EMAIL"
export GIT_AUTHOR_EMAIL
else
unset GIT_AUTHOR_EMAIL
fi
if test -n "$TARG_NAME"; then
GIT_AUTHOR_NAME="$TARG_NAME"
export GIT_AUTHOR_NAME
else
unset GIT_AUTHOR_NAME
fi
fi
'
git filter-branch $force --env-filter "$filt" -- $br
Ao fazer git rebase -i
há esta parte interessante no documento:
Se você quiser dobrar dois ou mais commits em um, substitua o comando
"pick"
pelo segundo e subseqüentes commits por"squash"
ou"fixup"
. Se as commits tiverem autores diferentes, a commit dobrada será atribuída ao autor da primeira commit. A mensagem de submissão sugerida para a submissão dobrada é a concatenação das mensagens de submissão da primeira submissão e daquelas com o comando "squash", mas omite as mensagens de submissão das submissões com o comando "fixup".
A-B-C-D-E-F
,B
e D
(= 2 commits),então você pode fazer:
git config user.email "[email protected]"
git rebase -i B^
seleciona o pai de
B`.pick
para o squash
para esses.Exemplo do que git rebase -i B^
lhe dará:
pick sha-commit-B some message
pick sha-commit-C some message
pick sha-commit-D some message
pick sha-commit-E some message
pick sha-commit-F some message
# pick sha-commit-empty1 empty
# pick sha-commit-empty2 empty
mudar isso para:
# change commit B's author
pick sha-commit-empty1 empty
squash sha-commit-B some message
# leave commit C alone
pick sha-commit-C some message
# change commit D's author
pick sha-commit-empty2 empty
squash sha-commit-D some message
# leave commit E-F alone
pick sha-commit-E some message
pick sha-commit-F some message
Ele o levará a editar as mensagens:
# This is a combination of 2 commits.
# The first commit's message is:
empty
# This is the 2nd commit message:
...some useful commit message there...
e você pode simplesmente remover as primeiras linhas.