refactor(tvix/eval): simplify thunk representations
For now, do not distinguish between closing and non-closing thunks, it will make the initial implementation easier. See Knuth etc. Change-Id: I0bd51e0f89f2c77e90bac63b507e5027b649e3d8 Reviewed-on: https://cl.tvl.fyi/c/depot/+/6346 Tested-by: BuildkiteCI Reviewed-by: sterni <sternenseemann@systemli.org>
This commit is contained in:
parent
28a9847c65
commit
8033a7abae
2 changed files with 8 additions and 8 deletions
|
@ -877,7 +877,7 @@ impl Compiler {
|
||||||
// Emit the thunk directly if it does not close over the
|
// Emit the thunk directly if it does not close over the
|
||||||
// environment.
|
// environment.
|
||||||
if thunk.lambda.upvalue_count == 0 {
|
if thunk.lambda.upvalue_count == 0 {
|
||||||
self.emit_constant(Value::Thunk(Thunk::new(thunk.lambda)));
|
self.emit_constant(Value::Thunk(Thunk::new(Rc::new(thunk.lambda))));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,13 +27,10 @@ use super::Lambda;
|
||||||
/// Internal representation of the different states of a thunk.
|
/// Internal representation of the different states of a thunk.
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
enum ThunkRepr {
|
enum ThunkRepr {
|
||||||
/// Thunk is suspended and awaiting execution.
|
|
||||||
Suspended { lambda: Lambda },
|
|
||||||
|
|
||||||
/// Thunk is closed over some values, suspended and awaiting
|
/// Thunk is closed over some values, suspended and awaiting
|
||||||
/// execution.
|
/// execution.
|
||||||
ClosedSuspended {
|
Suspended {
|
||||||
lambda: Lambda,
|
lambda: Rc<Lambda>,
|
||||||
upvalues: Vec<Value>,
|
upvalues: Vec<Value>,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -49,7 +46,10 @@ enum ThunkRepr {
|
||||||
pub struct Thunk(Rc<RefCell<ThunkRepr>>);
|
pub struct Thunk(Rc<RefCell<ThunkRepr>>);
|
||||||
|
|
||||||
impl Thunk {
|
impl Thunk {
|
||||||
pub fn new(lambda: Lambda) -> Self {
|
pub fn new(lambda: Rc<Lambda>) -> Self {
|
||||||
Thunk(Rc::new(RefCell::new(ThunkRepr::Suspended { lambda })))
|
Thunk(Rc::new(RefCell::new(ThunkRepr::Suspended {
|
||||||
|
lambda,
|
||||||
|
upvalues: vec![],
|
||||||
|
})))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue