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

닷넷 6 프로젝트의 "Conditional compilation symbols" 기본값 오류

Visual Studio 2022의 현재 버전(17.2.6)에서는 프로젝트 속성의 "Conditional compilation symbols" 값을 보면 다음과 같이 나옵니다.

$(DefineConstants)TRACE

사실 값 자체에는 오류가 있지만, 이 상태에서는 프로그램에 아무런 영향을 끼치지는 않습니다. 실제로 다음과 같이 코드를 작성하고,

using System.Diagnostics;

Trace.WriteLine("TEST_TRACE");
Debug.WriteLine("TEST_DEBUG");

빌드하면 "Output" 창에 다음과 같이 "TEST_TRACE", "TEST_DEBUG"가 정상적으로 출력됩니다.

invalid_initial_cond_value_1.png




저 잘못된 초깃값의 문제는, Symbols 값을 편집할 때 발생합니다. 가령 다음과 같이 "TEST"를 추가하고,

invalid_initial_cond_value_2.png

프로젝트 설정을 저장 후 다시 빌드를 하면 이제는 출력 결과가 이렇게 나옵니다.

invalid_initial_cond_value_3.png

버그죠? 분명히 "TEST_TRACE"도 함께 나왔어야 합니다. 이렇게 나오는 이유를, 위의 화면에서 중간의 파란색 원 영역을 보면 나옵니다.

Debug - TRACETRACE;DEBUG;NET;NET6_0;NETCOREAPP
Release - TRACETRACE;RELEASE;NET;NET6_0;NETCOREAPP

뭐가 잘못인지 아시겠죠? ^^ 그렇습니다. "$(DefineConstants)"에는 이미 "TRACE"가 포함돼 있습니다. 문제는 마지막에 세미콜론을 포함하지 않았다는 것과, Visual Studio가 제공하는 기본값에는 다시 그것을 "TRACE"와 연결해서 제공한다는 점입니다.
그럼, 왜 처음부터 이것이 문제가 되지 않았을까요?

왜냐하면, 기본 상태에서는 비주얼 스튜디오가 기본값을 그렇게 보여줄 뿐 실제 빌드 프로세스에는 반영하지 않기 때문입니다. 하지만, 사용자가 편집을 한 순간부터 csproj에는 그것이 반영되고,

<Project Sdk="Microsoft.NET.Sdk">

  <PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>net6.0</TargetFramework>
    <ImplicitUsings>enable</ImplicitUsings>
    <Nullable>enable</Nullable>
  </PropertyGroup>

  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|AnyCPU'">
    <DefineConstants>$(DefineConstants)TRACE;TEST</DefineConstants>
  </PropertyGroup>

  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|AnyCPU'">
    <DefineConstants>$(DefineConstants)TRACE;TEST</DefineConstants>
  </PropertyGroup>
</Project>

이후부터 빌드에 반영되기 때문에 빌드 결과에도 영향을 미치는 것입니다. 따라서 이 문제를 해결하려면 비주얼 스튜디오가 제공하는 기본값을 이런 식으로 바꾸면 됩니다.

// 세미콜론을 추가하거나,
$(DefineConstants);TRACE;TEST

// 어차피 TRACE를 포함하므로 지우거나,
$(DefineConstants);TEST

그럼 다시 정상적인 출력을 얻을 수 있습니다.

invalid_initial_cond_value_4.png




참고로, 이에 대한 이슈가 이미 있었습니다.

Can't remove "TRACE" from conditional compilation symbols
; https://developercommunity.visualstudio.com/t/Cant-remove-TRACE-from-conditional-co/1617120

제가 보기에는 문제를 충분히 잘 설명했는데도, 마이크로소프트의 "Luna Mi"라는 직원이 "without the additional information requested."라는 요구를 하면서 이슈를 "Closed" 시켜버렸습니다. ^^;

암튼, 그래서 좀 더 촘촘하게 설명을 해 이슈를 다시 열었는데,

Invalid initial "Conditional compilation symbols" values (Visual Studio 2022 17.2.6)
; https://developercommunity.visualstudio.com/t/Invalid-initial-Conditional-compilation/10102611

결과는 좀 지켜봐야겠습니다. ^^




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







[최초 등록일: ]
[최종 수정일: 7/24/2022]

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)
12416정성태11/19/202017431오류 유형: 681. Visual C++ - error LNK2001: unresolved external symbol _CrtDbgReport
12415정성태11/18/202017549.NET Framework: 971. UnmanagedCallersOnly 특성과 DNNE 사용파일 다운로드1
12414정성태11/18/202019760VC++: 138. x64 빌드에서 extern "C"가 아닌 경우 ___cdecl name mangling 적용 [4]파일 다운로드1
12413정성태11/17/202018677.NET Framework: 970. .NET 5 / .NET Core - UnmanagedCallersOnly 특성을 사용한 함수 내보내기파일 다운로드1
12412정성태11/16/202020775.NET Framework: 969. .NET Framework 및 .NET 5 - UnmanagedCallersOnly 특성 사용파일 다운로드1
12411정성태11/12/202017541오류 유형: 680. C# 9.0 - Error CS8889 The target runtime doesn't support extensible or runtime-environment default calling conventions.
12410정성태11/12/202017766디버깅 기술: 174. windbg - System.TypeLoadException 예외 분석 사례
12409정성태11/12/202019588.NET Framework: 968. C# 9.0의 Function pointer를 이용한 함수 주소 구하는 방법파일 다운로드1
12408정성태11/9/202034839도서: 시작하세요! C# 9.0 프로그래밍 [8]
12407정성태11/9/202019964.NET Framework: 967. "clr!JIT_DbgIsJustMyCode" 호출이 뭘까요?
12406정성태11/8/202020905.NET Framework: 966. C# 9.0 - (15) 최상위 문(Top-level statements) [5]파일 다운로드1
12405정성태11/8/202018906.NET Framework: 965. C# 9.0 - (14) 부분 메서드에 대한 새로운 기능(New features for partial methods)파일 다운로드1
12404정성태11/7/202019512.NET Framework: 964. C# 9.0 - (13) 모듈 이니셜라이저(Module initializers)파일 다운로드1
12403정성태11/7/202018303.NET Framework: 963. C# 9.0 - (12) foreach 루프에 대한 GetEnumerator 확장 메서드 지원(Extension GetEnumerator)파일 다운로드1
12402정성태11/7/202019883.NET Framework: 962. C# 9.0 - (11) 공변 반환 형식(Covariant return types) [1]파일 다운로드1
12401정성태11/5/202019170VS.NET IDE: 153. 닷넷 응용 프로그램에서의 "My Code" 범위와 "Enable Just My Code"의 역할 [1]
12400정성태11/5/202015343오류 유형: 679. Visual Studio - "Source Not Found" 창에 "Decompile source code" 링크가 없는 경우
12399정성태11/5/202018787.NET Framework: 961. C# 9.0 - (10) 대상으로 형식화된 조건식(Target-typed conditional expressions)파일 다운로드1
12398정성태11/4/202018463오류 유형: 678. Windows Server 2008 R2 환경에서 Powershell을 psexec로 원격 실행할 때 hang이 발생하는 문제
12397정성태11/4/202018506.NET Framework: 960. C# - 조건 연산자(?:)를 사용하는 경우 달라지는 메서드 선택 사례파일 다운로드1
12396정성태11/3/202015432VS.NET IDE: 152. Visual Studio - "Tools" / "External Tools..."에 등록된 외부 명령어에 대한 단축키 설정 방법
12395정성태11/3/202018278오류 유형: 677. SSMS로 DB 접근 시 The server principal "..." is not able to access the database "..." under the current security context.
12394정성태11/3/202015916오류 유형: 676. cacls - The Recycle Bin on ... is corrupted. Do you want to empty the Recycle Bin for this drive?
12393정성태11/3/202015441오류 유형: 675. Visual Studio - 닷넷 응용 프로그램 디버깅 시 Disassembly 창에서 BP 설정할 때 "Error while processing breakpoint." 오류
12392정성태11/2/202019974.NET Framework: 959. C# 9.0 - (9) 레코드(Records) [4]파일 다운로드1
12390정성태11/1/202019757디버깅 기술: 173. windbg - System.Configuration.ConfigurationErrorsException 예외 분석 방법
... [61]  62  63  64  65  66  67  68  69  70  71  72  73  74  75  ...