yakworks.commons.extensions.MapExtensions.groovy Maven / Gradle / Ivy
/*
* Copyright 2021 original authors
* SPDX-License-Identifier: Apache-2.0
*/
package yakworks.commons.extensions
import groovy.transform.CompileStatic
import yakworks.commons.map.Maps
/**
* Extensions to the {@code Map} interface.
*/
@CompileStatic
class MapExtensions {
/**
* Very similar to Groovy's {@code Map.get(Object key, Object defaultValue)}
* method, but allows the default value to be created in a closure.
* If there is no value for the given key, then the {@code create}
* closure is executed and its return value is set on the object for the key,
* and returned to the calling code.
*
* assert !myObject['someProperty']
* def result = map.getOrCreate('someProperty') { ->
* return 13
* }
* assert result == 13
* assert myObject['someProperty'] == 13
*
*
* @return The value stored in the object by {@code key}.
*/
static V getOrCreate(Map self, K key, Closure create) {
def value = self[key]
if (!value) {
self[key] = value = create()
}
return value
}
static boolean getBoolean(Map, ?> map, Object key, boolean defaultValue = false) {
Maps.getBoolean(map, key, defaultValue)
}
static List getList(Map, ?> map, Object key, List defaultValue = []) {
Maps.getList(map, key, defaultValue)
}
}