Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 77. Visual Studio 확장(VSIX) 만드는 방법 [링크 복사], [링크+제목 복사],
조회: 28679
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)

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

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

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

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

Microsoft Visual Studio 2012 SDK
; https://marketplace.visualstudio.com/items?itemName=VisualStudioProductTeam.MicrosoftVisualStudio2012SDK

Microsoft Visual Studio 2013 SDK 
; https://marketplace.visualstudio.com/items?itemName=VisualStudioProductTeam.MicrosoftVisualStudio2013SDK

용량은 각각 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 제품 및 확장 기능
; https://marketplace.visualstudio.com/

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

how_to_vsix_6.png

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

Walkthroughs for Customizing Visual Studio By Using VSPackages
; hhttps://learn.microsoft.com/en-us/previous-versions/cc138565(v=vs.140)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/12/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.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
정성태
2019-08-19 02시25분
Create a private gallery for self-hosted Visual Studio extensions
; https://devblogs.microsoft.com/visualstudio/create-a-private-gallery-for-self-hosted-visual-studio-extensions/

VisualStudio.Extensibility: 확장을 작성하는 새로운 방법 (2022-08-12)
; https://forum.dotnetdev.kr/t/visualstudio-extensibility/4285

새로운 Visual Studio 확장 SDK : VisualStudio.Extensibility (2024-02-22)
; https://forum.dotnetdev.kr/t/visual-studio-sdk-visualstudio-extensibility/9970
정성태
2023-05-12 04시26분
How to Control Visual Studio from an external application
; https://www.meziantou.net/control-visual-studio-from-an-external-application.htm

Running Object Table의 경우 전에 저도 Graph Filter를 알아내는 용도로 사용한 적이 있었습니다. ^^

Direct Show를 사용하는 다른 프로그램의 필터 그래프를 graphedt.exe에서 확인하는 방법
; https://www.sysnet.pe.kr/2/0/1652

C#에서 DirectShow를 이용한 미디어 재생
; https://www.sysnet.pe.kr/2/0/1632
정성태

1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13455정성태11/25/20233865닷넷: 2168. C# - Azure.AI.OpenAI 패키지로 OpenAI 사용파일 다운로드1
13454정성태11/23/20234235닷넷: 2167. C# - Qdrant Vector DB를 이용한 Embedding 벡터 값 보관/조회 (Azure OpenAI) [1]파일 다운로드1
13453정성태11/23/20233672오류 유형: 879. docker desktop 설치 시 "Invalid JSON string. (Exception from HRESULT: 0x83750007)"
13452정성태11/22/20233792닷넷: 2166. C# - Azure OpenAI API를 이용해 사용자가 제공하는 정보를 대상으로 검색하는 방법파일 다운로드1
13451정성태11/21/20233967닷넷: 2165. C# - Azure OpenAI API를 이용해 ChatGPT처럼 동작하는 콘솔 응용 프로그램 제작파일 다운로드1
13450정성태11/21/20233726닷넷: 2164. C# - Octokit을 이용한 GitHub Issue 검색파일 다운로드1
13449정성태11/21/20233849개발 환경 구성: 688. Azure OpenAI 서비스 신청 방법
13448정성태11/20/20234162닷넷: 2163. .NET 8 - Dynamic PGO를 결합한 성능 향상파일 다운로드1
13447정성태11/16/20234036닷넷: 2162. ASP.NET Core 웹 사이트의 SSL 설정을 코드로 하는 방법
13446정성태11/16/20233904닷넷: 2161. .NET Conf 2023 - Day 1 Blazor 개요 정리
13445정성태11/15/20234346Linux: 62. 리눅스/WSL에서 CA 인증서를 저장하는 방법
13444정성태11/15/20234051닷넷: 2160. C# 12 - Experimental 특성 지원
13443정성태11/14/20233975개발 환경 구성: 687. OpenSSL로 생성한 사용자 인증서를 ASP.NET Core 웹 사이트에 적용하는 방법
13442정성태11/13/20233735개발 환경 구성: 686. 비주얼 스튜디오로 실행한 ASP.NET Core 사이트를 WSL 2 인스턴스에서 https로 접속하는 방법
13441정성태11/12/20234198닷넷: 2159. C# - ASP.NET Core 프로젝트에서 서버 Socket을 직접 생성하는 방법파일 다운로드1
13440정성태11/11/20233651Windows: 253. 소켓 Listen 시 방화벽의 Public/Private 제어 기능이 비활성화된 경우
13439정성태11/10/20234688닷넷: 2158. C# - 소켓 포트를 미리 시스템에 등록/예약해 사용하는 방법(Port Exclusion Ranges)파일 다운로드1
13438정성태11/9/20233956닷넷: 2157. C# - WinRT 기능을 이용해 윈도우에서 실행 중인 Media App 제어
13437정성태11/8/20234081닷넷: 2156. .NET 7 이상의 콘솔 프로그램을 (dockerfile 없이) 로컬 docker에 배포하는 방법
13436정성태11/7/20234332닷넷: 2155. C# - .NET 8 런타임부터 (Reflection 없이) 특성을 이용해 public이 아닌 멤버 호출 가능
13435정성태11/6/20234180닷넷: 2154. C# - 네이티브 자원을 포함한 관리 개체(예: 스레드)의 GC 정리
13434정성태11/1/20233900스크립트: 62. 파이썬 - class의 정적 함수를 동적으로 교체
13433정성태11/1/20233510스크립트: 61. 파이썬 - 함수 오버로딩 미지원
13432정성태10/31/20233877오류 유형: 878. 탐색기의 WSL 디렉터리 접근 시 "Attempt to access invalid address." 오류 발생
13431정성태10/31/20234317스크립트: 60. 파이썬 - 비동기 FastAPI 앱을 gunicorn으로 호스팅
13430정성태10/30/20234094닷넷: 2153. C# - 사용자가 빌드한 ICU dll 파일을 사용하는 방법
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...