Skip to content

Latest commit

 

History

History
102 lines (63 loc) · 2.49 KB

File metadata and controls

102 lines (63 loc) · 2.49 KB

ConfigurateButWithBlackjackAndHookers

Not-so-stupid objectmapper

This library provides some nice-to have features which default ObjectMapper lacks.

WIP, but works Examples:

####Usage #### The mapper is compatible with ObjectMapper.


    @Settings
    @CustomAdapter(MyCustomTypeAdapter.class)
    private String someData;

Unlike default ObjectMapper this one allows you to supply custom (de)serialization logic for one more more specific fields within a @ConfigSerializable


In some cases you might want to get reference to the object which is currently being deserialized within MyCustomTypeAdapter.

@EnableSetterInjection
public class MyCustomTypeAdapter extends TypeSeriializer {
    
    private MyObject root;
    
    @Setter
    public void setRoot(MyObject object) {
        this.root = object;
    }
    .....
}

    @Settings
    @Static
    public static MY_CONFIG_NODE_I_WANT_TO_EASILY_ACCESS;

Unlike default ObjectMapper its allowed to de(serialize) static fields

Additionally if you are reloading your config its possible to define that the static variable may, or may not be updated only once via @Static(updateable=true/false)


Unlike default ObjectMapper its possible to set collection type. By default ObjectMapper will map only fields as follows:

List<T> -> ArrayList<T>
Set<T> -> HashSet<T>

This is not very useful if you from some various reasons want to store your data in a different data structure such TreeSet, SortedList etc.

One might think that you can declared a @Settings field already having a desired type impl. However configurate fails to deliver even here. On top of that writing a code directly against any specific collection impl in java is always seen like a bad practice.

    @Settings
    @AsCollectionImpl(TreeSet.class)
    private Set<T> someSortedSet;

As you might already expect @AsCollectionImpl will clash with @CustomAdapter. If both annotation are present per one specific field @CustomAdapter will be prioritized.

Fields annotated with @AsCollectionImpl wont ever be null after deserialization. So you can get rid of some null checks as long as you use the annotation.


Default ObjectMapper does not support custom handlers of nulls. Sometimes you want to ensure that field value is never null even if the node is missing in the config file.

    @Settings
    @Default(MyObjectDefaultImpl.class)
    private MyObject myobject;