branch A, B에서 서로 다른 작업을 하고 있습니다. 그런데 A에 있는 기능이 B에도 필요하게 되었습니다. 이런 경우에 merge를 사용하면 아주 간편합니다. git은 어떤 브랜치의 특정 커밋을 다른 브랜치에도 반영할 수 있도록 합니다. 우선 merge를 해보기 전에 branch 이동을 하면 working directory가 어떻게 바뀌는지 한번 보겠습니다.
저에게는 highlevel 브랜치와 master 브랜치가 있습니다. 두 브랜치의 working directory는 아래와 같습니다. 즉, 아직까지는 코드가 동일한 상태입니다.
이제 master 브랜치에 더하기 함수를 추가하고 커밋을 해보겠습니다.
코드창이 화면에 보이게 놓고 highlevel 브랜치로 이동하면 코드가 어떻게 변하는지 한번 보세요. 코드가 아래 그림처럼 바뀌는 것을 볼 수 있습니다! 만약 에러가 뜬다면 ' git stash ' 라는 명령어를 친 뒤에 다시 시도해보세요.
이처럼 브랜치간 이동을 할 때 코드 내용도 이동하는 브랜치에 맞게 변합니다. 이제 merge를 해보겠습니다.
더하기 함수를 highlevel 브랜치에 반영해보도록 하겠습니다. 먼저 highlevel 브랜치로 이동하고 ' git merge master ' 라는 명령어를 치면 끝입니다. 한번 확인해보겠습니다.
add 함수가 추가된 것을 확인할 수 있습니다. 그런데 merge를 할 때 오류가 나는 경우가 있습니다. highlevel의 add 함수의 이름을 add_highlevel로 바꿔주고, master의 add 함수를 add_master로 바꾼 뒤에 master에서 highlevel을 합병해보겠습니다.
그러면 위와 같은 오류가 발생합니다. 이를 '충돌이 발생했다'라고 하는데요, master와 branch에 모두 변화가 있는 상태에서 합병하려고 할 때 git은 어떤 것을 반영할지 모릅니다. print.py에서 코드를 한번 살펴보겠습니다.
이런 모습으로 나오는데요, 위쪽이 master 브랜치의 내용이고 아래쪽이 highlevel 브랜치의 내용이라는 뜻입니다.이를 해결하는 방법은 아주 간단합니다. 원하시는 함수의 이름을 새로 지어주고 덮어쓰면 됩니다. 저는 add_new라는 이름으로 바꿔주고 저장한 뒤에 커밋을 해보겠습니다.
잘 되네요! 만약에 merge를 취소하고 싶다면 ' git merge --abort ' 명령어를 치시면 됩니다.
merge에 대한 심화 내용은 좀 길어서 뒤에서 다시 다루도록 하겠습니다.
'Git' 카테고리의 다른 글
[Git] HEAD와 branch의 관계 (0) | 2022.01.14 |
---|---|
[Git] Remote repository의 브랜치 (0) | 2022.01.14 |
[Git] branch 소개 (0) | 2022.01.14 |
[Git] 커밋 파헤치기2 - 이전 커밋으로 돌아가기(reset) (0) | 2022.01.14 |
[Git] 커밋 파헤치기1- 커밋 해보기 (0) | 2022.01.14 |