The Git integration in Xcode 4 is very welcome however it seems to be a bit flaky when it comes to dealing with remote repositories. For clarity I'm using OS X version 10.6.7 and Xcode 4.0.2 (4A2002a).
If I create a new Xcode 4 Project and accept the option to create a local Git repository, all is well. I can commit locally and that's great.
When I want to push the new project to GitHub I want to add a remote repository and push my local changes up to GitHub. I can add a GitHub repository to Xcode 4 as a new Repository in the Organizer window but there's no method of setting it as a remote repository for my existing project.
So I switch to using git commands in Terminal.
git remote add origin https://<username>@github.com/<organization>/<repository>.git
If I then go back to Xcode 4 and try to use
File -> Source Control -> Push...
then the Choose the repository to which to push changes. dialog appears listing the origin remote repository. There's a yellow indicator saying that Authentication is required, which is fine as I've not been able to enter my credentials yet for HTTPS. However when I click 'Push' and it tries to push the changes it says "The operation could not be performed because access to the repository 'origin' is denied."
A dialog prompting me for my username and password then appears with my pre-filled out so it must be reading this correctly from the local repository's config.
When I enter my password Xcode 4 then crashes with the following error
ASSERTION FAILURE in /SourceCache/IDEKit/IDEKit-303/Framework/Classes/SourceControl/IDESourceControlOperationInfo.m:59
Details: Message sent to invalidated object: <IDESourceControlPushOperationInfo, 0x200bd2a80>. Backtrace for invalidation:
(null)
Object: <IDESourceControlPushOperationInfo: 0x200bd2a80>
Method: -invalidate
Thread: <NSThread: 0x200020700>{name = (null), num = 1}
Hints: None
If I restart Xcode an origin repository has been added to the Repositories browser in Organizer and I can see the master branch on GitHub so I know the credentials are right without me changing anything.
Has anyone found a reliable way of using Xcode 4 with GitHub starting with a local project first?
If I clone an existing GitHub repository with an Xcode project in it, open it with Xcode 4 then even though the first Push seems to fail, the 2nd push did then work. So maybe starting from absolute scratch with Xcode 4 creating the repository for me isn't the best pattern (until they improve the Git tooling in a later version of Xcode 4).
EDIT WITH FURTHER DETAILS OF ONE WORKAROUND
This example only really applies to the first project you're adding to a GitHub repository. As such I think you're better off with the following steps, bearing in mind there still seem to be some Xcode 'gotchas' in this solution.
- List item
- 'Connect to a repository' from Welcome to Xcode dialog.
- Use GitHub SSH URL for Location
- Give it a name (RepositoryName)and Clone to a directory
- 1st attempt appears to fail even though contents are downloaded
- Try Again and it works.
- There is now a new Repository defined in the Organizer window with its origin set to the GitHub remote SSH URL.
- Create a New Project within the directory you just cloned into but DO NOT tick the 'Create local git repository for this project' option.
- Do initial commit to local Git repository.
- Try Source Control -> Push and Xcode 4 fails with 'The operation could not be performed because access to the repository RepositoryName was denied. Check username and password'
- Try Source Control -> Push and Xcode 4 pops up the remote Repository dialog again but this time has detected a remote Repository called origin. Next to it there's a yellow ball and 'Authentication required'.
- Clicking 'Push' again caused the remote Push to work.
One thing I've spotted and not managed to work out yet is that the response messages back from GitHub with the checkin hash value and any messages seem to get reported in Xcode Log navigator as Push failures, even though the Push is successful as far as GitHub is concerned.
Anyone else have a better solution?