summaryrefslogtreecommitdiff
path: root/src/eval/mod.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/eval/mod.rs')
-rw-r--r--src/eval/mod.rs16
1 files changed, 14 insertions, 2 deletions
diff --git a/src/eval/mod.rs b/src/eval/mod.rs
index be168d63..cb80968c 100644
--- a/src/eval/mod.rs
+++ b/src/eval/mod.rs
@@ -633,7 +633,12 @@ impl Eval for WhileExpr {
let condition = self.condition();
while condition.eval(ctx, scp)?.cast::<bool>().at(condition.span())? {
let body = self.body();
- let value = body.eval(ctx, scp)?;
+ let value = match body.eval(ctx, scp) {
+ Ok(value) => value,
+ Err(Control::Break(_)) => break,
+ Err(Control::Continue(_)) => continue,
+ other => other?,
+ };
output = ops::join(output, value).at(body.span())?;
}
@@ -654,7 +659,14 @@ impl Eval for ForExpr {
for ($($value),*) in $iter {
$(scp.top.def_mut(&$binding, $value);)*
- let value = self.body().eval(ctx, scp)?;
+ let body = self.body();
+ let value = match body.eval(ctx, scp) {
+ Ok(value) => value,
+ Err(Control::Break(_)) => break,
+ Err(Control::Continue(_)) => continue,
+ other => other?,
+ };
+
output = ops::join(output, value)
.at(self.body().span())?;
}