I'm converting an old CVS repository to git, which has worked very well except all the commits are in UTC instead of each author's local timezone.
I would like to change the timezone of these commits on a per-author basis, so for example all commits from one author change from +0000 to +1000, while commits from other authors are unchanged. (So I can perform this procedure once for each author.)
The actual moment in time should stay the same, so a commit that is currently 02:00:00 +0000
should become 12:00:00 +1000
.
Is this possible with something like git filter-branch
?
I've come up with this, which seems to do the trick:
This changes the timezone for author
[email protected]
from+0000
to+1000
. If the timezone is already something else in a given commit then it will be left unchanged. In the event that this person was the author but not the committer (or vice-versa), only the date for their role will be updated.It won't handle changing UTC offsets due to DST as @MattJohnson pointed out, but perhaps you can add additional criteria for that if needed.
This works by taking advantage of git's internal date format, which is always measured in seconds since the epoch and looks like
@12345 +0000
. The timezone here is not used (the number of seconds is always in UTC) which allows you to alter the timezone without changing the effective moment in time that is being referenced. Changing the UTC offset here only affects the default formatting of the date.