Skip to content

A java library to map java.util.Properties to abitrary Object fields using annotations and reflection.

License

Notifications You must be signed in to change notification settings

roben/PropertiesMapper

Repository files navigation

PropertiesMapper

A java library to map the values from java.util.Properties objects (most likely read from .properties files for configuration) to abitrary java Object fields using annotations and reflection.

Supported field types are String, Long, Integer, Double, Float, Boolean and their primitive equivalents.

The library has no external dependencies and can be build using ant and Java 1.7. Previous java versions down to 1.5 should work, too, but are not yet tested and thus not enabled in the project properties. Feel free to report success when compiling with Java < 1.7!

Usage example (based on a simple TinkerForge configuration):

config.properties - A .properties file containing data:

tinker.daemon.host=10.1.2.3
tinker.daemon.port=4223
tinker.display.uid=aa1
tinker.temperature.uid=bb2

TinkerConfig.java - An object to hold the property values

public class TinkerConfig {
    @Property("tinker.daemon.host")
    private String brickDaemonHost;
    
    @Property("tinker.daemon.port")
    private Integer brickDaemonPort;
    
    @Property("tinker.temperature.uid")
    private String temperaturBrickletUid;
    
    @Property("tinker.display.uid")
    private String displayBrickletUid;
...
}

To map the contents of a Properties object to an arbitrary object (for our example, loadProperties() loads the config.properties file and myAnnotatedObject is an instance of TinkerConfig):

Properties p = loadProperties(); // you still need to do this by yourself, don't care where the properties come from
PropertiesMapper.mapPropertiesToObject(p, myAnnotatedObject); // values from the p are written to myConfigObject based on the @Property annotations

To map the field values from an Object back to a Properties instance:

Properties p = new Properties();
PropertiesMapper.mapObjectToProperties(myAnnotatedObject, p);

About

A java library to map java.util.Properties to abitrary Object fields using annotations and reflection.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages