Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies.

이상하군요, XmlCodeGenerator가 Preview 버전까지만 해도 잘 동작했는데 2022 정식 버전에서는 동작을 하지 않습니다. 디버깅을 해보니, "FileNotFoundException" 예외가 발생하는데요,

System.IO.FileNotFoundException: 'Could not load file or assembly 'Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies. The system cannot find the file specified.'

그러니까, 아예 XmlCodeGenerator 확장 DLL이 저것 때문에 올라오지도 못하고 있었던 것입니다.

=== Pre-bind state information ===
LOG: DisplayName = Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
 (Fully-specified)
LOG: Appbase = file:///C:/Program Files/Microsoft Visual Studio/2022/Enterprise/Common7/IDE/
LOG: Initial PrivatePath = NULL
Calling assembly : XmlCodeGenerator, Version=1.0.0.0, Culture=neutral, PublicKeyToken=8247e1cbdabdbe2d.
===
LOG: This bind starts in LoadFrom load context.
WRN: Native image will not be probed in LoadFrom context. Native image will only be probed in default load context, like with Assembly.Load().
LOG: Using application configuration file: %USERPROFILE%\AppData\Local\Microsoft\VisualStudio\17.0_03677d2cExp\devenv.exe.config
LOG: Using host configuration file: 
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework64\v4.0.30319\config\machine.config.
LOG: Post-policy reference: Microsoft.VisualStudio.TextTemplating.VSHost.15.0, Version=16.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a
LOG: The same bind was seen before, and was failed with hr = 0x80070002.

차근히 볼까요? Initial PrivatePath도 null이면 사실상 찾을만한 곳은 Appbase뿐이지만 실제로 devenv.exe가 실행된 프로세스를 보면 다음의 경로에서도 찾는 것을 볼 수 있습니다.

  • C:\Program Files\Microsoft Visual Studio\2022\Enterprise\Common7\IDE\
  • C:\Program Files\Microsoft Visual Studio\2022\Enterprise\Common7\IDE\PublicAssemblies
  • GAC

그리고 저 경로를 모두 살펴보면 "Microsoft.VisualStudio.TextTemplating.VSHost.15.0" 어셈블리가 없기 때문에 오류가 발생하는 것은 맞긴 합니다.




일단, 원인 분석은 되었으니, 이제 문제는 Microsoft.VisualStudio.TextTemplating.VSHost.15.0 어셈블리를 어떻게 vsix에 포함시키느냐입니다. 모든 참조 dll은 "Copy Local" 속성을 "true"로 했기 때문에 포함이 되어야 하는 것이 맞는데요, 이상하게도 vsix에는 오직 XmlCodeGenerator.dll 파일만 있습니다.

다행히 검색해 보면 다음의 글이 나오는데요,

How to add referenced DLLs to VSIX? 
; https://social.msdn.microsoft.com/Forums/sqlserver/en-US/e59b527b-a683-40ea-9a25-5d7acbb48074/how-to-add-referenced-dlls-to-vsix?forum=vsx

따라서, vsixmanifest 파일을 열어 추가해 주면 됩니다.

vsix_dll_1.png

실제로 저렇게 설정하고 빌드하면 vsix에 DLL 파일이 있고, 모든 기능이 정상적으로 잘 동작했습니다.




참고로, 이외에 여러 가지 변화가 있는데 경험상 2022는 바뀐 부분이 너무 많아서 경우에 따라 아예 extension을 2022 전용으로 작성하는 것이 편할 수 있습니다. 그렇지 않고 2019와 2022를 동시에 지원하려면... 상당히 피곤해지실 것입니다. ^^;





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







[최초 등록일: ]
[최종 수정일: 1/8/2022]

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

비밀번호

댓글 작성자
 




... 181  182  183  [184]  185  186  187  188  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
390정성태11/6/200626857    답변글 .NET Framework: 74.9. WCF에 SSL 적용 (2) - 서비스 제작파일 다운로드1
356정성태10/7/200622403COM 개체 관련: 19. COM의 Apartment를 이해해 보자. [8]
386light10/30/200617376    답변글 COM 개체 관련: 19.1. [답변]: COM 객체를 글로벌마샬으로 만든후, 사용한다.
355정성태10/9/200625141개발 환경 구성: 19. Internet_Zone 하위에 새로운 코드 그룹을 추가하는 예제 [4]파일 다운로드2
353정성태12/31/200633434개발 환경 구성: 18. 윈도우즈 인증서 서비스 이야기 [3]
354정성태10/23/200635966    답변글 개발 환경 구성: 18.1. 윈도우즈 인증서 서비스 설치
372정성태12/31/200637854    답변글 개발 환경 구성: 18.2. 웹 사이트에 SSL을 적용 [3]
373정성태10/24/200629253    답변글 개발 환경 구성: 18.3. 사용자 입장에서의 HTTPS 접근 (1)
374정성태10/25/200626512    답변글 개발 환경 구성: 18.4. 사용자 입장에서의 HTTPS 접근 (2)
391정성태11/7/200630644    답변글 개발 환경 구성: 18.5. 사용자 인증서 발급
392정성태11/11/200643838    답변글 개발 환경 구성: 18.6. 인증서 관리 (1) - 내보내기/가져오기
394정성태11/9/200628344    답변글 개발 환경 구성: 18.7. 인증서 관리 (2) - 개인키를 내보낼 수 있는 유형의 인증서 발급 [1]
395정성태11/9/200640458    답변글 개발 환경 구성: 18.8. 인증서 관리 (3) - 인증서 MMC 관리자 사용
414정성태12/23/200632162    답변글 개발 환경 구성: 18.9. CRL(Certificate Revocation List) 관리
428정성태12/31/200645032    답변글 개발 환경 구성: 18.10. IIS 7 - SSL 사이트 설정하는 방법 [4]
429정성태12/31/200631049    답변글 개발 환경 구성: 18.11. 서비스를 위한 인증서 설치
352정성태10/2/200620767개발 환경 구성: 17. VPC에 Linux 설치하는 방법 [1]
351정성태10/8/200623319개발 환경 구성: 16. 성태의 무식한(!) 리눅스 탐방기. [4]
349정성태9/26/200622000디버깅 기술: 10. C++/CLI에서 제공되는 명시적인 파괴자의 비밀
347정성태10/6/200625756디버깅 기술: 9. .NET IDisposable 처리 정리 [1]
346정성태9/23/200619261개발 환경 구성: 15. 툴박스에 컨트롤이 자동으로 나타나도록 해주는 옵션 설정
345정성태9/20/200618468오류 유형: 12. WCF 오류 메시지 - Error while trying to reflect on attribute 'MessageContractAttribute'
343정성태10/18/200630328개발 환경 구성: 14. SandCastle 사용법 (NDoc을 대체하는 문서화 도구) [1]파일 다운로드1
344정성태9/20/200620542    답변글 개발 환경 구성: 14.1. 오류 유형 - GAC 에 등록된 DLL 에 대한 문서화 시 오류
340정성태9/15/200619806개발 환경 구성: 13. ISO 파일을 가상 CD-ROM으로 매핑해주는 프로그램
339정성태9/14/200619283오류 유형: 11. ProtocolsSection?
... 181  182  183  [184]  185  186  187  188  189  190  191  192  193  194  195  ...