Xcode: “The working copy ____ has uncommitted changes” vs. git status: “nothing to commit, working directory clean”

左心房为你撑大大i 提交于 2021-01-20 14:59:11

问题


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):

  • Cannot push, pull or merge git. "Working copy has uncommited changes"
  • Commit or discard the changes and try again
  • Git pull fails: You have unstaged changes. Git status: nothing to commit (working directory clean)
  • Xcode Version Controll GIT - has uncommitted changes, just after commit
  • Xcode says "Uncommitted Changes" Whenever I try to git pull or push

回答1:


Okay, so I fixed my issue.

With Xcode open:

  1. Open terminal - cd / to your project directory.
  2. Type in: "git reset --hard"
  3. Type in git status

Restart Xcode and make a commit (Just a comment or something )

Repeat the above steps.

This sorted out my issue for me.




回答2:


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.




回答3:


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:

  1. Open Terminal
  2. CD to your project directory, and type the following:
  3. git add .
  4. git commit -m "Commit"
  5. git push origin master



回答4:


App Code solution:

  1. Confirm git status in Terminal:

    git status

  2. Open 'yourProject.xcworkspace' in App Code

  3. VCS > Git > Branches...

  4. Remote Branches > yourBranch > Checkout as new local branch

  5. Confirm fix via Terminal:

    git status



来源:https://stackoverflow.com/questions/20961822/xcode-the-working-copy-has-uncommitted-changes-vs-git-status-nothing

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!