/**
* This file Copyright (c) 2005-2010 Aptana, Inc. This program is
* dual-licensed under both the Aptana Public License and the GNU General
* Public license. You may elect to use one or the other of these licenses.
*
* This program is distributed in the hope that it will be useful, but
* AS-IS and WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, TITLE, or
* NONINFRINGEMENT. Redistribution, except as permitted by whichever of
* the GPL or APL you select, is prohibited.
*
* 1. For the GPL license (GPL), you can redistribute and/or modify this
* program under the terms of the GNU General Public License,
* Version 3, as published by the Free Software Foundation. You should
* have received a copy of the GNU General Public License, Version 3 along
* with this program; if not, write to the Free Software Foundation, Inc., 51
* Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Aptana provides a special exception to allow redistribution of this file
* with certain Eclipse Public Licensed code and certain additional terms
* pursuant to Section 7 of the GPL. You may view the exception and these
* terms on the web at http://www.aptana.com/legal/gpl/.
*
* 2. For the Aptana Public License (APL), this program and the
* accompanying materials are made available under the terms of the APL
* v1.0 which accompanies this distribution, and is available at
* http://www.aptana.com/legal/apl/.
*
* You may view the GPL, Aptana's exception and additional terms, and the
* APL in the file titled license.html at the root of the corresponding
* plugin containing this source file.
*
* Any modifications to this file must keep this entire header intact.
*/
package com.aptana.ide.installer.wizard;
import java.util.ArrayList;
import java.util.List;
import com.aptana.ide.update.manager.IPlugin;
import com.aptana.ide.update.manager.InstallerCategory;
/**
* @author Michael Xia (mxia@aptana.com)
*/
public class PluginTreeNode
{
private Object data;
private boolean installed;
private PluginTreeNode parent;
private List<PluginTreeNode> children;
public PluginTreeNode(Object data)
{
this.data = data;
children = new ArrayList<PluginTreeNode>();
}
/**
* Adds a child to the node.
*
* @param child
* the child node
*/
public void add(PluginTreeNode child)
{
children.add(child);
}
/**
* Removes all elements that belong to this node.
*/
public void clear()
{
data = null;
installed = false;
parent = null;
for (PluginTreeNode child : children)
{
child.clear();
}
children.clear();
}
/**
* Returns the data object that the node contains.
*
* @return the data object
*/
public Object getData()
{
return data;
}
/**
* Returns the id of the node.
*
* @return the id
*/
public String getID()
{
if (data == null)
{
return ""; //$NON-NLS-1$
}
if (data instanceof InstallerCategory)
{
return ((InstallerCategory) data).getID();
}
if (data instanceof IPlugin)
{
return ((IPlugin) data).getId();
}
return data.toString();
}
/**
* Returns whether or not the node represents a plug-in that is already installed.
*
* @return true if the plug-in is installed, false otherwise
*/
public boolean isInstalled()
{
return installed;
}
/**
* Returns the direct child of this node that has the specific id.
*
* @param id
* the id
* @return the child that matches the id
*/
public PluginTreeNode getChild(String id)
{
for (PluginTreeNode child : children)
{
if (child.getID().equals(id))
{
return child;
}
}
return null;
}
/**
* Returns all the direct children of this node.
*
* @return an array of all the children
*/
public PluginTreeNode[] getChildren()
{
return children.toArray(new PluginTreeNode[children.size()]);
}
/**
* Returns the parent of this node.
*
* @return the parent node
*/
public PluginTreeNode getParent()
{
return parent;
}
/**
* Sets the data object this node represents.
*
* @param data
* the data object
*/
public void setData(Object data)
{
this.data = data;
}
/**
* Sets whether or not the plug-in this node represents is installed.
*
* @param installed
* true if the plug-in is installed, false otherwise
*/
public void setInstalled(boolean installed)
{
this.installed = installed;
}
/**
* Sets the parent of this node.
*
* @param parent
* the parent node
*/
public void setParent(PluginTreeNode parent)
{
this.parent = parent;
}
}