Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

TFS의 이력에서 "Get This Version"과 같은 기능을 Git으로 처리한다면?

Visual Studio에서 기존 TFS를 사용했다면 "Get This Version"(Get Specific Version)을 사용해 종종 특정 시점으로 소스 코드를 돌려 본 적이 있을 것입니다. (가령, 이전에 없던 버그가 발생했을 때 어떤 소스 코드의 변경으로 인한 것인지 알 수 없을 때 유용할 수 있습니다.)

git_getthisver_1.png

반면, Git을 사용하는 경우에는 이런 메뉴가 없고, 대신 "Reset"이나 "Revert" 등이 있지만,

git_getthisver_2.png

해당 기능들은 TFS의 "Get This Version"과는 차이가 있습니다.

[초보용] Git 되돌리기( Reset, Revert )
; https://medium.com/nonamedeveloper/%EC%B4%88%EB%B3%B4%EC%9A%A9-git-%EB%90%98%EB%8F%8C%EB%A6%AC%EA%B8%B0-reset-revert-d572b4cb0bd5

(아쉽게도) 비주얼 스튜디오의 Git 메뉴에는 나오지 않지만, 명령행이라면 "git checkout"으로 이를 구현할 수 있는데요, 가령 다음과 같이 commit을 했을 때,

c:\temp\ConsoleApp2> git log
commit 0363a8f6e01fe396d123c12e4124ca50010cd396 (HEAD -> master)
Author: tester <tester@test.com>
Date:   Wed Sep 16 14:07:12 2020 +0900

    3

commit a0d0d229f618a7b0f6efc0f7bd5d7a279155be51
Author: tester <tester@test.com>
Date:   Wed Sep 16 14:06:41 2020 +0900

    2

commit 43751f5c67bdeeffe9d4283af887e5a3dfade8f0
Author: tester <tester@test.com>
Date:   Wed Sep 16 14:06:31 2020 +0900

    1

commit 001abba1b091dfd92627544394f864364ce1e3f3
Author: tester <tester@test.com>
Date:   Wed Sep 16 14:05:49 2020 +0900

    Add .gitignore and .gitattributes.

1번 commit이 되었던 시점으로 솔루션의 소스 코드를 되돌리고 싶다면 이렇게 할 수 있습니다.

c:\temp\ConsoleApp2> git checkout 43751f5c
Note: checking out '43751f5c'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:

  git checkout -b <new-branch-name>

HEAD is now at 43751f5 1

git_getthisver_3.png




그렇긴 한데, 사실 관점을 좀 달리해야 합니다. TFS와 Git을 있는 그대로 비교하면 안 되고, Git은 그 나름의 방법으로 해결하는 것이 바람직한데요, 이를 위해 그냥 "branch"를 활용하면 됩니다. 단순히 특정 시점의 commit에 대해 "New Branch..."를 선택하면 되는데, 예를 들어 위에서 했던 것처럼 1번 commit에 대해 branch를 새로 생성하면,

git_getthisver_4.png

구분도 명확하고 이후 다시 최신 소스 코드로 돌아오고 싶을 때도 Visual Studio의 "Team Explorer - Branches" UI에서 제공하는 브랜치 간의 "Checkout" 메뉴로 상태를 쉽게 이전할 수 있습니다. (참고로, 이렇게 곧바로 branch를 생성하는 것은, "git checkout ...[commitid]..." + "git checkout -b ...[branch_name]..."을 한 것과 동일합니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 9/16/2020]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 76  77  78  79  80  81  82  83  84  85  86  [87]  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11853정성태3/24/201924953개발 환경 구성: 435. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면? - 두 번째 이야기 [1]
11852정성태3/20/201922370개발 환경 구성: 434. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면?파일 다운로드1
11851정성태3/19/201926536Linux: 8. C# - 리눅스 환경에서 DllImport 대신 라이브러리 동적 로드 처리 [2]
11850정성태3/18/201927178.NET Framework: 813. C# async 메서드에서 out/ref/in 유형의 인자를 사용하지 못하는 이유
11849정성태3/18/201925796.NET Framework: 812. pscp.exe 기능을 C#으로 제어하는 방법파일 다운로드1
11848정성태3/17/201923025스크립트: 14. 윈도우 CMD - 파일이 변경된 경우 파일명을 변경해 복사하고 싶다면?
11847정성태3/17/201927358Linux: 7. 리눅스 C/C++ - 공유 라이브러리 동적 로딩 후 export 함수 사용 방법파일 다운로드1
11846정성태3/15/201926319Linux: 6. getenv, setenv가 언어/운영체제마다 호환이 안 되는 문제
11845정성태3/15/201925290Linux: 5. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) [3]
11844정성태3/14/201927487개발 환경 구성: 434. Visual Studio 2019 - 리눅스 프로젝트를 이용한 공유/실행(so/out) 프로그램 개발 환경 설정 [1]파일 다운로드1
11843정성태3/14/201922238기타: 75. MSDN 웹 사이트를 기본으로 영문 페이지로 열고 싶다면?
11842정성태3/13/201919205개발 환경 구성: 433. 마이크로소프트의 CoreCLR 프로파일러 예제를 Visual Studio CMake로 빌드하는 방법 [1]파일 다운로드1
11841정성태3/13/201919755VS.NET IDE: 132. Visual Studio 2019 - CMake의 컴파일러를 기본 g++에서 clang++로 변경
11840정성태3/13/201922588오류 유형: 526. 윈도우 10 Ubuntu App 환경에서는 USB 외장 하드 접근 불가
11839정성태3/12/201927569디버깅 기술: 124. .NET Core 웹 앱을 호스팅하는 Azure App Services의 프로세스 메모리 덤프 및 windbg 분석 개요 [3]
11838정성태3/7/201930744.NET Framework: 811. (번역글) .NET Internals Cookbook Part 1 - Exceptions, filters and corrupted processes [1]파일 다운로드1
11837정성태3/6/201943933기타: 74. 도서: 시작하세요! C# 7.3 프로그래밍 [10]
11836정성태3/5/201927626오류 유형: 525. Visual Studio 2019 Preview 4/RC - C# 8.0 Missing compiler required member 'System.Range..ctor' [1]
11835정성태3/5/201925097.NET Framework: 810. C# 8.0의 Index/Range 연산자를 .NET Framework에서 사용하는 방법 및 비동기 스트림의 컴파일 방법 [3]파일 다운로드1
11834정성태3/4/201923849개발 환경 구성: 432. Visual Studio 없이 최신 C# (8.0) 컴파일러를 사용하는 방법
11833정성태3/4/201925791개발 환경 구성: 431. Visual Studio 2019 - CMake를 이용한 공유/실행(so/out) 리눅스 프로젝트 설정파일 다운로드1
11832정성태3/4/201919522오류 유형: 524. Visual Studio CMake - rsync: connection unexpectedly closed
11831정성태3/4/201921408오류 유형: 523. Visual Studio 2019 - 새 창으로 뜬 윈도우를 닫을 때 비정상 종료
11830정성태2/26/201919883오류 유형: 522. 이벤트 로그 - Error opening event log file State. Log will not be processed. Return code from OpenEventLog is 87.
11829정성태2/26/201920885개발 환경 구성: 430. 마이크로소프트의 CoreCLR 프로파일러 예제 빌드 방법 - 리눅스 환경 [1]
11828정성태2/26/201930009개발 환경 구성: 429. Component Services 관리자의 RuntimeBroker 설정이 2개 있는 경우 [8]
... 76  77  78  79  80  81  82  83  84  85  86  [87]  88  89  90  ...