Toy Codegen is the example compiler for semantic-analyzer-rs.
As Codegen backend used LLVM, with inkwell.
There is a basic implementation of code-generation
. The Semantic AST
structure is
used as a basic data source. This means that any subset of programming languages
can be represented, the main criterion for which is representability in a
finite AST structure of Semantic Analyzer, which is used in the semantic-analyzer
library.
The codege is focused only on those instructions that are presented as
an AST sample. And it is not intended to cover all possible complex
cases of code generation based on a complete set of SemanticStateContext
instructions. However, the end result is a fully functional binary code.
The basic parts is:
- Function declarations
- Functions parameters initializations
- Types declarations
- Constants declarations
- Function body implementation
- Let-binding
- Codegen variables state
- Binding
- Expressions
- Codegen type conversions
- If conditions flow
- Loop conditions flow
- Function return flow
- Let-binding
- Target triple initialization (LLVM backend)
- LLVM IR source code generation (and store to file)
- Binary code generation (and store to file)
- Code generation error flow with custom error types