Should I git ignore xcodeproject/project.pbxproj file?

IosXcodeMacosGit

Ios Problem Overview


in a XCode project, I offen got xcodeproject/project.pbxproj file changed, but useless info for me, it for compile.

Should I git ignore this file and xcodeproject/projectxworkspace/username.xcuserdata/UserInterfaceState.xcuserstate file?

Ios Solutions


Solution 1 - Ios

Update in the light of Swift Package Manager: If you're building a project as a Swift package - you should definitely ignore this file as it can be generated using file system as source of truth. You can do that by using the following command:

$ cd ~/Projects/MyProjectFolder/
$ swift package generate-xcodeproj

For non-SwiftPM answer - see below.

This file holds the list of all the files in the project, settings of targets and which files belong to which targets. It's probably the meatiest file in project bundle. You should not ignore this file. There are few points for this:

  1. You may not want to work on this project alone or;
  2. You're planning on working on project from different machines;
  3. You'll want to share your code base with others;

Solution 2 - Ios

That is the only file that you want in your repos from the xcodeproj bundle. That file holds all of the info for targets files and build settings.

Solution 3 - Ios

Unfortunately, if your Build Settings includes code signing, you have to re-enter your code-signing entity after every "git pull" if another team member has changed it. It seems to me this info should be in the user settings, not the global pbxproj file.

Solution 4 - Ios

If you exclude project.pbxproj Jenkins builds will fail. So this is important if you use Jenkins.

Solution 5 - Ios

> project.pbxproj is an important file in the Xcode configuration bundle. It is responsible for maintaining references to all of the linked files and their groupings, linked frameworks, and most importantly, the project’s build settings. Because of this, we cannot exclude project.pbxproj from version control.

Here is my general .gitignore for my Xcode Project.

# OS X Finder
.DS_Store

# Xcode per-user config
*.mode1
*.mode1v3
*.mode2v3
*.perspective
*.perspectivev3
*.pbxuser
*.xcworkspace
xcuserdata

# Build products
build/
*.o
*.LinkFileList
*.hmap

# Automatic backup files
*~.nib/
*.swp
*~
*.dat
*.dep

Solution 6 - Ios

I found that I also need to preserve the xcworkspace file(s). If didn't, project with a sub-project broke.

Solution 7 - Ios

You can use Xcodegen to generate a pbxproj out of a YAML project specification file then you can ignore pbxproj in git and generate them every time you need.

I have already used Xcodegen on a second project which has a modular architecture (many pbxprojs) and more then 8 developers is working on it.

https://github.com/yonaskolb/XcodeGen

Hope it helps.

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
QuestionqichunrenView Question on Stackoverflow
Solution 1 - IosEimantasView Answer on Stackoverflow
Solution 2 - IosGrady PlayerView Answer on Stackoverflow
Solution 3 - IosJulius SmithView Answer on Stackoverflow
Solution 4 - IosJoseph Bolade Caxton-IdowuView Answer on Stackoverflow
Solution 5 - IosDylanView Answer on Stackoverflow
Solution 6 - IosPaul CezanneView Answer on Stackoverflow
Solution 7 - IosCyril CermakView Answer on Stackoverflow