부모글 보이기/감추기 AD BLOCK 해제 요청 이 글에는 광고가 많이 들어가 있지 않습니다. adblock을 해제하셔도 글을 읽는데 그다지 부담이 없으니 해제를 부탁드립니다. (연관된 글이 1개 있습니다.) (2021-06-27 업데이트) .NET Core 2.2.2 SDK부터 함께 배포되는 Roslyn 컴파일러에는 이제 더 이상 csc.exe가 제공되지 않으며 csc.dll로만 존재해 직접적으로 수행할 수 없게 되었습니다. .NET Core 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 (4.x 기준의) .NET Framework이 설치된 경우에는 다음의 경로에, 32비트: C:\Windows\Microsoft.NET\Framework\v4.0.30319 64비트: C:\Windows\Microsoft.NET\Framework64\v4.0.30319 고정적으로 csc.exe가 있어 다음과 같이 쉽게(?) 빌드할 수 있었습니다. c:\temp> "C:\Windows\Microsoft.NET\Framework\v4.0.30319\csc" program.cs 그런데, 닷넷 코어 환경에서는 경로가 잘 알려진 "dotnet.exe"가 기본적으로 프로젝트 기반으로 빌드를 담당하면서 내부적으로는 csc.exe가 감춰져 있는 형태입니다. 따라서 개별 파일로 빌드하려면 직접 csc.exe를 찾아내야 하는데요. 이럴 때 where.exe를 이용해 다음과 같이 csc.exe가 있는 폴더로 이동할 수 있습니다. C:\temp> where dotnet C:\Program Files\dotnet\dotnet.exe C:\Program Files (x86)\dotnet\dotnet.exe C:\temp> cd "C:\Program Files\dotnet\sdk\3.0.100\Roslyn\bincore" C:\Program Files\dotnet\sdk\3.0.100\Roslyn\bincore> csc Microsoft (R) Visual C# Compiler version 3.3.1-beta3-19461-02 (2fd12c21) Copyright (C) Microsoft Corporation. All rights reserved. warning CS2008: No source files specified. error CS1562: Outputs without source must have the /out option specified 역시나, 저렇게 Roslyn 폴더를 찾아가기보다는... "dotnet build"가 더 선호될 수밖에 없겠습니다. ^^ [이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.] [다음 글] 개발 환경 구성: 461. C# 8.0의 #nulable 관련 특성을 .NET Framework 프로젝트에서 사용하는 방법[이전 글] 개발 환경 구성: 459. .NET Framework 프로젝트에서 C# 8.0/9.0 컴파일러를 사용하는 방법 [연관 글] .NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [최초 등록일: 10/12/2019] [최종 수정일: 7/7/2023] 이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다. by SeongTae Jeong, mailto:techsharer at outlook.com 비밀번호 댓글 작성자 2019-10-12 11시19분 Is it possible to compile a single C# code file with the .NET Core Roslyn compiler?; https://stackoverflow.com/questions/46065777/is-it-possible-to-compile-a-single-c-sharp-code-file-with-the-net-core-roslyn-c 정성태 ... 106 [107] 108 109 110 111 112 113 114 115 116 117 118 119 120 ... NoWriterDateCnt.TitleFile(s) 11282정성태8/26/201720398Math: 22. 행렬로 바라보는 피보나치 수열11281정성태8/26/201722586.NET Framework: 677. Visual Studio 2017 - NuGet 패키지를 직접 참조하는 PackageReference 지원 [2]11280정성태8/24/201720068디버깅 기술: 94. windbg - 풀 덤프에 포함된 모든 모듈을 파일로 저장하는 방법11279정성태8/23/201731395.NET Framework: 676. C# Thread가 Running 상태인지 아는 방법11278정성태8/23/201719834오류 유형: 417. TFS - Warning - Unable to refresh ... because you have a pending edit. [1]11277정성태8/23/201720993오류 유형: 416. msbuild - error MSB4062: The "TransformXml" task could not be loaded from the assembly11276정성태8/23/201724842.NET Framework: 675. C# - (파일) 확장자와 연결된 실행 파일 경로 찾기 [2]111275정성태8/23/201734201개발 환경 구성: 323. Visual Studio 설치 없이 빌드 환경 구성 - Visual Studio 2017용 Build Tools [1]11274정성태8/22/201720853.NET Framework: 674. Thread 타입의 Suspend/Resume/Join 사용 관련 예외 처리11273정성태8/22/201722319오류 유형: 415. 윈도우 업데이트 에러 Error 0x8007064311272정성태8/21/201726163VS.NET IDE: 120. 비주얼 스튜디오 2017 버전 15.3.1 - C# 7.1 공개 [2]11271정성태8/19/201720099VS.NET IDE: 119. Visual Studio 2017에서 .NET Core 2.0 프로젝트 환경 구성하는 방법11270정성태8/17/201732287.NET Framework: 673. C#에서 enum을 boxing 없이 int로 변환하기 [2]11269정성태8/17/201722390디버깅 기술: 93. windbg - 풀 덤프에서 .NET 스레드의 상태를 알아내는 방법11268정성태8/14/201722448디버깅 기술: 92. windbg - C# Monitor Lock을 획득하고 있는 스레드 찾는 방법11267정성태8/10/201726109.NET Framework: 672. 모노 개발 환경11266정성태8/10/201726252.NET Framework: 671. C# 6.0 이상의 소스 코드를 Visual Studio 설치 없이 명령행에서 컴파일하는 방법11265정성태8/10/201754160기타: 66. 도서: 시작하세요! C# 7.1 프로그래밍: 기본 문법부터 실전 예제까지 [11]11264정성태8/9/201725551오류 유형: 414. UWP app을 signtool.exe로 서명 시 0x8007000b 오류 발생11263정성태8/9/201720881오류 유형: 413. The C# project "..." is targeting ".NETFramework, Version=v4.0", which is not installed on this machine. [3]11262정성태8/5/201719450오류 유형: 412. windbg - SOS does not support the current target architecture. [3]11261정성태8/4/201721888디버깅 기술: 91. windbg - 풀 덤프 파일로부터 강력한 이름의 어셈블리 추출 후 사용하는 방법11260정성태8/3/201720384.NET Framework: 670. C# - 실행 파일로부터 공개키를 추출하는 방법11259정성태8/2/201718932.NET Framework: 669. 지연 서명된 어셈블리를 sn.exe -Vr 등록 없이 사용하는 방법11258정성태8/1/201720255.NET Framework: 668. 지연 서명된 DLL과 서명된 DLL의 차이점111257정성태7/31/201719880.NET Framework: 667. bypassTrustedAppStrongNames 옵션 설명1 ... 106 [107] 108 109 110 111 112 113 114 115 116 117 118 119 120 ...