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 |
} |