Visual Studio Add-in: HyperAddin 도구 사용 설명
재미있는 add-in을 하나 발견했습니다. ^^
Hyperlink your source code
; http://blogs.msdn.com/brada/archive/2007/09/04/hyperlink-your-source-code.aspx
HyperAddin: A Visual Studio Addin which adds hyperlinking in your source code
; http://www.codeplex.com/hyperAddin
무슨 유틸리티인지 잠시 설명드리면.
보통 Visual Studio 안에서 열고 있는 파일에 "
http://"로 시작하는 문자열이 나오면 "Ctrl" 버튼을 누르면서 마우스 좌측 버튼을 함께 누르면 웹 브라우저가 뜨고 그 문서를 보여주는 기능을 제공하지요.
마찬가지로,
code: 프로토콜을 제공해서 소스 코드들 간의 지정된 위치로 이동할 수 있는 기능을 HyperAddin이 제공해줍니다. 어디... 예를 한번 들어볼까요?
==== Window1.xaml.cs ====
namespace WpfApplication1
{
// #firstPosition
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
public void DoMethod()
{
// code:#firstPosition Window1 로 이동
}
}
}
위와 같이 단일 파일 내에서 이동하는 경우에는 "code:#" + "[문자열]"을 주면 됩니다. VS.NET IDE에서 마우스로 "code:#firstPosition" 위치로 이동해서 "Ctrl" + "마우스 오른쪽 버튼"을 누르면 상단의 "// #firstPosition" 위치가 선택되어집니다.
음... 별로 매력적이지 않다고요?
그럼 이런 경우는 어떨까요? 코드에서 사용하고 있는 메서드가 정의된 곳으로 가고 싶을 때 보통 "Go To Definition" 기능을 사용하지요. 그런데, 만약 그 코드가 인터페이스에 기반한 인스턴스라면 "Go To Definition" 기능을 이용하게 되면 "클래스에 정의된 메서드"가 아닌 "인터페이스에 정의된 메서드"로 이동하게 되지요. 바로 이럴 때 다음과 같은 식으로 주석을 적어주면 편리할 수 있습니다.
========= WpfApplication1 프로젝트의 Window1.xaml.cs =====
namespace WpfApplication1
{
public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}
public void DoMethod()
{
IMyClass myClass = new MyClass();
// code:MyClass#Def_DoMethod 구현 메서드로 이동(인터페이스 메서드가 아닌!)
myClass.DoMethod();
}
}
}
========= ClassLibrary1 프로젝트의 Class1.cs =====
namespace ClassLibrary1
{
public class MyClass : IMyClass
{
public MyClass()
{
}
// #Def_DoMethod
public void DoMethod()
{
}
}
}
========= ClassLibrary1 프로젝트의 Interface1.cs =====
namespace ClassLibrary1
{
public interface IMyClass
{
void DoMethod();
}
}
위와 같은 경우는 링크가 다른 파일에 연결되는데요. 이럴 때는 "code:" + "타입이름#식별문자열"과 같은 형식으로 표기해야 합니다. 왠지, 이번 예제는 좀 실용성이 있을 것도 같죠? ^^ "DoMethod"의 정의로 이동하고 싶을 때 "code:MyClass#Def_DoMethod"를 마우스로 클릭해 주면 되니까요. (사실, 위에서는 사용하는 코드에서 "code:..." 링크를 해줬지만 실제로는 인터페이스 메서드 쪽에서 링크를 관리하는 것이 더 편할 수 있습니다.)
한 가지 아쉬운 점이 있다면, "동적 로드된 어셈블리"에 대해서는 검색하지 않는다는 점입니다. 대부분의 인터페이스 기반 프로그래밍이 동적 로드에 기반한다는 것을 감안하면 치명적이군요. (다시 실망하셨나요? ^^ 사실... 저도 실망했습니다.)
설치 방법
- http://www.codeplex.com/hyperAddin/Release/ProjectReleases.aspx?ReleaseId=6808에서 HyperAddmin.zip 파일을 다운로드해 로컬에 압축을 해제합니다.
- "C:\Users\[로그인 계정]\Documents\Visual Studio 2008\Addins" 폴더 하위에 압축 해제된 파일을 복사합니다. (Windows Vista / VS.NET 2008 기준, 다른 환경에서는 경로가 달라질 수 있습니다.)
- Visual Studio 2008을 실행시키면 자동으로 Addin이 설치되고 주 메뉴에 "HyperAddin"이 생성됩니다. (만약, UAC 모드라면 Visual Studio 2008을 최초 한 번은 관리자 모드로 실행해 줘야 합니다.)
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]