MSBuild - DefineConstants에 다중 전처리 값 설정
msbuild.exe에서의 전처리기 설정에 대해 설명드린 적이 있는데요.
MSBuild를 이용한 닷넷 응용프로그램의 다중 어셈블리 출력 빌드
; https://www.sysnet.pe.kr/2/0/965
예를 들면, 아래와 같이 사용을 하는데,
msbuild MyTest.csproj /p:DefineConstants=ISNET35;PlatformTarget=x86;Platform=x86;
DefineConstants 설정이 값을 추가하는 것이 아니라, 덮어버린다는 사실을 이제껏 모르고 사용했습니다. ^^;
분명히 소스 코드에 "System.Diagnostics.Trace.WriteLine"으로 출력하는 코드를 넣어두었는데 테스트 서버에 배포된 어셈블리에서 WriteLine 결과물이
dbgview에 전혀 확인이 안되는 현상이 있었습니다.
.NET Reflector로 확인을 해보았더니 추가된 WriteLine 코드가 통째로 없는 것이었습니다. 처음에는, 배포 스크립트가 잘못되었나 싶어서 엉뚱하게 그 부분만 집중적으로 봤는데, 나중에 알고 보니 DefineConstants로 인해 TRACE 매크로가 정의되지 않아서 Trace.WriteLine 코드가 빌드에서 누락된 것이었습니다.
그럼, 어떻게 재정의해야 할까요?
이에 대해서는 다음의 글에 답변이 있습니다.
Defining multiple values in DefineConstants in MsBuild element?
; http://stackoverflow.com/questions/506687/defining-multiple-values-in-defineconstants-in-msbuild-element
그래서, 다음과 같이 수정하면 정상적으로 Trace.WriteLine 코드가 포함되어집니다.
msbuild MyTest.csproj /p:DefineConstants="ISNET35;TRACE";PlatformTarget=x86;Platform=x86;
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]