All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.javakaffee.kryoserializers.jodatime.IdentifiableChronology Maven / Gradle / Ivy

package de.javakaffee.kryoserializers.jodatime;

import org.joda.time.Chronology;
import org.joda.time.chrono.BuddhistChronology;
import org.joda.time.chrono.CopticChronology;
import org.joda.time.chrono.EthiopicChronology;
import org.joda.time.chrono.GJChronology;
import org.joda.time.chrono.GregorianChronology;
import org.joda.time.chrono.ISOChronology;
import org.joda.time.chrono.IslamicChronology;
import org.joda.time.chrono.JulianChronology;

import com.esotericsoftware.kryo.io.Input;

/**
 * An enumeration that provides a String id for subclasses of {@link Chronology}.
 * For {@link ISOChronology}, null is used as id, as {@link ISOChronology}
 * is used as default and the id does not have to be serialized.
 * 
 * @author Martin Grotzke ([email protected]) (initial creation)
 */
enum IdentifiableChronology {
    
    ISO( null, ISOChronology.getInstance() ),
    COPTIC( "COPTIC", CopticChronology.getInstance() ),
    ETHIOPIC( "ETHIOPIC", EthiopicChronology.getInstance()),
    GREGORIAN("GREGORIAN", GregorianChronology.getInstance()),
    JULIAN("JULIAN", JulianChronology.getInstance()),
    ISLAMIC("ISLAMIC",IslamicChronology.getInstance()),
    BUDDHIST( "BUDDHIST", BuddhistChronology.getInstance()),
    GJ( "GJ", GJChronology.getInstance());
    
    private final String _id;
    private final Chronology _chronology;
    
    private IdentifiableChronology( final String id, final Chronology chronology ) {
        _id = id;
        _chronology = chronology;
    }
    
    public String getId() {
        return _id;
    }
    
    /**
     * Determines the id for the given {@link Chronology} subclass that later
     * can be used to resolve the {@link Chronology} with {@link #valueOfId(String)}.
     * For {@link ISOChronology} class null is returned.
     * 
     * @param clazz a subclass of {@link Chronology}.
     * @return an id, or null for {@link ISOChronology}.
     * @throws IllegalArgumentException if the {@link Chronology} is not supported.
     */
    public static String getIdByChronology( final Class clazz ) throws IllegalArgumentException {
        for( final IdentifiableChronology item : values() ) {
            if ( clazz.equals( item._chronology.getClass() ) ) {
                return item._id;
            }
        }
        throw new IllegalArgumentException( "Chronology not supported: " + clazz.getSimpleName() );
    }
    
    /**
     * Returns the chronology of the {@link IdentifiableChronology} matching the
     * provided id. If the provided id is null,
     * {@link ISOChronology} is returned.
     * @param id the id from {@link #getIdByChronology(Class)}.
     * @return a matching {@link Chronology} if any was found.
     * @throws IllegalArgumentException if no match was found.
     */
    public static Chronology valueOfId(final String id) throws IllegalArgumentException {
        if ( id == null ) {
            return ISO._chronology;
        }
        for( final IdentifiableChronology item : values() ) {
            if ( id.equals( item._id ) ) {
                return item._chronology;
            }
        }
        throw new IllegalArgumentException( "No chronology found for id " + id );
    }
    
    static Chronology readChronology( final Input input ) {
        final String chronologyId = input.readString();
        return IdentifiableChronology.valueOfId( "".equals( chronologyId ) ? null : chronologyId );
    }
    
    static String getChronologyId( final Chronology chronology ) {
        return IdentifiableChronology.getIdByChronology( chronology.getClass() );
    }
    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy