# HG changeset patch # User Mike Pavone # Date 1376198786 25200 # Node ID 75be44ed9df5d42f5bb5b6799b2c0e903ec79dad # Parent f594e6836c4499f7edebdeb6b729dd0c589fae6f Dict improvements diff -r f594e6836c44 -r 75be44ed9df5 modules/dict.tp --- a/modules/dict.tp Sat Aug 10 19:09:22 2013 -0700 +++ b/modules/dict.tp Sat Aug 10 22:26:26 2013 -0700 @@ -10,10 +10,10 @@ els <- #[] find <- :tofind { idx <- 0 - while: { - if: idx < (els length) { + while: { + if: idx < (els length) { ((els get: idx) key: ) != tofind - } else: {false} + } else: {false} } do: { idx <- idx + 1 } @@ -29,11 +29,11 @@ } self } - + get <- :k { get: k withDefault: false } - + get:withDefault <- :k default { idx <- find: k if: idx < 0 { @@ -42,13 +42,25 @@ (els get: idx) val } } - + + get:elseSet <- :k :else { + idx <- find: k + if: idx < 0 { + v <- else: + els append: (key: k val: v) + v + } else: { + (els get: idx) val + } + } + foreach <- :l { foreach: els :idx el { l: (el key) (el val) } } + length <- { els length } } }