[git] 레파지토리의 변경사항을 다른 레파지토리에 적용하기
아~ 점심 먹고 와서 꼬박 3시간을 매달려서 겨우 방법을 알아낸 것 같다. 아니.. 오전부터 준비를 하긴 했으니그보다 많은 시간이.. 방법을 알아내고 나니 긴장이 풀렸는지.. 피곤함이 급 밀려온다. 아고~ 방전상태다.
A라는 프로젝트를 a_proj 레파지토리를 사용하고 B 프로젝트는 b_proj 레파지토리를 사용할 경우 경우에 따라A 프로젝트 변경사항을 B 프로젝트에 적용하고 싶을 경우가 있다. 그런 경우에 사용할 수 있는 방법을 git에서 제공하고 있는데 Subtree Merging 방법이다. 이런 것 제공하는 걸 보면 git를 사랑할 수 밖에 없게 된다.
먼저 이 방법의 개략적인 내용을 정리하면 아래와 같다.
0. a_proj 의 변경사항을 b_proj 레파지토리에 반영한다고 가정한다.
1. b_proj 에서 a_proj 레파지토리의 변경사항을 추적할 branch를 생성한다.
2. 브랜치에서 a_proj의 변경사항을 pull 한다.
3. 브랜치를 master에 merge 한다.
이런 순서로 진행을 하면 다른 레파지토리의 변경사항을 비교적 쉽게 적용할 수 있다.
1. a_proj를 b_proj의 원격 레파지토리로 추가
아래는 원격의 a_proj 레파지토리를 a_repo 로 추가하는 것이다.
$ git remote add a_repo git@github.com:aaaa/a_proj.git
$ git fetch a_repo
2. a_proj 레파지토리의 변경사항을 추적할 branch를 생성
아래는 a_branch라는 이름으로 branch를 추가하는 것이다.
$ git checkout -b a_branch a_repo/master
3. a_proj 의 subtree를 생성한다.
$ git read-tree --prefix=a_dir/ -u a_branch
prefix의 값을 이용해 a_dir 디렉토리를 생성 후 그 안에 a_proj 파일이 저장된다.
4. a_proj 의 변경사항을 a_branch에 적용
$ git checkout a_branch
$ git pull
5. master 에 a_branch를 merge
$ git checkout master
$ git merge a_branch
위 과정을 거치면 a_proj의 변경사항이 b_proj에 반영된다.
참고자료 : http://git-scm.com/book/ch6-7.html
추가 1:
master 브랜치에서 git status로 확인하면 subtree로 지정된 디렉토리의 파일이 new file 로 표시된다. 이 때는 일단commit을 하고 이 coomit 취소하면 더 이상 git status에서 표시되지 않는다.
$ git commit -m 'subtree directory added' -a
$ git reset HEAD^