Skip to content

CHICPRO

  • Life Log
  • Cycling Log
  • Photo Log
    • Portrait
    • Landscape
    • Flower
    • Etc
  • Coding Log
  • Information

[git] 레파지토리의 변경사항을 다른 레파지토리에 적용하기

2013-10-06 by 편리

아~ 점심 먹고 와서 꼬박 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^

Post navigation

Previous Post:

퍼머 해볼까?

Next Post:

구글 크롬 브라우저의 메뉴 스타일 이전 스타일로 변경

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

Recent Posts

  • php 배열 연산에서 + 와 array_merge 의 차이
  • pcntl_fork 를 이용한 다중 프로세스 실행
  • 아이폰 단축어를 이용하여 주중 공휴일엔 알람 울리지 않게 하기
  • 구글 캘린더 전체일정 재동기화
  • OpenLiteSpeed 웹서버에 HTTP 인증 적용
  • OpenLiteSpeed 웹어드민 도메인 연결
  • WireGuard를 이용한 VPN 환경 구축
  • Ubuntu 22.04 서버에 OpenLiteSpeed 웹서버 세팅
  • 맥 vim 세팅
  • 우분투 시스템 터미널쉘 zsh 로 변경

Recent Comments

  • 편리 on 업무관리용 그누보드 게시판 스킨
  • 임종섭 on 업무관리용 그누보드 게시판 스킨
  • 캐논 5D 펌웨어 | Dslr 펌웨어 업그레이드 방법 82 개의 베스트 답변 on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • Top 5 캐논 5D 펌웨어 Top 89 Best Answers on 캐논 EOS 30D 펌웨어 Ver 1.0.6 , EOS 5D 펌웨어 Ver 1.1.1
  • 편리 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 임팀장 on 워드프레스 애니메이션 gif 파일을 mp4로 변환하여 출력하기
  • 편리 on Notepad++ NppFTP 플러그인 수동 설치
  • paul-j on Notepad++ NppFTP 플러그인 수동 설치
  • YS on Windows 10 iCloud 사진 저장 폴더 변경
  • 편리 on Docker를 이용한 Centos7 + httpd + php 5.4 개발환경 구축

Meta

  • Log in
  • Entries feed
  • Comments feed
  • WordPress.org
© 2025 CHICPRO | Built using WordPress and SuperbThemes