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

History | View | Annotate | Download (1.54 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.between(1,2),
15
            "Returns a time stamp from the arguments",
16
            FUNCTION_TIMESTAMP+"({{timestamp}}, format)",
17
            new String[]{
18
                "timestamp - a string with a date/time",
19
                "format - Optional. Format to use to parse the timestamp"
20
            },
21
            "Timestamp"
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
        String date = getStr(args, 0);
33
        String format = null;
34
        if( args.length==2 ) {
35
            format = getStr(args, 1);
36
        }
37
        SimpleDateFormat df = new SimpleDateFormat();
38
        if( format != null ) {
39
            df.applyPattern(format);
40
        }
41
        try {
42
            Date x = df.parse(date);
43
            return x;
44
        } catch (ParseException ex) {
45
            throw new RuntimeException("Can't parse date value '"+date+"' with format '"+format==null?"":format+"'", ex);
46
        }
47
        
48
    }
49
    
50

    
51
}