Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 77. Visual Studio 확장(VSIX) 만드는 방법 [링크 복사], [링크+제목 복사]
조회: 15001
글쓴 사람
정성태 (kevin13@chol.net)
홈페이지
첨부 파일
 

Visual Studio 확장(VSIX) 만드는 방법

요즘들어 Visual Studio에서 "Tools" / "Extensions and Updates..." 메뉴를 종종 이용하게 됩니다. 그만큼 이젠 확장 애드인들이 풍부해졌다는 이야기가 되는데요.

때로는 ^^ 여기에 자신이 만든 확장 도구를 배포하고 싶은 마음이 들 수 있는데요. 오늘은 이 방법에 대해서 알아보겠습니다.

우선, Visual Studio 확장을 만들기 위해서는 Visual Studio SDK가 있어야 합니다. 아래는 각 버전에 해당하는 것이니 그에 맞게 다운로드 해서 설치합니다. (물론 2개다 하셔도 됩니다.)

Microsoft Visual Studio 2012 SDK
; http://www.microsoft.com/en-us/download/details.aspx?id=30668

Microsoft Visual Studio 2013 SDK 
; http://www.microsoft.com/en-sa/download/details.aspx?id=40758

용량은 각각 100MB 정도하기 때문에 모두 설치해도 크게 부담은 없는 수준입니다.

이렇게 SDK를 설치하고 나면 새 프로젝트에 "Visual Studio Package"가 제공되고,

how_to_vsix_1.png

이를 선택하면 몇 가지 간단한 것들을 물어보는데, 그 중에서 3번째 단계가 의미있습니다.

how_to_vsix_2.png

이번 실습에서는 Visual Studio의 메뉴에 항목을 추가할 것이므로 "Menu Command"만 선택했지만, 여러분들이 만들려는 확장이 있다면 그에 맞게 선택해 주시면 됩니다. 이후에 메뉴 이름을 정하는 대화창이 진행되는데 제 경우에는 "AttachDebug"라는 이름을 선택했습니다.

일단 프로젝트가 생성되면 곧바로 F5 키를 눌러 디버깅을 시작하는 경우, 새롭게 Visual Studio가 뜨게 되고 다음과 같이 "TOOLS" 메뉴에서 우리가 만든 메뉴가 추가된 것을 볼 수 있습니다.

how_to_vsix_3.png

메뉴가 선택된 경우 원하는 동작을 하고 싶다면 MenuItemCallback 메서드에 코드를 채워넣으면 됩니다.

how_to_vsix_4.png




일반적으로 Visual Studio 확장을 제작하는 경우 대부분 EnvDTE 객체가 필요합니다. 기존의 Visual Studio Add-in 프로젝트에서는 이 값이 클래스 멤버로 제공되지만 VSIX 프로젝트에서는 직접 구해줘야 합니다.

private DTE2 _applicationObject;

protected override void Initialize()
{
    base.Initialize();

    _applicationObject = (EnvDTE80.DTE2)this.GetService(typeof(EnvDTE.DTE));

    // ... 생략 ...
}

자, 그럼 이렇게 해서 원하는 기능을 구현한 후 빌드를 하면 exe 대신 vsix 확장자를 가진 파일이 생성됩니다. (vsix 파일은 zip 압축 형식입니다.)

vsix 내부에는 빌드한 바이너리와 manifest 관련 정보를 포함하고 있기 때문에 그것 자체가 배포 단위로 동작합니다. 따라서 Visual Studio가 설치된 PC에서 vsix 파일을 더블클릭하면 Visual Studio에 의해 자동으로 설치됩니다.

"Tools" / "Extensions and Updates..." 메뉴를 실행해 보면 다음과 같이 설치 유무와 "Disable", "Uninstall"까지 할 수 있습니다

how_to_vsix_5.png




잘 만들어진 도구를 자랑하고 싶다거나 ^^ 판매를 하고 싶다면 어떻게 해야 할까요? 간단합니다. 다음의 사이트를 방문해서,

Visual Studio 제품 및 확장 기능
; http://visualstudiogallery.msdn.microsoft.com/

"등록하기" 메뉴를 이용해 자신이 제작한 VSIX 파일을 업로드하면 전 세계의 Visual Studio 개발자들이 이용할 수 있게 됩니다.

how_to_vsix_6.png

참고로, Visual Studio Package를 만드는 공식 문서는 다음에서 제공됩니다. ^^

Walkthroughs for Customizing Visual Studio By Using VSPackages
; http://msdn.microsoft.com/en-us/library/vstudio/cc138565.aspx




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





[최초 등록일: ]
[최종 수정일: 10/25/2013 ]

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

비밀번호

댓글 쓴 사람
 



2013-11-05 03시22분
vsix가 설치되면 "C:\Users\[계정명]\AppData\Local\Microsoft\VisualStudio\12.0\Extensions" 경로에 파일이 풀립니다.


정성태
2015-10-05 12시26분
Microsoft/ConcordExtensibilitySamples
; https://github.com/Microsoft/ConcordExtensibilitySamples/wiki
정성태
2018-10-12 10시44분
%LOCALAPPDATA%\Microsoft\VisualStudio\15.0_2502db9e\Extensions
정성태

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
11950정성태6/18/201958.NET Framework: 845. C# - 윈도우 작업 관리자와 리소스 모니터의 메모리 값을 구하는 방법
11949정성태6/18/201916오류 유형: 547. CoreCLR Profiler 예제 프로젝트 빌드 시 컴파일 오류 유형
11948정성태6/17/201947Linux: 15. 리눅스 환경의 Visual Studio Code에서 TFS 서버 연동
11947정성태6/17/201966Linux: 14. 리눅스 환경에서 TFS 서버 연동
11946정성태6/17/201942개발 환경 구성: 445. C# - MathNet으로 정규 분포를 따르는 데이터를 생성, PLplot으로 Histogram 표현파일 다운로드1
11945정성태6/17/201942Linux: 13. node.js에서 syslog로 출력하는 방법
11944정성태6/16/201943Linux: 12. Ubuntu 16.04/18.04에서 node.js 최신 버전 설치 방법
11943정성태6/15/201990.NET Framework: 844. C# - 박싱과 언박싱
11942정성태6/20/2019145개발 환경 구성: 444. 로컬의 Visual Studio Code로 원격 리눅스 머신에 접속해 개발하는 방법
11941정성태6/13/201925오류 유형: 546. "message NETSDK1057: You are using a preview version of .NET Core" 빌드 경고 없애는 방법
11940정성태6/13/201971개발 환경 구성: 443. Visual Studio의 Connection Manager 기능(Remote SSH 관리)을 위한 명령행 도구파일 다운로드1
11939정성태6/13/201929오류 유형: 545. Managed Debugging Assistant 'FatalExecutionEngineError'
11938정성태6/12/201977Math: 59. C# - 웨이트 벡터 갱신식을 이용한 퍼셉트론 분류파일 다운로드1
11937정성태6/11/2019282개발 환경 구성: 442. .NET Core 3.0 preview 5를 이용해 Windows Forms/WPF 응용 프로그램 개발 [1]
11936정성태6/10/201970Math: 58. C# - 최소 자승법의 1차, 2차 수렴 그래프 변화 확인파일 다운로드1
11935정성태6/9/2019129.NET Framework: 843. C# - PLplot 출력을 파일이 아닌 Window 화면으로 변경
11934정성태6/7/201960VC++: 133. typedef struct와 타입 전방 선언으로 인한 C2371 오류파일 다운로드1
11933정성태6/7/201998VC++: 132. enum 정의를 C++11의 enum class로 바꿀 때 유의할 사항파일 다운로드1
11932정성태6/7/201952오류 유형: 544. C++ - fatal error C1017: invalid integer constant expression파일 다운로드1
11931정성태6/6/201994개발 환경 구성: 441. C# - CairoSharp/GtkSharp 사용을 위한 프로젝트 구성 방법
11930정성태6/5/2019145.NET Framework: 842. .NET Reflection을 대체할 System.Reflection.Metadata 소개
11929정성태6/5/201960.NET Framework: 841. Windows Forms/C# - 클립보드에 RTF 텍스트를 복사 및 확인하는 방법
11928정성태6/5/201978오류 유형: 543. PowerShell 확장 설치 시 "Catalog file '[...].cat' is not found in the contents of the module" 오류 발생
11927정성태6/5/2019135스크립트: 15. PowerShell ISE의 스크립트를 복사 후 PPT/Word에 붙여 넣으면 한글이 깨지는 문제 [1]
11926정성태6/4/201954오류 유형: 542. Visual Studio - pointer to incomplete class type is not allowed
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...