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