Microsoft MVP성태의 닷넷 이야기
VS.NET IDE: 77. Visual Studio 확장(VSIX) 만드는 방법 [링크 복사], [링크+제목 복사],
조회: 34358
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 6개 있습니다.)
VS.NET IDE: 77. Visual Studio 확장(VSIX) 만드는 방법
; https://www.sysnet.pe.kr/2/0/1515

VS.NET IDE: 78. Visual Studio 확장으로 XmlCodeGenerator 제작하는 방법
; https://www.sysnet.pe.kr/2/0/1518

VS.NET IDE: 115. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법
; https://www.sysnet.pe.kr/2/0/11184

VS.NET IDE: 116. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법 (2) - 동적 메뉴 구성
; https://www.sysnet.pe.kr/2/0/11185

VS.NET IDE: 117. Visual Studio 확장(VSIX)을 이용해 사용자 매크로를 추가하는 방법
; https://www.sysnet.pe.kr/2/0/11186

VS.NET IDE: 165. Visual Studio 2022를 위한 Extension 마이그레이션
; https://www.sysnet.pe.kr/2/0/12682




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

-----------------------------------------------------

VS Code 확장 프로그램 개발 팁 첫 번째, 상태 표시줄 다루기
; https://occamsrazr.net/tt/409

VS Code 확장 프로그램 개발 팁 #2 - 풍선 도움말 다루기
; https://occamsrazr.net/tt/411

VS Code 확장 프로그램 개발 팁 #3 - 자동 완성 다루기
; https://occamsrazr.net/tt/414
정성태

... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
600정성태10/9/200832231디버깅 기술: 18. TFS Team Build + Source Server = 소스 코드 디버깅 [3]
603정성태10/15/200824152    답변글 디버깅 기술: 18.1. 소스 서버 구성, 그 외의 이야기
599정성태10/5/200830083디버깅 기술: 17. TFS Team Build + Symbol Server [1]
598정성태10/3/200820076VS.NET IDE: 57. VS.NET 2008 - 다중 프로젝트에서 단일 SNK를 사용하는 방법
597정성태10/2/200818767Team Foundation Server: 25. VSTS 2008의 Build Explorer
596정성태10/2/200825517오류 유형: 58. WPF : 드롭다운 유형의 ComboBox가 펼쳐지지 않는 문제
595정성태10/1/200833080디버깅 기술: 16. Watson Bucket 정보를 이용한 CLR 응용 프로그램 예외 분석 [2]
594정성태9/22/200821099.NET Framework: 104. Win32Exception 클래스 소개
591정성태7/24/200817845오류 유형: 57. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상
592정성태7/28/200817847    답변글 오류 유형: 57.1. VS.NET 2008 TFC - 체크인 시에 비프 음과 함께 정지되는 현상 [1]
590정성태7/20/200823648.NET Framework: 103. WPF - ControlTemplate을 코드에서 다뤄보기 [1]
589정성태6/17/200820545.NET Framework: 102. COM 개체의 이벤트를 구독하는 코드 제작 [1]
588정성태6/13/200822405VC++: 35. COM 이벤트에서 반환값을 가진 콜백 정의
587정성태6/10/200827153VS.NET IDE: 56. C#에서 아쉬운 __DATE__, __TIME__ 매크로 [2]
586정성태6/4/200824788오류 유형: 56. WPF 디자이너 - The string was not recognized as a valid DateTime [2]
585정성태6/4/200832918.NET Framework: 101. WPF - ActiveX 컨트롤 호스팅하는 방법 [2]
582정성태5/16/200824770오류 유형: 55. Windowless ActiveX controls are not supported
580정성태4/24/200823859VC++: 34. 64비트 윈도우즈에서의 이벤트 후킹
579정성태4/24/200823676VC++: 33. 변환 후의 RGS 파일 내용을 얻는 방법
577정성태4/16/200824571.NET Framework: 100. XML Serializer를 이용한 값 복사 [5]
575정성태4/7/200821707오류 유형: 54. TFS Source Control - 명령을 사용할 수 없음 [2]
574정성태3/31/200819995오류 유형: 53. TFS 연결 오류 - The workspace [...] exists on computer [...]
573정성태3/25/200823721Windows: 31. TS Web Access와 UAC [1]
570정성태3/17/200823072오류 유형: 52. TFS 연결 오류 - TF31001 [2]
569정성태3/16/200824003Team Foundation Server: 24. TFS 2008로 마이그레이션 (2) [2]
566정성태2/28/200825157.NET Framework: 99. AppDomain.GetEntryAssembly()를 우회하는 방법파일 다운로드1
... 166  167  168  169  170  171  172  173  174  175  [176]  177  178  179  180  ...