fix(tvix/eval): thunk HasAttr expressions
HasAttrs was weird because with longer attribute paths it would sometimes not turn out to be a thunk. If it was a thunk, it'd usually still do some eval strictly which we'll want to avoid. Verified against C++ Nix using a new test suite introduced in a later CL. Change-Id: I6d047ccc68d046bb268462f170a3c4f3c5ddeffe Reviewed-on: https://cl.tvl.fyi/c/depot/+/8656 Autosubmit: sterni <sternenseemann@systemli.org> Tested-by: BuildkiteCI Reviewed-by: tazjin <tazjin@tvl.su>
This commit is contained in:
parent
9d0425acc0
commit
2aab01ac29
1 changed files with 3 additions and 1 deletions
|
@ -257,7 +257,9 @@ impl Compiler<'_> {
|
|||
self.thunk(slot, binop, move |c, s| c.compile_binop(s, binop))
|
||||
}
|
||||
|
||||
ast::Expr::HasAttr(has_attr) => self.compile_has_attr(slot, has_attr),
|
||||
ast::Expr::HasAttr(has_attr) => {
|
||||
self.thunk(slot, has_attr, move |c, s| c.compile_has_attr(s, has_attr))
|
||||
}
|
||||
|
||||
ast::Expr::List(list) => self.thunk(slot, list, move |c, s| c.compile_list(s, list)),
|
||||
|
||||
|
|
Loading…
Reference in a new issue