aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBrett Snyder <bsnyder@digitalocean.com>2019-05-15 07:22:03 -0500
committerLouis Pilfold <louis@lpil.uk>2019-05-15 17:32:50 +0100
commitee03f5a0465e176e220060164a5ffc408f73ed0d (patch)
tree1963a55b088684d78a5c575193edcc46f4e7738e /src
parentaf07c099e69e296aaeabeebcb3e0a304bcb24d1d (diff)
downloadgleam_stdlib-ee03f5a0465e176e220060164a5ffc408f73ed0d.tar.gz
gleam_stdlib-ee03f5a0465e176e220060164a5ffc408f73ed0d.zip
optimize map:fold recursion
Diffstat (limited to 'src')
-rw-r--r--src/map_dict.gleam12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/map_dict.gleam b/src/map_dict.gleam
index c25378f..2ec141a 100644
--- a/src/map_dict.gleam
+++ b/src/map_dict.gleam
@@ -87,10 +87,14 @@ pub fn update(dict, key, f) {
}
}
-pub fn fold(dict, acc, f) {
- let kvs = to_list(dict)
- case kvs {
+fn do_fold(list, acc, f) {
+ case list {
| [] -> acc
- | [{k, v} | _] -> fold(delete(dict, k), f(k, v, acc), f)
+ | [{k, v} | tail] -> do_fold(tail, f(k, v, acc), f)
}
}
+
+pub fn fold(dict, acc, f) {
+ let kvs = to_list(dict)
+ do_fold(kvs, acc, f)
+}