net.sourceforge.squirrel_sql.fw.sql.ISQLDriver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of fw Show documentation
Show all versions of fw Show documentation
The framework library contains utility classes that are generic and useful for building applications
that introspect a database via JDBC. These are not intended to be SQuirreLSQL-specific and could be
used by other projects JDBC front-end applications. This project is guaranteed to have no code
dependencies on other SQuirreLSQL projects and could therefore be used when building a different
JDBC front-end application.
package net.sourceforge.squirrel_sql.fw.sql;
/*
* Copyright (C) 2001-2002 Colin Bell
* [email protected]
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
import java.beans.PropertyChangeListener;
import net.sourceforge.squirrel_sql.fw.id.IHasIdentifier;
import net.sourceforge.squirrel_sql.fw.id.IIdentifier;
import net.sourceforge.squirrel_sql.fw.persist.ValidationException;
import net.sourceforge.squirrel_sql.fw.util.beanwrapper.StringWrapper;
public interface ISQLDriver extends IHasIdentifier, Comparable
{
/**
* JavaBean property names for this class.
*/
public interface IPropertyNames
{
String DRIVER_CLASS = "driverClassName";
String ID = "identifier";
String JARFILE_NAME = "jarFileName";
String JARFILE_NAMES = "jarFileNames";
String NAME = "name";
String URL = "url";
String WEBSITE_URL = "websiteUrl";
}
/**
* Assign data from the passed ISQLDriver
to this one. This
* does not copy the identifier.
*
* @param rhs ISQLDriver
to copy data from.
*
* @exception ValidationException
* Thrown if an error occurs assigning data from
* rhs
.
*/
void assignFrom(ISQLDriver rhs) throws ValidationException;
/**
* Compare this ISQLDriver to another object. If the passed object
* is a ISQLDriver, then the getName() functions of the two
* ISQLDriver objects are used to compare them. Otherwise, it throws a
* ClassCastException (as ISQLDriver objects are comparable only to
* other ISQLDriver objects).
*/
int compareTo(ISQLDriver rhs);
IIdentifier getIdentifier();
String getDriverClassName();
void setDriverClassName(String driverClassName)
throws ValidationException;
/**
* @deprecated Replaced by getJarFileURLs().
*/
String getJarFileName();
void setJarFileName(String value) throws ValidationException;
StringWrapper[] getJarFileNameWrappers();
StringWrapper getJarFileNameWrapper(int idx) throws ArrayIndexOutOfBoundsException;
void setJarFileNameWrappers(StringWrapper[] value);
void setJarFileNameWrapper(int idx, StringWrapper value) throws ArrayIndexOutOfBoundsException;
String[] getJarFileNames();
void setJarFileNames(String[] values);
String getUrl();
void setUrl(String url) throws ValidationException;
String getName();
void setName(String name) throws ValidationException;
boolean isJDBCDriverClassLoaded();
void setJDBCDriverClassLoaded(boolean cl);
void addPropertyChangeListener(PropertyChangeListener listener);
void removePropertyChangeListener(PropertyChangeListener listener);
String getWebSiteUrl();
void setWebSiteUrl(String url) throws ValidationException;
}