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 / TimestampFunction.java @ 44759

History | View | Annotate | Download (1.48 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 static org.gvsig.expressionevaluator.ExpressionBuilder.FUNCTION_TIMESTAMP;
8
import org.gvsig.expressionevaluator.Interpreter;
9
import org.gvsig.expressionevaluator.spi.AbstractFunction;
10

    
11
public class TimestampFunction extends AbstractFunction {
12

    
13
    public TimestampFunction() {
14
        super("Date", FUNCTION_TIMESTAMP,Range.is(1),
15
            "Returns a time stamp from the arguments",
16
            FUNCTION_TIMESTAMP+"({{timestamp}})",
17
            new String[]{
18
                "timestamp - a string with a date/time"
19
            },
20
            "Timestamp"
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
            return new java.sql.Timestamp(((Date) date_obj).getTime());
34
        }
35
        String date = getStr(args, 0);
36
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
37
        try {
38
            java.sql.Timestamp x = java.sql.Timestamp.valueOf(date);
39
            return x;
40
        } catch (Exception ex) {
41
            throw new RuntimeException("Can't parse timestamp value '"+date+"' expected format 'yyyy-MM-dd HH:mm:ss'.", ex);
42
        }
43
        
44
    }
45
    
46

    
47
}