Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.library / org.gvsig.expressionevaluator / org.gvsig.expressionevaluator.lib / org.gvsig.expressionevaluator.lib.impl / src / main / java / org / gvsig / expressionevaluator / impl / function / operator / DivOperator.java @ 44198

History | View | Annotate | Download (3.05 KB)

1
package org.gvsig.expressionevaluator.impl.function.operator;
2

    
3
import org.gvsig.expressionevaluator.Code;
4
import org.gvsig.expressionevaluator.Function;
5
import org.gvsig.expressionevaluator.Interpreter;
6
import org.gvsig.expressionevaluator.Optimizer;
7

    
8
public class DivOperator 
9
        extends AbstractBinaryOperator 
10
        implements Optimizer.FunctionOptimizer
11
    {
12
    public static final String NAME = "/";
13

    
14
    public DivOperator() {
15
        super(Function.GROUP_NUMERIC, NAME);
16
    }
17

    
18
    @Override
19
    public boolean allowConstantFolding() {
20
        return true;
21
    }
22
    
23
    @Override
24
    public Object call(Interpreter interpreter, Object op1, Object op2) {               
25
        int type = this.getType(op1, op2);
26
        if( (type & TYPE_DOUBLE) == TYPE_DOUBLE ) {
27
            double value = ((Number) op1).doubleValue() / ((Number) op2).doubleValue();
28
            return value;
29
        }
30
        if( (type & TYPE_FLOAT) == TYPE_FLOAT ) {
31
            double value = ((Number) op1).floatValue() / ((Number) op2).floatValue();
32
            return value;
33
        }
34
        if( (type & TYPE_LONG) == TYPE_LONG ) {
35
            long value = ((Number) op1).longValue() / ((Number) op2).longValue();
36
            return value;
37
        }
38
        if( (type & TYPE_INT) == TYPE_INT ) {
39
            int value = ((Number) op1).intValue() / ((Number) op2).intValue();
40
            return value;
41
        }
42
        throw new IllegalArgumentException("Types not allowed in '"+name()+"' operand.");
43
    }
44
    
45

    
46
    @Override
47
    public Code optimize(Optimizer optimizer, Code.Caller caller) {
48
        Code op1 = optimizer.optimize(caller.parameters().get(0));
49
        Code op2 = optimizer.optimize(caller.parameters().get(1));
50
        
51
        if ( op1.code() == Code.CONSTANT && op2.code() == Code.CONSTANT) {
52
            Code newCode = optimizer.getCodeBuilder().constant(
53
                    call(
54
                            optimizer.getInterpreter(), 
55
                            ((Code.Constant)op1).value(), 
56
                            ((Code.Constant)op2).value()
57
                    )
58
            );
59
            return newCode;
60
            
61
        } else if ( op1.code() == Code.CONSTANT ) {
62
            Object value = ((Code.Constant)op1).value();
63
            if( value instanceof Number ) {
64
                double n = ((Number) value).doubleValue();
65
                if( n == 0 ) {
66
                    Code newCode = optimizer.getCodeBuilder().constant(0);
67
                    return newCode;
68
                }
69
            }
70
            Code newCode = optimizer.getCodeBuilder().operator(caller.name(), op1, op2);
71
            return newCode;
72

    
73
        } else if ( op2.code() == Code.CONSTANT ) {
74
            Object value = ((Code.Constant)op2).value();
75
            if( value instanceof Number ) {
76
                double n = ((Number) value).doubleValue();
77
                if( n == 1 ) {
78
                    return op1;
79
                }
80
            }
81
            Code newCode = optimizer.getCodeBuilder().operator(caller.name(), op1, op2);
82
            return newCode;
83
        }
84

    
85
        return caller;
86
    }
87
    
88
}