BRONZE
BRONZE 등급의 판매자 자료

[컴파일러]A+받은 컴퓨터 컴파일러 프로젝트 프로그램

컴파일러 수업시간에 구현했던 프로그램입니다. 실제로 잘 구동되구요~ 성적도 좋았던 프로그램입니다. 소스뿐만 아니라 컴파일 되어 있는 상태 그대로 압축해서 올렸습니다. 개발은 Visual C++을 사용했습니다. 자세한 요구사항과 설명은 내부의 문서를 참고하세요. ----------------------------------------------------------------- 이 프로젝트는 scanner와 parser를 구현하는 프로그램. Scanner는 lexical analysis를 담당하는 부분으로 Finite State Automata를 만든 후 구현하며, syntax analysis를 담당하는 parser의 부분은 Push Down Automata의 형태를 취하여 구현하게 됩니다. Parser 구현을 위한 Syntax는 아래에 주어진 문법을 사용하게 되는 데, scanner 에서는 action table을 parser에서는 parsing table을 통한 automata 를 구현하기를 권장합니다. 그러나, 불가피한 경우에 한해 recursive predictive parser로 구현할 수 도 있습니다. 이를 위한 input, output의 형태와 구현을 위한 처리 조건은 아래와 같습니다. ▶ 입력 ☆ 표 1에 주어진 문법에 맞게 작성된 program file로 file 이름은 사용자가 다음과 같은 요령으로 입력하기로 한다. 즉 여러분이 만든 compiler를 구동하기 위해서는 CP2005-학번 (예를 들면, CP200123456 testfile) 를 입력하도록 한다. ▶ 출력 ☆ 표 2에 주어진 instruction set을 이용한 목적 code file로, file 이름은 입력 file의 이름에 code 라는 extension을 붙인다. 예를 들면, 상기한 입력의 file의 출력 file 이름은 testfile.code 가 된다. ☆ 출력 file은 아래 출력의 예에서 보여주는 바와 같이 표 2 에서의 목적 코드와 사용된 register의 수를 명시해야 합니다. ▶ 처리 조건 ☆ 주어진 Grammar는 필요에 따라 변환 할 수 있다. 단 그 내용에 있어서(syntax and semantics) 동등해야 한다. ☆ 목적 code는 표 2 에 주어진 명령어(instruction)들 만을 사용해야 합니다. 부득이한 경우 새로운 명령어를 사용할 때는 documentation에 명확하게 명시해야 합니다. ☆ variable들은 target program 의 첫머리에 그 변수들이 저장될 data section을 설정하고, 각각의 위치를 16진법의 absolute address로 나타냅니다. 즉, 이 address는 0xa000으로부터 시작하되, 모든 integer variable들은 word boundary(multiple of 4)에서 시작하는 것으로 합니다. ☆ 비교값의 결과는 condition code register인 Reg1 에 그리고 return 되는 value 는 return register인 Reg0 에 저장됩니다. 따라서 이 Register들은 다른 용도에 사용되지 않아야 합니다. ☆ Register는 충분히 많다고 가정하나 될 수 있으면 적은 숫자의 register를 사용하도록 하고 사용된 register의 개수를 code의 마지막 줄에 출력하도록 합니다.
3 페이지
압축파일
최초등록일 2005.12.27 최종저작일 2005.12
[컴파일러]A+받은 컴퓨터 컴파일러 프로젝트 프로그램
  • 미리보기

    소개

    컴파일러 수업시간에 구현했던 프로그램입니다.
    실제로 잘 구동되구요~ 성적도 좋았던 프로그램입니다.
    소스뿐만 아니라 컴파일 되어 있는 상태 그대로 압축해서 올렸습니다.

    개발은 Visual C++을 사용했습니다.

    자세한 요구사항과 설명은 내부의 문서를 참고하세요.
    -----------------------------------------------------------------
    이 프로젝트는 scanner와 parser를 구현하는 프로그램.
    Scanner는 lexical analysis를 담당하는 부분으로 Finite State Automata를 만든 후 구현하며, syntax analysis를 담당하는 parser의 부분은 Push Down Automata의 형태를 취하여 구현하게 됩니다. Parser 구현을 위한 Syntax는 아래에 주어진 문법을 사용하게 되는 데, scanner 에서는 action table을 parser에서는 parsing table을 통한 automata 를 구현하기를 권장합니다. 그러나, 불가피한 경우에 한해 recursive predictive parser로 구현할 수 도 있습니다. 이를 위한 input, output의 형태와 구현을 위한 처리 조건은 아래와 같습니다.

    ▶ 입력
    ☆ 표 1에 주어진 문법에 맞게 작성된 program file로 file 이름은 사용자가 다음과 같은 요령으로 입력하기로 한다. 즉 여러분이 만든 compiler를 구동하기 위해서는 CP2005-학번 (예를 들면, CP200123456 testfile) 를 입력하도록 한다.

    ▶ 출력
    ☆ 표 2에 주어진 instruction set을 이용한 목적 code file로, file 이름은 입력 file의 이름에 code 라는 extension을 붙인다. 예를 들면, 상기한 입력의 file의 출력 file 이름은 testfile.code 가 된다.
    ☆ 출력 file은 아래 출력의 예에서 보여주는 바와 같이 표 2 에서의 목적 코드와 사용된 register의 수를 명시해야 합니다.

    ▶ 처리 조건
    ☆ 주어진 Grammar는 필요에 따라 변환 할 수 있다. 단 그 내용에 있어서(syntax and semantics) 동등해야 한다.
    ☆ 목적 code는 표 2 에 주어진 명령어(instruction)들 만을 사용해야 합니다. 부득이한 경우 새로운 명령어를 사용할 때는 documentation에 명확하게 명시해야 합니다.
    ☆ variable들은 target program 의 첫머리에 그 변수들이 저장될 data section을 설정하고, 각각의 위치를 16진법의 absolute address로 나타냅니다. 즉, 이 address는 0xa000으로부터 시작하되, 모든 integer variable들은 word boundary(multiple of 4)에서 시작하는 것으로 합니다.
    ☆ 비교값의 결과는 condition code register인 Reg1 에 그리고 return 되는 value 는 return register인 Reg0 에 저장됩니다. 따라서 이 Register들은 다른 용도에 사용되지 않아야 합니다.
    ☆ Register는 충분히 많다고 가정하나 될 수 있으면 적은 숫자의 register를 사용하도록 하고 사용된 register의 개수를 code의 마지막 줄에 출력하도록 합니다.

    컴파일 실행환경

    비주얼 C++을 사용해서 컴파일 하면됩니다.
    project.c
    parser.c
    parser.h
    로 구성되어 있습니다.
    -실행-
    CP2005 <sorce file>

    결과
    sourcefile.str
    sourcefile.code
    가 생성됩니다.

    본문내용

    #include <stdio.h>

    #define MAXLENGTH 512
    #define CHARLENGTH 20
    #define STARTADDRESS 0xa000

    #define ISOPERATOR 1
    #define ISDIVISOR 2
    #define ISSEP 3
    #define STACKMAX 255
    #define VARMAX 50 //the number of variables


    #define INT 4
    #define CHAR 1

    typedef struct
    {
    char vname[CHARLENGTH];
    int address;
    }VARIABLES;

    typedef struct
    {
    int regnum;
    int value;
    }REGISTER;

    enum{STATE_START,STATE_DECL,STATE_STAT,STATE_EXPR,STATE_COND,STATE_FINAL}; //States


    extern char wordtbl[MAXLENGTH][CHARLENGTH];
    extern int numtbl[MAXLENGTH];
    extern int wordcnt;
    extern int numcnt;

    extern char funcname[CHARLENGTH];
    extern VARIABLES var[VARMAX];
    extern int varcnt;

    int Push(char **str);
    char* Pop();
    void Viewstack();

    void Scanner(FILE *src,FILE *des);
    int CheckToken(char *str); //Check str is token or not
    int ApplyStr(char *str,FILE *fp); //Check str is keyword or number or word, and print to file
    void Parser(FILE *src,FILE *des);
    void Error(char *str);
    void Scantype(char *buffer,REGISTER *reg,FILE *des);
    int Stateprocess(FILE *src,FILE *des,int curstate);

    참고자료

    · 없음
  • 자료후기

      Ai 리뷰
      지식판매자가 등록한 자료는 과제에 직접 활용할 수 있는 유용한 내용이 많아, 큰 도움이 되었습니다. 앞으로도 계속 좋은 자료 부탁드립니다! 감사합니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우

    함께 구매한 자료도 확인해 보세요!

    찾으시던 자료가 아닌가요?

    지금 보는 자료와 연관되어 있어요!
    왼쪽 화살표
    오른쪽 화살표
    문서 초안을 생성해주는 EasyAI
    안녕하세요. 해피캠퍼스의 방대한 자료 중에서 선별하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 목차부터 본문내용까지 자동 생성해 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 캐시를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 07월 17일 목요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    10:05 오전