diff options
author | Lyle Mantooth <lyle@menteeth.us> | 2022-12-03T05·18-0500 |
---|---|---|
committer | clbot <clbot@tvl.fyi> | 2022-12-03T13·26+0000 |
commit | f4e17caae88a1180444d8120ba35565e9853199d (patch) | |
tree | d16b895a642f35bb4544541eceb71cfe9a1d9014 /tvix/eval/src/builtins/mod.rs | |
parent | 9fed61297a9766be4e5bd4c0a4461cfb176115c9 (diff) |
feat(tvix/eval): Continue removing leakage of BTreeMap. r/5379
Fixes b/212. Based on feedback in https://cl.tvl.fyi/c/depot/+/7492, all uses of `NixAttrs::from_map` have been removed. Only `from_iter` and `from_kv` remain. Change-Id: I52e25f73018c2aa1843197427516b7a852503e2c Reviewed-on: https://cl.tvl.fyi/c/depot/+/7500 Reviewed-by: tazjin <tazjin@tvl.su> Tested-by: BuildkiteCI Autosubmit: IslandUsurper <lyle@menteeth.us>
Diffstat (limited to 'tvix/eval/src/builtins/mod.rs')
-rw-r--r-- | tvix/eval/src/builtins/mod.rs | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/tvix/eval/src/builtins/mod.rs b/tvix/eval/src/builtins/mod.rs index 536fc9082b87..f75acd48ad31 100644 --- a/tvix/eval/src/builtins/mod.rs +++ b/tvix/eval/src/builtins/mod.rs @@ -16,7 +16,7 @@ use regex::Regex; use crate::warnings::WarningKind; use crate::{ - errors::ErrorKind, + errors::{ErrorKind, EvalResult}, value::{Builtin, CoercionKind, NixAttrs, NixList, NixString, Value}, vm::VM, }; @@ -329,12 +329,8 @@ mod pure_builtins { } else { return Ok(Value::attrs(NixAttrs::empty())); }; - Ok(Value::attrs(NixAttrs::from_map( - formals - .arguments - .iter() - .map(|(k, v)| (k.clone(), (*v).into())) - .collect(), + Ok(Value::attrs(NixAttrs::from_iter( + formals.arguments.iter().map(|(k, v)| (k.clone(), (*v))), ))) } @@ -543,7 +539,7 @@ mod pure_builtins { // Map entries earlier in the list take precedence over entries later in the list map.entry(name).or_insert(value); } - Ok(Value::attrs(NixAttrs::from_map(map))) + Ok(Value::attrs(NixAttrs::from_iter(map.into_iter()))) } #[builtin("map")] @@ -560,12 +556,15 @@ mod pure_builtins { #[builtin("mapAttrs")] fn builtin_map_attrs(vm: &mut VM, f: Value, attrs: Value) -> Result<Value, ErrorKind> { let attrs = attrs.to_attrs()?; - let mut res = BTreeMap::new(); - for (key, value) in attrs.as_ref() { - let value = vm.call_with(&f, [key.clone().into(), value.clone()])?; - res.insert(key.clone(), value); - } - Ok(Value::attrs(NixAttrs::from_map(res))) + let res = + attrs + .as_ref() + .into_iter() + .flat_map(|(key, value)| -> EvalResult<(NixString, Value)> { + let value = vm.call_with(&f, [key.clone().into(), value.clone()])?; + Ok((key.to_owned(), value)) + }); + Ok(Value::attrs(NixAttrs::from_iter(res))) } #[builtin("match")] @@ -1081,9 +1080,7 @@ pub fn global_builtins(source: SourceCode) -> GlobalsMapFunc { let mut globals: GlobalsMap = HashMap::new(); - let builtins = Rc::new(NixAttrs::from_map( - map.into_iter().map(|(k, v)| (k.into(), v)).collect(), - )); + let builtins = Rc::new(NixAttrs::from_iter(map.into_iter())); // known global builtins from the builtins set. for global in &[ |