/* * The University of Wales, Cardiff Triana Project Software License (Based * on the Apache Software License Version 1.1) * * Copyright (c) 2007 University of Wales, Cardiff. All rights reserved. * * Redistribution and use of the software in source and binary forms, with * or without modification, are permitted provided that the following * conditions are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * 3. The end-user documentation included with the redistribution, if any, * must include the following acknowledgment: "This product includes * software developed by the University of Wales, Cardiff for the Triana * Project (http://www.trianacode.org)." Alternately, this * acknowledgment may appear in the software itself, if and wherever * such third-party acknowledgments normally appear. * * 4. The names "Triana" and "University of Wales, Cardiff" must not be * used to endorse or promote products derived from this software * without prior written permission. For written permission, please * contact triana@trianacode.org. * * 5. Products derived from this software may not be called "Triana," nor * may Triana appear in their name, without prior written permission of * the University of Wales, Cardiff. * * 6. This software may not be sold, used or incorporated into any product * for sale to third parties. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN * NO EVENT SHALL UNIVERSITY OF WALES, CARDIFF OR ITS CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. * * ------------------------------------------------------------------------ * * This software consists of voluntary contributions made by many * individuals on behalf of the Triana Project. For more information on the * Triana Project, please see. http://www.trianacode.org. * * This license is based on the BSD license as adopted by the Apache * Foundation and is governed by the laws of England and Wales. * */ package org.trianacode.taskgraph; /** * A suite of utility methods that make handling control tasks easier * * @author Ian Wang * @version $Revision: 4048 $ */ public class NodeUtils { /** * Gets the top level node ignoring control tasks */ public static Node getTopLevelNode(Node node) { Node top = node.getTopLevelNode(); TaskGraph taskgraph = top.getTask().getParent(); while ((top != null) && (taskgraph.getControlTask() == top.getTask())) { if (top.isInputNode()) { top = top.getTask().getDataOutputNode(taskgraph.getDataOutputNodeCount() + top.getNodeIndex()) .getCable().getReceivingNode().getTopLevelNode(); } else { top = top.getTask().getDataInputNode(taskgraph.getDataInputNodeCount() + top.getNodeIndex()).getCable() .getSendingNode().getTopLevelNode(); } taskgraph = top.getTask().getParent(); } return top; } /** * Gets the top level task ignoring control tasks */ public static Task getTopLevelTask(Node node) { return getTopLevelNode(node).getTask(); } /** * Gets the bottom level node ignoring control tasks */ public static Node getBottomLevelNode(Node node) { Node bottom = node.getBottomLevelNode(); Node connect = null; if (bottom.isConnected()) { if (bottom.isInputNode()) { connect = bottom.getCable().getSendingNode(); } else { connect = bottom.getCable().getReceivingNode(); } } while (bottom.isConnected() && (bottom.getTask().getParent() != null) && (bottom.getTask().getParent().getControlTask() == connect.getTask())) { if (connect.isInputNode()) { bottom = connect.getTask().getDataOutputNode( connect.getNodeIndex() - connect.getTask().getParent().getDataInputNodeCount()) .getBottomLevelNode(); } else { bottom = connect.getTask().getDataInputNode( connect.getNodeIndex() - connect.getTask().getParent().getDataOutputNodeCount()) .getBottomLevelNode(); } if (bottom.isConnected()) { if (bottom.isInputNode()) { connect = bottom.getCable().getSendingNode(); } else { connect = bottom.getCable().getReceivingNode(); } } } return bottom; } /** * Gets the bottom level task ignoring control tasks */ public static Task getBottomLevelTask(Node node) { return getBottomLevelNode(node).getTask(); } }