Statistics
| Revision:

gvsig-mssqlserver / trunk / org.gvsig.mssqlserver / org.gvsig.mssqlserver.provider / src / main / java / org / gvsig / mssqlserver / dal / expressionbuilderformatter / ST_Disjoint.java @ 218

History | View | Annotate | Download (1.32 KB)

1
package org.gvsig.mssqlserver.dal.expressionbuilderformatter;
2

    
3
import java.text.MessageFormat;
4
import java.util.List;
5
import org.apache.commons.lang3.StringUtils;
6

    
7
import org.gvsig.expressionevaluator.ExpressionBuilder;
8
import org.gvsig.expressionevaluator.ExpressionBuilder.Function;
9
import org.gvsig.expressionevaluator.ExpressionBuilder.Value;
10
import org.gvsig.expressionevaluator.Formatter;
11
import org.gvsig.fmap.dal.SQLBuilder;
12

    
13
/**
14
 *
15
 * @author jjdelcerro
16
 */
17
class ST_Disjoint implements Formatter<Value> {
18

    
19
    private final Formatter<Value> formatter;
20
    private final SQLBuilder builder;
21

    
22
    public ST_Disjoint(SQLBuilder builder, Formatter<Value> formatter) {
23
        this.builder = builder;
24
        this.formatter = formatter;
25
    }
26

    
27
    @Override
28
    public boolean canApply(Value value) {
29
        if (value instanceof Function) {
30
            return StringUtils.equalsIgnoreCase(ExpressionBuilder.FUNCTION_ST_DISJOINT, ((Function) value).name());
31
        }
32
        return false;
33
    }
34

    
35
    @Override
36
    public String format(Value function) {
37
        List<Value> parameters = ((Function) function).parameters();
38
        String p1 = parameters.get(0).toString(formatter);
39
        String p2 = parameters.get(1).toString(formatter);
40
        String r = MessageFormat.format("(({0}).ST_Disjoint({1})=1)", p1, p2);
41
        return r;
42
    }
43

    
44
}