Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정 [링크 복사], [링크+제목 복사],
조회: 26571
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

(시리즈 글이 10개 있습니다.)
VS.NET IDE: 60. Output 경로에 매크로 상수 사용하는 방법
; https://www.sysnet.pe.kr/2/0/688

개발 환경 구성: 91. MSBuild를 이용한 닷넷 응용프로그램의 플랫폼(x86/x64)별 빌드
; https://www.sysnet.pe.kr/2/0/963

개발 환경 구성: 93. MSBuild를 이용한 닷넷 응용프로그램의 다중 어셈블리 출력 빌드
; https://www.sysnet.pe.kr/2/0/965

개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정
; https://www.sysnet.pe.kr/2/0/988

개발 환경 구성: 115. MSBuild - x86/x64, .NET 2/4, debug/release 빌드에 대한 배치 처리
; https://www.sysnet.pe.kr/2/0/1017

개발 환경 구성: 372. MSBuild - 빌드 전/후, 배포 전/후 실행하고 싶은 Task 정의
; https://www.sysnet.pe.kr/2/0/11507

개발 환경 구성: 452. msbuild - csproj에 환경 변수 조건 사용
; https://www.sysnet.pe.kr/2/0/11985

개발 환경 구성: 580. msbuild의 Exec Task에 robocopy를 사용하는 방법
; https://www.sysnet.pe.kr/2/0/12716

개발 환경 구성: 693. msbuild - .NET Core/5+ 프로젝트에서 resgen을 이용한 리소스 파일 생성 방법
; https://www.sysnet.pe.kr/2/0/13481

닷넷: 2235. MSBuild - AccelerateBuildsInVisualStudio 옵션
; https://www.sysnet.pe.kr/2/0/13593




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;




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







[최초 등록일: ]
[최종 수정일: 7/18/2021]

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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  [172]  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
705정성태4/20/200920904개발 환경 구성: 40. TFS2008 SP1의 DBTier에 SQL Server 2008 SP1 설치 [1]
704정성태4/19/200920851개발 환경 구성: 39. Together 2007 SP1 설치
702정성태4/18/200932144.NET Framework: 130. Infragistics - Tabbed MDI WPF 응용 프로그램파일 다운로드1
701정성태4/17/200927018Windows: 44. bootsect 오류 - Access is denied.
700정성태4/17/200930099.NET Framework: 129. Infragistics WPF 컨트롤 사용 [1]
699정성태4/16/200928659.NET Framework: 128. 이벤트 멤버의 명시적 구현파일 다운로드1
696정성태4/12/200927890오류 유형: 77. RDP 연결이 되지 않는 경우. [1]
693정성태4/9/200922398오류 유형: 76. "Client found response content type of '', but expected 'text/xml'. The request failed with an empty response.No Reports".
692정성태4/8/200935379.NET Framework: 127. ClickOnce로 ActiveX를 같이 배포하는 방법 [2]파일 다운로드1
690정성태4/5/200922977오류 유형: 75. Event Viewer - The data is invalid (13)
688정성태4/5/200929024VS.NET IDE: 60. Output 경로에 매크로 상수 사용하는 방법 [1]
687정성태4/5/200923354.NET Framework: 126. Composite Application Guidance for WPF and Silverlight
689정성태4/5/200923222    답변글 .NET Framework: 126.1. CAG - 빌드 환경 구성파일 다운로드1
691정성태4/6/200923005    답변글 .NET Framework: 126.2. CAG - Shell 띄우기파일 다운로드1
695정성태4/10/200924768    답변글 .NET Framework: 126.3. CAG - 간단한 유형의 모듈 제작파일 다운로드1
703정성태4/18/200923654        답변글 .NET Framework: 126.6. CAG - Tabbed MDI Shell 적용파일 다운로드1
697정성태4/13/200927899    답변글 .NET Framework: 126.4. CAG - Unity 컨테이너 사용 [1]파일 다운로드1
698정성태4/15/200927165    답변글 .NET Framework: 126.5. CAG에 MVVM 패턴 적용 (1) [2]파일 다운로드1
686정성태4/4/200948817웹: 11. IE 8 - TabProcGrowth 레지스트리 키 [2]
685정성태4/3/200949580개발 환경 구성: 38. Hyper-V 사용 후기 [5]
684정성태4/2/200924047오류 유형: 74. IE 8 설치 이후, VS.NET 위저드 화면 동작 오류
683정성태3/28/200930814디버깅 기술: 26. 보호 모드로 응용 프로그램 디버깅하는 방법 - 두 번째 이야기 [3]
682정성태3/27/200927918디버깅 기술: 25. 보호 모드로 응용 프로그램 디버깅하는 방법 [2]
681정성태3/23/200925122오류 유형: 73. SQL Server 2008 Express 설치 오류
680정성태3/21/200925002.NET Framework: 125. WPF - RadioButton에 대한 데이터바인딩(2) [1]파일 다운로드1
679정성태3/15/200920087오류 유형: 72. IE 8 멈춤 현상 - 두 번째 이야기
... 166  167  168  169  170  171  [172]  173  174  175  176  177  178  179  180  ...