Reputation: 8323
In Xcode 5.0.2, I try to pull from a remote and am given the following message:
"The working copy 'project-name' has uncommitted changes. Commit or discard the changes and try again."
Fair enough. I pull up the commit dialog, and am then given the message, "This file does not exist at the requested revision." Clicking 'OK' brings me on into the commit dialog. (There is no revision displayed in the right pane, presumably for the same reason I was given the most recent message.) Selecting the flat view, I see that there is only one modified file: project.pbxproj
. I enter a commit message and click 'Commit 1 File'. When I then go to pull, I find that I am in exactly the same position as before--the same messages appear and I am unable to pull (or push) no matter how many times I make a commit.
Curious, I run git diff
to see just what has changed. Nothing. git status
provides me with equally helpful output: nothing to commit, working directory clean
. git push
or git pull
? Yep, those work just fine from the command line.
So what gives? Why does Xcode insist that I have changes in my working directory? Why won't it tell me what they are? Have tried restarting Xcode and system. While I'm happy that I still have some way to push and pull, it would be really nice if the Xcode git integration was behaving nicely. Any ideas?
I've found these similar questions, but none address this particular issue (or provide an acceptable solution):
Upvotes: 36
Views: 36865
Reputation: 3804
The top answer did not work for me unfortunately because I had untracked git files.
To fix this, go to your working folder in Terminal, type: git status
That will show you files that are not being tracked by git. Now add each file with:
git add <file with location>
You should be able to copy/pasta the file with location from what gets printed out from git status
.
Upvotes: 0
Reputation: 15
Try this:
Step 1:
git rm --cached ProjectName.xcodeproj/project.xcworkspace/xcuserdata/username.xcuserdatad/UserInterfaceState.xcuserstate
Step 2:
git commit -m "Removed file that shouldn't be tracked"
Upvotes: 0
Reputation: 13083
xCode is really-really crappy. Everytime you just look at files, a file called UserInterfaceState.xcuserstate is changed. You don't see it in the overview of xCode itself, through the command line you can.
Quick fix:
git add .
git commit -m "Commit"
git push origin master
Upvotes: 3
Reputation: 3290
App Code solution:
Confirm git status in Terminal:
git status
Open 'yourProject.xcworkspace' in App Code
VCS > Git > Branches...
Remote Branches > yourBranch > Checkout as new local branch
Confirm fix via Terminal:
git status
Upvotes: 0
Reputation: 6530
You must fix it with command line git. Go to your working folder in Terminal, type:
git status
That will show you what files have uncommitted changes. Crashlytics, for instance, will update itself as soon as you run it, and even using Xcode/Source Control/Discard Changes won't get rid of it.
Once you see the files that have uncommitted changes (ignore added files), use:
git checkout -- Folder/filename.ext
That's the same as a "discard" in Xcode.
After you've done that, go back to Xcode and you should be able to switch branches.
Upvotes: 8
Reputation: 7370
Okay, so I fixed my issue.
With Xcode open:
git reset --hard
" git status
Restart Xcode and make a commit (Just a comment or something )
Repeat the above steps.
This sorted out my issue for me.
Upvotes: 77