Clover coverage report - Java Language Levels Test Coverage (javalanglevels-20120305-r5436)
Coverage timestamp: Sun Mar 4 2012 22:02:46 CST
file stats: LOC: 111   Methods: 9
NCLOC: 70   Classes: 1
 
 Source file Conditionals Statements Methods TOTAL
ComplexSuperConstructorInvocation.java 37.5% 53.2% 44.4% 48.6%
coverage coverage
 1    package edu.rice.cs.javalanglevels.tree;
 2   
 3    import edu.rice.cs.javalanglevels.SourceInfo;
 4   
 5    /**
 6    * Class ComplexSuperConstructorInvocation, a component of the JExpressionIF composite hierarchy.
 7    * Note: null is not allowed as a value for any field.
 8    * @version Generated automatically by ASTGen at Sun Mar 04 22:01:28 CST 2012
 9    */
 10    public class ComplexSuperConstructorInvocation extends SuperConstructorInvocation {
 11    private final Expression _enclosing;
 12   
 13    /**
 14    * Constructs a ComplexSuperConstructorInvocation.
 15    * @throws java.lang.IllegalArgumentException If any parameter to the constructor is null.
 16    */
 17  6 public ComplexSuperConstructorInvocation(SourceInfo in_sourceInfo, Expression in_enclosing, ParenthesizedExpressionList in_arguments) {
 18  6 super(in_sourceInfo, in_arguments);
 19   
 20  6 if (in_enclosing == null) {
 21  0 throw new java.lang.IllegalArgumentException("Parameter 'enclosing' to the ComplexSuperConstructorInvocation constructor was null. This class may not have null field values.");
 22    }
 23  6 _enclosing = in_enclosing;
 24    }
 25   
 26  12 final public Expression getEnclosing() { return _enclosing; }
 27   
 28  0 public <RetType> RetType visit(JExpressionIFVisitor<RetType> visitor) { return visitor.forComplexSuperConstructorInvocation(this); }
 29  0 public void visit(JExpressionIFVisitor_void visitor) { visitor.forComplexSuperConstructorInvocation(this); }
 30   
 31    /**
 32    * Implementation of toString that uses
 33    * {@link #output} to generated nicely tabbed tree.
 34    */
 35  0 public java.lang.String toString() {
 36  0 java.io.StringWriter w = new java.io.StringWriter();
 37  0 output(w);
 38  0 return w.toString();
 39    }
 40   
 41    /**
 42    * Prints this object out as a nicely tabbed tree.
 43    */
 44  0 public void output(java.io.Writer writer) {
 45  0 outputHelp(new TabPrintWriter(writer, 2));
 46    }
 47   
 48  2 public void outputHelp(TabPrintWriter writer) {
 49  2 writer.print("ComplexSuperConstructorInvocation" + ":");
 50  2 writer.indent();
 51   
 52  2 writer.startLine("");
 53  2 writer.print("sourceInfo = ");
 54  2 SourceInfo temp_sourceInfo = getSourceInfo();
 55  2 if (temp_sourceInfo == null) {
 56  0 writer.print("null");
 57    } else {
 58  2 writer.print(temp_sourceInfo);
 59    }
 60   
 61  2 writer.startLine("");
 62  2 writer.print("enclosing = ");
 63  2 Expression temp_enclosing = getEnclosing();
 64  2 if (temp_enclosing == null) {
 65  0 writer.print("null");
 66    } else {
 67  2 temp_enclosing.outputHelp(writer);
 68    }
 69   
 70  2 writer.startLine("");
 71  2 writer.print("arguments = ");
 72  2 ParenthesizedExpressionList temp_arguments = getArguments();
 73  2 if (temp_arguments == null) {
 74  0 writer.print("null");
 75    } else {
 76  2 temp_arguments.outputHelp(writer);
 77    }
 78  2 writer.unindent();
 79    }
 80   
 81    /**
 82    * Implementation of equals that is based on the values
 83    * of the fields of the object. Thus, two objects
 84    * created with identical parameters will be equal.
 85    */
 86  1 public boolean equals(java.lang.Object obj) {
 87  0 if (obj == null) return false;
 88  1 if ((obj.getClass() != this.getClass()) || (obj.hashCode() != this.hashCode())) {
 89  1 return false;
 90    } else {
 91  0 ComplexSuperConstructorInvocation casted = (ComplexSuperConstructorInvocation) obj;
 92  0 if (! (getEnclosing().equals(casted.getEnclosing()))) return false;
 93  0 if (! (getArguments().equals(casted.getArguments()))) return false;
 94  0 return true;
 95    }
 96    }
 97   
 98    /**
 99    * Implementation of hashCode that is consistent with
 100    * equals. The value of the hashCode is formed by
 101    * XORing the hashcode of the class object with
 102    * the hashcodes of all the fields of the object.
 103    */
 104  0 protected int generateHashCode() {
 105  0 int code = getClass().hashCode();
 106  0 code ^= 0;
 107  0 code ^= getEnclosing().hashCode();
 108  0 code ^= getArguments().hashCode();
 109  0 return code;
 110    }
 111    }