Skip to content

Package: LessNode

LessNode

nameinstructionbranchcomplexitylinemethod
LessNode(AbstractNode, AbstractNode)
M: 0 C: 5
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 2
100%
M: 0 C: 1
100%
equals(Object)
M: 0 C: 11
100%
M: 0 C: 4
100%
M: 0 C: 3
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
hashCode()
M: 0 C: 6
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
M: 0 C: 1
100%
interpret(CommunicationManager)
M: 0 C: 93
100%
M: 0 C: 18
100%
M: 0 C: 10
100%
M: 0 C: 13
100%
M: 0 C: 1
100%
toString()
M: 0 C: 12
100%
M: 0 C: 0
100%
M: 0 C: 1
100%
M: 0 C: 2
100%
M: 0 C: 1
100%

Coverage

1: package pruefskript.parser.nodes;
2:
3: import basic.PruefskriptConstants;
4: import pruefskript.CommunicationManager;
5: import pruefskript.parser.exceptions.CheckScriptException;
6: import pruefskript.parser.exceptions.WrongNodeException;
7: import pruefskript.parser.values.AbstractReturnValue;
8: import pruefskript.parser.values.BooleanValue;
9:
10: /**
11: * LessNode.
12: *
13: * @author Group B5
14: *
15: */
16: public class LessNode extends AbstractBinaryOperationNode {
17:         /**
18:          * LessNode.
19:          *
20:          * @param operand1
21:          * AbstractNode
22:          * @param operand2
23:          * AbstractNode
24:          */
25:         public LessNode(final AbstractNode operand1, final AbstractNode operand2) {
26:                 super(operand1, operand2);
27:         }
28:
29:         @Override
30:         public String toString() {
31:                 return PruefskriptConstants.LESSNODETITLE + PruefskriptConstants.BRACKET_OPEN
32:                                 + super.toString() + PruefskriptConstants.BRACKET_CLOSE;
33:         }
34:
35:         @Override
36:         public boolean equals(final Object obj) {
37:•                return super.equals(obj) && obj instanceof LessNode;
38:
39:         }
40:
41:         @Override
42:         public int hashCode() {
43:                 return super.hashCode() + PruefskriptConstants.LESSNODE_HASHCODE;
44:         }
45:
46:         /**
47:          * Die beiden Operanten werden zunaechst separat ausgewertet. Handlet es sich bei beiden um
48:          * numerische Werte, wird ein ein Boolscher Wert erzeugt, indem geprueft wird, ob operant1
49:          * kleiner oeprant2 ist. Handelt es sich bei beiden um Versions-Werte, wird ein Boolscher Wert
50:          * erzeugt, indem grprueft wird, ob der Versionswert von operant 1 verglichen mit den von
51:          * operant2 kleiner 0 ist. Handelt es sich um String-Werte, wird ein boolscher Wert erzeugt
52:          * indem der String-Wert von Operant1 verglichen mit dem von Operant2 kleiner 0 ist.
53:          *
54:          * Ansonsten wird eine Exception geworfen.
55:          */
56:         @Override
57:         public BooleanValue interpret(final CommunicationManager mgr) throws CheckScriptException {
58:                 final BooleanValue result;
59:                 final AbstractReturnValue op1 = this.getOperand1().interpret(mgr);
60:                 final AbstractReturnValue op2 = this.getOperand2().interpret(mgr);
61:•                if (op1.isNumericValue() && op2.isNumericValue()) {
62:                         result = new BooleanValue(
63:•                                        op1.toNumericValue().getValue() < op2.toNumericValue().getValue());
64:•                } else if (op1.isVersionValue() && op2.isVersionValue()) {
65:                         result = new BooleanValue(op1.toVersionValue().getValue()
66:•                                        .compareToIgnoreCase(op2.toVersionValue().getValue()) < 0);
67:•                } else if (op1.isStringValue() && op2.isStringValue()) {
68:                         result = new BooleanValue(op1.toStringValue().getValue()
69:•                                        .compareToIgnoreCase(op2.toStringValue().getValue()) < 0);
70:                 } else {
71:                         throw new WrongNodeException(PruefskriptConstants.UNEXPECTED_BOOL_OPERATION);
72:                 }
73:                 return result;
74:         }
75: }