Microsoft MVP성태의 닷넷 이야기
.NET Framework: 254. Roslyn 맛보기 - C# Interactive (2) [링크 복사], [링크+제목 복사],
조회: 30505
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 7개 있습니다.)

Roslyn 맛보기 - C# Interactive (2)


Roslyn 맛보기 (1) - C# 소스 코드를 스크립트 처럼 다루는 방법
Roslyn 맛보기 (2) - C# Interactive (1)
Roslyn 맛보기 (3) - C# Interactive (2)
Roslyn 맛보기 (4) - Roslyn Services APIs를 이용한 Code Issue 및 Code Action 기능 소개
Roslyn 맛보기 (5) - Syntax Analysis (Roslyn Syntax API)
Roslyn 맛보기 (6) - Roslyn Symbol / Binding API
Roslyn 맛보기 (7) - SyntaxTree 조작

지난번에 이어서,

Roslyn 맛보기 - C# Interactive (1)
; https://www.sysnet.pe.kr/2/0/1154

이번에는 몇 가지 유용한 팁을 주제별로 한번 알아볼까요? ^^


1. CSharpInteractive.rsp

처음 C# Interactive 창이 로드되면 다음과 같은 메시지를 볼 수 있습니다.

Microsoft (R) Roslyn C# Compiler version 1.0.11014.5
Loading context from 'CSharpInteractive.rsp'.
Type "#help" for more information.

또한 "#reset" 명령어를 내리면 세션을 초기화하는 것과 같은 역할을 하는데, 이 때에도 역시 다음과 같은 메시지를 볼 수 있습니다.

> #reset 
Resetting execution engine
Loading context from 'CSharpInteractive.rsp'.

해당 파일이 저장된 위치는 (현재 CTP 기준으로) 아래와 같고,

%PROGRAMFILES% (x86)\Microsoft Visual Studio 10.0\Common7\IDE\Extensions\Microsoft\Roslyn Interactive Window\1.0.11014.5\CSharpInteractive.rsp

기본적으로 파일 내용도 간단합니다.

===== CSharpInteractive.rsp ====
/r:System
/r:System.Core
/r:Microsoft.CSharp
/r:System.Data
/r:System.Data.DataSetExtensions
/r:System.Xml
/r:System.Xml.Linq
SeedUsings.csx

===== SeedUsings.csx ====
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

기타... 설명은 그다지 필요없겠지요. ^^ 참고로, WPF 응용 프로그램을 주로 만드는 분이라면 CSharpInteractive.rsp 파일에 다음의 참조를 추가해주는 것이 편리할 수 있습니다.

/r:System.Xaml
/r:WindowsBase
/r:PresentationCore
/r:PresentationFramework

또는, 필요할 때 마다 C# Interactive 창에서 다음과 같이 참조 추가를 할 수 있습니다.

#r "System.Xaml"
#r "WindowsBase"
#r "PresentationCore"
#r "PresentationFramework"


2. 현재 로딩 중인 프로젝트를 참조하는 방법

물론, C# Interactive 창을 부분적인 C# 코드의 실행 용도로 쓸 수 있겠지만 기왕이면 현재 Visual Studio에 로딩된 프로젝트를 대상으로 연동할 수 있으면 좋을 텐데요. "%PROGRAMFILES% (x86)\Microsoft Codename Roslyn CTP\Documentation\Interactive - Seeding the Interactive Window from a WPF Project.docx" 문서에 의하면, 예를 들어 현재 로딩된 프로젝트의 결과물이 WpfSeedRepl.exe인 경우 다음과 같이 참조하는 것이 가능하다는 식으로 설명되어 있습니다.

#r "WpfSeedRepl.exe"

아쉽게도 안 되더군요. ^^ 그 대신, 전체 파일 경로를 주어야만 했습니다.

#r "C:\...[생략]...\CSharp\WpfSeedRepl\bin\Debug\WpfSeedRepl.exe"

또는, csproj 파일이 있는 폴더 기준으로 '명시적인 상대경로'를 주면 로드가 됩니다.

#r ".\bin\Debug\WpfSeedRepl.exe"

이렇게 참조가 성공하면, 해당 프로젝트의 (public에 한해서) 모든 코드를 실행해 보는 것이 가능합니다. 일례로 WPF의 MainWindow를 띄우는 것도 가능한데요.

> var win = new WpfSeedRepl.MainWindow();
. win.Show();

그럼, 이렇게 WPF MainWindow 창을 띄운 상태에서 본래의 프로젝트가 '잠김'없이 빌드가 될까요? 다행이면서도/불행한 일이지만 정상적으로 빌드가 됩니다.

사실, Visual Studio에서 C# Interactive 창을 하나 띄울 때 마다 "%PROGRAMFILES% (x86)\Microsoft Visual Studio 10.0\Common7\IDE\Extensions\Microsoft\Roslyn Interactive Window\1.0.11014.5\InteractiveHost.exe" 프로세스가 실행되고 모든 명령어는 "InteractiveHost.exe"에서 실행이 됩니다. 이는 "#r" 명령어를 이용한 참조는 모두 "InteractiveHost.exe" 프로세스를 위한 것이라고 보면 되는데요.

참조하는 DLL/EXE들이 잠기지 않는다는 것은 해당 어셈블리를 별도로 복사해서 사용한다는 의미가 됩니다. 실제로 위의 WpfSeedRepl.exe 경우에 다음과 같은 경로로 복사되어 InteractiveHost.exe 프로세스에 로드된 것을 확인할 수 있었습니다.

"C:\Users\[사용자 계정]\AppData\Local\Temp\39d1ff4f-b6d7-41a7-b9cf-85d8ea943a62\WpfSeedRepl_9a83ba01-c1f8-4a8c-90b3-af87151f2c0c.exe"

나쁜 소식이라면... 새롭게 프로젝트를 빌드해도 InteractiveHost.exe에는 여전히 예전 WpfSeedRepl.exe 모듈이 참조되어 있어서 반영되지 않는다는 점입니다. 이 때문에, 변경된 프로젝트를 대상으로 코드를 실행하고 싶다면 다음과 같이 새롭게 로드하는 절차를 수행해야 합니다.

> #reset
Resetting execution engine
Loading context from 'CSharpInteractive.rsp'.
> #r ".\bin\Debug\WpfSeedRepl.exe"
> var win = new WpfSeedRepl.MainWindow();
. win.Show();

이쯤에서 다시 이전의 "CSharpInteractive.rsp" 주제로 넘어가 볼까요? 그 파일에서 "/r" 옵션으로 참조를 추가하면 혹시 Visual Studio가 무거워지지 않을까 하는 걱정으로 가능한 변경하지 않으려고 하시는 분들은 걱정 붙들어매시기 바랍니다. ^^ 무거워지는 것은 "InteractiveHost.exe"이기 때문에!


3. 자주 쓰는 명령어가 있다면?

load 명령어를 사용하면 파일로 저장된 일련의 명령어를 불러옴과 동시에 실행하는 것이 가능합니다. 문서에 보면, 단순하게 다음과 같이 로드를 시도하고 있는데요.

> #load "setup.csx"

실제로 실행하면, Visual Studio가 로딩한 프로젝트 파일이 있는 폴더 기준이 아닌 사용자 계정 폴더가 기준임을 알 수 있습니다.

> #load "setup.csx"
Specified file not found.
Searched in directory:
  C:\Users\[사용자 계정]

따라서 다음과 같이 절대 경로를 입력해 주거나,

> #load "C:\...\Microsoft Codename Roslyn CTP - October 2011\CSharp\WpfSeedRepl\setup.csx"

혹은, setup.csx 파일을 "C:\Users\[사용자 계정]" 폴더에 복사한 후 "#load setup.csx" 명령어를 내리는 식으로 해결할 수 있습니다.

어쨌든... '기준이 되는 폴더'가 #r 과 #load에 대해서 다르게 적용된다는 점은 다소 혼란스러운 점이군요.




이 정도의 내용이 "%PROGRAMFILES% (x86)\Microsoft Codename Roslyn CTP\Documentation\Interactive - Seeding the Interactive Window from a WPF Project.docx" 문서에서 얻을 수 있는 팁입니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 




... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...
NoWriterDateCnt.TitleFile(s)
12153정성태2/23/202024307.NET Framework: 898. Trampoline을 이용한 후킹의 한계파일 다운로드1
12152정성태2/23/202021339.NET Framework: 897. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 - 세 번째 이야기(Trampoline 후킹)파일 다운로드1
12151정성태2/22/202023986.NET Framework: 896. C# - Win32 API를 Trampoline 기법을 이용해 C# 메서드로 가로채는 방법 - 두 번째 이야기 (원본 함수 호출)파일 다운로드1
12150정성태2/21/202024078.NET Framework: 895. C# - Win32 API를 Trampoline 기법을 이용해 C# 메서드로 가로채는 방법 [1]파일 다운로드1
12149정성태2/20/202020977.NET Framework: 894. eBEST C# XingAPI 래퍼 - 연속 조회 처리 방법 [1]
12148정성태2/19/202025609디버깅 기술: 163. x64 환경에서 구현하는 다양한 Trampoline 기법 [1]
12147정성태2/19/202020964디버깅 기술: 162. x86/x64의 기계어 코드 최대 길이
12146정성태2/18/202022179.NET Framework: 893. eBEST C# XingAPI 래퍼 - 로그인 처리파일 다운로드1
12145정성태2/18/202023788.NET Framework: 892. eBEST C# XingAPI 래퍼 - Sqlite 지원 추가파일 다운로드1
12144정성태2/13/202023989.NET Framework: 891. 실행 시에 메서드 가로채기 - CLR Injection: Runtime Method Replacer 개선 - 두 번째 이야기파일 다운로드1
12143정성태2/13/202018392.NET Framework: 890. 상황별 GetFunctionPointer 반환값 정리 - x64파일 다운로드1
12142정성태2/12/202022301.NET Framework: 889. C# 코드로 접근하는 MethodDesc, MethodTable파일 다운로드1
12141정성태2/10/202021280.NET Framework: 888. C# - ASP.NET Core 웹 응용 프로그램의 출력 가로채기 [2]파일 다운로드1
12140정성태2/10/202022653.NET Framework: 887. C# - ASP.NET 웹 응용 프로그램의 출력 가로채기파일 다운로드1
12139정성태2/9/202022309.NET Framework: 886. C# - Console 응용 프로그램에서 UI 스레드 구현 방법
12138정성태2/9/202028560.NET Framework: 885. C# - 닷넷 응용 프로그램에서 SQLite 사용 [6]파일 다운로드1
12137정성태2/9/202020201오류 유형: 592. [AhnLab] 경고 - 디버거 실행을 탐지했습니다.
12136정성태2/6/202021862Windows: 168. Windows + S(또는 Q)로 뜨는 작업 표시줄의 검색 바가 동작하지 않는 경우
12135정성태2/6/202027654개발 환경 구성: 468. Nuget 패키지의 로컬 보관 폴더를 옮기는 방법 [2]
12134정성태2/5/202024920.NET Framework: 884. eBEST XingAPI의 C# 래퍼 버전 - XingAPINet Nuget 패키지 [5]파일 다운로드1
12133정성태2/5/202022670디버깅 기술: 161. Windbg 환경에서 확인해 본 .NET 메서드 JIT 컴파일 전과 후 - 두 번째 이야기
12132정성태1/28/202025706.NET Framework: 883. C#으로 구현하는 Win32 API 후킹(예: Sleep 호출 가로채기) [1]파일 다운로드1
12131정성태1/27/202024425개발 환경 구성: 467. LocaleEmulator를 이용해 유니코드를 지원하지 않는(한글이 깨지는) 프로그램을 실행하는 방법 [1]
12130정성태1/26/202022027VS.NET IDE: 142. Visual Studio에서 windbg의 "Open Executable..."처럼 EXE를 직접 열어 디버깅을 시작하는 방법
12129정성태1/26/202029002.NET Framework: 882. C# - 키움 Open API+ 사용 시 Registry 등록 없이 KHOpenAPI.ocx 사용하는 방법 [3]
12128정성태1/26/202023143오류 유형: 591. The code execution cannot proceed because mfc100.dll was not found. Reinstalling the program may fix this problem.
... 61  62  63  64  65  66  67  68  69  70  71  72  73  74  [75]  ...