/*
* The contents of this file are subject to the Mozilla Public License
* Version 1.1 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
* License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is iSQL-Viewer, A Mutli-Platform Database Tool.
*
* The Initial Developer of the Original Code is iSQL-Viewer, A Mutli-Platform Database Tool.
* Portions created by Mark A. Kobold are Copyright (C) 2000-2007. All Rights Reserved.
*
* Contributor(s):
* Mark A. Kobold [mkobold <at> isqlviewer <dot> com].
*
* If you didn't download this code from the following link, you should check
* if you aren't using an obsolete version: http://www.isqlviewer.com
*/
package org.isqlviewer.swing.outline;
import javax.swing.tree.TreeModel;
/**
* TreeTableModel is the model used by a JTreeTable.
* <p>
* It extends TreeModel to add methods for getting inforamtion about the set of columns each node in the TreeTableModel
* may have. Each column, like a column in a TableModel, has a name and a type associated with it. Each node in the
* TreeTableModel can return a value for each of the columns and set that value if isCellEditable() returns true.
*
* @author Philip Milne
* @author Scott Violet
*/
public interface OutlineModel extends TreeModel {
/**
* Returns the number ofs availible column.
*/
public int getColumnCount();
/**
* Returns the name for column number <code>column</code>.
*/
public String getColumnName(int column);
/**
* Returns the type for column number <code>column</code>.
*/
public Class getColumnClass(int column);
/**
* Returns the value to be displayed for node <code>node</code>, at column number <code>column</code>.
*/
public Object getValueAt(Object node, int column);
/**
* Indicates whether the the value for node <code>node</code>, at column number <code>column</code> is
* editable.
*/
public boolean isCellEditable(Object node, int column);
/**
* Sets the value for node <code>node</code>, at column number <code>column</code>.
*/
public void setValueAt(Object aValue, Object node, int column);
}
|