fix(tvix/value): KV struct needs to carry name as Value, too

Users may construct a pair that falls into the name/value optimisation
but where `name` is not actually a string, as from the language
perspective there is nothing special about this attribute set.

We also can not conditionally apply this by forcing the key at this
point, as this would change the language semantics.

Therefore, the name in the optimised representation is also carried as
`Value`.

Change-Id: I5be8a4c98ba19ebdfb7203a929f714a04492512e
Reviewed-on: https://cl.tvl.fyi/c/depot/+/6101
Reviewed-by: grfn <grfn@gws.fyi>
Tested-by: BuildkiteCI
This commit is contained in:
Vincent Ambo 2022-08-09 18:19:34 +03:00 committed by tazjin
parent 2dcbbb8c4a
commit e876c3a41c

View file

@ -11,7 +11,7 @@ use super::Value;
#[derive(Debug)]
pub enum NixAttrs {
Map(BTreeMap<NixString, Value>),
KV { name: NixString, value: Value },
KV { name: Value, value: Value },
}
impl Display for NixAttrs {
@ -22,6 +22,7 @@ impl Display for NixAttrs {
NixAttrs::KV { name, value } => {
f.write_fmt(format_args!("name = \"{}\"; ", name))?;
f.write_fmt(format_args!("value = {}; ", value))?;
f.write_str("/* optimised pair! */")?;
}
NixAttrs::Map(map) => {