티스토리 뷰

CVS

svn merge 방법

hoiogi 2012. 10. 16. 11:04

맥에서 소스 관리를 위해 svn을 사용중이다.


trunk -> brach -> merge 작업을 빈번하게 사용하는데 


이게 할때마다 자꾸 잊어먹어서 정리 해둔다.(빙그레C 님 감사!)




출처 : http://binggrec.tistory.com/104


branch merge를 할 시점이 오면 항상 헷갈리던건데... 

이번에 한번 개념 제대로 잡고 정리를 해보자.

branch에서 작업한 내용을 trunk에 머지 시킬때

1. 일단 trunk에서 branch를 가지고 왔을때의 리비전을 확인해야 한다.
$ cd dev/branch/1.0
$ svn log --stop-on-copy 
branch를 checkout 받은 디렉토리에서 --stop-on-copy를 해주면 과거에 copy 명령이 일어난 지점까지만 로그를 보여준다.
해서 가장 아래에 있는 리비전을 확인하도록 한다. (copy가 일어난 시점의 리비전)

2. 그리고는 trunk를 checkout 받은 디렉토리에 가서 --dry-run 옵션으로 머지를 시도해본다. (머지하는데 확신이 든다면 이 과정은 생략해도 된다)
머지는 아까 확인한 copy가 일어난 시점의 리비전과 HEAD를 비교하여 이루어진다. (여기서는 2671 리비전이라고 가정) 
$ cd dev/trunk
$ svn merge --dry-run -r2671:HEAD svn://svn.example.co.kr/project/branches/1.0 ./
(--dry-run 옵션에 대해서는 여기에 정리를 해두었으니 참고)
해서 머지가 실행됬을때의 결과를 확인할 수 있다. 

3. 대충 훑어보고 원하는 결과가 맞다면 실제로 머지를 실행. (위 명령에서 --dry-run 옵션만 빼면 된다)
$ svn merge -r2671:HEAD svn://svn.test.co.kr/project/branches/1.0 ./ 
머지가 실행된 후 충돌이 난 파일들은 작업자가 확인 후에 충돌을 해소한 후에 trunk로 최종 커밋을 해주면 된다.
충돌난 파일들의 임시파일들은 svn resolved 명령어로 해결. (이곳 참고)

간혹 한번 생성해서 trunk로의 머지까지 완료된 branch를 머지된 이후에도 계속 사용하는 경우가 있는데
이 경우 해당 branch에서 새로운 프로젝트 작업 후 trunk로의 머지를 할 경우에는 리비전 명시에 주의를 해야 한다.
처음 merge시에는 copy된 리비전을 알기위해 --stop-on-copy 옵션을 썼지만, 같은 브랜치를 두번째로 merge 할 경우에는 첫번째 머지한 이후의 리비전과 HEAD를 비교해야 하므로, 첫번째 머지했을때의 리비전을 작업자가 관리해야 하는 불편함이 생긴다.
그래서 되도록이면 두번째 프로젝트를 시작할 경우에는 머지가 완료된 해당 브랜치를 그대로 사용하기보다, trunk에서 새로운 브랜치를 copy해와서 작업하는게 더 좋을 듯 하다.


'CVS' 카테고리의 다른 글

github 는 어떻게 읽어야 되나요?  (0) 2012.10.16
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함