Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.plugin / org.gvsig.sqlite / org.gvsig.sqlite.provider / src / main / java / org / gvsig / sqlite / dal / expressionbuilderformatter / Date.java @ 47579

History | View | Annotate | Download (2.34 KB)

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

    
3
import java.time.LocalDate;
4
import java.time.LocalDateTime;
5
import java.time.ZoneId;
6
import java.time.format.DateTimeFormatter;
7
import java.time.temporal.ChronoField;
8
import java.time.temporal.TemporalField;
9
import java.util.List;
10
import org.apache.commons.lang3.StringUtils;
11
import org.gvsig.expressionevaluator.ExpressionBuilder;
12
import static org.gvsig.expressionevaluator.ExpressionBuilder.FUNCTION_TIME;
13
import org.gvsig.expressionevaluator.ExpressionBuilder.Function;
14
import org.gvsig.expressionevaluator.ExpressionBuilder.Value;
15
import org.gvsig.expressionevaluator.Formatter;
16
import org.gvsig.fmap.dal.SQLBuilder;
17
import org.gvsig.fmap.dal.store.jdbc2.spi.expressionbuilder.formatters.$Constant;
18
import org.gvsig.tools.dataTypes.DataTypeUtils;
19

    
20
/**
21
 *
22
 * @author jjdelcerro
23
 */
24
public class Date implements Formatter<Value> {
25
    
26
    private final SQLBuilder sqlbuilder;
27
    private final Formatter<Value> formatter;
28
    
29
    public Date(SQLBuilder sqlbuilder, Formatter<Value> formatter) {
30
        this.sqlbuilder = sqlbuilder;
31
        this.formatter = formatter;
32
    }
33
    
34
    @Override
35
    public boolean canApply(ExpressionBuilder.Value value) {
36
        if (value instanceof ExpressionBuilder.Function) {
37
            if( StringUtils.equalsIgnoreCase(ExpressionBuilder.FUNCTION_DATE, ((Function) value).name()) ) {
38
                List<Value> parameters = ((Function) value).parameters();
39
                if( parameters.size()==1) {
40
                    Value p1 = parameters.get(0);
41
                    if( $Constant.isConstant(p1) ) {
42
                        return true;
43
                    }
44
                    
45
                }
46
            }
47
        }
48
        return false;
49
    }
50

    
51
    @Override
52
    public String format(Value function) {
53
        List<Value> parameters = ((Function) function).parameters();
54
        Value p1 = parameters.get(0);
55
        ExpressionBuilder.Constant p1value = $Constant.resolveAsConstant(this.sqlbuilder, this.formatter, p1);
56
        LocalDateTime localDate = DataTypeUtils.toLocalDateTime(p1value.value());
57
        
58
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
59
        
60
//        long t = localDate.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
61
        
62
        String r = "('"+localDate.format(formatter)+"')";
63
        return r;
64
    }
65
    
66
}