Git pull: error: Entry foo not uptodate. Cannot merge

Git

Git Problem Overview


I'm trying to update my repo from a remote branch and keep getting this error when I do a "git pull". I haven't made any local changes, and even if I have I don't need to keep them.

I've tried:

git reset --hard

and I get the same problem

The only thing that seems to work is deleting the offending file and try a git pull again.

I've also tried git stash followed by a git pull. No go.

edit: using PortableGit-1.6.4-preview20090729 so any previous bugs with spurious errors should be fixed.

Git Solutions


Solution 1 - Git

This may happen if you update the index to ignore certain files:

git update-index --assume-unchanged <file>

and then for instance checkout some other branch:

git checkout <branch>
> error: Entry '<file>' not uptodate. Cannot merge.

Forcing index refresh fixes the issue:

git update-index --really-refresh
<file>: needs update

Followed by:

git reset --hard 

And then everything should be back to normal.

Solution 2 - Git

There's a couple of ways to fix this but I've found git stash works good for me. It temporary puts your local changes into another place. Then you can pull, to grab the latest changes. And then you can get your local changes back.

Just like this:

$ git pull
...
...
file your_file.rb not up to date, cannot merge.

$ git stash
$ git pull
$ git stash pop

Solution 3 - Git

This sort of problem is frequently caused by trying to pull from a repository that has two filenames that differ only in case. If you are on FAT, NTFS in case-insensitive mode (essentially, any time it's being used under Windows), or HFS+ in case-insensitive mode, and have two files "foobar" and "FOOBAR", then Git will see two distinct files, but the filesystem will only see one, which will cause all kinds of problems. Git will checkout, say, "FOOBAR", and then checkout "foobar", which the filesystem sees as simply replacing the contents of "FOOBAR" but leaving it in place. Now to Git, it appears that "FOOBAR" has been replaced with the contents of "foobar", and "foobar" is gone.

There are two different manifestations of this basic problem. One is when your repository actually contains two files that differ only on case. In this case, you need to work on a case-sensitive file system, or you will need to edit the repository to ensure that no collisions of this sort occur; a case-insensitive file system simply cannot store the contents of this repository.

A different case that you can workaround is when a rename happens that changes the case of the file. Say, for example, that the Git repository contains a rename from "EXAMPLE" to "example". Before Git checks out the new version, it will try and check to make sure it's not overwriting some existing file that you have on your disk. Since it thinks that "example" is a new filename, it will ask the filesystem if it exists, and the filesystem will see "EXAMPLE" and say yes, so Git will refuse to check out the new version since it thinks it will be overwriting untracked files. In this case, if you have no local changes that you care about, a simple git reset --hard <revision-to-checkout> will generally be sufficient to get you past the problem and to the new revision. Just try and remember not to rename files to other names that differ only in case if you're on a case-insensitive file system, as it will cause problems like this.

Solution 4 - Git

For further elaborate on @Brian Campbell's post (because reset hard didn't work either) I want to point out an edge case that was stopping me.

I had moved a file OldFile to a different folder and renamed it NewFile. I then flagged the the file as assume-unchanged.

This was preventing me from switching branches and there was no stash to save or commit to push. The problem was I didn't commit this file change with a new name before setting the assume-unchanged flag. So I set it back to no-assume-unchanged, committed it, then set it back to assume-unchanged and I could switch branches again.

Solution 5 - Git

Generally speaking, this means you have changes in your local files that haven't been committed to your local repository. You can also see this stackoverflow question for a bit more detail.

Solution 6 - Git

I was seeing a similar issue (Windows 10): I was on branchA and wanted to go to the master branch. I had some uncommitted changes, so first I called git stash, and then git checkout -f master.

Unfortunately, I kept getting the Entry 'fileName' not uptodate. Cannot merge error message.

The command git status didn't show information that there are any changes to commit.

Eventually I just removed the file manually, and was able to go to the other branch (what of course made my file come back). I suspect there was a bug in the Git repository.

Solution 7 - Git

It might a problem also with file permissions. Git is versioning them too, unless config says otherwise. Just adding this answer for people who has almost but not the like problem.

Solution 8 - Git

Worth a try:

Could you set, just for this update, set the config parameter core.trustctime to false?

core.trustctime

> If false, the ctime differences between the index and the working copy are ignored; useful when the inode change time is regularly modified by something outside Git (file system crawlers and some backup systems).

Solution 9 - Git

Adding my answer because none of the others mention this. In my case this happened after I added new files into the index with the -N flag, so just adding them to the index without adding their content. In this state, doing git stash yields this error.

Solution 10 - Git

I was trying to perform git merge --abort. The command git restore your_file has fixed the issue for me

Solution 11 - Git

I had the same error, after a situation where git status said new file: foo.cpp for a file not added to the staging area. i.e. under the "Changes not staged for commit" heading. Very weird, this usually doesn't happen.

Solution: git add foo.cpp, and then git stash worked again.

Solution 12 - Git

Came to this question and none of the answers worked for me, so here's what did it: deleting the file.

rm -rf the_conflicting_file

then

git checkout your_branch

Solution 13 - Git

If git update-index --really-refresh doesn't work, try:

git update-index --no-skip-worktree <file>

Solution 14 - Git

I was also getting the same error but while checking out a different branch. with the error message > error: Entry 'file' not uptodate. Cannot merge.

Turns out the problem is with a file that was previously removed from the index using the below command in the current branch but the same file was committed in the destination branch. > git update-index --skip-worktree foo

So the fix was to update index to include that file > git update-index --no-skip-worktree foo

and the use git stash or git rm to keep or delete the file.

Solution 15 - Git

Nothing here worked for me, in the end I just put my file in a different file path and then put it back, seems to have did the trick.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionyuitView Question on Stackoverflow
Solution 1 - GithabitatsView Answer on Stackoverflow
Solution 2 - GitmanatView Answer on Stackoverflow
Solution 3 - GitBrian CampbellView Answer on Stackoverflow
Solution 4 - GitAggressorView Answer on Stackoverflow
Solution 5 - GitcodeincarnateView Answer on Stackoverflow
Solution 6 - Gituser276648View Answer on Stackoverflow
Solution 7 - GitDrachenfelsView Answer on Stackoverflow
Solution 8 - GitVonCView Answer on Stackoverflow
Solution 9 - GitAviad P.View Answer on Stackoverflow
Solution 10 - GitYouness MarhraniView Answer on Stackoverflow
Solution 11 - GitDavid FaureView Answer on Stackoverflow
Solution 12 - GitWolfgangView Answer on Stackoverflow
Solution 13 - GitOmerView Answer on Stackoverflow
Solution 14 - GitrathourdeveshView Answer on Stackoverflow
Solution 15 - Gitcode-monkeyView Answer on Stackoverflow