// // Copyright (C) 2006 United States Government as represented by the // Administrator of the National Aeronautics and Space Administration // (NASA). All Rights Reserved. // // This software is distributed under the NASA Open Source Agreement // (NOSA), version 1.3. The NOSA has been approved by the Open Source // Initiative. See the file NOSA-1.3-JPF at the top of the distribution // directory tree for the complete NOSA document. // // THE SUBJECT SOFTWARE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY OF ANY // KIND, EITHER EXPRESSED, IMPLIED, OR STATUTORY, INCLUDING, BUT NOT // LIMITED TO, ANY WARRANTY THAT THE SUBJECT SOFTWARE WILL CONFORM TO // SPECIFICATIONS, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR // A PARTICULAR PURPOSE, OR FREEDOM FROM INFRINGEMENT, ANY WARRANTY THAT // THE SUBJECT SOFTWARE WILL BE ERROR FREE, OR ANY WARRANTY THAT // DOCUMENTATION, IF PROVIDED, WILL CONFORM TO THE SUBJECT SOFTWARE. // package gov.nasa.jpf.util.script; import java.io.PrintWriter; import java.util.Iterator; public abstract class ScriptElementContainer extends ScriptElement implements Iterable <ScriptElement> { protected class SECIterator implements Iterator<ScriptElement>, Cloneable { SECIterator prev; // to build ad hoc stacks ScriptElement cur; SECIterator () { cur = firstChild; } public boolean hasNext() { return (cur != null); } public ScriptElement next() { if (cur != null) { ScriptElement ret = cur; cur = cur.nextSibling; return ret; } else { return null; } } public void remove() { throw new UnsupportedOperationException("no ScriptElement removal supported"); } public SECIterator getPrev() { return prev; } public void setPrev (SECIterator it) { prev = it; } public Object clone() { try { // need to deep copy iterators SECIterator it = (SECIterator)super.clone(); if (prev != null) { it.prev = (SECIterator) prev.clone(); } return it; } catch (CloneNotSupportedException cnsx) { return null; // can't happen, just compiler pleasing } } } ScriptElement firstChild; ScriptElementContainer (ScriptElement parent, int line) { super(parent, line); } public ScriptElement getFirstChild () { return firstChild; } /** * beware, this sets the nextSibling */ public void add (ScriptElement e) { e.nextSibling = null; if (firstChild == null) { firstChild = e; } else { ScriptElement p=firstChild; while (p.nextSibling != null) p=p.nextSibling; p.nextSibling = e; } } public int getNumberOfChildren() { int n=0; ScriptElement e = firstChild; while (e != null) { n++; e = e.getNextSibling(); } return n; } public SECIterator iterator () { return new SECIterator(); } void dump (PrintWriter w, int level, ScriptElement elem) { try { while (elem != null) { for (int i=0; i<level; i++) { w.print(" "); } w.print(elem); if (elem instanceof ScriptElementContainer) { ScriptElementContainer c = (ScriptElementContainer) elem; w.println(" {"); dump(w, level+1, c.getFirstChild()); for (int i=0; i<level; i++) { w.print(" "); } w.println("}"); } else { w.println(); } elem = elem.getNextSibling(); } } catch (Throwable t) { t.printStackTrace(); } } protected String toString (String type) { StringBuilder sb = new StringBuilder(); if (type != null) { sb.append(type); sb.append(' '); } sb.append("{"); int i=0; for (ScriptElement e = firstChild; e != null; e = e.nextSibling) { if (i++ > 0) { sb.append(','); } sb.append(e); } sb.append("}"); return sb.toString(); } public String toString() { return toString(null); } public void dump (PrintWriter w) { dump(w, 0, firstChild); } public void processChildren(ElementProcessor p) { for (ScriptElement e = firstChild; e != null; e = e.nextSibling) { e.process(p); } } }