Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 102. MSBuild - DefineConstants에 다중 전처리 값 설정 [링크 복사], [링크+제목 복사],
조회: 27770
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...
NoWriterDateCnt.TitleFile(s)
1663정성태4/28/201420027오류 유형: 226. Visual Studio - We were unable to establish the connection because it is configured for user
1662정성태4/28/201424624개발 환경 구성: 220. supportedRuntime 설정을 위한 app.config Transformation [1]
1661정성태4/26/201421143.NET Framework: 432. WPF - System.Windows.Data Error: 47 : XmlDataProvider has inline XML that does not explicitly set its XmlNamespace (xmlns="").
1660정성태4/25/201429048VC++: 77. C++ 숫자형 값이 범위를 벗어나는 경우의 출력 사례 모음
1659정성태4/17/201429152.NET Framework: 431. .NET EXE 파일을 닷넷 프레임워크 버전에 상관없이 실행할 수 있을까요? [5]
1658정성태4/17/201420992.NET Framework: 430. C#에서 사용자 정의 예약어가 가능할까요? [1]
1657정성태4/10/201441308.NET Framework: 429. C# - 유니코드 한글 문자열을 ks_c_5601-1987로 변환하는 방법 [3]파일 다운로드1
1656정성태3/19/201424470오류 유형: 225. regsvcs 등록 시 0x80040153 오류
1655정성태3/19/201424604Windows: 92. Thumbs.db 파일이 삭제 안 되는 문제
1654정성태3/19/201426669개발 환경 구성: 219. SOS.dll 확장 모듈을 버전 별로 구하는 방법 [4]
1653정성태3/13/201421385.NET Framework: 428. .NET Reflection으로 다차원/Jagged 배열을 구분하는 방법
1652정성태3/12/201422276VC++: 76. Direct Show를 사용하는 다른 프로그램의 필터 그래프를 graphedt.exe에서 확인하는 방법파일 다운로드1
1651정성태3/11/201426170.NET Framework: 427. C# 컴파일러는 변수를 초기화시키지 않을까요?
1650정성태3/6/201427083VC++: 75. Visual C++ 컴파일 오류 - Cannot use __try in functions that require object unwinding [1]파일 다운로드1
1649정성태3/5/201421559기타: 44. BTN 스토어 앱 개인정보 보호 정책 안내
1648정성태3/5/201421956개발 환경 구성: 218. 스토어 앱 인증 실패 - no privacy statement
1647정성태3/3/201423281오류 유형: 224. 스카이드라이브 비정상 종료 - Error 0x80040A41: No error description available
1646정성태3/3/201432593오류 유형: 223. Microsoft-Windows-DistributedCOM 10016 이벤트 로그 에러 [1]
1645정성태3/1/201422329기타: 43. 마이크로소프트 MVP들이 모여 전국 세미나를 엽니다.
1644정성태2/26/201429376.NET Framework: 426. m3u8 스트리밍 파일을 윈도우 8.1 Store App에서 재생하는 방법파일 다운로드1
1643정성태2/25/201425154오류 유형: 222. 윈도우 8 Store App - APPX1204 SignTool Error: An unexpected internal error has occurred [1]
1642정성태2/25/201429830Windows: 91. 한글이 포함된 사용자 프로파일 경로 변경 [2]
1641정성태2/24/201426480기타: 42. 클래스 설명 [5]
1640정성태2/24/201447539.NET Framework: 425. C# - VLC(ActiveX) 컨트롤을 레지스트리 등록 없이 사용하는 방법 [15]
1639정성태2/23/201423257기타: 41. BBS 스토어 앱 개인정보 보호 정책 안내
1638정성태2/18/201446054Windows: 90. 실행 파일로부터 관리자 요구 권한을 제거하는 방법(부제: 크랙 버전을 보다 안전하게 실행하는 방법) [8]
... 136  [137]  138  139  140  141  142  143  144  145  146  147  148  149  150  ...