Git ignore le fichier pour les projets Xcode

Quels fichiers dois-je inclure dans .gitignore lors de l’utilisation de Git avec Xcode ?

Mods: Veuillez ne pas approuver les modifications apscopes à cette réponse. Jusqu’à présent, chaque édition a été INCORRECT et provoque une perte de données. S’il vous plaît laissez cette réponse seul!


Si vous voulez éditer cette réponse … non. Lisez tout d’abord en premier: il existe un moyen simple de créer votre propre fork, et si cela ne vous suffit pas, vous pouvez le commenter.


J’utilisais auparavant la réponse avec le plus grand nombre de votes, mais il a besoin d’un peu de nettoyage, donc ici, il est refait pour Xcode 4, avec quelques améliorations.

J’ai recherché chaque fichier de cette liste, mais plusieurs d’entre eux n’existent pas dans les docs officiels xcode d’Apple, alors j’ai dû aller sur les listes de diffusion Apple.

Apple continue à append des fichiers non documentés, potentiellement corrompre nos projets en direct. Cet IMHO est inacceptable et j’ai maintenant commencé à enregistrer les bogues à chaque fois. Je sais qu’ils s’en moquent, mais peut-être que l’un d’entre eux aura honte de traiter les développeurs de manière plus équitable.


Si vous avez besoin de personnaliser, voici un aperçu que vous pouvez fourrer: https://gist.github.com/3786883


 ######################### # .gitignore file for Xcode4 and Xcode5 Source projects # # Apple bugs, waiting for Apple to fix/respond: # # 15564624 - what does the xccheckout file in Xcode5 do? Where's the documentation? # # Version 2.6 # For latest version, see: http://stackoverflow.com/questions/49478/git-ignore-file-for-xcode-projects # # 2015 updates: # - Fixed typo in "xccheckout" line - thanks to @lyck for pointing it out! # - Fixed the .idea optional ignore. Thanks to @hashier for pointing this out # - Finally added "xccheckout" to the ignore. Apple still refuses to answer support requests about this, but in practice it seems you should ignore it. # - minor tweaks from Jona and Coeur (slightly more precise xc* filtering/names) # 2014 updates: # - appended non-standard items DISABLED by default (uncomment if you use those tools) # - removed the edit that an SO.com moderator made without bothering to ask me # - researched CocoaPods .lock more carefully, thanks to Gokhan Celiker # 2013 updates: # - fixed the broken "save personal Schemes" # - added line-by-line explanations for EVERYTHING (some were missing) # # NB: if you are storing "built" products, this WILL NOT WORK, # and you should use a different .gitignore (or none at all) # This file is for SOURCE projects, where there are many extra # files that we want to exclude # ######################### ##### # OS X temporary files that should never be committed # # cf http://www.westwind.com/reference/os-x/invisibles.html .DS_Store # cf http://www.westwind.com/reference/os-x/invisibles.html .Trashes # cf http://www.westwind.com/reference/os-x/invisibles.html *.swp # # *.lock - this is used and abused by many editors for many different things. # For the main ones I use (eg Eclipse), it should be excluded # from source-control, but YMMV. # (lock files are usually local-only file-synchronization on the local FS that should NOT go in git) # cf the "OPTIONAL" section at bottom though, for tool-specific variations! # # In particular, if you're using CocoaPods, you'll want to comment-out this line: *.lock # # profile - REMOVED temporarily (on double-checking, I can't find it in OS X docs?) #profile #### # Xcode temporary files that should never be committed # # NB: NIB/XIB files still exist even on Storyboard projects, so we want this... *~.nib #### # Xcode build files - # # NB: slash on the end, so we only remove the FOLDER, not any files that were badly named "DerivedData" DerivedData/ # NB: slash on the end, so we only remove the FOLDER, not any files that were badly named "build" build/ ##### # Xcode private settings (window sizes, bookmarks, breakpoints, custom executables, smart groups) # # This is complicated: # # SOMETIMES you need to put this file in version control. # Apple designed it poorly - if you use "custom executables", they are # saved in this file. # 99% of projects do NOT use those, so they do NOT want to version control this file. # ..but if you're in the 1%, comment out the line "*.pbxuser" # .pbxuser: http://lists.apple.com/archives/xcode-users/2004/Jan/msg00193.html *.pbxuser # .mode1v3: http://lists.apple.com/archives/xcode-users/2007/Oct/msg00465.html *.mode1v3 # .mode2v3: http://lists.apple.com/archives/xcode-users/2007/Oct/msg00465.html *.mode2v3 # .perspectivev3: http://stackoverflow.com/questions/5223297/xcode-projects-what-is-a-perspectivev3-file *.perspectivev3 # NB: also, whitelist the default ones, some projects need to use these !default.pbxuser !default.mode1v3 !default.mode2v3 !default.perspectivev3 #### # Xcode 4 - semi-personal settings # # Apple Shared data that Apple put in the wrong folder # cf http://stackoverflow.com/a/19260712/153422 # FROM ANSWER: Apple says "don't ignore it" # FROM COMMENTS: Apple is wrong; Apple code is too buggy to trust; there are no known negative side-effects to ignoring Apple's unofficial advice and instead doing the thing that actively fixes bugs in Xcode # Up to you, but ... current advice: ignore it. *.xccheckout # # # OPTION 1: --------------------------------- # throw away ALL personal settings (including custom schemes! # - unless they are "shared") # As per build/ and DerivedData/, this ought to have a trailing slash # # NB: this is exclusive with OPTION 2 below xcuserdata/ # OPTION 2: --------------------------------- # get rid of ALL personal settings, but KEEP SOME OF THEM # - NB: you must manually uncomment the bits you want to keep # # NB: this *requires* git v1.8.2 or above; you may need to upgrade to latest OS X, # or manually install git over the top of the OS X version # NB: this is exclusive with OPTION 1 above # #xcuserdata/**/* # (requires option 2 above): Personal Schemes # #!xcuserdata/**/xcschemes/* #### # Xcode 4 workspaces - more detailed # # Workspaces are important! They are a core feature of Xcode - don't exclude them :) # # Workspace layout is quite spammy. For reference: # # /(root)/ # /(project-name).xcodeproj/ # project.pbxproj # /project.xcworkspace/ # contents.xcworkspacedata # /xcuserdata/ # /(your name)/xcuserdatad/ # UserInterfaceState.xcuserstate # /xcshareddata/ # /xcschemes/ # (shared scheme name).xcscheme # /xcuserdata/ # /(your name)/xcuserdatad/ # (private scheme).xcscheme # xcschememanagement.plist # # #### # Xcode 4 - Deprecated classes # # Allegedly, if you manually "deprecate" your classes, they get moved here. # # We're using source-control, so this is a "feature" that we do not want! *.moved-aside #### # OPTIONAL: Some well-known tools that people use side-by-side with Xcode / iOS development # # NB: I'd rather not include these here, but gitignore's design is weak and doesn't allow # modular gitignore: you have to put EVERYTHING in one file. # # COCOAPODS: # # cf http://guides.cocoapods.org/using/using-cocoapods.html#what-is-a-podfilelock # cf http://guides.cocoapods.org/using/using-cocoapods.html#should-i-ignore-the-pods-directory-in-source-control # #!Podfile.lock # # RUBY: # # cf http://yehudakatz.com/2010/12/16/clarifying-the-roles-of-the-gemspec-and-gemfile/ # #!Gemfile.lock # # IDEA: # # cf https://www.jetbrains.com/objc/help/managing-projects-under-version-control.html?search=workspace.xml # #.idea/workspace.xml # # TEXTMATE: # # -- UNVERIFIED: cf http://stackoverflow.com/a/50283/153422 # #tm_build_errors #### # UNKNOWN: recommended by others, but I can't discover what these files are # 

Basé sur ce guide pour Mercurial, mon fichier .gitignore comprend:

 .DS_Store *.swp *~.nib build/ *.pbxuser *.perspective *.perspectivev3 

J’ai aussi choisi d’inclure:

 *.mode1v3 *.mode2v3 

qui, selon cet article de la liste de diffusion Apple , sont des “parameters de projet spécifiques à l’utilisateur”.

Et pour Xcode 4:

 xcuserdata 

En ce qui concerne l’exclusion de répertoire ‘build’ –

Si vous placez vos fichiers de construction dans un répertoire différent de celui de votre source, vous n’avez pas à vous soucier du dossier dans l’arborescence.

Cela rend également la vie plus simple pour le partage de votre code, empêchant les sauvegardes excessives et même lorsque vous avez des dépendances par rapport à d’autres projets Xcode (tout en exigeant que les générations soient dans le même répertoire)

Vous pouvez obtenir une copie à jour de l’essentiel de Github https://gist.github.com/708713

Mon fichier actuel .gitignore est

 # 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 

Pour Xcode 4, j’ajoute aussi:

 YourProjectName.xcodeproj/xcuserdata/* YourProjectName.xcodeproj/project.xcworkspace/xcuserdata/* 

J’ai inclus ces suggestions dans un Gist I créé sur Github: http://gist.github.com/137348

Sentez-vous libre de la bifurquer et de la rendre meilleure.

Les personnes de GitHub ont des fichiers .gitignore exhaustifs et documentés pour les projets Xcode:

Swift: https://github.com/github/gitignore/blob/master/Swift.gitignore

Objective-C: https://github.com/github/gitignore/blob/master/Objective-C.gitignore

J’utilise à la fois AppCode et XCode. Donc .idea/ devrait être ignoré.

ajoutez ceci à .gitignore d’Adam

 #### # AppCode .idea/ 

Vous devriez vérifier gitignore.io pour Objective C et Swift

Voici le fichier .gitignore que j’utilise

 # Xcode .DS_Store */build/* *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata profile *.moved-aside DerivedData .idea/ *.hmap *.xccheckout *.xcworkspace !default.xcworkspace #CocoaPods Pods 

Le mien est un .bzrignore, mais même idée 🙂

 .DS_Store *.mode1v3 *.pbxuser *.perspectivev3 *.tm_build_errors 

le tm_build_errors est pour quand j’utilise TextMate pour construire mon projet. Pas tout à fait aussi complet que Hagelin, mais je pensais que cela valait la peine de poster pour la ligne tm_build_errors.

Voici un script que j’ai créé pour créer automatiquement vos fichiers .gitignore et .gitatsortingbutes en utilisant Xcode … Je l’ai piraté avec quelques trucs d’autres personnes. S’amuser!

Xcode-Git-User-Script

Pas de garantie … Je crains tout au plus – donc à utiliser à vos risques et périls

append un fichier .gitignore pour

MAC OS X + XCode + Swift

Voici comment j’ai ajouté un fichier .gitignore dans mon projet Swift

  1. Sélectionnez votre projet dans XCode et cliquez droit -> Nouveau groupe -> Nommez-le ” Git
  2. Sélectionnez le dossier Git et faites un clic droit -> Ajouter un nouveau fichier
  3. Dans l’ onglet iOS -> sélectionnez Autre -> fichier vide

entrer la description de l'image ici

  1. donner le nom du fichier ici ” .gitignore

entrer la description de l'image ici

  1. Confirmez le nom du fichier et le type

entrer la description de l'image ici

Voici la structure de résultat

entrer la description de l'image ici

  1. ouvrir le fichier et passé sous le code

 # file ######################################################################### # # # Title - .gitignore file # # For - MAC OSX , Xcode7 and Swift Source projects # # Updated by - Ramdhan Choudhary # # Updated on - 13 - November - 2015 # # # ######################################################################### ########### Xcode ########### # Xcode temporary files that should never be committed ## Build generated build/ DerivedData # NB: NIB/XIB files still exist even on Storyboard projects, so we want this *~.nib *.swp ## Various settings *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata ## Other *.xccheckout *.moved-aside *.xcuserstate *.xcscmblueprint *.xcscheme ########### OSX ########### # OS X temporary files that should never be committed .DS_Store .AppleDouble .LSOverride # Icon must end with two \r Icon # Thumbnails ._* # Files that might appear in the root of a volume .DocumentRevisions-V100 .fseventsd .Spotlight-V100 .TemporaryItems .Trashes .VolumeIcon.icns # Directories potentially created on remote AFP share .AppleDB .AppleDesktop Network Trash Folder Temporary Items .apdisk ########## Obj-C/Swift specific ########## *.hmap *.ipa # CocoaPods # # We recommend against adding the Pods directory to your .gitignore. However # you should judge for yourself, the pros and cons are mentioned at: # https://guides.cocoapods.org/using/using-cocoapods.html#should-i-check-the-pods-directory-into-source-control # # Pods/ # Carthage # # Add this line if you want to avoid checking in source code from Carthage dependencies. # Carthage/Checkouts Carthage/Build # fastlane # # It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the fastlane/report.xml fastlane/screenshots 

Eh bien, grâce à Adam , sa réponse m’a beaucoup aidé mais il me fallait encore append quelques entrées supplémentaires car je voulais .gitignore pour

MAC OS X + XCode + Swift

Références: ceci et cela

Pour XCode 5, j’ajoute:

 #### # Xcode 5 - VCS metadata # *.xccheckout 

De la réponse de Berik

J’ai ajouté:

 xcuserstate xcsettings 

et placé mon fichier .gitignore à la racine de mon projet.

Après avoir commis et poussé J’ai alors couru:

 git rm --cached UserInterfaceState.xcuserstate WorkspaceSettings.xcsettings 

enterré avec le dossier ci-dessous:

 /.xcodeproj/project.xcworkspace/xcuserdata/.xcuserdatad/ 

J’ai ensuite couru git commit et repoussé

J’utilise le fichier .gitignore suivant généré dans gitignore.io:

 ### Xcode ### build/ *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata *.xccheckout *.moved-aside DerivedData *.xcuserstate ### Objective-C ### # Xcode # build/ *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata *.xccheckout *.moved-aside DerivedData *.hmap *.ipa *.xcuserstate # CocoaPods # # We recommend against adding the Pods directory to your .gitignore. However # you should judge for yourself, the pros and cons are mentioned at: # http://guides.cocoapods.org/using/using-cocoapods.html#should-i-ignore-the-pods-directory-in-source-control # Pods/ 

Voici le .gitignore que GitHub utilise par défaut pour les nouveaux référentiels Xcode:

https://github.com/github/gitignore/blob/master/Objective-C.gitignore

Il est susceptible d’être raisonnablement correct à tout moment.

le meilleur de tous,

gitignore.io

Allez choisir votre langue, puis elle vous donnera le fichier.

Nous avons constaté que même si vous ajoutez le fichier .gitignore et le fichier .gitatsortingbte, le fichier * .pbxproj peut être corrompu. Nous avons donc un plan simple.

Toute personne qui code au bureau ignore simplement les modifications apscopes à ce fichier. Dans le commit, nous mentionnons simplement les fichiers ajoutés dans la source. Et puis poussez sur le serveur. Notre responsable de l’intégration tire et voit les détails de la validation et ajoute les fichiers dans les ressources.

Une fois qu’il met à jour la télécommande, tout le monde aura toujours une copie de travail. Si quelque chose manque, nous l’informons de l’append puis de le retirer à nouveau.

Cela a fonctionné pour nous sans aucun problème.

Je recommande d’utiliser joe pour générer un fichier .gitignore .

Pour un projet iOS, exécutez la commande suivante:

$ joe g osx,xcode > .gitignore

Il va générer ce .gitignore :

 .DS_Store .AppleDouble .LSOverride Icon ._* .DocumentRevisions-V100 .fseventsd .Spotlight-V100 .TemporaryItems .Trashes .VolumeIcon.icns .AppleDB .AppleDesktop Network Trash Folder Temporary Items .apdisk build/ DerivedData *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata *.xccheckout *.moved-aside *.xcuserstate 

Utilisez https://www.gitignore.io/ pour générer et append les fichiers mac, cacoaPods ci-dessous:

 ## Mac .DS_Store ## cocoaPods Pod ## Build generated build/ DerivedData/ ## Various settings *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 xcuserdata/ ## Other *.moved-aside *.xccheckout *.xcscmblueprint ### Xcode Patch ### *.xcodeproj/* !*.xcodeproj/project.pbxproj !*.xcodeproj/xcshareddata/ !*.xcworkspace/contents.xcworkspacedata /*.gcno 

Une structure d’un fichier .gitignore standerd pour un projet Xcode>

 .DS_Store .DS_Store? ._* .Spotlight-V100 .Trashes Icon? ehthumbs.db Thumbs.db build/ *.pbxuser !default.pbxuser *.mode1v3 !default.mode1v3 *.mode2v3 !default.mode2v3 *.perspectivev3 !default.perspectivev3 !default.xcworkspace xcuserdata profile *.moved-aside DerivedData .idea/