diff options
| author | Laurenz <laurmaedje@gmail.com> | 2021-01-30 10:24:51 +0100 |
|---|---|---|
| committer | Laurenz <laurmaedje@gmail.com> | 2021-01-30 10:24:51 +0100 |
| commit | ac24075469f171fe83a976b9a97b9b1ea078a7e3 (patch) | |
| tree | e89155de4670efa636b71f4a9a5e5f422c76214d /src/eval | |
| parent | 2036663ed25b5885a87eb3a80caec3fa2e258d77 (diff) | |
Moves captures visitor into separate file 🚚
Diffstat (limited to 'src/eval')
| -rw-r--r-- | src/eval/capture.rs (renamed from src/eval/template.rs) | 24 | ||||
| -rw-r--r-- | src/eval/mod.rs | 14 |
2 files changed, 19 insertions, 19 deletions
diff --git a/src/eval/template.rs b/src/eval/capture.rs index 040685f8..b7052c70 100644 --- a/src/eval/template.rs +++ b/src/eval/capture.rs @@ -1,29 +1,17 @@ use super::*; use crate::syntax::visit::*; -impl Eval for Spanned<&ExprTemplate> { - type Output = Value; - - fn eval(self, ctx: &mut EvalContext) -> Self::Output { - let mut template = self.v.clone(); - let mut visitor = CapturesVisitor::new(ctx); - visitor.visit_template(&mut template); - Value::Template(template) - } -} - /// A visitor that replaces all captured variables with their values. -struct CapturesVisitor<'a> { +#[derive(Debug)] +pub struct CapturesVisitor<'a> { external: &'a Scopes<'a>, internal: Scopes<'a>, } impl<'a> CapturesVisitor<'a> { - fn new(ctx: &'a EvalContext) -> Self { - Self { - external: &ctx.scopes, - internal: Scopes::default(), - } + /// Create a new visitor for the given external scopes. + pub fn new(external: &'a Scopes) -> Self { + Self { external, internal: Scopes::default() } } } @@ -43,7 +31,7 @@ impl<'a> Visitor<'a> for CapturesVisitor<'a> { fn visit_expr(&mut self, expr: &'a mut Expr) { if let Expr::Ident(ident) = expr { // Find out whether the identifier is not locally defined, but - // captured, and if so, replace it with it's value. + // captured, and if so, replace it with its value. if self.internal.get(ident).is_none() { if let Some(value) = self.external.get(ident) { *expr = Expr::CapturedValue(value.clone()); diff --git a/src/eval/mod.rs b/src/eval/mod.rs index 9e45a67b..af3303af 100644 --- a/src/eval/mod.rs +++ b/src/eval/mod.rs @@ -3,13 +3,14 @@ #[macro_use] mod value; mod call; +mod capture; mod context; mod ops; mod scope; mod state; -mod template; pub use call::*; +pub use capture::*; pub use context::*; pub use scope::*; pub use state::*; @@ -208,6 +209,17 @@ impl Eval for Spanned<&ExprDict> { } } +impl Eval for Spanned<&ExprTemplate> { + type Output = Value; + + fn eval(self, ctx: &mut EvalContext) -> Self::Output { + let mut template = self.v.clone(); + let mut visitor = CapturesVisitor::new(&ctx.scopes); + visitor.visit_template(&mut template); + Value::Template(template) + } +} + impl Eval for Spanned<&ExprBlock> { type Output = Value; |
