WHAT I WANT TO DO
I have a file which contains sensitive datas so I don't want to push content of this file to remote server.
WHAT I DID?
To achieve this, I made a commit when the file was empty and pushed this empty file to server (GitHub). And then fill the file with sensitive datas and applied git update-index --skip-worktree path/to/file
. But I didn't made any commit.
Now I'm trying to switch my branch but I'm getting this error :
error: Your local changes to the following files would be overwritten by checkout:
path/to/file
Please, commit your changes or stash them before you can switch branches.
Aborting
WHY I USE skip-worktree
INSTEAD OF assume-unchanged
?
I read a few SO questions about this subject, and found Borealid's answer.
--assume-unchanged assumes that a developer shouldn’t change a file. This flag is meant for improving performance for not-changing folders like SDKs.
--skip-worktree is useful when you instruct git not to touch a specific file ever because developers should change it. For example, if the main repository upstream hosts some production-ready configuration files and you don’t want to accidentally commit changes to those files, --skip-worktree is exactly what you want.
After this, I found Jeff's question and VonC's answer. Jeff's problem is almost same with mine, and I followed VonC's solution. However it's not work for me. Maybe because of git version difference. Because that question from 2012. We talked with VonC and he said to ask this as a new question because he couldn't remember answer.
I tried to use --assume-unchanged
and --skip-worktree
together, and soft reseting worktree. But nothing changed.
SO?
Can you help me about my problem ?
Thank you.
I got the same problem and it boiled down to be casued by incoming changes on the file I wanted to assume-unchanged on.
So if I just do no-assume-unchanged on the file, stash it, checkout the latest version, pop my stash, and assume-unchanged again.
So now I'm able to switch branches again.
I haven't been able to find a neat solution to this, so I'm using a
.bat
file to run--no-skip-worktree
on the affected files. I thenstash
, switch branch,stash apply
, and then use another.bat
file to run--skip-worktree
on the same files.It's not nice, but it's the simplest and quickest way I've found so far.
Well, this is a cruddy solution, but seems to work reasonably well (though it is only lightly tested):
Create a file named
git-checkoutsw
somewhere in yourPATH
, with the following content:The script captures the list of ignored files, unignores them, checks out the new branch with
-m
(for merge) and whatever other parameters have been specified, and then ignores them again.Now you can do
git checkoutsw
instead ofgit checkout
.So far, --assume-unchanged and --skip-worktree do not work as I found. My git version is : git version 2.8.4 (Apple Git-73) Stash is the only way that works so far.
You can enable sparse checkout and add the file there together with adding the skip-worktree flag (if you add the sparse checkout alone it probably will be deleted).
To exclude a file you should put to sparse-checkout file (see git-read-tree manual):
Then it will not be touched at update (so you don't get content of the other branch there, instead preserving your edits). It might be not what you want.
Just find one line to do --no-skip-worktree on all files
You can easily make a little alias.unhideall with that command :)