부모글 보이기/감추기 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 정성태 ... 181 182 183 184 185 186 [187] 188 189 190 191 192 193 194 195 ... NoWriterDateCnt.TitleFile(s) 312정성태8/5/200631328 디버깅 기술: 5.3. PDB 파일에 따른 Debug 정보 - .NET 2.0 Web Site Model 유형의 프로젝트313정성태8/12/200630480 디버깅 기술: 5.4. VS.NET 2005 디버그 모드에서의 PDB 파일 사용 차이 (1)317정성태8/12/200627876 디버깅 기술: 5.5. VS.NET 2005 디버그 모드에서의 PDB 파일 사용 차이 (2)318정성태8/12/200634308 디버깅 기술: 5.6. VS.NET 2005를 이용한 미니덤프 파일 분석 (1)319정성태8/12/200629468 디버깅 기술: 5.7. VS.NET 2005를 이용한 미니덤프 파일 분석 (2) [1]320정성태8/12/200633496 디버깅 기술: 5.8. WinDBG를 이용한 미니덤프 파일 분석 [1]321정성태8/13/200638136 디버깅 기술: 5.9. Microsoft의 PDB 파일 관리323정성태8/15/200639491 디버깅 기술: 5.10. Symbol Server 생성 [4]324정성태8/15/200636070 디버깅 기술: 5.11. PDB 파일과 소스 코드325정성태9/8/200628837 디버깅 기술: 5.12. CCP를 이용한 Windows Source Code 수준의 디버깅329정성태8/19/200627716 디버깅 기술: 5.13. 소스 서버 구성 [1]332정성태8/20/200629221 디버깅 기술: 5.14. GAC 에 등록된 Assembly 디버그 [2]341정성태9/16/200621587 디버깅 기술: 5.15. [내용 예약]342정성태9/16/200639182 디버깅 기술: 5.16. ASP.NET 디버깅 환경 구성 [1]1306정성태2/13/200718634기타: 15. .NET 이 생산성이 높다는 증거(!)304정성태7/21/200620746VS.NET IDE: 41. 하위 폴더의 모든 프로젝트의 출력물을 제거 (Clean)305정성태7/21/200620437 VS.NET IDE: 41.1. 하위 폴더의 모든 프로젝트의 출력물을 제거 (Clean) [1]303정성태7/20/200618395Team Foundation Server: 12. 사용자 계정 재생성에 따른 Version Control 영향302정성태8/21/200620131Team Foundation Server: 11. TFS Team Build와 VC++ Project 설정299정성태7/23/200620300개발 환경 구성: 5. VMWare - VM 생성 화면 캡쳐300정성태7/15/200624857 개발 환경 구성: 5.1. VMWare 오류 유형 - The handle is invalid.301정성태7/18/200619872 개발 환경 구성: 5.2. VMWare - 사용 후기.298정성태7/14/200620079개발 환경 구성: 4. VMWare Server를 64bit 운영체제에 설치 시 주의 사항 [2]296정성태7/10/200629403.NET Framework: 73. [ASP.NET] HTC(DHTML Control Behavior)를 WebResource.axd로 제공하는 방법 [3]295정성태7/1/200622653VC++: 25. Microsoft National Language Support Downlevel APIs 1.0 사용 방법1294정성태6/30/200619225.NET Framework: 72. XSDObjectGen.EXE 기능 개선 ... 181 182 183 184 185 186 [187] 188 189 190 191 192 193 194 195 ...