Skip to content

Instantly share code, notes, and snippets.

@antsmartian
Forked from timyates/tree.md
Created April 24, 2012 10:07
Show Gist options
  • Save antsmartian/2478582 to your computer and use it in GitHub Desktop.
Save antsmartian/2478582 to your computer and use it in GitHub Desktop.
A two-line tree in Groovy

Two line Tree in Groovy

The other day, I saw Harold Cooper's One-line tree in Python via autovivication, and wondered if the same thing was possible in Groovy.

The answer is yes! But you need to define the variable tree before you can assign it to the self-referential withDefault closure, hence with Groovy, it's a two-line solution ;-)

Anyway, given:

def tree
tree = { -> return [:].withDefault{ tree() } }

We can then do:

users = tree()
users.harold.username = 'hrldcpr'
users.yates.username = 'tim'

And printing this out

println new groovy.json.JsonBuilder( users ).toPrettyString()

gives:

{
    "harold": {
        "username": "hrldcpr"
    },
    "yates": {
        "username": "tim"
    }
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment