generated from ElnuDev/rust-project
Add variable-to-variable assignment
This commit is contained in:
parent
01173d2f7d
commit
4bf6e7b820
2 changed files with 55 additions and 50 deletions
|
@ -6,7 +6,9 @@ if True:
|
|||
"Bob will be here in [x] seconds."
|
||||
if True:
|
||||
x = "1"
|
||||
let x = "4"
|
||||
let y = "4"
|
||||
y = "5"
|
||||
x = y
|
||||
"[x]"
|
||||
"Bob will be here in [x] seconds."
|
||||
"Bob will be here in [x] seconds."
|
||||
|
|
|
@ -37,62 +37,65 @@ impl CommandContext {
|
|||
assign_type,
|
||||
variable,
|
||||
value,
|
||||
} => match assign_type {
|
||||
Define => panic!("define command should not be executed at runtime!"),
|
||||
GlobalAssign => {
|
||||
if let Token::Keyword(_) = value {
|
||||
todo!("assignment variable interpolation isn't implemented");
|
||||
}
|
||||
let root = self.context.borrow().get_root(&self.context);
|
||||
// Don't want to re-borrow if root is self
|
||||
let root = if Rc::ptr_eq(&self.context, &root) {
|
||||
&self.context
|
||||
} else {
|
||||
&root
|
||||
};
|
||||
root.borrow_mut()
|
||||
.variables
|
||||
.as_ref()
|
||||
.borrow_mut()
|
||||
.insert(variable.clone(), value.clone());
|
||||
return None;
|
||||
}
|
||||
Let => {
|
||||
if let Token::Keyword(_) = value {
|
||||
todo!("assignment variable interpolation isn't implemented");
|
||||
}
|
||||
} => {
|
||||
let value = if let Token::Keyword(keyword) = value {
|
||||
self.context
|
||||
.borrow()
|
||||
.variables
|
||||
.borrow_mut()
|
||||
.insert(variable.clone(), value.clone());
|
||||
return None;
|
||||
}
|
||||
Assign => {
|
||||
if let Token::Keyword(_) = value {
|
||||
todo!("assignment variable interpolation isn't implemented");
|
||||
.get_variables()
|
||||
.get(keyword)
|
||||
.unwrap_or_else(|| panic!("undefined variable `{keyword}`"))
|
||||
.clone()
|
||||
} else {
|
||||
value.clone()
|
||||
};
|
||||
match assign_type {
|
||||
Define => panic!("define command should not be executed at runtime!"),
|
||||
GlobalAssign => {
|
||||
let root = self.context.borrow().get_root(&self.context);
|
||||
// Don't want to re-borrow if root is self
|
||||
let root = if Rc::ptr_eq(&self.context, &root) {
|
||||
&self.context
|
||||
} else {
|
||||
&root
|
||||
};
|
||||
root.borrow_mut()
|
||||
.variables
|
||||
.as_ref()
|
||||
.borrow_mut()
|
||||
.insert(variable.clone(), value.clone());
|
||||
return None;
|
||||
}
|
||||
let mut block_option = Some(self.context.clone());
|
||||
let mut modified = false;
|
||||
while let Some(block) = block_option {
|
||||
let block = block.borrow();
|
||||
block
|
||||
Let => {
|
||||
self.context
|
||||
.borrow()
|
||||
.variables
|
||||
.borrow_mut()
|
||||
.entry(variable.clone())
|
||||
.and_modify(|e| {
|
||||
*e = value.clone();
|
||||
modified = true;
|
||||
});
|
||||
if modified {
|
||||
break;
|
||||
.insert(variable.clone(), value.clone());
|
||||
return None;
|
||||
}
|
||||
Assign => {
|
||||
let mut block_option = Some(self.context.clone());
|
||||
let mut modified = false;
|
||||
while let Some(block) = block_option {
|
||||
let block = block.borrow();
|
||||
block
|
||||
.variables
|
||||
.borrow_mut()
|
||||
.entry(variable.clone())
|
||||
.and_modify(|e| {
|
||||
*e = value.clone();
|
||||
modified = true;
|
||||
});
|
||||
if modified {
|
||||
break;
|
||||
}
|
||||
block_option = block.parent.clone();
|
||||
}
|
||||
block_option = block.parent.clone();
|
||||
if !modified {
|
||||
panic!("undefined variable `{variable}`");
|
||||
}
|
||||
return None;
|
||||
}
|
||||
if !modified {
|
||||
panic!("undefined variable `{variable}`");
|
||||
}
|
||||
return None;
|
||||
}
|
||||
},
|
||||
Eat { .. } => return None,
|
||||
|
|
Loading…
Add table
Reference in a new issue