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

비밀번호

댓글 작성자
 




... 151  152  153  [154]  155  156  157  158  159  160  161  162  163  164  165  ...
NoWriterDateCnt.TitleFile(s)
1263정성태3/9/201225634개발 환경 구성: 148. tinyget 사용법
1262정성태3/8/201246504개발 환경 구성: 147. .keystore 파일에 저장된 개인키 추출 방법과 인증기관으로부터 온 공개키를 합친 pfx 파일 만드는 방법 [1]
1261정성태3/7/201226911Phone: 2. 개발자용 윈도우 폰 7 기기 등록하는 방법
1260정성태3/6/201227235Phone: 1. 윈도폰 7 개발자 (회사) 등록하는 방법 [3]
1259정성태3/4/201238784Windows: 57. 새로 추가된 네트워크 커널 디버깅 및 PowerShell 3.0 [1]
1258정성태3/3/201240261개발 환경 구성: 146. SQL Server 2012에 포함된 LocalDB 기능 소개 [3]파일 다운로드1
1257정성태3/3/201228708.NET Framework: 312. Native 스레드와 Managed 스레드 개체의 상태 관계 [1]파일 다운로드1
1256정성태3/3/201231990Math: 5. Euler's totient function - C#파일 다운로드1
1255정성태3/3/201234152Math: 4. 소수 판정 및 소인수 분해 소스 코드 - C# [1]파일 다운로드1
1254정성태3/1/201229632Windows: 56. Windows 8 Consumer Preview를 사용해 보고... [1]
1253정성태3/1/201231016VS.NET IDE: 71. Visual Studio 11 Ultimate 베타 설치 [3]
1252정성태3/1/201228204Windows: 55. 윈도우 8 베타 설치 과정 [1]
1251정성태2/27/201232013VC++: 60. C/C++ Native 스레드 콜 스택 덤프를 얻는 공개 라이브러리 [2]파일 다운로드1
1250정성태2/27/201234504VC++: 59. C/C++ 프로젝트 빌드 속도 개선 - UnityBuild를 아세요? [3]
1249정성태2/26/201234573.NET Framework: 311. .NET 스레드 콜 스택 덤프 (5) - ICorDebug 인터페이스 사용법 [2]파일 다운로드3
1248정성태2/25/201245399.NET Framework: 310. C#의 Shift 비트 연산 정리파일 다운로드1
1247정성태2/25/201228227.NET Framework: 309. .NET 응용 프로그램에 기본 생성되는 스레드들에 대한 탐구 [1]파일 다운로드1
1246정성태2/25/201227529개발 환경 구성: 145. 한영 변환은 되지만, 정작 한글 입력이 안되는 경우
1245정성태2/25/201238573개발 환경 구성: 144. 윈도우에서도 유닉스처럼 명령행으로 원격 접속하는 방법
1244정성태2/24/201235682.NET Framework: 308. .NET System.Threading.Thread 개체에서 Native Thread Id를 구할 수 있을까? [1]파일 다운로드1
1243정성태2/23/201235641개발 환경 구성: 143. Visual Studio 2010 - .NET Framework 소스 코드 디버깅 - 두 번째 이야기 [1]
1242정성태2/20/201242224VC++: 58. API Hooking - 64비트를 고려해야 한다면? EasyHook! [7]파일 다운로드1
1241정성태2/20/201228709.NET Framework: 307. .NET 4.0 응용 프로그램을 위한 ILMerge
1240정성태2/19/201235356디버깅 기술: 48. C/C++ JNI DLL을 Visual Studio로 디버깅하는 방법 [2]
1239정성태2/19/201226939.NET Framework: 306. 컴퓨터에 실행된 프로세스 중에 닷넷 응용 프로그램임을 알 수 있는 방법 - C# [1]파일 다운로드1
1238정성태2/19/201231389.NET Framework: 305. GetPrivateProfileSection / WritePrivateProfileSection의 C# 버전파일 다운로드1
... 151  152  153  [154]  155  156  157  158  159  160  161  162  163  164  165  ...