diff options
author | Vincent Ambo <mail@tazj.in> | 2021-01-17T17·31+0300 |
---|---|---|
committer | tazjin <mail@tazj.in> | 2021-01-17T21·17+0000 |
commit | 30a6fcccee19877daad027a37fd3ee369a7d5d1e (patch) | |
tree | f02f365ebdd458dd9e169454adc7c35eb09cf4cc /users/tazjin/rlox/src/treewalk/interpreter.rs | |
parent | 861c0f0c79c4bd182552eea519978c8a1446d634 (diff) |
refactor(tazjin/rlox): Move entrypoints into interpreters r/2123
Right now this introduces a simple mechanism to flip between the interpreters. Change-Id: I92ee920c53d76ab6b664ac671993a6d6426af61a Reviewed-on: https://cl.tvl.fyi/c/depot/+/2412 Reviewed-by: tazjin <mail@tazj.in> Tested-by: BuildkiteCI
Diffstat (limited to 'users/tazjin/rlox/src/treewalk/interpreter.rs')
-rw-r--r-- | users/tazjin/rlox/src/treewalk/interpreter.rs | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/users/tazjin/rlox/src/treewalk/interpreter.rs b/users/tazjin/rlox/src/treewalk/interpreter.rs index 32822d72face..5b47dc0248f9 100644 --- a/users/tazjin/rlox/src/treewalk/interpreter.rs +++ b/users/tazjin/rlox/src/treewalk/interpreter.rs @@ -1,7 +1,7 @@ use crate::errors::{Error, ErrorKind}; use crate::parser::{self, Block, Expr, Literal, Statement}; -use crate::treewalk::resolver; use crate::scanner::{self, TokenKind}; +use crate::treewalk::resolver; use std::collections::HashMap; use std::rc::Rc; use std::sync::RwLock; @@ -223,9 +223,13 @@ impl Interpreter { // Interpreter itself pub fn interpret(&mut self, mut program: Block) -> Result<Value, Error> { - let globals = self.env.read() + let globals = self + .env + .read() .expect("static globals lock poisoned") - .values.keys().map(Clone::clone) + .values + .keys() + .map(Clone::clone) .collect::<Vec<String>>(); resolver::resolve(&globals, &mut program)?; |