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 / date / DateFunction.java @ 44750

History | View | Annotate | Download (1.56 KB)

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

    
3
import java.text.ParseException;
4
import java.text.SimpleDateFormat;
5
import java.util.Date;
6
import org.apache.commons.lang3.Range;
7
import org.gvsig.expressionevaluator.Interpreter;
8
import org.gvsig.expressionevaluator.spi.AbstractFunction;
9
import static org.gvsig.expressionevaluator.ExpressionBuilder.FUNCTION_DATE;
10

    
11
public class DateFunction extends AbstractFunction {
12

    
13
    public DateFunction() {
14
        super("Date", FUNCTION_DATE,Range.is(1),
15
            "Returns a date from the arguments",
16
            FUNCTION_DATE+"({{date}})",
17
            new String[]{
18
                "date - a string with a date"
19
            },
20
            "Date"
21
        );
22
    }
23

    
24
    @Override
25
    public boolean allowConstantFolding() {
26
        return true;
27
    }
28
    
29
    @Override
30
    public Object call(Interpreter interpreter, Object[] args) {
31
        Object date_obj = getObject(args, 0);
32
        if( date_obj instanceof Date ) {
33
            Date x = new Date(((Date) date_obj).getTime());
34
            x.setHours(0);
35
            x.setMinutes(0);
36
            x.setSeconds(0);
37
            return x;
38
        }
39
        String date = getStr(args, 0);
40
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
41
        try {
42
            Date x = df.parse(date);
43
            x.setHours(0);
44
            x.setMinutes(0);
45
            x.setSeconds(0);
46
            return x;
47
        } catch (ParseException ex) {
48
            throw new RuntimeException("Can't parse date value '"+date+"', expected format 'yyyy-MM-dd'.", ex);
49
        }
50
        
51
    }
52
    
53

    
54
}