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 / string / ReverseInStrFunction.java @ 46047

History | View | Annotate | Download (1.61 KB)

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

    
3
import org.apache.commons.lang3.Range;
4
import org.gvsig.expressionevaluator.Interpreter;
5
import org.gvsig.expressionevaluator.spi.AbstractFunction;
6

    
7
public class ReverseInStrFunction extends AbstractFunction {
8

    
9
    public ReverseInStrFunction() {
10
        super(
11
                "String", "REVERSEINSTR", Range.is(2),
12
                "Returns the index (position) of the last occurrence of a specified substring in a string.",
13
                "REVERSEINSTR"+"({{string}}, substring)",
14
                new String[]{
15
                    "string - String in which to perform the search. ",
16
                    "substring - String to search"
17
                },
18
                "Integer",
19
                true
20
        );        
21
        // Nota: 
22
        // Habria que poner un formatter. Para REVERSEINSTR(string, substring):
23
        //   En H2: INSTR(string,substring, -1)
24
        //   En PostgreSQL: LENGTH(string)-STRPOS(REVERSE(string), substring)
25
        //   En Oracle: LEN(string)-INSTR(REVERSE(string), substring)
26
        //   En SQL Server: LEN(string)-CHARINDEX(substring, REVERSE(string))
27
    }
28

    
29
    @Override
30
    public boolean allowConstantFolding() {
31
        return true;
32
    }
33
    
34
    @Override
35
    public Object call(Interpreter interpreter, Object[] args) throws Exception {
36
        String string = getStr(args, 0);
37
        String substring = getStr(args, 1);
38
        if( string == null || substring == null ) {
39
            return null;
40
        }
41
        int n = string.lastIndexOf(substring);
42
        if( n<0 ) {
43
            return 0;
44
        }
45
        return n+1;
46
    }
47
}