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

com.alee.managers.version.VersionInfo Maven / Gradle / Ivy

There is a newer version: 1.2.14
Show newest version
/*
 * This file is part of WebLookAndFeel library.
 *
 * WebLookAndFeel library is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * WebLookAndFeel library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with WebLookAndFeel library.  If not, see .
 */

package com.alee.managers.version;

import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import com.thoughtworks.xstream.annotations.XStreamConverter;

import java.io.Serializable;

/**
 * Web Look and Feel library version information class.
 */

@XStreamAlias ( "VersionInfo" )
public class VersionInfo implements Serializable
{
    /**
     * Full library name.
     */
    @XStreamAsAttribute
    private String name;

    /**
     * Version number.
     */
    @XStreamAsAttribute
    private int version;

    /**
     * Build number.
     */
    @XStreamAsAttribute
    private int build;

    /**
     * Build type.
     */
    @XStreamAsAttribute
    private String type;

    /**
     * Version release date.
     */
    @XStreamAsAttribute
    @XStreamConverter ( VersionDateConverter.class )
    private long date;

    /**
     * Short version description.
     */
    @XStreamAsAttribute
    private String comment;

    /**
     * Constructs empty version information class.
     */
    public VersionInfo ()
    {
        super ();
    }

    /**
     * Returns full library name.
     *
     * @return full library name
     */
    public String getName ()
    {
        return name;
    }

    /**
     * Sets full library name.
     *
     * @param name full library name
     */
    public void setName ( final String name )
    {
        this.name = name;
    }

    /**
     * Returns library version.
     *
     * @return library version
     */
    public int getVersion ()
    {
        return version;
    }

    /**
     * Sets library version.
     *
     * @param version library version
     */
    public void setVersion ( final int version )
    {
        this.version = version;
    }

    /**
     * Returns build number.
     *
     * @return build number
     */
    public int getBuild ()
    {
        return build;
    }

    /**
     * Sets build number.
     *
     * @param build build number
     */
    public void setBuild ( final int build )
    {
        this.build = build;
    }

    /**
     * Returns build type.
     *
     * @return build type
     */
    public String getType ()
    {
        return type;
    }

    /**
     * Sets build type.
     *
     * @param type build type
     */
    public void setType ( final String type )
    {
        this.type = type;
    }

    /**
     * Returns version release date.
     *
     * @return version release date
     */
    public long getDate ()
    {
        return date;
    }

    /**
     * Sets version release date.
     *
     * @param date version release date
     */
    public void setDate ( final long date )
    {
        this.date = date;
    }

    /**
     * Returns short version description.
     *
     * @return short version description
     */
    public String getComment ()
    {
        return comment;
    }

    /**
     * Sets short version description.
     *
     * @param comment short version description
     */
    public void setComment ( final String comment )
    {
        this.comment = comment;
    }

    /**
     * Returns a negative integer, zero, or a positive integer as version is less than, equal to, or greater than the specified one.
     *
     * @param version version to compare with
     * @return a negative integer, zero, or a positive integer as version is less than, equal to, or greater than the specified one
     */
    public int compareTo ( final VersionInfo version )
    {
        if ( this.version < version.getVersion () )
        {
            return -1;
        }
        else if ( this.version > version.getVersion () )
        {
            return 1;
        }
        else
        {
            if ( this.build < version.getBuild () )
            {
                return -1;
            }
            if ( this.build > version.getBuild () )
            {
                return 1;
            }
            else
            {
                return 0;
            }
        }
    }

    /**
     * {@inheritDoc}
     */
    public String toString ()
    {
        return name + " v" + version + "." + build + ( build > 0 ? " (" + type + ")" : "" );
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy