data:image/s3,"s3://crabby-images/1a7e9/1a7e981c2f2d4a455370a12b21e3c052aaee9785" alt=""
git config --global -e
- git bash에
git config --global -e
입력 > VSCode창 open
- VSCode에 하기 내용 입력
[merge]
tool = vscode
[mergetool "vscode"]
cmd = "code --wait $MERGED"
data:image/s3,"s3://crabby-images/0c270/0c27045beeab299ba521ce60c05018beb152bcd0" alt=""
data:image/s3,"s3://crabby-images/3dd5d/3dd5d9c930064771c88df8bb6b04929af0192e7e" alt=""
Git Merge
- 현재 위치한 Branch에 다른 Branch 병합
data:image/s3,"s3://crabby-images/8ede4/8ede4e16a3b35ae023284a0b45176dc6e12396df" alt=""
- main branch에 "my name is noma" 내용의 test.txt 파일 생성, add, commit
data:image/s3,"s3://crabby-images/726e5/726e5ff7e568ec6a062f981f6d4631502d448a97" alt=""
data:image/s3,"s3://crabby-images/6dfc5/6dfc52d36f9997732305bad758caa72e066ec511" alt=""
- dev branch에 "are you?"내용 추가하여 test.txt.파일 갱신, commit
- add를 생략하고 바로 commit할 수도 있습니다.
data:image/s3,"s3://crabby-images/44777/447771bd89ba9e38164df1f0c05096c4912dbbf4" alt=""
3. main branch 이동 후 git merge dev
입력 (dev branch merge)
4. test.txt파일이 "my name is noma /n and you?"로 갱신되어 있음.
Git Conflict
- Branch를 Merge하는 과정 또는 Push, Pull하는 과정에서 충돌이 있을 수 있음.
data:image/s3,"s3://crabby-images/ee78e/ee78e235a0d714072794b4ff22f8f88bdbfb2b55" alt=""
- main branch의 test.txt파일을 "hello, noma."로 갱신, commit
data:image/s3,"s3://crabby-images/25540/2554051ad78aafb045dba608e114f5b8cdc150ea" alt=""
data:image/s3,"s3://crabby-images/4e54b/4e54b103ba729b6e5773df23dd85b1c1f9058a0b" alt=""
2. dev2 branch 생성
3. main branch의 test.txt파일을 "hello, zero."로 갱신, commit
data:image/s3,"s3://crabby-images/69c79/69c796a4f22aa5c1bf73c097b628e2c8a896c1e6" alt=""
data:image/s3,"s3://crabby-images/c4449/c4449b3c94eb79b7bd24d4a8dfb51ac339bdebe0" alt=""
- dev2 branch 이동
- dev2 branch의 test.txt파일을 "hello, base."로 갱신, commit
data:image/s3,"s3://crabby-images/28932/2893276de09e55058fc8ddf395b05e8d80cf5487" alt=""
- main branch 이동
git merge dev2
입력 -> conflict 발생
data:image/s3,"s3://crabby-images/228bf/228bfff3c68d77bfe4f6d22f88d4a73a21ef6581" alt=""
Conflict 해결 후 Merge
data:image/s3,"s3://crabby-images/3e390/3e390edc24f8db1ee0a2662e4c1248d58e792474" alt=""
data:image/s3,"s3://crabby-images/91056/91056fb641f0d240bd378dfd3db8040af1aa09a5" alt=""
git mergetool
입력
- VSCode 창에 충돌되는 파일 내용 출력됨
data:image/s3,"s3://crabby-images/0d0a5/0d0a54a55c553d2e56f8f28b4462f3dd39a7e1d3" alt=""
- 충돌되는 내용 하나로 정리, 저장, 닫기
data:image/s3,"s3://crabby-images/95b49/95b4906ea8ba8603a0bd3e7e9494824f4de07582" alt=""
4. git add test.txt
입력 후 git commit
입력
5. test.txt 조회시 hello, base 출력