diff options
author | Vincent Ambo <mail@tazj.in> | 2022-08-11T16·02+0300 |
---|---|---|
committer | tazjin <tazjin@tvl.su> | 2022-08-26T15·06+0000 |
commit | 999b9c7a138a5dd5277085570042fc67a893e5af (patch) | |
tree | e7eb2baadeb0a172e2b6c48c1644f6604c58d769 /tvix/eval/src/value/attrs.rs | |
parent | f331874aeb6ed528d667f8737d1d0b1c6f6f61cf (diff) |
refactor(tvix/value): replace static representation with SmolStr r/4498
The only uses of the static variant were for `"name"` and `"value"`, which are both small enough to fit into a SmolStr. The size of NixString accomodates `String` anyways, so we may as well inline them. Additionally smol_str is already in the dependency graph because rnix uses it, and using it for representations of identifiers is sensible. Change-Id: I9969312256d1657d69128e54c47dc7294a18ce58 Reviewed-on: https://cl.tvl.fyi/c/depot/+/6165 Tested-by: BuildkiteCI Reviewed-by: sterni <sternenseemann@systemli.org> Reviewed-by: grfn <grfn@gws.fyi>
Diffstat (limited to 'tvix/eval/src/value/attrs.rs')
-rw-r--r-- | tvix/eval/src/value/attrs.rs | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/tvix/eval/src/value/attrs.rs b/tvix/eval/src/value/attrs.rs index ecb819fad77c..0ab4538a4d8c 100644 --- a/tvix/eval/src/value/attrs.rs +++ b/tvix/eval/src/value/attrs.rs @@ -38,8 +38,8 @@ impl AttrsRep { AttrsRep::KV { name, value } => { *self = AttrsRep::Map(BTreeMap::from([ - ("name".into(), std::mem::replace(name, Value::Blackhole)), - ("value".into(), std::mem::replace(value, Value::Blackhole)), + (NixString::NAME, std::mem::replace(name, Value::Blackhole)), + (NixString::VALUE, std::mem::replace(value, Value::Blackhole)), ])); self.map_mut() } @@ -62,7 +62,7 @@ impl AttrsRep { None } - AttrsRep::Map(map) => map.get(&key.to_string().into()), + AttrsRep::Map(map) => map.get(&key.into()), } } } |