refactor(tvix/eval): delay allocation when comparing attr values
Delays allocation (through cloning) of the values to be compared until *after* the keys have been compared. Change-Id: I7d68c27d7a0fbcdcc387db7c092bce50ca4b94ea Reviewed-on: https://cl.tvl.fyi/c/depot/+/9900 Autosubmit: tazjin <tazjin@tvl.su> Reviewed-by: flokli <flokli@flokli.de> Tested-by: BuildkiteCI
This commit is contained in:
parent
2dd2b844c7
commit
99f618bcb4
1 changed files with 4 additions and 4 deletions
|
@ -505,8 +505,8 @@ impl Value {
|
||||||
return Ok(Value::Bool(false));
|
return Ok(Value::Bool(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
let iter1 = a1.into_iter_sorted();
|
let iter1 = a1.iter_sorted();
|
||||||
let iter2 = a2.into_iter_sorted();
|
let iter2 = a2.iter_sorted();
|
||||||
|
|
||||||
for ((k1, v1), (k2, v2)) in iter1.zip(iter2) {
|
for ((k1, v1), (k2, v2)) in iter1.zip(iter2) {
|
||||||
if k1 != k2 {
|
if k1 != k2 {
|
||||||
|
@ -515,8 +515,8 @@ impl Value {
|
||||||
|
|
||||||
if !generators::check_equality(
|
if !generators::check_equality(
|
||||||
&co,
|
&co,
|
||||||
v1,
|
v1.clone(),
|
||||||
v2,
|
v2.clone(),
|
||||||
std::cmp::max(ptr_eq, PointerEquality::AllowNested),
|
std::cmp::max(ptr_eq, PointerEquality::AllowNested),
|
||||||
)
|
)
|
||||||
.await?
|
.await?
|
||||||
|
|
Loading…
Reference in a new issue