From: Jeff King <peff@peff.net>
To: "Halde, Faiz" <fhalde@paypal.com>
Cc: "git@vger.kernel.org" <git@vger.kernel.org>
Subject: Re: Git issue
Date: Tue, 1 Nov 2016 13:45:26 -0400 [thread overview]
Message-ID: <20161101174526.e2tilsriz2fqaru3@sigill.intra.peff.net> (raw)
In-Reply-To: <BY2PR0601MB16400EAC3E9683841907F4B2A2A10@BY2PR0601MB1640.namprd06.prod.outlook.com>
On Tue, Nov 01, 2016 at 10:28:57AM +0000, Halde, Faiz wrote:
> I frequently use the following command to ignore changes done in a file
>
> git update-index --assume-unchanged somefile
>
> Now when I do a pull from my remote branch and say the file 'somefile'
> was changed locally and in remote, git will abort the merge saying I
> need to commit my changes of 'somefile'.
>
> But isn't the whole point of the above command to ignore the changes
> within the file?
No. The purpose of --assume-unchanged is to promise git that you will
not change the file, so that it may skip checking the file contents in
some cases as an optimization.
From "git help update-index":
--[no-]assume-unchanged
When this flag is specified, the object names recorded for
the paths are not updated. Instead, this option sets/unsets
the "assume unchanged" bit for the paths. When the "assume
unchanged" bit is on, the user promises not to change the
file and allows Git to assume that the working tree file
matches what is recorded in the index. If you want to change
the working tree file, you need to unset the bit to tell Git.
This is sometimes helpful when working with a big project on
a filesystem that has very slow lstat(2) system call (e.g.
cifs).
Git will fail (gracefully) in case it needs to modify this
file in the index e.g. when merging in a commit; thus, in
case the assumed-untracked file is changed upstream, you will
need to handle the situation manually.
-Peff
next prev parent reply other threads:[~2016-11-01 17:45 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-11-01 10:28 Git issue Halde, Faiz
2016-11-01 17:45 ` Jeff King [this message]
2016-11-01 18:11 ` Junio C Hamano
2016-11-07 22:34 ` Git issue - ignoring changes to tracked file with assume-unchanged Jakub Narębski
2016-11-01 20:50 ` Git issue Philip Oakley
2016-11-01 21:03 ` Jeff King
2016-11-01 21:23 ` Junio C Hamano
2016-11-04 4:52 ` Jacob Keller
2016-11-01 21:04 ` [PATCH] doc: update-index --assume-unchanged Philip Oakley
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=20161101174526.e2tilsriz2fqaru3@sigill.intra.peff.net \
--to=peff@peff.net \
--cc=fhalde@paypal.com \
--cc=git@vger.kernel.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).