On 27 May 2011, at 18:11, Wayne Beaton wrote:
Also, do you know why the Git contribution rules
amend the author instead of using the signed-off-by
instead? E.g.
Because that's what I thought we should do. Nobody offered
alternatives. Is it time to consider alternatives?
Yes, I believe so. The author of a commit should really
remain the same, as it shows who originated the code in the
first place. That's how you can get traceability of the code in
the first place.
Git has the concept of a 'signed off by' which is used to
attach information about someone who approves a commit. This can
be done with git commit -s on the change(s) in question.
-s, --signoff
Add Signed-off-by line by the committer at the
end of the commit
log message.
In places like GitHub, the author is shown as the author, and the
committer is the person who has the signed-off-by annotation. The
reason for having this is to record some kind of approval of the
change but whilst still maintaining the traceability to the
author. (It also means you don't need to muck around with the
rewriting authorship history or doing nasty things -- a commit
--amend -s will be enough for you to add your approval to someone
else's change.
Gerrit also presents 'author' versus 'committer' as separate
fields. For example:
has
On the other hand, there are cases where these differ:
The point is that the Author is always the person who
originated the change, whereas the Committer is the person who
put that change in the repository. Many times they are the same
person but when they differ, the Author identifies who wrote it
and the Commiter represents who approved its inclusion in the
history.
In other words, I think the advice at the moment is entirely
backwards :)
What I would suggest is that we use the 'signed-off-by' to
require a committer on the project but the author can be anyone.
So the people who can commit to a project either show up as
authors, or as signatories to other changes.
Note that it's also somewhat conventional to add the
'signed-off-by' field to your own commits.
EGit has an option to 'add signed-off-by' upon commit as
well.
In other words, signed-off-by is perfect for this use case :)
Alex
PS If the submitted change is a single commit, then a
committer can pull the change, then do a commit amend with the
signoff without having to do any rewriting. It'll change the
commit id but will save you having to run lots of command line
commands to work. If it's multiple then you need to do a rebase
type op to add the committer names on.
_______________________________________________
ecf-dev mailing list
ecf-dev@xxxxxxxxxxx
https://dev.eclipse.org/mailman/listinfo/ecf-dev