Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alaazameldev/flutter-to-html-and-js-transpiler
Experimental transpiler for "Flutter-like" code to HTML & JS. Built with ANTLR, focusing on lexer, parser, AST generation, and error handling.
https://github.com/alaazameldev/flutter-to-html-and-js-transpiler
antlr4 composite-pattern flutter html java javascript lexer parser visitor-pattern
Last synced: about 1 month ago
JSON representation
Experimental transpiler for "Flutter-like" code to HTML & JS. Built with ANTLR, focusing on lexer, parser, AST generation, and error handling.
- Host: GitHub
- URL: https://github.com/alaazameldev/flutter-to-html-and-js-transpiler
- Owner: alaazamelDev
- License: mit
- Created: 2024-08-16T07:26:19.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-08-16T12:27:45.000Z (5 months ago)
- Last Synced: 2024-08-20T14:26:01.950Z (5 months ago)
- Topics: antlr4, composite-pattern, flutter, html, java, javascript, lexer, parser, visitor-pattern
- Language: Java
- Homepage:
- Size: 12.3 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Flutter-like to HTML/JS Transpiler
## Project Overview
This project is an experimental transpiler that translates "Flutter-like" code into HTML and JavaScript. It was developed as a university assignment to demonstrate the process of building a transpiler, including lexical analysis, parsing, syntax and semantic error handling, Abstract Syntax Tree (AST) construction, and code generation.
The main goal of this project is to allow users to write code in a Flutter-like syntax and have it automatically translated into web technologies (HTML & JS). This showcases the ability to work with compiler design concepts and implement complex language processing systems.
## Features
- Custom lexer for tokenizing Flutter-like syntax
- Parser with comprehensive syntax and semantic error handling
- Multi-scoped symbol table implementation using a stack of hashmaps
- Abstract Syntax Tree (AST) generation
- Code generation from AST to HTML and JavaScript
- Visual representation of the AST using jGraphT library## Project Structure
The project is structured using the Composite Design Pattern, which is ideal for representing the parent-child relationships in the language structure. The main components are:
1. Program: The root of the structure, containing statements and the main scaffold.
2. Widgets: Both pre-defined and custom UI elements.
3. Statements: Variable declarations, assignments, and custom widget definitions.
4. Properties: Attributes and settings for widgets.
5. Expressions: Mathematical and logical expressions.## Implementation Details
### Transpiler Process
1. **Lexical Analysis**: Tokenizes the input code and checks for syntactic errors.
2. **Parsing and Semantic Analysis**: Matches token sequences against parsing rules and performs semantic checks (e.g., undefined variables, duplicate names, nested scopes).
3. **Abstract Syntax Tree (AST) Generation**: Builds an AST representing the essential structure of the code.
4. **Code Generation**: Converts the AST into the target languages (HTML and JavaScript).![Transpiling Process](project_workflow.png)
### Design Patterns Used
- **Composite Design Pattern**: Used to structure the project, representing the parent-child relationships in the language elements.
- **Visitor Design Pattern**: Employed to separate the logic applied to the parsing tree (for AST generation and syntactic error checking) and the AST (for code generation and other operations) from the structure itself.### Technologies and Tools
- ANTLR4: Used for lexer and parser generation
- Java: Primary programming language
- jGraphT library: Utilized for visualizing the AST as a graph## Documentation
For complete documentation of the project in Arabic, please refer to the following link:
[Arabic Documentation](https://docs.google.com/document/d/1c1PCO6FGULGv2V9SRgx8zC3AI9ZIaIeHzJyvhV3BaeE/edit?usp=sharing)
## How to Use
[To be added in a future update]
## Examples
Here's an example of how the Flutter-like code is transpiled to HTML and JavaScript:
### Flutter-like Source Code
[Source Language Code](test_source.drt)
### Transpiled HTML & JavaScript
[Transpiled Code](test_transpiled.html)
View Result
## Future Improvements
The project's structure, thanks to the use of Composite and Visitor design patterns, allows for easy extensibility and improvements without affecting the existing codebase. Potential areas for enhancement include:
- Expanding the set of supported Flutter-like widgets and properties
- Optimizing the generated HTML and JavaScript code
- Adding support for more complex Flutter features
- Implementing a user-friendly interface for the transpiler## Contributors
This project was developed as a university assignment by the following team members:
- [Alaa Aldeen Zamel](https://github.com/alaazamelDev)
- Mhd Hadi Barakat
- Anas Rish
- Anas Durra
- Sham TuamehWe appreciate the hard work and dedication of all team members in bringing this project to fruition.
## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.