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:
sterni 2023-05-27 21:21:43 +02:00 committed by clbot
parent 9d0425acc0
commit 2aab01ac29

View file

@ -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)),