Microsoft MVP성태의 닷넷 이야기
.NET Framework: 2098. dotnet build에 /p 옵션을 적용 시 유의점 [링크 복사], [링크+제목 복사],
조회: 12373
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

dotnet build에 /p 옵션을 적용 시 유의점

csproj를 보면 "PropertyGroup"의 자식으로 다양한 Property를 정의할 수 있는데요,

<Project Sdk="Microsoft.NET.Sdk">

  <PropertyGroup>
    <OutputType>Exe</OutputType>
    <TargetFramework>net7.0</TargetFramework>
    <ImplicitUsings>enable</ImplicitUsings>
    <Nullable>enable</Nullable>
      
  </PropertyGroup>

</Project>

이런 옵션들을 "dotnet build" 명령행에서 "/p" 인자를 이용해 직접 제어하는 것이 가능합니다. 예를 들어, 다음과 같이 코딩한 경우,

class Program
{
    static unsafe void Main(string[] args)
    {
        int n = 5;
        int* p = &n;

        Console.WriteLine(*p);
    }
}

기본 csproj 상태로는 "error CS0227: Unsafe code may only appear if compiling with /unsafe" 컴파일 오류가 발생하지만, csproj에 이렇게 AllowUnsafeBlocks 옵션을 설정하거나,

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        ...[생략]...

        <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
    </PropertyGroup>

</Project>

dotnet build의 경우 동일한 이름의 옵션을 다음과 같이 /p로 연결해서 빌드하면 정상적으로 실행됩니다.

c:\temp\ConsoleApp1\ConsoleApp1> dotnet build /p:AllowUnsafeBlocks=true

c:\temp\ConsoleApp1\ConsoleApp1> dotnet run
5




위에서 설명한 옵션 같은 경우에는, 그 옵션이 적용되지 않으면 컴파일 오류가 발생하기 때문에 적용 여부를 바로 알아챌 수 있는데요, 그렇지 않은 경우, 가령 CheckForOverflowUnderflow 옵션 등은 dotnet build 시 주의해야 합니다.

역시 간단하게 예를 들어볼까요? ^^

short c = -32768;
c--;
Console.WriteLine(c); // 32767

csproj에 CheckForOverflowUnderflow 옵션을 주고 위의 소스 코드를 빌드하면,

<Project Sdk="Microsoft.NET.Sdk">

    <PropertyGroup>
        ...[생략]...

        <CheckForOverflowUnderflow>true</CheckForOverflowUnderflow>
    </PropertyGroup>

</Project>

실행 시 overflow 예외가 발생합니다.

Unhandled exception. System.OverflowException: Arithmetic operation resulted in an overflow.
   at Program.<Main>$(String[] args) in C:\Users\SeongTae Jeong\Dropbox\articles\checked_dotnet_build\ConsoleApp1\ConsoleApp1\Program.cs:line 2

그런데, 이 과정을 (csproj의 CheckForOverflowUnderflow 옵션을 삭제하고) dotnet build로 바꿔보면 어떻게 될까요?

c:\temp\ConsoleApp1\ConsoleApp1> dotnet build
c:\temp\ConsoleApp1\ConsoleApp1> dotnet run
32767

일단 정상적으로 나왔습니다. 그런데, 위의 빌드에 이어서 /p 옵션을 주고 빌드하면,

c:\temp\ConsoleApp1\ConsoleApp1> dotnet build /p:CheckForOverflowUnderflow=true
c:\temp\ConsoleApp1\ConsoleApp1> dotnet run
32767

마치 옵션 값을 무시하는 듯, overflow 예외가 발생하지 않습니다. 이유는 간단합니다. 소스 코드 또는 csproj의 내용이 바뀌어야 재빌드를 하는데, 단순히 명령행 옵션만 바뀌었기 때문에 재빌드를 안 한 것입니다.

재미있는 건, .\bin\Debug\net7.0 디렉터리의 내용을 모두 삭제하고 다시 "dotnet build ..."를 해도 새롭게 빌드하지 않고 .\obj\Debug\net7.0 디렉터리에 빌드돼 있던 바이너리를 복사해 온다는 점입니다.

따라서, /p 옵션을 변경해 다시 빌드해야 한다면 \.obj\Debug\net7.0 디렉터리의 내용을 삭제하든가, 아니면 "dotnet clean" 명령어를 먼저 실행하고 진행해야 합니다.





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

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/29/2023]

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

비밀번호

댓글 작성자
 




... 121  122  123  124  [125]  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10833정성태8/18/201527024.NET Framework: 525. C# - 닷넷에서 프로세스가 열고 있는 파일 목록을 구하는 방법파일 다운로드1
10832정성태8/17/201531173디버깅 기술: 74. x64 콜 스택 인자 추적과 windbg의 Child-SP, RetAddr, Args to Child 값 확인 [8]파일 다운로드2
10831정성태8/13/201531715.NET Framework: 524. .NET 4.0과 .NET 4.5의 컴파일 결과 차이점 [1]파일 다운로드1
10830정성태8/12/201525593개발 환경 구성: 275. Web.config이 적용되지 않는 프로젝트에서 Razor 템플릿 파일의 C# 컴파일러 버전 제어 [1]
10829정성태8/10/201527764개발 환경 구성: 274. PowerShell/명령행에서 JDK/JRE를 무인(unattended)/자동 설치를 하는 방법 [3]
10828정성태8/10/201533263웹: 30. Edge 브라우저에서 "이 웹 사이트에는 Internet Explorer가 필요함" 단계를 없애는 방법 [1]
10827정성태7/8/201534065개발 환경 구성: 273. Visual Studio 2015에서 Github와 연동하는 방법 [3]
10826정성태7/8/201524467오류 유형: 301. The trust relationship between this workstation and the primary domain failed. - 두 번째 이야기
10825정성태7/8/201523054개발 환경 구성: 272. Visual Studio IDE 설치 없이 Visual Studio SDK 설치하는 방법
10824정성태7/7/201528694개발 환경 구성: 271. Team Foundation Server 2015 설치 방법 [1]
10823정성태7/7/201529642오류 유형: 300. SqlException (0x80131904): Unable to open the physical file
10822정성태7/7/201528360오류 유형: 299. The 'Visual C++ Project System Package' package did not load correctly.
10821정성태7/7/201521534오류 유형: 298. Unable to start debugging on the web server. IIS does not list a web site that matches the launched URL.
10820정성태7/7/201527146오류 유형: 297. HTTP Error 503. The service is unavailable. - 두 번째
10819정성태7/2/201530314오류 유형: 296. SQL Server Express 시작 오류 - error code 3417
10818정성태7/1/201529458오류 유형: 295. HTTP Error 503. The service is unavailable. [1]
10817정성태6/29/201533570.NET Framework: 523. C# 람다(Lambda)에서 변수 캡처 방식 [3]
10816정성태6/25/201529259.NET Framework: 522. 닷넷의 어셈블리 서명 데이터 확인 방법파일 다운로드1
10815정성태6/23/201527669Graphics: 1. 자네 나와 함께... UNITY 하지 않겠는가! [4]
10814정성태6/22/201525297.NET Framework: 521. Roslyn을 이용해 C# 문법 변형하기 (2) [5]
10813정성태6/21/201526449.NET Framework: 520. Roslyn을 이용해 C# 문법 변형하기 (1)
10812정성태6/20/201527351.NET Framework: 519. C# 6.0 오픈 소스 컴파일러 Roslyn - 빌드 및 테스트 방법 [1]
10811정성태6/20/201524487오류 유형: 294. OpenAuth 사용 시 System.Data.SqlClient.SqlException 예외가 Output 창에 출력되는 문제
10810정성태6/18/201524141개발 환경 구성: 270. Visual Studio에서 github 오픈 소스를 fork해서 테스트하는 방법 [1]
10809정성태6/18/201521598.NET Framework: 518. AllowPartiallyTrustedCallers 특성이 적용된 GAC 어셈블리에서 DynamicMethod의 calli 명령어 사용파일 다운로드1
10808정성태6/17/201523606.NET Framework: 517. calli IL 호출이 DllImport 호출보다 빠를까요? [1]파일 다운로드1
... 121  122  123  124  [125]  126  127  128  129  130  131  132  133  134  135  ...