Microsoft MVP성태의 닷넷 이야기
.NET Framework: 551. 인터프리터 어휘 분석 프로그램 - C# 예제 [링크 복사], [링크+제목 복사],
조회: 21576
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

인터프리터 어휘 분석 프로그램 - C# 예제

요즘 이런 ^^ 책을 읽고 있습니다.

만들면서 배우는 인터프리터: 컴파일러 이론으로 만드는 나만의 스크립트 언어 
; http://www.yes24.com/24/goods/7858784?scode=032

책도 얇고 전반적인 개념과 함께 코드를 부분적으로 곁들여 설명하고 있기 때문에 한번쯤 편안하게 읽어보시는 것도 좋을 것 같습니다.

당연히 코드를 입력해가면서 실습도 병행하고 있는데요. C++로 하지 않고 C#으로 실습을 하고 있기 때문에 변환해 둔 것을 공유하는 것이 좋겠다 싶어 제 블로그에 올려둘 예정입니다.

전체적으로 보니까, 동작하는 소스코드가 중간에 3개 정도 있고 마지막에 전체 소스 코드를 실어놓은 형식이라서 아마 앞으로도 3번 정도는 올리게 될 것 같습니다. 혹시나 C#으로 간단한 인터프리터 공부하실 분들이라면 위의 책을 구매하시고 제 소스 코드를 함께 보시면 도움이 되실 듯 합니다.

오늘은 그 첫번째로 "3.6.5 어휘 분석 프로그램"의 67페이지에 포함된 token_p.cpp 파일을 C# 버전으로 작성한 것을 공유합니다. ^^

실행하면 다음의 입력을,

if dt<=100
    dt = (a+200) * b
else
    dt=300
end

print "dt=", dt

파싱해서 다음과 같은 출력 결과를 얻습니다.

          if           16 = If                    0
          dt           20 = Ident                 0
          <=           13 = LessEq                0
                       21 = IntNum              100
          dt           20 = Ident                 0
           =            7 = Assign                0
           (            1 = Lparen                0
           a           20 = Ident                 0
           +            3 = Plus                  0
                       21 = IntNum              200
           )            2 = Rparen                0
           *            5 = Multi                 0
           b           20 = Ident                 0
        else           17 = Else                  0
          dt           20 = Ident                 0
           =            7 = Assign                0
                       21 = IntNum              300
         end           18 = End                   0
       print           19 = Print                 0
         dt=           22 = String                0
           ,            8 = Comma                 0
          dt           20 = Ident                 0
                       25 = EofToken              0

(첨부한 파일은 소스 코드입니다.)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/23/2016]

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

비밀번호

댓글 작성자
 




1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13854정성태12/27/20245873C/C++: 186. Golang - 콘솔 응용 프로그램을 NT 서비스를 지원하도록 변경파일 다운로드1
13853정성태12/26/20244814디버깅 기술: 213. Windbg - swapgs 명령어와 (Ring 0 커널 모드의) FS, GS Segment 레지스터
13852정성태12/25/20245903디버깅 기술: 212. Windbg - (Ring 3 사용자 모드의) FS, GS Segment 레지스터파일 다운로드1
13851정성태12/23/20245100디버깅 기술: 211. Windbg - 커널 모드 디버깅 상태에서 사용자 프로그램을 디버깅하는 방법
13850정성태12/23/20246224오류 유형: 940. "Application Information" 서비스를 중지한 경우, "This file does not have an app associated with it for performing this action."
13849정성태12/20/20246201디버깅 기술: 210. Windbg - 논리(가상) 주소를 Segmentation을 거쳐 선형 주소로 변경
13848정성태12/18/20245691디버깅 기술: 209. Windbg로 알아보는 Prototype PTE파일 다운로드2
13847정성태12/18/20245762오류 유형: 939. golang - 빌드 시 "unknown directive: toolchain" 오류 빌드 시 이런 오류가 발생한다면?
13846정성태12/17/20246320디버깅 기술: 208. Windbg로 알아보는 Trans/Soft PTE와 2가지 Page Fault 유형파일 다운로드1
13845정성태12/16/20245175디버깅 기술: 207. Windbg로 알아보는 PTE (_MMPTE)
13844정성태12/14/20246679디버깅 기술: 206. Windbg로 알아보는 PFN (_MMPFN)파일 다운로드1
13843정성태12/13/20245197오류 유형: 938. Docker container 내에서 빌드 시 error MSB3021: Unable to copy file "..." to "...". Access to the path '...' is denied.
13842정성태12/12/20245388디버깅 기술: 205. Windbg - KPCR, KPRCB
13841정성태12/11/20246026오류 유형: 937. error MSB4044: The "ValidateValidArchitecture" task was not given a value for the required parameter "RemoteTarget"
13840정성태12/11/20245276오류 유형: 936. msbuild - Your project file doesn't list 'win' as a "RuntimeIdentifier"
13839정성태12/11/20246239오류 유형: 936. msbuild - error CS1617: Invalid option '12.0' for /langversion. Use '/langversion:?' to list supported values.
13838정성태12/4/20245968오류 유형: 935. Windbg - Breakpoint 0's offset expression evaluation failed.
13837정성태12/3/20246754디버깅 기술: 204. Windbg - 윈도우 핸들 테이블 (3) - Windows 10 이상인 경우
13836정성태12/3/20245312디버깅 기술: 203. Windbg - x64 가상 주소를 물리 주소로 변환 (페이지 크기가 2MB인 경우)
13835정성태12/2/20246732오류 유형: 934. Azure - rm: cannot remove '...': Directory not empty
13834정성태11/29/20246718Windows: 275. C# - CUI 애플리케이션과 Console 윈도우 (Windows 10 미만의 Classic Console 모드인 경우) [1]파일 다운로드1
13833정성태11/29/20246088개발 환경 구성: 737. Azure Web App에서 Scale-out으로 늘어난 리눅스 인스턴스에 SSH 접속하는 방법
13832정성태11/27/20245724Windows: 274. Windows 7부터 도입한 conhost.exe
13831정성태11/27/20245070Linux: 111. eBPF - BPF_MAP_TYPE_PERF_EVENT_ARRAY, BPF_MAP_TYPE_RINGBUF에 대한 다양한 용어들
13830정성태11/25/20246570개발 환경 구성: 736. 파이썬 웹 앱을 Azure App Service에 배포하기
13829정성태11/25/20246698스크립트: 67. 파이썬 - Windows 버전에서 함께 설치되는 py.exe
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...