Re: GIT_COMMITTER_* and reflog

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



copying Dscho,

On 26/10/2019 03:43, Luke Dashjr wrote:
On Saturday 26 October 2019 02:20:39 Jonathan Nieder wrote:
Luke Dashjr wrote:
It appears the reflog currently allows its log data (name and date) to be
overridden by the GIT_COMMITTER_* environment variables. At least for my
workflow, this kinda breaks the reflog (as I regularly set
GIT_COMMITTER_DATE to produce deterministic commit objects).
Can you say more about this?  What is the workflow this is part of?  Can
you describe a sequence of steps and how you are affected during those
steps?
I maintain a bleeding-edge variant of a more stable project, which is
constantly being rebased on the latest stable version.
This looks to have a strong similarity to the Git-for-Windows patches which are regularly rebased on top of this here upstream Git.

Dscho uses the `garden shears` script [1] to help update the patch set, in conjunction with the 'updated' --rebase-merges option (replaces the deprecated --preserve-merges).

To make this easier, I
use a Perl script to generate the bleeding-edge version's git branches:
     https://github.com/bitcoinknots/assemble-deriv
It uses GIT_COMMITTER_DATE to ensure that I can repeatedly generate the branch
until everything merges successfully, without polluting the repository with
hundreds of merge commits each attempt. (Which would be annoying, since I
literally never prune.)

Because git's reflog also uses GIT_COMMITTER_DATE, my reflogs (HEAD in
particular) get polluted with incorrect timestamps during this process.

Is there a need to support this override for the reflog?
Yes.

Is there any reason it can't be changed to use GIT_REFLOG_* instead?
Would a new GIT_REFLOG_* set of envvars that overrides GIT_COMMITTER_*
work for you?  If I understand correctly, you could set
GIT_REFLOG_NAME and GIT_REFLOG_EMAIL to an appropriate identity, but
you wouldn't have a good value to put in GIT_REFLOG_DATE.

If GIT_COMMITTER_{NAME,EMAIL} were used when writing reflogs but
GIT_COMMITTER_DATE weren't, would that help with your workflow?
Yes, it's really only GIT_COMMITTER_DATE that's messing me up personally.
I never use GIT_COMMITTER_{NAME,EMAIL}.

--
Philip

[1] https://github.com/git-for-windows/build-extra/blob/master/shears.sh




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux