Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

Visual Studio에서 github 오픈 소스를 fork해서 테스트하는 방법

제목이 좀 이상하긴 한데. ^^

그러니까, github에 공개된 유명 프로젝트(가령, CoreClr이나 CoreFx)들의 소스코드를 살펴보고 싶을 때가 있습니다. 여기서는 새로운 C# 6.0 컴파일러인 roslyn이 그 대상이라고 가정해 보겠습니다.

dotnet/roslyn 
; https://github.com/dotnet/roslyn

물론 roslyn repo를 직접 clone해서 테스트하는 것이 깔끔합니다.

https://github.com/dotnet/roslyn.git

하지만... 저런 식으로 하면 아무도 제가 roslyn에 관심있다는 것을 모릅니다. ^^ 따라서, 왠지 멋있는 척 하기 위해 dotnet/roslyn을 제 계정의 github repo에 fork하게 됩니다.

그런 후 fork한 repo를 Visual Studio의 "File" / "Open" / "Open from Source Control..." 메뉴를 이용해 다음과 같이 로컬에 clone할 수 있습니다.

github_clone_1.png

문제는 그렇게 fork/clone해서 검토하다 보면 시간은 흘러 원래의 "dotnet/roslyn" repo의 소스코드는 업데이트되어 우리가 만지고 있는 repo가 과거의 버전이 된다는 점입니다.

따라서, 최신 버전의 "dotnet/roslyn" repo를 다시 우리가 fork한 repo에 반영하고 싶을 텐데요. 이런 경우는 다음과 같은 단계를 거치면 됩니다.

  1. dotnet/roslyn repo를 local에 clone해 둔 repo에 병합
  2. 최신버전으로 병합된 local repo를 github의 개인 fork repo에 push

이에 대한 구체적인 git 명령어는 다음의 글을 참고하시면 됩니다.

Bitbucket: Update a fork to merge changes of master repo?
; http://stackoverflow.com/questions/9944898/bitbucket-update-a-fork-to-merge-changes-of-master-repo

여기서는 비주얼 스튜디오 2015가 git에 얼마나 잘 통합되어 있는지 알 수 있도록 UI를 통해 해보겠습니다. 이를 위해 우선 "Team Explorer"의 "Settings" / "Repositories Settings"로 가서 "Remotes"에 "dotnet/roslyn" repo를 등록해 줍니다.

github_clone_2.png

그다음 Team Explorer 홈 메뉴의 "Branches"로 가서 방금 추가했던 "dotnet/rosyln" repo의 master 브랜치를 지정하고 병합을 원하는 local 브랜치를 선택해 "Merge"를 해줍니다. (여기서는 제가 별도로 로컬에 clone 해 둔 repo에 브랜치를 만들지 않았기 때문에 "master"로 선택했습니다.)

github_clone_3.png

그럼, 그 동안의 모든 변경 사항이 local의 master 브랜치에 반영이 됩니다. 정말로 반영되었는지, master 브랜치의 컨텍스트 메뉴를 이용해 "View History..."를 선택하면 다음과 같이 최신 변경 사항이 병합되었음을 알 수 있습니다.

github_clone_4.png

하지만 이렇게 했다고 해서 github에 있는 repo에 최신 버전이 반영된 것은 아닙니다. 따라서, 마지막으로 local master 브랜치를 github에 Push 해야 하는 작업이 남았습니다.

방법은 역시 Team Explorer에서 "Sync" 메뉴를 선택한 후 "Push" 메뉴로 원본(github의 stjeong/roslyn) repo에 올릴 수 있습니다.

github_clone_5.png




비주얼 스튜디오에서 git.exe가 실행되는 명령행 창도 쉽게 열 수 있습니다. Team Explorer의 아무 메뉴나 선택하면 다음과 같이 "Actions" 링크가 나오는데요. 그 하위에 "Open Command Prompt" 메뉴를 선택하면 됩니다.

github_clone_6.png

그럼, git.exe 실행 파일을 바로 쓸 수 있는 환경이 설정된 cmd.exe 창이 뜹니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/28/2021]

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

비밀번호

댓글 작성자
 



2020-08-12 11시45분
GitHub.com Searching for information on GitHub
; https://help.github.com/en/github/searching-for-information-on-github/searching-code

repo:USERNAME/REPOSITORY
repo:dotnet/coreclr

https://github.com/search/advanced

user:dotnet repo:coreclr language:C++ extension:h
정성태

... 91  92  93  94  95  96  [97]  98  99  100  101  102  103  104  105  ...
NoWriterDateCnt.TitleFile(s)
11510정성태4/30/201821772.NET Framework: 742. windbg로 확인하는 Finalizer를 가진 객체의 GC 과정파일 다운로드1
11509정성태4/28/201820056.NET Framework: 741. windbg로 확인하는 객체의 GC 여부
11508정성태4/23/201821648개발 환경 구성: 373. MSBuild를 이용해 프로젝트 배포 후 결과물을 zip 파일로 압축하는 방법파일 다운로드1
11507정성태4/20/201821566개발 환경 구성: 372. MSBuild - 빌드 전/후, 배포 전/후 실행하고 싶은 Task 정의
11506정성태4/20/201825840.NET Framework: 740. C#에서 enum을 boxing 없이 int로 변환하기 - 두 번째 이야기 [7]파일 다운로드1
11505정성태4/19/201818646개발 환경 구성: 371. Azure Web App 확장 예제 - Simple WebSite Extension
11504정성태4/19/201820099오류 유형: 465. Azure Web App 확장 - Extplorer File manager 적용 시 오류
11503정성태4/19/201819917오류 유형: 464. PowerShell - Start-Service 명령 오류 (Service 'xxx' cannot be started)
11502정성태4/17/201821769개발 환경 구성: 370. Azure VM/App Services(Web Apps)에 Let's Encrypt 무료 인증서 적용 방법 [3]
11501정성태4/17/201818734개발 환경 구성: 369. New-AzureRmADServicePrincipal로 생성한 계정의 clientSecret, key 값을 구하는 방법파일 다운로드1
11500정성태4/17/201819676개발 환경 구성: 368. PowerShell로 접근하는 Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11499정성태4/17/201818291개발 환경 구성: 367. Azure - New-AzureRmADServicePrincipal / New-AzureRmRoleAssignment 명령어
11498정성태4/17/201818378개발 환경 구성: 366. Azure Active Directory(Microsoft Enfra ID)의 사용자 유형 구분 - Guest/Member
11497정성태4/17/201816394개발 환경 구성: 365. Azure 리소스의 액세스 제어(Access control) 별로 사용자에게 권한을 할당하는 방법 [2]
11496정성태4/17/201816863개발 환경 구성: 364. Azure Portal에서 구독(Subscriptions) 메뉴가 보이지 않는 경우
11495정성태4/16/201819111개발 환경 구성: 363. Azure의 Access control 보안과 Azure Active Directory의 계정 관리 서비스
11494정성태4/16/201815638개발 환경 구성: 362. Azure Web Apps(App Services)에 사용자 DNS를 지정하는 방법
11493정성태4/16/201817433개발 환경 구성: 361. Azure Web App(App Service)의 HTTP/2 프로토콜 지원
11492정성태4/13/201815392개발 환경 구성: 360. Azure Active Directory의 사용자 도메인 지정 방법
11491정성태4/13/201818549개발 환경 구성: 359. Azure 가상 머신에 Web Application을 배포하는 방법
11490정성태4/12/201817622.NET Framework: 739. .NET Framework 4.7.1의 새 기능 - Configuration builders [1]파일 다운로드1
11489정성태4/12/201815247오류 유형: 463. 윈도우 백업 오류 - a Volume Shadow Copy Service operation failed.
11488정성태4/12/201818318오류 유형: 462. Unhandled Exception in Managed Code Snap-in - FX:{811FD892-5EB4-4E73-A147-F1E079E36C4E}
11487정성태4/12/201817372디버깅 기술: 115. windbg - 닷넷 메모리 덤프에서 정적(static) 필드 값을 조사하는 방법
11486정성태4/11/201816475오류 유형: 461. Error MSB4064 The "ComputeOutputOnly" parameter is not supported by the "VsTsc" task
11485정성태4/11/201823721.NET Framework: 738. C# - Console 프로그램이 Ctrl+C 종료 시점을 감지하는 방법파일 다운로드1
... 91  92  93  94  95  96  [97]  98  99  100  101  102  103  104  105  ...