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

vcpkg - "Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++"

이 오류의 원인은 다양하겠지만, 제 경우에는 다음과 같은 상황에서도 발생했습니다.

Build FAILED.

       "c:/temp/vcpkg\toolsrc\dirs.proj" (default target) (1) ->
       "c:/temp/vcpkg\toolsrc\vcpkg\vcpkg.vcxproj" (Build target) (2:2) ->
       "c:/temp/vcpkg\toolsrc\vcpkglib\vcpkglib.vcxproj" (default target) (3:4) ->
       (ClCompile target) ->
         c:/temp/vcpkg\toolsrc\src\vcpkg\base\cofffilereader.cpp(248): error C4996: 'std::fpos<_Mbstatet>::seekpos
       ': warning STL4019: The member std::fpos::seekpos() is non-Standard, and is preserved only for compatibility wit
       h workarounds for old versions of Visual C++. It will be removed in a future release, and in this release always
        returns 0. Please use standards-conforming mechanisms to manipulate fpos, such as conversions to and from strea
       moff, or an integral type, instead. If you are receiving this message while compiling Boost.IOStreams, a fix has
        been submitted upstream to make Boost use standards-conforming mechanisms, as it does for other compilers. You
       can define _SILENCE_FPOS_SEEKPOS_DEPRECATION_WARNING to acknowledge that you have received this warning, or defi
       ne _REMOVE_FPOS_SEEKPOS to remove std::fpos::seekpos entirely. [c:/temp/vcpkg\toolsrc\vcpkglib\vcpkglib.vcxproj]

    0 Warning(s)
    1 Error(s)

Time Elapsed 00:00:08.10
c:/temp/vcpkg\scripts\bootstrap.ps1 : Building vcpkg.exe failed. Please ensure you have installed Visual Studio with the Desktop C++ workload and the Windows SDK for Desktop C++.
At line:1 char:4
+ & {& 'c:/temp/vcpkg\scripts\bootstrap.ps1'}
+    ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [Write-Error], WriteErrorException
    + FullyQualifiedErrorId : Microsoft.PowerShell.Commands.WriteErrorException,bootstrap.ps1

즉, Visual Studio를 업그레이드하면서 Visual C++ 컴파일러가 보다 더 공격적으로 표준을 지키는 기본 동작을 하는 바람에 vcpkg 소스 코드가 빌드가 안 되는 것입니다.

이런 경우에 해법은 2가지가 있을 것입니다. 하나는 vcxproj 파일의 빌드 옵션에 /WX를 추가하는 것입니다.

/WX (Treat Linker Warnings as Errors)
; https://docs.microsoft.com/en-us/cpp/build/reference/wx-treat-linker-warnings-as-errors

또는, 약간의 시간이 지나고 나면 vcpkg 개발팀도 이 문제를 인지하고 github 소스 코드를 업데이트할 것이므로 "git pull" 명령어로 최신 업데이트를 받아 보는 것입니다. 제 경우에는 후자의 조치로 해결을 했습니다. ^^




참고로, git pull 명령어가 다음과 같이 막힐 때가 있습니다.

c:/temp/vcpkg>git pull
error: Your local changes to the following files would be overwritten by merge:
        scripts/cmake/vcpkg_get_windows_sdk.cmake
        scripts/getWindowsSDK.ps1
Please commit your changes or stash them before you merge.
Aborting
Updating 76096c95..eccae2ad

메시지에 따라 다음과 같이 stash를 하든,

c:/temp/vcpkg>git stash
Saved working directory and index state WIP on master: 76096c95 Merge pull request #2381 from markgarcia/tbb-2018_U2

어차피 vcpkg의 소스 코드를 수정하지 않는다고 하면 clean을 해도 무방할 것입니다.




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







[최초 등록일: ]
[최종 수정일: 7/12/2021]

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

비밀번호

댓글 작성자
 




... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13201정성태12/20/20225389오류 유형: 835. PyCharm 사용 시 C 드라이브 용량 부족
13200정성태12/19/20224262오류 유형: 834. 이벤트 로그 - SSL Certificate Settings created by an admin process for endpoint
13199정성태12/19/20224532개발 환경 구성: 656. Internal Network 유형의 스위치로 공유한 Hyper-V의 VM과 호스트가 통신이 안 되는 경우
13198정성태12/18/20224431.NET Framework: 2080. C# - Microsoft.XmlSerializer.Generator 처리 없이 XmlSerializer 생성자를 예외 없이 사용하고 싶다면?파일 다운로드1
13197정성태12/17/20224364.NET Framework: 2079. .NET Core/5+ 환경에서 XmlSerializer 사용 시 System.IO.FileNotFoundException 예외 발생하는 경우파일 다운로드1
13196정성태12/16/20224521.NET Framework: 2078. .NET Core/5+를 위한 SGen(Microsoft.XmlSerializer.Generator) 사용법
13195정성태12/15/20225058개발 환경 구성: 655. docker - bridge 네트워크 모드에서 컨테이너 간 통신 시 --link 옵션 권장 이유
13194정성태12/14/20225079오류 유형: 833. warning C4747: Calling managed 'DllMain': Managed code may not be run under loader lock파일 다운로드1
13193정성태12/14/20225145오류 유형: 832. error C7681: two-phase name lookup is not supported for C++/CLI or C++/CX; use /Zc:twoPhase-
13192정성태12/13/20225145Linux: 55. 리눅스 - bash shell에서 실수 연산
13191정성태12/11/20226046.NET Framework: 2077. C# - 직접 만들어 보는 SynchronizationContext파일 다운로드1
13190정성태12/9/20226538.NET Framework: 2076. C# - SynchronizationContext 기본 사용법파일 다운로드1
13189정성태12/9/20227210오류 유형: 831. Visual Studio - Windows Forms 디자이너의 도구 상자에 컨트롤이 보이지 않는 문제
13188정성태12/9/20226000.NET Framework: 2075. C# - 직접 만들어 보는 TaskScheduler 실습 (SingleThreadTaskScheduler)파일 다운로드1
13187정성태12/8/20225908개발 환경 구성: 654. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법 (2)
13186정성태12/6/20224465오류 유형: 831. The framework 'Microsoft.AspNetCore.App', version '...' was not found.
13185정성태12/6/20225449개발 환경 구성: 653. Windows 환경에서의 Hello World x64 어셈블리 예제 (NASM 버전)
13184정성태12/5/20224710개발 환경 구성: 652. ml64.exe와 link.exe x64 실행 환경 구성
13183정성태12/4/20224561오류 유형: 830. MASM + CRT 함수를 사용하는 경우 발생하는 컴파일 오류 정리
13182정성태12/4/20225287Windows: 217. Windows 환경에서의 Hello World x64 어셈블리 예제 (MASM 버전)
13181정성태12/3/20224691Linux: 54. 리눅스/WSL - hello world 어셈블리 코드 x86/x64 (nasm)
13180정성태12/2/20224892.NET Framework: 2074. C# - 스택 메모리에 대한 여유 공간 확인하는 방법파일 다운로드1
13179정성태12/2/20224298Windows: 216. Windows 11 - 22H2 업데이트 이후 Terminal 대신 cmd 창이 뜨는 경우
13178정성태12/1/20224797Windows: 215. Win32 API 금지된 함수 - IsBadXxxPtr 유의 함수들이 안전하지 않은 이유파일 다운로드1
13177정성태11/30/20225516오류 유형: 829. uwsgi 설치 시 fatal error: Python.h: No such file or directory
13176정성태11/29/20224435오류 유형: 828. gunicorn - ModuleNotFoundError: No module named 'flask'
... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...