ConfigSlurper is a utility class within Groovy for writing properties file like scripts for performing configuration. Unlike regular Java properties files ConfigSlurper scripts support native Java types and are structured like a tree.
Below is an example of how you could configure Log4j with a ConfigSlurper script:
To load this into a readable config you can do:
As you can see from the example above you can navigate the config using dot notation and the return values are Java types like strings and booleans.
You can also use scoping in config scripts to avoid repeating yourself. So the above config could also be written as:
Converting to and from Java properties files
You can convert ConfigSlurper configs to and from Java properties files. For example:
You can merge config objects so if you have multiple config files and want to create one central config object you can do:
Serializing a configuration to disk
You can serialize a config object to disk. Each config object implements the groovy.lang.Writable interface that allows you to write out the config to any java.io.Writer:
Special "environments" Configuration
The ConfigSlurper class has a special constructor other than the default constructor that takes an "environment" parameter. This special constructor works in concert with a property setting called environments. This allows a default setting to exist in the property file that can be superceded by a setting in the appropriate environments closure. This allows multiple related configurations to be stored in the same file.
Given this groovy property file:
Here is the demo code that exercises this configuration:
Note: the environments closure is not directly parsable. Without using the special environment constructor the closure is ignored.
The value of the environment constructor is also available in the configuration file, allowing you to build the configuration like this: