tags:

views:

46

answers:

1

I wish to stop tracking files but still keep them in my working tree.

I've gathered that git rm --cached FILE will let me do that. However, if someone else pulls this change, will their local copies be deleted?

+2  A: 

Yes, their copies will be automatically deleted. Imagine if this deletion wouldn't happen--then working copies of all users would be polluted with piles of deleted files, which aren't needed anymore.

However, if the remote users made local changes to these files, they won't be deleted, since pull will result in a merge conflict.

As Jefromi suggests in his comment, while the files are removed at the other users' sides, they can easily be restored--they're under a version-control, aren't they? ;-) Files could be gotten by git checkout <revision> -- <files...>. As revision you may specify the id of the previous commit, for pull it's saved in ORIG_HEAD (see this question for details):

git checkout ORIG_HEAD -- removed_file
Pavel Shved
And if the pull doesn't conflict, but they want the files back, all they have to do is `git checkout HEAD^ <path>`.
Jefromi
Thanks, that's what I needed to know.Fingers crossed I didn't delete any vital xcode files on my colleagues' working directories.
rod
@Jefromi, thanks, merged your comment into my answer
Pavel Shved