Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- (def asym-hobbit-body-parts [{:name "head" :size 3}
- {:name "left-eye" :size 1}
- {:name "left-ear" :size 1}
- {:name "mouth" :size 1}
- {:name "nose" :size 1}
- {:name "neck" :size 2}
- {:name "left-shoulder" :size 3}
- {:name "left-upper-arm" :size 3}
- {:name "chest" :size 10}
- {:name "back" :size 10}
- {:name "left-forearm" :size 3}
- {:name "abdomen" :size 6}
- {:name "left-kidney" :size 1}
- {:name "left-hand" :size 2}
- {:name "left-knee" :size 2}
- {:name "left-thigh" :size 4}
- {:name "left-lower-leg" :size 3}
- {:name "left-achilles" :size 1}
- {:name "left-foot" :size 2}])
- (defn matching-part
- [part]
- {:name (clojure.string/replace (:name part) #"^left-" "right-")
- :size (:size part)})
- ➊ (defn symmetrize-body-parts
- "Expects a seq of maps that have a :name and :size"
- [asym-body-parts]
- ➋ (loop [remaining-asym-parts asym-body-parts
- final-body-parts []]
- ➌ (if (empty? remaining-asym-parts)
- final-body-parts
- ➍ (let [[part & remaining] remaining-asym-parts]
- ➎ (recur remaining
- (into final-body-parts
- (set [part (matching-part part)])))))))
Add Comment
Please, Sign In to add comment