Egloos | Log-in
결론에 가보기
결론에 가보기
[팁] 오픈소스의 버전업관리 #2


우선 가장 좋은 방법은 우리가 변경한 내용을 커미터들에게 보내서
왜 우리가 이렇게 쓰고 있는지 얘기를 하고 반영이 되기를 바라는 것이다.
종종 이렇게 처리를 하긴 하였지만.. 우리만의 특수한 상황은 어쩔수 없다..
그래서 찾은 것이 diff, patch라는 방법이다.

우리팀은 Aptana라는 IDE를 쓰고 있는데.. eclipse기반으로 만들어진
루비용 IDE이기에 아래에 보여지는 내용은 eclipse을 쓰면 그대로 할수 있는 것이고
조금 힘들지라도 리눅스에서는 diff, patch 명령어로 적용 가능할 것이다.

단계 0. 오픈소스의 원본과 우리팀의 소스 2개를 준비해둔다.
단계 1. diff 파일을 만든다.
한번 적용하였던 버전 이후부터 최신까지를 선택한다.
그리고 그것을 파일로 생성한다.
단계 2. 우리의 소스에 patch를 적용한다.

 우리의 repository에서 패치적용을 선택한다


아까 생성한 파일을 선택한다.
적용해야 하는 우리 소스의 repository를 선택한다.
여기가 좀 중요하다

ignore leading path name segments 라는 항목은 diff 파일에 생성되어 있는 파일의 위치를 맞춰주는 것이다. 
예를 들어서 Index: E:/zeous/Develop/src/redmine_original/test/functional/repositories_subversion_controller_test.rb
라고 기록된 내용에서 4(/를 기준으로 4번) 를 선택한 것은 E:/zeous/Develop/src/redmine_original 의 위치를 무시하고
적용을 한다는 것을 의미한다. (숫자를 선택하다가 보면 file dose not exist가 안뜨는것이 있다 ^^)

Reverse patch를 선택한 이유는 원본 소스에서 최신에서 과거버전으로 diff를 생성하였기에 반대로 적용을 해야 하는 것이다.
체크박스를 선택하고 finish를 누르면 패치가 적용이 된다.


이 단계를 모두 하게 되면 오픈소스의 원본소스는 거의 90%이상 반영이 된다.
반영에 실패한 파일들은 *.rej 이라는 파일이 생성이 되는데..
이 부분은 수동으로 적용을 할수밖에 없다.
대부분은 우리가 원본 소스를 수정하여서 추가된 부분,
추가된 부분으로 라인수가 변경이 되어서
기준점의 손실로 패치가 안되는 부분들이다.

물론 한번 수동작업을 해야 하지만
그래도 힘든 작업을 많이 덜어주는 편이다 ^^
by 제우스 | 2008/02/13 14:19 | 컴퓨터 | 트랙백 | 핑백(1) | 덧글(2)
트랙백 주소 : http://zeous.egloos.com/tb/1747722
☞ 내 이글루에 이 글과 관련된 글 쓰기 (트랙백 보내기) [도움말]
Linked at 결론에 가보기 : [잡생각] .. at 2010/01/06 15:56

... 다음은 소스 부분이다. 1년동안 버전업을 하지 않았기에, 우리에 맞도록 고쳐썼기때문에, 크게 많이 변경되었으면 정말 GG 이다. IDE를 통해서 특정버전과 비교해서 작업하는 방법이 있기는 하지만 대략 난감이다.데이터베이스를 마이그레이션하고, 소스를 모두 업그레이드한 다음에 두개가 잘 결합하는지를 확인하여야 한 ... more

Commented by 황시연 at 2009/05/29 16:57
최근 같은 방법으로 작업을 해 보려하였으나,
그쪽 apache에서 접근을 막아 두었는지 실행이 되지 않더군요.
제가 잘못하는 건지..

혹시 요즘도 같은 방법을 사용하시는지요?
Commented by 제우스 at 2009/05/29 17:19
이 프로젝트가 끝나서 지금도 하고 있지는 않지만
이것은 aptana에서 지원해주는 기능이라서 접근/실행이 안된다는것이
어떤 이야기인지 잘 모르겠네요..

:         :

:

비공개 덧글

◀ 이전 페이지 다음 페이지 ▶

카테고리
영화나 책
말말말
컴퓨터
게임이야기
태그
똑바로일하라 개발자 제이슨프라이드 2nd밴드 디아블로3 공연 게임 마이너코드 나꼽살 ngrinder 재태크 ror 오픈세미나 보험 웹개발자 스테가노그래피 vanish 메이저코드 화성학 개발 라이프사이클 helloworld 파워코드 하이코드 서버개발 원리 슬럼프 기타코드 직업
전체보기
최근 등록된 덧글
엄지척 바짝 올립니다. 궁금했던..
by 초보 at 10/11
다자가이든 소작이든 닭이 천 마리..
by yada at 09/20
나는 팔라독 헬 깸.
by 남영찬 at 06/17
^안녕.하세요^;; 골드팟 생기개..
by 전설의레전드소설책 at 03/25
이왕이면---- A7 등등 '7' 이 붙는..
by papagoat at 04/12
매우 감사합니다 ! 아주 쉽게 키..
by papagoat at 04/12
자꾸 F를 라로 표기하시네요 ㅎㅎ
by 안녕하세요 at 12/21
시 클라식 기타 코드표 도 보여..
by 강초보 at 06/08
sp를 싫어하는 개발자들은 유지..
by 나도개발자 at 04/23
여자친구와의 금연약속을 어겨서..
by 구사일생 at 11/13
라이프로그
똑바로 일하라
똑바로 일하라

펜트하우스 코끼리
펜트하우스 코끼리

화폐전쟁
화폐전쟁

10억
10억

거북이 달린다
거북이 달린다

용의자 X의 헌신
용의자 X의 헌신

마더
마더

터미네이터 : 미래전쟁의 시작
터미네이터 : 미래전쟁의 시작

스타트렉 더 비기닝
스타트렉 더 비기닝

천사와 악마
천사와 악마

노잉
노잉

7급 공무원
7급 공무원

박쥐
박쥐

인사동 스캔들
인사동 스캔들

와이키키 브라더스
와이키키 브라더스

매란방
매란방

건투를 빈다
건투를 빈다

코끼리는 생각하지 마
코끼리는 생각하지 마

배려
배려

벤자민 버튼의 시간은 거꾸로 간다
벤자민 버튼의 시간은 거꾸로 간다

작전
작전

워낭소리
워낭소리

작전명 발키리
작전명 발키리

적벽대전 2 : 최후의 결전
적벽대전 2 : 최후의 결전

트랜스포터 - 라스트미션
트랜스포터 - 라스트미션

디파이언스
디파이언스

사랑하지 않으면 떠나라!
사랑하지 않으면 떠나라!

촐라체
촐라체

쌍화점
쌍화점

황후화
황후화

크리스마스 별장
크리스마스 별장

눈먼 자들의 도시
눈먼 자들의 도시

예스맨
예스맨

순정만화
순정만화

펀치 레이디
펀치 레이디

눈에는 눈 이에는 이
눈에는 눈 이에는 이

전략적 책읽기
전략적 책읽기

돈, 뜨겁게 사랑하고 차갑게 다루어라
돈, 뜨겁게 사랑하고 차갑게 다루어라

좋은 놈, 나쁜 놈, 이상한 놈
좋은 놈, 나쁜 놈, 이상한 놈

다크 나이트
다크 나이트

H2 1
H2 1

그림으로 읽는 생생 심리학
그림으로 읽는 생생 심리학

호모 코레아니쿠스
호모 코레아니쿠스

강철중: 공공의 적 1-1
강철중: 공공의 적 1-1

이채원의 가치투자
이채원의 가치투자

쿵푸 팬더
쿵푸 팬더

카불의 사진사
카불의 사진사

인디아나 존스 4 - 크리스탈 해골의 왕국
인디아나 존스 4 - 크리스탈 해골의 왕국

시골의사의 부자경제학
시골의사의 부자경제학

종자돈 700만 원으로 부동산 투자 200억 만들기
종자돈 700만 원으로 부동산 투자 200억 만들기

우리동네
우리동네

디지로그 digilog
디지로그 digilog

대하소설 주역 4
대하소설 주역 4

읽지 않은 책에 대해 말하는 법
읽지 않은 책에 대해 말하는 법

Stick 스틱!
Stick 스틱!

색즉시공 시즌 2
색즉시공 시즌 2

바르게 살자
바르게 살자

20대는 통장을, 40대는 인생을 채워라
20대는 통장을, 40대는 인생을 채워라

점퍼
점퍼

생로병사의 비밀
생로병사의 비밀

추격자
추격자

오늘의 거짓말
오늘의 거짓말

주식시장을 이기는 작은책
주식시장을 이기는 작은책

대한민국 진화론
대한민국 진화론

무방비 도시
무방비 도시

피라니아 이야기
피라니아 이야기

우아한 세계
우아한 세계

경제를 읽는 기술
경제를 읽는 기술

실용주의 프로그래머
실용주의 프로그래머

블로그 비즈니스
블로그 비즈니스

어거스트 러쉬
어거스트 러쉬

세븐데이즈
세븐데이즈

뷰티풀 선데이
뷰티풀 선데이

괴물 1
괴물 1

킹덤
킹덤

당신과 일하기 힘들어 죽겠어
당신과 일하기 힘들어 죽겠어

뉴욕의 프로그래머
뉴욕의 프로그래머

나를 바꾸는 데는 단 하루도 걸리지 않는다
나를 바꾸는 데는 단 하루도 걸리지 않는다

벽오 금학도
벽오 금학도

해바라기
해바라기

펀드투자가 미래의 부를 결정한다
펀드투자가 미래의 부를 결정한다

상식이 통하는 웹사이트가 성공한다
상식이 통하는 웹사이트가 성공한다

아버지의 가계부
아버지의 가계부

본 얼티메이텀
본 얼티메이텀

최강 로맨스
최강 로맨스

여자도 여자를 모른다
여자도 여자를 모른다

부동산 10년 대폭락 시나리오
부동산 10년 대폭락 시나리오

아키텍트 이야기
아키텍트 이야기

보물지도
보물지도

오션스 13
오션스 13

게임회사 이야기
게임회사 이야기

바람피기 좋은 날
바람피기 좋은 날

조폭 마누라 3
조폭 마누라 3

삼미 슈퍼스타즈의 마지막 팬클럽
삼미 슈퍼스타즈의 마지막 팬클럽

광기와 우연의 역사
광기와 우연의 역사

런어웨이
런어웨이

회사가 당신에게 알려주지 않는 50가지 비밀
회사가 당신에게 알려주지 않는 50가지 비밀

롱테일 법칙
롱테일 법칙

해리 포터와 불사조 기사단
해리 포터와 불사조 기사단

사소한 것에 목숨 걸지 마라 - 습관 바꾸기 편
사소한 것에 목숨 걸지 마라 - 습관 바꾸기 편

우리가 미처 알지 못한 소프트웨어 공학의 사실과 오해
우리가 미처 알지 못한 소프트웨어 공학의 사실과 오해

트랜스포머
트랜스포머

20대부터 시작하는 스트레스 제로기술
20대부터 시작하는 스트레스 제로기술

미운오리새끼의 출근
미운오리새끼의 출근

캐리비안의 해적 : 세상의 끝에서
캐리비안의 해적 : 세상의 끝에서

미녀는 괴로워
미녀는 괴로워

유태우 교수의 내몸개혁 6개월 프로젝트
유태우 교수의 내몸개혁 6개월 프로젝트

브레이크 업 : 이별후애(愛)
브레이크 업 : 이별후애(愛)

인사이드 맨
인사이드 맨

마키아벨리, 회사에 가다
마키아벨리, 회사에 가다

웹 2.0 경제학
웹 2.0 경제학

한반도
한반도

연애, 그 참을 수 없는...
연애, 그 참을 수 없는...

구미호 가족
구미호 가족

럭키 넘버 슬레븐
럭키 넘버 슬레븐

찰리와 초콜릿 공장
찰리와 초콜릿 공장

아파트
아파트

레전드 오브 조로
레전드 오브 조로

rss

skin by jiinny
X