/TuBes-IF2124-TBFO

Tugas Besar IF2124 Teori Bahasa Formal dan Otomata Compiler Bahasa JavaScript

Primary LanguagePython

TuBes-IF2124-TBFO

🐍 JavaScript Compiler with Python 🐍


Table of Contents

  1. General Info
  2. Member List
  3. Features
  4. Structure
  5. Contact

General Information

Dalam proses pembuatan program dari sebuah bahasa menjadi instruksi yang dapat dieksekusi oleh mesin, terdapat pemeriksaan sintaks bahasa atau parsing yang dibuat oleh programmer untuk memastikan program dapat dieksekusi tanpa menghasilkan error. Parsing ini bertujuan untuk memastikan instruksi yang dibuat oleh programmer mengikuti aturan yang sudah ditentukan oleh bahasa tersebut. Baik bahasa berjenis interpreter maupun compiler, keduanya pasti melakukan pemeriksaan sintaks. Perbedaannya terletak pada apa yang dilakukan setelah proses pemeriksaan (kompilasi/compile) tersebut selesai dilakukan. Dibutuhkan grammar bahasa dan algoritma parser untuk melakukan parsing. Sudah sangat banyak grammar dan algoritma yang dikembangkan untuk menghasilkan compiler dengan performa yang tinggi. Terdapat CFG, CNF-e, CNF+e, 2NF, 2LF, dll untuk grammar yang dapat digunakan, dan terdapat LL(0), LL(1), CYK, Earley’s Algorithm, LALR, GLR, Shift-reduce, SLR, LR(1), dll untuk algoritma yang dapat digunakan untuk melakukan parsing.

Member List

Nama NIM
M. Abdul Aziz Ghazali 13521128
M. Zaki Amanullah 13521146
M. Rifqi Farhansyah 13521166

Features

Pada tugas besar ini, telah diimplementasikan parser JavaScript (Node.js) untuk beberapa statement dan sintaks bawaan JavaScript. Konsep CFG (Context Free Grammar) digunakan untuk pengerjaan parser yang mengevaluasi syntax program. Sementara itu, nama variabel dan operasi (+, -, >, dll) dalam program, akan dievalusi menggunakan FA (Finite Automata).

Structure

β”‚   coba.js
β”‚   coba.py
β”‚   main.py
β”‚   parser_main.py
β”‚   README.md
β”‚
β”œβ”€β”€β”€.vscode
β”‚       tasks.json
β”‚
β”œβ”€β”€β”€CYK
β”‚   β”‚   cyk.py
β”‚   β”‚   __init__.py
β”‚   β”‚
β”‚   └───__pycache__
β”‚           cyk.cpython-310.pyc
β”‚           cyk.cpython-39.pyc
β”‚           __init__.cpython-310.pyc
β”‚           __init__.cpython-39.pyc
β”‚
β”œβ”€β”€β”€fileProcessing
β”‚   β”‚   file.txt
β”‚   β”‚   file_processing.py
β”‚   β”‚   token.py
β”‚   β”‚   __init__.py
β”‚   β”‚
β”‚   └───__pycache__
β”‚           token.cpython-310.pyc
β”‚           token.cpython-39.pyc
β”‚           __init__.cpython-310.pyc
β”‚           __init__.cpython-39.pyc
β”‚
β”œβ”€β”€β”€grammar
β”‚   β”‚   debug_grammar.txt
β”‚   β”‚   grammar.txt
β”‚   β”‚   grammar_convert.py
β”‚   β”‚   grammar_parser.py
β”‚   β”‚   __init__.py
β”‚   β”‚
β”‚   └───__pycache__
β”‚           grammar_convert.cpython-310.pyc
β”‚           grammar_convert.cpython-39.pyc
β”‚           grammar_parser.cpython-310.pyc
β”‚           grammar_parser.cpython-39.pyc
β”‚           __init__.cpython-310.pyc
β”‚           __init__.cpython-39.pyc
β”‚
β”œβ”€β”€β”€result
β”‚       tokenResult.txt
β”‚
β”œβ”€β”€β”€variable_fa
β”‚       variable_fa.py
β”‚
└───__pycache__
        CFGtoCNF.cpython-310.pyc
        CFGtoCNF.cpython-39.pyc

Contact

Created by JawaScript
2022