Statistics
| Revision:

root / trunk / org.gvsig.postgresql / org.gvsig.postgresql.provider / src / main / java / org / gvsig / postgresql / dal / expressionbuilderformatter / JsonValue.java @ 999

History | View | Annotate | Download (2.04 KB)

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

    
3
import java.text.MessageFormat;
4
import java.util.List;
5
import org.apache.commons.lang3.StringUtils;
6
import org.gvsig.expressionevaluator.ExpressionBuilder;
7
import static org.gvsig.expressionevaluator.ExpressionBuilder.FUNCTION_IFNULL;
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
import org.gvsig.tools.dataTypes.DataTypes;
13

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

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

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

    
28
    @Override
29
    public boolean canApply(Value value) {
30
        if (value instanceof Function) {
31
            if (value instanceof ExpressionBuilder.Function) {
32
                boolean canApply = StringUtils.equalsIgnoreCase(ExpressionBuilder.FUNCTION_JSON_VALUE, ((Function) value).name());
33
                return canApply;
34
            }
35
        }
36
        return false;
37
    }
38

    
39
    @Override
40
    public String format(Value function) {
41
        List<Value> parameters = ((Function) function).parameters();
42
        String p1 = parameters.get(0).toString(formatter);
43
        String p2 = parameters.get(1).toString(formatter);
44
        String p3 = null;
45
        if(parameters.size()==3) {
46
          p3 = parameters.get(2).toString(formatter).replace("'", "");
47
        }
48
        
49
        String r;
50
        if (p3 != null) {
51
            r = MessageFormat.format(
52
                    "jsonb_path_query_first({0}::jsonb, {1})::{2}",
53
                    p1,
54
                    p2,
55
                    p3
56
            );
57
        } else {
58
            r = MessageFormat.format(
59
                    "jsonb_path_query_first({0}::jsonb, {1})",
60
                    p1,
61
                    p2
62
            );
63
        }
64
        return r;
65

    
66
    }
67

    
68
}