All of lore.kernel.org
 help / color / mirror / Atom feed
From: Johan Herland <johan@herland.net>
To: Nicholas LaRoche <nlaroche@vt.edu>
Cc: git@vger.kernel.org
Subject: Re: Can `git config` override entries in .gitconfig?
Date: Tue, 23 Dec 2008 18:59:13 +0100	[thread overview]
Message-ID: <200812231859.13619.johan@herland.net> (raw)
In-Reply-To: <4950D41A.5050009@vt.edu>

On Tuesday 23 December 2008, Nicholas LaRoche wrote:
> Is there a direct way to change the user.email entry for a git
> repository for one user (applied to all previous commits)?
>
> I tried `git config --unset user.email` followed by `git config
> user.email email2` but it just sets a second field called user.email
> that shows up in `git config -l` as a duplicate. My ~/.gitconfig file
> contains email1 for the user.email entry.
>
> Also, when the repository is created can I specify a second set of
> contact information (i.e. using a project specific email) which isn't a
> part of ~/.gitconfig?
>
> output of `git config -l`:
> user.email=email1
> ..
> ..
> user.email=email2

Hi,

Use git-config's --global option to set options in your ~/.gitconfig. 
Otherwise, your config changes are stored in the current repo's config 
(.git/config).

In your case, when you did `git config --unset user.email`, you unset the 
(non-existing) user.email in your repo config, without touching the one in 
~/.gitconfig, and when you did `git config user.email email2`, you set 
user.email in the repo config (without changing the one in your 
~/.gitconfig).

Although `git config -l` displays options from both ~/.gitconfig and the 
repo config, AFAIK the repo config does _override_ the ~/.gitconfig, so 
when you have user.email set in both, your new commits will use the one in 
the repo config (i.e. "email2").

As for rewriting your email address in all previous commits, that is 
impossible to do without rewriting your entire history. Rewriting your 
history is probably not something you want to do if you have published your 
repo, and other people have started working on top of your commits. If you 
_do_ want to rewrite your history, you should look at the "git 
filter-branch" command.


Have fun!

...Johan

-- 
Johan Herland, <johan@herland.net>
www.herland.net

      reply	other threads:[~2008-12-23 18:00 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-12-23 12:05 Can `git config` override entries in .gitconfig? Nicholas LaRoche
2008-12-23 17:59 ` Johan Herland [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=200812231859.13619.johan@herland.net \
    --to=johan@herland.net \
    --cc=git@vger.kernel.org \
    --cc=nlaroche@vt.edu \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.