Skip to content

Commit

Permalink
Fix: Fixed parse_var_decl Function to Stop Redefining.
Browse files Browse the repository at this point in the history
  • Loading branch information
PranavVerma-droid committed Oct 8, 2024
1 parent bb25794 commit 27c775b
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 6 deletions.
2 changes: 1 addition & 1 deletion code/Normal/file-14.td
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,6 @@ if (x > 0 && y < 10) {
print("This should never happen");
}

var x = true;
x = true;
print(!x);
print(!(x && false));
13 changes: 8 additions & 5 deletions src/parser.rs
Original file line number Diff line number Diff line change
Expand Up @@ -412,24 +412,27 @@ impl<'a> Parser<'a> {
_ => panic!("Expected var or novar"),
};
self.eat(self.current_token.clone());

let name = if let Token::Identifier(ident) = self.current_token.clone() {
self.eat(Token::Identifier(ident.clone()));
ident
} else {
panic!("Expected identifier in variable declaration");
};



if self.symbol_table.contains_key(&name) {
panic!("Variable '{}' has already been declared", name);
}

self.symbol_table.insert(name.clone(), is_mutable);

let initializer = if self.current_token == Token::Assign {
self.eat(Token::Assign);
Some(Box::new(self.parse_expr()))
} else {
None
};

self.eat(Token::Semicolon);
ASTNode::Var(name, initializer, is_mutable)
}
Expand Down

0 comments on commit 27c775b

Please sign in to comment.