// This file is automatically generated by DemeterJ.

EqualVisitor {
  {{
    private java.util.Stack history = new java.util.Stack();
    public EqualVisitor(Object obj) {
      history.push(obj);
    }
  }}

  before Main {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    Object temp1 = host.get_s();
    Object temp2 = ((Main) obj).get_s();
    if(temp1 == null && temp2 == null) {}
    else if(temp1 == null ||
            temp2 == null ||
            !temp1.equals(temp2)) { is_equal = false; return; }
  }}

  before Shape {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
  }}

  before Rectangle {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_x() == ((Rectangle) obj).get_x();
    is_equal = is_equal && host.get_y() == ((Rectangle) obj).get_y();
    is_equal = is_equal && host.get_width() == ((Rectangle) obj).get_width();
    is_equal = is_equal && host.get_height() == ((Rectangle) obj).get_height();
  }}

  before Circle {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_x() == ((Circle) obj).get_x();
    is_equal = is_equal && host.get_y() == ((Circle) obj).get_y();
    is_equal = is_equal && host.get_radius() == ((Circle) obj).get_radius();
  }}

  before -> Combination, shape_list, Shape_List {{
    if (is_equal) {
      Combination obj = (Combination) history.peek();
      Object temp3 = obj.get_shape_list();
      if(temp3==null) { is_equal = false; return; }
      history.push(temp3);
    }
  }}
  after -> Combination, shape_list, Shape_List {{
    if (is_equal) history.pop();
  }}

  before Combination {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
  }}

  before PrintVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_indent() == ((PrintVisitor) obj).get_indent();
    is_equal = is_equal && host.get_needSpace() == ((PrintVisitor) obj).get_needSpace();
  }}

  before CopyVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    Object temp4 = host.get_copy();
    Object temp5 = ((CopyVisitor) obj).get_copy();
    if(temp4 == null && temp5 == null) {}
    else if(temp4 == null ||
            temp5 == null ||
            !temp4.equals(temp5)) { is_equal = false; return; }
  }}

  before SubgraphVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_is_equal() == ((SubgraphVisitor) obj).get_is_equal();
  }}

  before EqualVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_is_equal() == ((EqualVisitor) obj).get_is_equal();
  }}

  before DisplayVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_indent() == ((DisplayVisitor) obj).get_indent();
  }}

  before TraceVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
    is_equal = is_equal && host.get_indent() == ((TraceVisitor) obj).get_indent();
  }}

  before UniversalVisitor {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
  }}

  before -> Shape_List, first, Nonempty_Shape_List {{
    if (is_equal) {
      Shape_List obj = (Shape_List) history.peek();
      Object temp6 = obj.get_first();
      if(temp6==null) { is_equal = false; return; }
      history.push(temp6);
    }
  }}
  after -> Shape_List, first, Nonempty_Shape_List {{
    if (is_equal) history.pop();
  }}

  before Shape_List {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
  }}

  before -> Nonempty_Shape_List, it, Shape {{
    if (is_equal) {
      Nonempty_Shape_List obj = (Nonempty_Shape_List) history.peek();
      Object temp7 = obj.get_it();
      if(temp7==null) { is_equal = false; return; }
      history.push(temp7);
    }
  }}
  after -> Nonempty_Shape_List, it, Shape {{
    if (is_equal) history.pop();
  }}

  before -> Nonempty_Shape_List, next, Nonempty_Shape_List {{
    if (is_equal) {
      Nonempty_Shape_List obj = (Nonempty_Shape_List) history.peek();
      Object temp8 = obj.get_next();
      if(temp8==null) { is_equal = false; return; }
      history.push(temp8);
    }
  }}
  after -> Nonempty_Shape_List, next, Nonempty_Shape_List {{
    if (is_equal) history.pop();
  }}

  before Nonempty_Shape_List {{
    Object obj = history.peek();
    is_equal = is_equal && obj.getClass().equals(host.getClass());
    if(!is_equal) return;
  }}

  return boolean {{ is_equal }}
}