some documentation
This commit is contained in:
parent
61a056157b
commit
2d739d98cc
2 changed files with 7 additions and 0 deletions
|
@ -1,5 +1,6 @@
|
||||||
use crate::{expression::Expression, statement::Statement, token::Literal};
|
use crate::{expression::Expression, statement::Statement, token::Literal};
|
||||||
|
|
||||||
|
/// Generate a string representation of a list of AST statements.
|
||||||
pub fn print(statements: &[Statement]) -> String {
|
pub fn print(statements: &[Statement]) -> String {
|
||||||
let mut result = String::new();
|
let mut result = String::new();
|
||||||
for statement in statements {
|
for statement in statements {
|
||||||
|
@ -8,6 +9,7 @@ pub fn print(statements: &[Statement]) -> String {
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Recursively generate a string representation of a single AST statement.
|
||||||
fn print_statement(statement: &Statement, indent: usize) -> String {
|
fn print_statement(statement: &Statement, indent: usize) -> String {
|
||||||
let indent_str = " ".repeat(indent);
|
let indent_str = " ".repeat(indent);
|
||||||
match statement {
|
match statement {
|
||||||
|
@ -131,6 +133,7 @@ fn print_statement(statement: &Statement, indent: usize) -> String {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Recursively generate a string representation of a single AST expression.
|
||||||
fn print_expression(expr: &Expression) -> String {
|
fn print_expression(expr: &Expression) -> String {
|
||||||
match expr {
|
match expr {
|
||||||
Expression::Assign { name, value } => {
|
Expression::Assign { name, value } => {
|
||||||
|
|
|
@ -40,9 +40,13 @@ enum ClassType {
|
||||||
/// Resolve variable references and perform static analysis before interpretation.
|
/// Resolve variable references and perform static analysis before interpretation.
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Resolver<'a> {
|
pub struct Resolver<'a> {
|
||||||
|
/// Stack of scopes, each mapping variable names to their initialized state.
|
||||||
scopes: Vec<HashMap<String, bool>>,
|
scopes: Vec<HashMap<String, bool>>,
|
||||||
|
/// Reference to the interpreter to resolve variable depths.
|
||||||
interpreter: &'a mut Interpreter,
|
interpreter: &'a mut Interpreter,
|
||||||
|
/// Track the type of the current function being resolved (regular, method, initializer, ...).
|
||||||
current_fun: FunctionType,
|
current_fun: FunctionType,
|
||||||
|
/// Tracks the type of the current class being resolved (regular, subclass, ...).
|
||||||
current_class: ClassType,
|
current_class: ClassType,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue