Git ignore을 스마트하게 설정해보자

이번에 팀플을 하면서 git conflict가 너무 많이 났습니다. DS_store 등 프로젝트와 관계없는 파일이 계속 올라가고 있었기 때문인데요, 이를 줄이기 위해 git ignore를 설정하면서 다음과 같은 사이트를 알게 되어 공유하려고 합니다. http://www.gitignore.io/

저는 다음과 같은 키워드를 주었습니다.

추가적으로 맨아래에 DS_store도 ignore해주게 하였습니다.

# Created by https://www.gitignore.io/api/xcode,swift,cocoapods
# Edit at https://www.gitignore.io/?templates=xcode,swift,cocoapods

### CocoaPods ###
## CocoaPods GitIgnore Template

# CocoaPods - Only use to conserve bandwidth / Save time on Pushing
#           - Also handy if you have a large number of dependant pods
#           - AS PER https://guides.cocoapods.org/using/using-cocoapods.html NEVER IGNORE THE LOCK FILE
Pods/

### Swift ###
# Xcode
#
# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore

## Build generated
build/
DerivedData/

## Various settings
*.pbxuser
!default.pbxuser
*.mode1v3
!default.mode1v3
*.mode2v3
!default.mode2v3
*.perspectivev3
!default.perspectivev3
xcuserdata/

## Other
*.moved-aside
*.xccheckout
*.xcscmblueprint

## Obj-C/Swift specific
*.hmap
*.ipa
*.dSYM.zip
*.dSYM

## Playgrounds
timeline.xctimeline
playground.xcworkspace

# Swift Package Manager
# Add this line if you want to avoid checking in source code from Swift Package Manager dependencies.
# Packages/
# Package.pins
# Package.resolved
.build/
# Add this line if you want to avoid checking in Xcode SPM integration.
# .swiftpm/xcode

# 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/
# Add this line if you want to avoid checking in source code from the Xcode workspace
# *.xcworkspace

# Carthage
# Add this line if you want to avoid checking in source code from Carthage dependencies.
# Carthage/Checkouts

Carthage/Build

# Accio dependency management
Dependencies/
.accio/

# fastlane
# It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the
# screenshots whenever they are needed.
# For more information about the recommended setup visit:
# https://docs.fastlane.tools/best-practices/source-control/#source-control

fastlane/report.xml
fastlane/Preview.html
fastlane/screenshots/**/*.png
fastlane/test_output

# Code Injection
# After new code Injection tools there's a generated folder /iOSInjectionProject
# https://github.com/johnno1962/injectionforxcode

iOSInjectionProject/

### Xcode ###
# Xcode
# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore

## User settings

## compatibility with Xcode 8 and earlier (ignoring not required starting Xcode 9)

## compatibility with Xcode 3 and earlier (ignoring not required starting Xcode 4)

## Xcode Patch
*.xcodeproj/*
!*.xcodeproj/project.pbxproj
!*.xcodeproj/xcshareddata/
!*.xcworkspace/contents.xcworkspacedata
/*.gcno

### Xcode Patch ###
**/xcshareddata/WorkspaceSettings.xcsettings

##DS_store - 이건 제가 추가적으로 넣어주었습니다.
**/.DS_Store

# End of https://www.gitignore.io/api/xcode,swift,cocoapods

이 코드를 개발중인 git 폴더의 최상위에 .gitignore 이라는 파일로 만들어주면 됩니다. 생성을 완료하고 finder에서 숨긴 파일을 볼 수 있게 해주는 shift + command + . 을 눌러 확인해보면 생성된 것을 확인할 수 있습니다. 적용이 완료되면 개발하는데 보다 편할 것 같아서 공유합니다.

좋아요 7

오~ github에서 Swift템플릿으로 자동생성되는 gitirnore에 아쉬움이 있었는데,

이거 좋네요.

참고로, 이미 git에 등록된 파일은 gitignore에 적용되지 않아요.

git에서 먼저 삭제를 해야 gitignore에 적용됩니다.

좋아요 3

이미 등록된 파일은 적용이 되지 않는군요… 그건 몰랐습니다ㅎㅎ 좋은 개발팁 감사합니다!

좋아요 1

오 저희 팀도 merge 과정에서 몇몇 파일들이 수정한 적도 없는데 계속 conflict 가 나서 저렇게 해서 conflict 를 없앴습니다. 좋은 것 같아요! 굳굳!

좋아요 2