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 @ 44761

History | View | Annotate | Download (1.49 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
            true
22
        );
23
    }
24

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

    
50
}