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

Platform Toolset 설정에 따른 Visual C++의 헤더 파일 기본 디렉터리

"Platform Toolset"을 "Visual Studio 2017 (v141)"로 설정이 되면 기본적으로 다음의 디렉터리들이 include 폴더 대상이 됩니다.

C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.12.25827\include
C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.12.25827\atlmfc\include
C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Auxiliary\VS\include
C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\ucrt
C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\um
C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\shared
C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\winrt
C:\Program Files (x86)\Windows Kits\NETFXSDK\4.7.1\Include\um

위의 디렉터리들은 사실 다음과 같은 변수로 할당되어 있는데,

$(VC_IncludePath) = C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.12.25827\include
                    C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Tools\MSVC\14.12.25827\atlmfc\include
                    C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise\VC\Auxiliary\VS\include
                    C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\ucrt

$(WindowsSDK_IncludePath) = C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\um
                            C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\shared
                            C:\Program Files (x86)\Windows Kits\10\Include\10.0.16299.0\winrt
                            C:\Program Files (x86)\Windows Kits\NETFXSDK\4.7.1\Include\um

결국 Visual Studio 2017에서 C++ 프로젝트를 생성하는 경우에는 기본적으로 다음과 같은 헤더 폴더 경로가 설정된 것으로 시작합니다.

$(VC_IncludePath)
$(WindowsSDK_IncludePath)

그런데 만약 "Platform Toolset"을 다른 값, 예를 들어 "Visual Studio 2015 - Windows XP (v140_xp)"로 바꾸면 헤더 파일을 위한 기본 디렉터리가 다음과 같이 바뀝니다.

C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\include
C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\atlmfc\include
C:\Program Files (x86)\Windows Kits\10\Include\10.0.10240.0\ucrt
C:\Program Files (x86)\Microsoft SDKs\Windows\v7.1A\include

역시 이것도 다음의 변수에 각각 할당된 것들입니다.

$(WindowsSdk_71A_IncludePath) = C:\Program Files (x86)\Microsoft SDKs\Windows\v7.1A\include

$(VC_IncludePath) = C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\include
                    C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\atlmfc\include
                    C:\Program Files (x86)\Windows Kits\10\Include\10.0.10240.0\ucrt

참고로, WindowsSdk_71A_IncludePath와 WindowsSDK_IncludePath 변수들은 해당 플랫폼 툴셋이 정의된 경우에만 정상적인 경로를 갖습니다.




주의해야 할 사항이 있다면, 이전 버전의 Visual Studio에서 생성한 Visual C++ 프로젝트를 2017 버전으로 마이그레이션하는 경우 헤더 파일을 위한 기본 디렉터리가 자동으로 바뀌지는 않는다는 점입니다.

즉, 기존 프로젝트가 "Visual Studio 2015 - Windows XP (v140_xp)"로 설정되어 있으면 그 프로젝트를 (마이그레이션 없이) 2017 버전에서 여는 경우 기본 디렉터리가 $(VC_IncludePath), $(WindowsSDK_IncludePath)로 바뀌지 않습니다.




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







[최초 등록일: ]
[최종 수정일: 8/26/2024]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
13714정성태8/19/20249560닷넷: 2295. C# 12 - 기본 생성자(Primary constructors) (책 오타 수정) [3]
13713정성태8/16/202412199개발 환경 구성: 721. WSL 2에서의 Hyper-V Socket 연동
13712정성태8/14/202410695개발 환경 구성: 720. Synology NAS - docker 원격 제어를 위한 TCP 바인딩 추가
13711정성태8/13/202411196Linux: 77. C# / Linux - zombie process (defunct process) [1]파일 다운로드1
13710정성태8/8/202412334닷넷: 2294. C# 13 - (6) iterator 또는 비동기 메서드에서 ref와 unsafe 사용을 부분적으로 허용파일 다운로드1
13709정성태8/7/202410911닷넷: 2293. C# - safe/unsafe 문맥에 대한 C# 13의 (하위 호환을 깨는) 변화파일 다운로드1
13708정성태8/7/202411722개발 환경 구성: 719. ffmpeg / YoutubeExplode - mp4 동영상 파일로부터 Audio 파일 추출
13707정성태8/6/202411227닷넷: 2292. C# - 자식 프로세스의 출력이 4,096보다 많은 경우 Process.WaitForExit 호출 시 hang 현상파일 다운로드1
13706정성태8/5/202410549개발 환경 구성: 718. Hyper-V - 리눅스 VM에 새로운 디스크 추가
13705정성태8/4/202410886닷넷: 2291. C# 13 - (5) params 인자 타입으로 컬렉션 허용 [2]파일 다운로드1
13704정성태8/2/202412622닷넷: 2290. C# - 간이 dotnet-dump 프로그램 만들기파일 다운로드1
13703정성태8/1/202410527닷넷: 2289. "dotnet-dump ps" 명령어가 닷넷 프로세스를 찾는 방법
13702정성태7/31/202411855닷넷: 2288. Collection 식을 지원하는 사용자 정의 타입을 CollectionBuilder 특성으로 성능 보완파일 다운로드1
13701정성태7/30/202412665닷넷: 2287. C# 13 - (4) Indexer를 이용한 개체 초기화 구문에서 System.Index 연산자 허용파일 다운로드1
13700정성태7/29/202412587디버깅 기술: 200. DLL Export/Import의 Hint 의미
13699정성태7/27/202412788닷넷: 2286. C# 13 - (3) Monitor를 대체할 Lock 타입파일 다운로드1
13698정성태7/27/202411902닷넷: 2285. C# - async 메서드에서의 System.Threading.Lock 잠금 처리파일 다운로드1
13697정성태7/26/202410582닷넷: 2284. C# - async 메서드에서의 lock/Monitor.Enter/Exit 잠금 처리파일 다운로드1
13696정성태7/26/202410972오류 유형: 920. dotnet publish - error NETSDK1047: Assets file '...\obj\project.assets.json' doesn't have a target for '...'
13695정성태7/25/202411068닷넷: 2283. C# - Lock / Wait 상태에서도 STA COM 메서드 호출 처리파일 다운로드1
13694정성태7/25/202410892닷넷: 2282. C# - ASP.NET Core Web App의 Request 용량 상한값 (Kestrel, IIS)
13693정성태7/24/202410352개발 환경 구성: 717. Visual Studio - C# 프로젝트에서 레지스트리에 등록하지 않은 COM 개체 참조 및 사용 방법파일 다운로드1
13692정성태7/24/202412085디버깅 기술: 199. Windbg - 리눅스에서 뜬 닷넷 응용 프로그램 덤프 파일에 포함된 DLL의 Export Directory 탐색
13691정성태7/23/202410779디버깅 기술: 198. Windbg - 스레드의 Win32 Message Queue 정보 조회
13690정성태7/23/20249530오류 유형: 919. Visual C++ 리눅스 프로젝트 - error : ‘u8’ was not declared in this scope
13689정성태7/22/202413000디버깅 기술: 197. Windbg - PE 포맷의 Export Directory 탐색
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...