mirror of
https://github.com/artegoser/ONLang
synced 2024-11-05 20:43:57 +03:00
fix: panic when deleting a variable
after exiting the scope
This commit is contained in:
parent
e7b4a02ab7
commit
a3cb87e8b4
1 changed files with 10 additions and 8 deletions
|
@ -129,7 +129,7 @@ impl Interpreter {
|
|||
},
|
||||
"delete" => match value {
|
||||
Value::String(value) => {
|
||||
self.delete(value);
|
||||
self.delete(value, true);
|
||||
}
|
||||
_ => {
|
||||
self.error("Unsupported data type for the `delete` argument, must be a string");
|
||||
|
@ -321,7 +321,7 @@ impl Interpreter {
|
|||
fn delete_last_scope(&mut self) {
|
||||
let vars = self.scopes[self.scope].clone();
|
||||
for name in vars {
|
||||
self.delete(&name);
|
||||
self.delete(&name, false);
|
||||
}
|
||||
self.scopes.remove(self.scope);
|
||||
}
|
||||
|
@ -359,10 +359,11 @@ impl Interpreter {
|
|||
}
|
||||
}
|
||||
|
||||
fn delete(&mut self, var_name: &String) {
|
||||
fn delete(&mut self, var_name: &String, panic: bool) {
|
||||
if self.var_exists(var_name) {
|
||||
self.vars.remove(var_name);
|
||||
} else {
|
||||
if panic {
|
||||
self.error(&format!(
|
||||
"The variable {} does not exist and cannot be deleted",
|
||||
var_name
|
||||
|
@ -370,6 +371,7 @@ impl Interpreter {
|
|||
panic!();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn get_var(&mut self, var_name: &String) -> Value {
|
||||
let var = self.vars.get(var_name);
|
||||
|
|
Loading…
Reference in a new issue