Created
March 11, 2015 21:21
Simple, recursive deep-merge in Clojure.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(ns deep-merge-spec | |
(:require [midje.sweet :refer :all] | |
[util :as u])) | |
(fact (u/deep-merge {:one 1 :two 2} | |
{:one 1 :two {}}) | |
=> {:one 1 :two {}}) | |
(fact (u/deep-merge {:one 1 :two {:three 3 :four {:five 5}}} | |
{:two {:three {:test true}}}) | |
=> {:one 1 :two {:three {:test true} :four {:five 5}}}) | |
(fact (u/deep-merge {:one {:two {:three 3}} | |
:four {:five {:six 6}}} | |
{:one {:seven 7 :two {:three "three" :nine 9}} | |
:four {:eight 8 :five 5} | |
:ten 10}) | |
=> {:one {:two {:three "three" :nine 9} | |
:seven 7} | |
:four {:five 5 :eight 8} | |
:ten 10}) | |
(fact (u/deep-merge {:one {:two 2 :three 3}} | |
{:one {:four 4 :five 5}}) | |
=> {:one {:two 2 :three 3 :four 4 :five 5}}) | |
(fact (u/deep-merge {:one 1 :two {:three 3}} | |
{:one 2 :two {:three 4}} | |
{:one 3 :two {:three 5}} | |
{:one 4 :two {:three 6}}) | |
=> {:one 4 :two {:three 6}}) | |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
(ns util) | |
(defn deep-merge [v & vs] | |
(letfn [(rec-merge [v1 v2] | |
(if (and (map? v1) (map? v2)) | |
(merge-with deep-merge v1 v2) | |
v2))] | |
(when (some identity vs) | |
(reduce #(rec-merge %1 %2) v vs)))) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Here's one more version.
This one is a lot less concise, but potentially easier to understand. It might also perform better than some other versions, since I'm using loops and recurs.