/*
* (c) Copyright 2010-2011 AgileBirds
*
* This file is part of OpenFlexo.
*
* OpenFlexo 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.
*
* OpenFlexo 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 OpenFlexo. If not, see <http://www.gnu.org/licenses/>.
*
*/
package org.openflexo.xmlcode.examples.example5;
import java.util.Enumeration;
import java.util.Vector;
import org.openflexo.xmlcode.XMLSerializable;
/**
* Class <code>Node</code> is intented to represent a graph's node object in XML coding/decoding example.
*
* @author <a href="mailto:Sylvain.Guerin@enst-bretagne.fr">Sylvain Guerin</a>
*/
public class Node implements XMLSerializable {
public Vector preConditions;
public Vector outgoingEdges;
public Graph graph;
public int identifier;
public Node() {
super();
outgoingEdges = new Vector();
preConditions = new Vector();
}
public Node(int anIdentifier, Graph aGraph) {
this();
identifier = anIdentifier;
graph = aGraph;
graph.nodes.add(this);
}
public String toShortString() {
return "Node:" + identifier;
}
@Override
public String toString() {
String returned = toShortString() + "\n";
for (Enumeration e = preConditions.elements(); e.hasMoreElements();) {
returned += e.nextElement().toString() + "\n";
}
for (Enumeration e = outgoingEdges.elements(); e.hasMoreElements();) {
returned += e.nextElement().toString() + "\n";
}
return returned;
}
}