Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정 [링크 복사], [링크+제목 복사],
조회: 27785
글쓴 사람
정성태 (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)
519정성태7/27/200729127오류 유형: 44. System.BadImageFormatException [2]
518정성태7/26/200730200오류 유형: 43. System.ComponentModel.LicenseException [1]
517정성태7/19/200718398개발 환경 구성: 26. VPC - 일반 사용자 계정으로 구동
516정성태7/19/200721635오류 유형: 42. TFS - Error loading menu: Index was outside the bounds of the array [2]
515정성태7/18/200729585오류 유형: 41. SSL 서버 자격 증명을 만드는 동안 심각한 오류가 발생했습니다.
514정성태7/14/200722148Team Foundation Server: 19. Orcas에서 개선되는 TFS 기능들
513정성태7/4/200733305.NET Framework: 91. Foreground Thread / Background Thread [1]
512정성태6/27/200722838오류 유형: 40. error PRJ0050: Failed to register output.
511정성태6/25/200731026.NET Framework: 90. XmlSerializer 생성자의 실행 속도를 올리는 방법 [2]
510정성태6/25/200746236디버깅 기술: 15. First-Chance Exception
508정성태6/21/200729135Team Foundation Server: 18. Team Build에 사용되는 각종 Property 값 [4]
507정성태6/11/200726751VS.NET IDE: 50. Orcas - UAC 설정 관련
506정성태6/9/200721577오류 유형: 39. VC Package not available or not registered
505정성태6/9/200721284오류 유형: 38. Visual SourceSafe - DB 잠김 오류
504정성태6/9/200726623오류 유형: 37. Visual SourceSafe - Anaylze 도중 비정상 종료
503정성태6/7/200729331VS.NET IDE: 49. Orcas - VC++ 다중 소스 동시 컴파일 옵션: /MP
502정성태6/7/200724111VS.NET IDE: 48. Orcas - VC++ 프로젝트 마이그레이션
500정성태6/4/200732895VS.NET IDE: 47. Orcas - Web Browser Debugger를 이용한 보호 모드의 ActiveX 컨트롤 디버깅
499정성태6/3/200725457VS.NET IDE: 46. Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한파일 다운로드1
498정성태5/31/200719950Windows: 26. 스마트 카드 암호 바꾸는 방법.
497정성태5/31/200723398오류 유형: 36. SQL 2005 - DB 속성창 띄울 때 오류
496정성태5/29/200721372VS.NET IDE: 45. VS.NET 2005/Orcas 솔루션 파일과 UAC
495정성태5/28/200723776VS.NET IDE: 44. Orcas와 VS.NET 2005의 혼합 개발 [1]
494정성태5/26/200728071오류 유형: 35. 비스타 탐색기 - 특정 파일을 오른쪽 마우스 클릭했을 때, 비정상 종료되는 문제
493정성태5/26/200727099오류 유형: 34. Windows Server 2008 : CA 인증서 발급 실패
492정성태5/23/200726602.NET Framework: 89. ManagedThreadId - 두 번째 이야기 [5]파일 다운로드1
... 166  167  168  169  170  171  172  173  174  175  176  177  178  179  [180]  ...