45

I'm trying to run the following:

git update-index --assume-unchanged myFolderToIgnore

Where myFolderToIgnore is a folder. However it fails saying its "unable to mark" it.

So I tried:

git update-index --assume-unchanged myFolderToIgnore/

Which GIT responds to with Ignoring path myFolderToIgnore/ but doesn't do anything (it still sees my changes and tries to check them in).

In the end I had to go in and manually mark each individual file as unchanged. What am I missing here?

Chronial
  • 66,706
  • 14
  • 93
  • 99
gxc
  • 4,946
  • 6
  • 37
  • 55

2 Answers2

79

update-index is an internal plumbing command and thus not as comfortable as the real front-end commands. You will have to handle the recursion bit yourself:

git ls-files -z myFolderToIgnore/ | xargs -0 git update-index --assume-unchanged

PSA: There is a high chance that assume-unchanged is not what you are looking for and you should use skip-worktree instead. See here for more info.

Chronial
  • 66,706
  • 14
  • 93
  • 99
  • 2
    On a GNU system `ls-files -z` with `xargs -0` is a more robust solution, just in case there are files with whitespace in their names. – CB Bailey May 02 '13 at 21:06
  • thank you so much, I have been searching the internet for hours and this finally worked. May God bless your holy immortal soul. – Iamsodarncool Nov 10 '19 at 09:31
1

I ran into this issue where my folder had hundreds of thousands of files, and thousands of folders.

This resulted in "Argument list too long".

The following solution will run the command for each folder and traverse the contents in those folders. So as long as your hundreds of thousands of files are separated in folders then this will work.

find . -maxdepth 1 -type d \( ! -name . \) -exec bash -c "cd '{}' && pwd && git ls-files -z ${pwd} | xargs -0 git update-index --assume-unchanged" \;
Chad Cache
  • 9,668
  • 3
  • 56
  • 48