package EDU.neu.ccs.demeter.tools.apstudio.graphedit;
import java.awt.*;
import java.io.*;
import java.util.*;
import EDU.neu.ccs.demeter.*;
import EDU.neu.ccs.demeter.common.tg.*;


import EDU.neu.ccs.demeter.*;
class Glob_Commalist implements java.util.Enumeration, Cloneable {
  protected Nonempty_Glob_Commalist first;
  public Nonempty_Glob_Commalist get_first() { return first; }
  public void set_first(Nonempty_Glob_Commalist new_first)
    { first = new_first; }
  Glob_Commalist() { super(); }
  public Glob_Commalist(Nonempty_Glob_Commalist first) {
    super();
    set_first(first);
  }
  public static Glob_Commalist parse(java.io.InputStream in) throws ParseException
    { return new Parser(in)._Glob_Commalist(); }
  public static Glob_Commalist parse(String s) {
    try { return parse(new java.io.ByteArrayInputStream(s.getBytes())); }
    catch (ParseException e) { throw new RuntimeException(e.toString()); }
  }
  void universal_trv0_bef(UniversalVisitor _v_) {
    _v_.before(this);
  }
  void universal_trv0_aft(UniversalVisitor _v_) {
    _v_.after(this);
  }
  void universal_trv0(UniversalVisitor _v_) {
    universal_trv0_bef(_v_);
    _v_.before_first(this, first);
    first.universal_trv0(_v_);
    _v_.after_first(this, first);
    universal_trv0_aft(_v_);
  }
  void toAllSubclasses_Program_trv_bef(ClassNameTranspVisitor cntv, EdgeVisitor aev) {  }
  void toAllSubclasses_Program_trv_aft(ClassNameTranspVisitor cntv, EdgeVisitor aev) {  }
  void toAllSubclasses_Program_trv(ClassNameTranspVisitor cntv, EdgeVisitor aev) {
    toAllSubclasses_Program_trv_bef(cntv, aev);
    first.toAllSubclasses_Program_trv(cntv, aev);
    toAllSubclasses_Program_trv_aft(cntv, aev);
  }
  void checkStars_ProgramBehavior_trv_bef(DummyVisitor dv) {  }
  void checkStars_ProgramBehavior_trv_aft(DummyVisitor dv) {  }
  void checkStars_ProgramBehavior_trv(DummyVisitor dv) {
    checkStars_ProgramBehavior_trv_bef(dv);
    first.checkStars_ProgramBehavior_trv(dv);
    checkStars_ProgramBehavior_trv_aft(dv);
  }
  void __trav_getFirst_StrategyGraph_trv_bef(__V_StrategyGraph_getFirst __v0) {  }
  void __trav_getFirst_StrategyGraph_trv_aft(__V_StrategyGraph_getFirst __v0) {  }
  void __trav_getFirst_StrategyGraph_trv(java.util.BitSet nodes, __V_StrategyGraph_getFirst __v0) {
    __trav_getFirst_StrategyGraph_trv_bef(__v0);
    { java.util.BitSet newnodes = new java.util.BitSet();
      newnodes.set(1);
      newnodes.and(nodes);
      if (!newnodes.equals(new java.util.BitSet()))
        first.__trav_getFirst_StrategyGraph_trv(newnodes, __v0); }
    __trav_getFirst_StrategyGraph_trv_aft(__v0);
  }
  void collectBypassVs_SGEdge_trv_bef(VecVisitor vv) {  }
  void collectBypassVs_SGEdge_trv_aft(VecVisitor vv) {  }
  void collectBypassVs_SGEdge_trv(VecVisitor vv) {
    collectBypassVs_SGEdge_trv_bef(vv);
    first.collectBypassVs_SGEdge_trv(vv);
    collectBypassVs_SGEdge_trv_aft(vv);
  }
  void collectOnlyThruVs_SGEdge_trv_bef(VecVisitor vv) {  }
  void collectOnlyThruVs_SGEdge_trv_aft(VecVisitor vv) {  }
  void collectOnlyThruVs_SGEdge_trv(VecVisitor vv) {
    collectOnlyThruVs_SGEdge_trv_bef(vv);
    first.collectOnlyThruVs_SGEdge_trv(vv);
    collectOnlyThruVs_SGEdge_trv_aft(vv);
  }
  void collectPartGlob_SGEdge_trv_bef(VecVisitor vv) {  }
  void collectPartGlob_SGEdge_trv_aft(VecVisitor vv) {  }
  void collectPartGlob_SGEdge_trv(VecVisitor vv) {
    collectPartGlob_SGEdge_trv_bef(vv);
    first.collectPartGlob_SGEdge_trv(vv);
    collectPartGlob_SGEdge_trv_aft(vv);
  }
  void collectSubclassGlob_SGEdge_trv_bef(VecVisitor vv) {  }
  void collectSubclassGlob_SGEdge_trv_aft(VecVisitor vv) {  }
  void collectSubclassGlob_SGEdge_trv(VecVisitor vv) {
    collectSubclassGlob_SGEdge_trv_bef(vv);
    first.collectSubclassGlob_SGEdge_trv(vv);
    collectSubclassGlob_SGEdge_trv_aft(vv);
  }
  void allGlobs_GlobSpec_trv_bef(GlobVisitor v) {  }
  void allGlobs_GlobSpec_trv_aft(GlobVisitor v) {  }
  void allGlobs_GlobSpec_trv(GlobVisitor v) {
    allGlobs_GlobSpec_trv_bef(v);
    first.allGlobs_GlobSpec_trv(v);
    allGlobs_GlobSpec_trv_aft(v);
  }
  void allClassGlobs_GlobSpec_trv_bef(GlobVisitor v) {  }
  void allClassGlobs_GlobSpec_trv_aft(GlobVisitor v) {  }
  void allClassGlobs_GlobSpec_trv(GlobVisitor v) {
    allClassGlobs_GlobSpec_trv_bef(v);
    first.allClassGlobs_GlobSpec_trv(v);
    allClassGlobs_GlobSpec_trv_aft(v);
  }
  void allEdgeGlobs_GlobSpec_trv_bef(GlobVisitor v) {  }
  void allEdgeGlobs_GlobSpec_trv_aft(GlobVisitor v) {  }
  void allEdgeGlobs_GlobSpec_trv(GlobVisitor v) {
    allEdgeGlobs_GlobSpec_trv_bef(v);
    first.allEdgeGlobs_GlobSpec_trv(v);
    allEdgeGlobs_GlobSpec_trv_aft(v);
  }

  private Nonempty_Glob_Commalist tail;
  public void addElement(Glob e) { 
    checktail(); 
    if (tail == null) {
      first = new Nonempty_Glob_Commalist(e,null); tail = first;
    } else {
	tail.set_next(new Nonempty_Glob_Commalist(e,null)); tail = tail.get_next();
    }
  }

  public void push(Glob e) { first = new Nonempty_Glob_Commalist(e,first); }

  public java.util.Enumeration elements() { return new Glob_Commalist(first); } 

  public int size() {
    int i= 0;
    for (java.util.Enumeration e=elements(); e.hasMoreElements(); i++)
	e.nextElement();
    return i;
  }
  public boolean isEmpty() { return (first == null); }

  public boolean hasMoreElements() { return (first != null); }

  public Object nextElement() {
    Glob car = first.get_it();
    first = first.get_next();
    return (Object) car;
  }

  private void checktail() {
    if (tail == null && first != null) {
	tail = first;
	while (tail.get_next() != null) tail = tail.get_next();
    }
  }
  public boolean contains(Glob e) {
    java.util.Enumeration en = this.elements();
    while (en.hasMoreElements())
	if (e.equals((Glob) en.nextElement())) return true;
    return false;
  }
}

