src.com.ibm.as400.data.PcmlNode Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: PcmlNode.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2000 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.data;
import com.ibm.as400.access.Trace;
import java.io.Serializable;
import java.util.Vector;
import java.util.Enumeration;
import java.util.Hashtable;
abstract class PcmlNode implements Serializable, Cloneable { // @C2A
static final long serialVersionUID = -2955209136470053178L; // @C1A
private static Hashtable separatorsMap_;
private PcmlNode parent;
private PcmlNode prevSibling;
private PcmlNode nextSibling;
private PcmlNode firstChild;
private PcmlNode lastChild;
private int nbrChildren;
PcmlNode()
{
parent = null;
prevSibling = null;
nextSibling = null;
firstChild = null;
lastChild = null;
nbrChildren = 0;
}
// All pcml document nodes support clone.
// This is a deep clone in that the result is to
// clone an entire subtree. This method recursively
// clones its children.
public Object clone() // @C2A
{ // @C2A
PcmlNode node = null, child = null, newChild = null; // @C2A
try // @C2A
{ // @C2A
node = (PcmlNode) super.clone(); // @C2A
node.parent = null; // @C2A
node.firstChild = null; // @C2A
node.lastChild = null; // @C2A
node.prevSibling = null; // @C2A
node.nextSibling = null; // @C2A
node.nbrChildren = 0; // @C2A
} // @C2A
catch (CloneNotSupportedException e) // @C2A
{} // @C2A
return node; // @C2A
} // @C2A
// Custom deserialization post-processing
// This processing cannot be done during readObject() because
// references to parent objects in the document are not yet set
// due to the recursive nature of deserialization.
void readObjectPostprocessing() // @C1A
{ // @C1A
Enumeration items; // @C1A
PcmlNode child; // @C1A
if (getNbrChildren() == 0) // @C1A
return; // @C1A
items = getChildren(); // @C1A
while (items.hasMoreElements() ) // @C1A
{ // @C1A
child = (PcmlNode) items.nextElement(); // @C1A
child.readObjectPostprocessing(); // @C1A
} // @C1A
} // @C1A
public abstract String getName();
public abstract String getQualifiedName();
protected final PcmlNode getParent()
{
return parent;
}
private final void setParent(PcmlNode node)
{
parent = node;
}
protected final PcmlNode getNextSibling()
{
return nextSibling;
}
private final void setNextSibling(PcmlNode node)
{
nextSibling = node;
}
protected final PcmlNode getPrevSibling()
{
return prevSibling;
}
private final void setPrevSibling(PcmlNode node)
{
prevSibling = node;
}
protected Enumeration getChildren()
{
Vector v = new Vector(nbrChildren);
PcmlNode child = firstChild;
while (child != null)
{
v.addElement(child);
child = child.getNextSibling();
}
return v.elements();
}
protected final int getNbrChildren()
{
return nbrChildren;
}
protected final int getChildNbr()
{
int birthOrder = 0;
PcmlNode p = this;
while (p.getPrevSibling() != null)
{
birthOrder++;
p = p.getPrevSibling();
}
return birthOrder;
}
protected final boolean hasChildren()
{
return nbrChildren > 0;
}
protected void addChild(PcmlNode node)
{
if (!hasChildren())
{
firstChild = node;
}
else
{
lastChild.setNextSibling(node);
node.setPrevSibling(lastChild);
}
lastChild = node;
node.setParent(this);
nbrChildren++;
}
// Return the root node of this node
protected PcmlDocRoot getRootNode()
{
PcmlNode p = this;
PcmlNode q = parent; // @C4A
while ( q != null ) // @C4C
{
p = q; // @C4A
q = p.getParent(); // @C4C
}
if (p instanceof PcmlDocRoot)
{
return (PcmlDocRoot) p;
}
else
{
return null;
}
}
// Print the PcmlDescNode tree
protected void printTree(PcmlNode p, int level)
{
Enumeration items;
PcmlNode child;
for (int i = 0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy