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

Visual C++ - "Treat Warnings As Errors" 옵션이 꺼져 있는데도 일부 경고가 에러 처리되는 경우

특정 API를 사용했는데,

hr = CorBindToRuntimeEx(
    pszVersion,                     // Runtime version 
    pszFlavor,                      // Flavor of the runtime to request 
    0,                              // Runtime startup flags 
    CLSID_CorRuntimeHost,           // CLSID of ICorRuntimeHost 
    IID_PPV_ARGS(&pCorRuntimeHost)  // Return ICorRuntimeHost 
);

이런 컴파일 경고가 발생할 수 있습니다.

1>E:\DotNetSamples\Cpp\netfx_host\netfx_host\netfx_host.cpp(38,9): warning C4996: 'CorBindToRuntimeEx': This API has been deprecated. Refer to https://go.microsoft.com/fwlink/?LinkId=143720 for more details.

경고를 원치 않는다면, mscoree.h에서 요구하는 데로 USE_DEPRECATED_CLR_API_WITHOUT_WARNING 전처리 지시자를 정의하면 됩니다.

#ifndef USE_DEPRECATED_CLR_API_WITHOUT_WARNING
#define DEPRECATED_CLR_API_MESG "This API has been deprecated. Refer to https://go.microsoft.com/fwlink/?LinkId=143720 for more details."
#define DECLARE_DEPRECATED __declspec(deprecated(DEPRECATED_CLR_API_MESG))
#define DEPRECATED_CLR_STDAPI EXTERN_C DECLARE_DEPRECATED HRESULT STDAPICALLTYPE
#else // USE_DEPRECATED_CLR_API_WITHOUT_WARNING
#define DECLARE_DEPRECATED 
#define DEPRECATED_CLR_STDAPI STDAPI
#endif // !USE_DEPRECATED_CLR_API_WITHOUT_WARNING

그런데, 특정 빌드에서 "경고"가 아닌 "예러"로 다뤄질 때가 있습니다. 분명히 "Treat Warnings As Errors" 설정이 안 되어 있는데도, 이렇게 컴파일 오류가 발생합니다.

1>E:\DotNetSamples\Cpp\netfx_host\netfx_host\netfx_host.cpp(38,9): error C4996: 'CorBindToRuntimeEx': This API has been deprecated. Refer to https://go.microsoft.com/fwlink/?LinkId=143720 for more details.

이거저거 옵션을 조정해 보니 "Configuration Properties / C/C++ / General" 범주의 "SDL checks" 옵션이 켜져(/sdl) 있는 경우 그렇게 처리가 되었는데요, 그리고 그렇게 원인을 찾고 나서 문서를 보니 이에 대한 내용이 나옵니다. ^^

/sdl (Enable Additional Security Checks)
; https://docs.microsoft.com/en-us/cpp/build/reference/sdl-enable-additional-security-checks

그러니까, /sdl 옵션의 영향 중에는 컴파일 시점에 4146, 4308, 4532, 4533, 4700, 4703, 4789, 4995, 4996 경고에 대한 오류 처리를 포함합니다.




종종 이런 유의 문제가 있습니다. 어떤 문제의 원인은 그 원인의 문서에 자세하게 나와 있는데, 정작 그 원인을 모르면 문서도 있는지 모르는... 그런. ^^




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







[최초 등록일: ]
[최종 수정일: 11/24/2020]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
12206정성태4/2/202018366오류 유형: 613. 파일 잠금이 바로 안 풀린다면? - The process cannot access the file '...' because it is being used by another process.
12205정성태4/2/202015033스크립트: 18. Powershell에서는 cmd.exe의 명령어를 지원하진 않습니다.
12204정성태4/1/202015057스크립트: 17. Powershell 명령어에 ';' (semi-colon) 문자가 포함된 경우
12203정성태3/18/202017856오류 유형: 612. warning: 'C:\ProgramData/Git/config' has a dubious owner: '...'.
12202정성태3/18/202021120개발 환경 구성: 486. .NET Framework 프로젝트를 위한 GitLab CI/CD Runner 구성
12201정성태3/18/202018364오류 유형: 611. git-credential-manager.exe: Using credentials for username "Personal Access Token". [1]
12200정성태3/18/202018473VS.NET IDE: 145. NuGet + Github 라이브러리 디버깅 관련 옵션 3가지 - "Enable Just My Code" / "Enable Source Link support" / "Suppress JIT optimization on module load (Managed only)"
12199정성태3/17/202016119오류 유형: 610. C# - CodeDomProvider 사용 시 Unhandled Exception: System.IO.DirectoryNotFoundException: Could not find a part of the path '...\f2_6uod0.tmp'.
12198정성태3/17/202019502오류 유형: 609. SQL 서버 접속 시 "Cannot open user default database. Login failed."
12197정성태3/17/202018743VS.NET IDE: 144. .NET Core 콘솔 응용 프로그램을 배포(publish) 시 docker image 자동 생성 - 두 번째 이야기 [1]
12196정성태3/17/202015920오류 유형: 608. The ServicedComponent being invoked is not correctly configured (Use regsvcs to re-register).
12195정성태3/16/202018247.NET Framework: 902. C# - 프로세스의 모든 핸들을 열람 - 세 번째 이야기
12194정성태3/16/202020965오류 유형: 607. PostgreSQL - Npgsql.NpgsqlException: sorry, too many clients already
12193정성태3/16/202017856개발 환경 구성: 485. docker - SAP Adaptive Server Enterprise 컨테이너 실행 [1]
12192정성태3/14/202019869개발 환경 구성: 484. docker - Sybase Anywhere 16 컨테이너 실행
12191정성태3/14/202021001개발 환경 구성: 483. docker - OracleXE 컨테이너 실행 [1]
12190정성태3/14/202015548오류 유형: 606. Docker Desktop 업그레이드 시 "The process cannot access the file 'C:\Program Files\Docker\Docker\resources\dockerd.exe' because it is being used by another process."
12189정성태3/13/202021168개발 환경 구성: 482. Facebook OAuth 처리 시 상태 정보 전달 방법과 "유효한 OAuth 리디렉션 URI" 설정 규칙
12188정성태3/13/202025986Windows: 169. 부팅 시점에 실행되는 chkdsk 결과를 확인하는 방법
12187정성태3/12/202015505오류 유형: 605. NtpClient was unable to set a manual peer to use as a time source because of duplicate error on '...'.
12186정성태3/12/202017368오류 유형: 604. The SysVol Permissions for one or more GPOs on this domain controller and not in sync with the permissions for the GPOs on the Baseline domain controller.
12185정성태3/11/202017939오류 유형: 603. The browser service was unable to retrieve a list of servers from the browser master...
12184정성태3/11/202019866오류 유형: 602. Automatic certificate enrollment for local system failed (0x800706ba) The RPC server is unavailable. [3]
12183정성태3/11/202017669오류 유형: 601. Warning: DsGetDcName returned information for \\[...], when we were trying to reach [...].
12182정성태3/11/202019166.NET Framework: 901. C# Windows Forms - Vista/7 이후의 Progress Bar 업데이트가 느린 문제파일 다운로드1
12181정성태3/11/202019433기타: 76. 재현 가능한 최소한의 예제 프로젝트란? - 두 번째 예제파일 다운로드1
... 61  62  63  64  65  66  67  68  [69]  70  71  72  73  74  75  ...