Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

xcodeproj under version control

What are the best practices while including a Xcode project under version control.

like image 846
shreyasva Avatar asked Jan 13 '11 18:01

shreyasva


2 Answers

This is what is in my Global .gitignore file which you can see as a gist on GitHub, but the Xcode list can be applied to other systems

# Mac OS X *.DS_Store  # Xcode *.pbxuser *.mode1v3 *.mode2v3 *.perspectivev3 *.xcuserstate project.xcworkspace/ xcuserdata/  # Generated files *.o *.pyc  #Python modules MANIFEST dist/ build/  # Backup files *~.nib \#*# .#* 
like image 199
Abizern Avatar answered Oct 04 '22 16:10

Abizern


Check in project.pbxproj, ignore the user specific files.

Include shared components and third party libraries as project dependencies using submodules/externals/whatever your VCS supports instead of manually copying static library binaries without any history.

You will get merge conflicts in the project.pbxproj, be prepared to deal with this and try to minimize the difficulty of resolving them.

  • Have a consistent structure for where files should be on disk and how that maps to groups in Xcode.
  • Sort the resources included in your build targets and the order of resources within your project's groups. I really need to write a script to do this for me because it is so much easier to identify the cause of a merge conflict when you don't have to diff two random sets of files. It also avoids many merge conflicts as you're less likely to have multiple developers all appending new resources to the bottom of a list.

Check in early and often.

like image 25
Jonah Avatar answered Oct 04 '22 18:10

Jonah