com.alee.managers.plugin.data.PluginLibrary Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of weblaf-core Show documentation
Show all versions of weblaf-core Show documentation
Core components for WebLaf
/*
* 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.plugin.data;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import java.io.Serializable;
/**
* Plugin library information data class.
*
* @author Mikle Garin
* @see How to use PluginManager
* @see com.alee.managers.plugin.PluginManager
*/
@XStreamAlias ( "PluginLibrary" )
public class PluginLibrary implements Serializable
{
/**
* Application-wide unique library ID.
* This should be the same in different version of the same library.
* Will be used to warn that this library getting loaded more than once, possibly with different version.
*/
private String id;
/**
* Library title.
*/
private String title;
/**
* Short library description.
* Will be useful to understand what the hell this library is doing in this plugin.
*/
private String description;
/**
* Plugin version.
* Made string as different plugins might use lots of different versioning types.
* Simply put any plugin version string here so version can be compared.
*/
private String version;
/**
* Library file path relative to plugin file location.
*/
private String file;
/**
* Constructs new plugin library information data object.
*/
public PluginLibrary ()
{
super ();
}
/**
* Constructs new plugin library information data object with the specified values.
*
* @param id application-wide unique library ID
* @param title library title
* @param description library description
* @param version library version
* @param file library file path
*/
public PluginLibrary ( final String id, final String title, final String description, final String version, final String file )
{
super ();
this.id = id;
this.title = title;
this.description = description;
this.version = version;
this.file = file;
}
/**
* Returns plugin library ID.
*
* @return plugin library ID
*/
public String getId ()
{
return id;
}
/**
* Sets plugin library ID.
*
* @param id new plugin library ID
*/
public void setId ( final String id )
{
this.id = id;
}
/**
* Returns plugin library title.
*
* @return plugin library title
*/
public String getTitle ()
{
return title;
}
/**
* Sets plugin library title.
*
* @param title new plugin library title
*/
public void setTitle ( final String title )
{
this.title = title;
}
/**
* Returns plugin library description.
*
* @return plugin library description
*/
public String getDescription ()
{
return description;
}
/**
* Sets plugin library description.
*
* @param description new plugin library description
*/
public void setDescription ( final String description )
{
this.description = description;
}
/**
* Returns plugin library version.
*
* @return plugin library version
*/
public String getVersion ()
{
return version;
}
/**
* Sets plugin library version.
*
* @param version new plugin library version
*/
public void setVersion ( final String version )
{
this.version = version;
}
/**
* Returns plugin library file path relative to plugin file location.
*
* @return plugin library file path relative to plugin file location
*/
public String getFile ()
{
return file;
}
/**
* Sets plugin library file path relative to plugin file location.
*
* @param file new plugin library file path
*/
public void setFile ( final String file )
{
this.file = file;
}
@Override
public String toString ()
{
return title + " " + version;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy