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 / foldersmanager / LastPathFunction.java @ 44389

History | View | Annotate | Download (1.33 KB)

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

    
3
import java.io.File;
4
import org.apache.commons.lang3.Range;
5
import org.gvsig.expressionevaluator.Interpreter;
6
import org.gvsig.expressionevaluator.spi.AbstractFunction;
7
import org.gvsig.tools.ToolsLocator;
8
import org.gvsig.tools.folders.FoldersManager;
9

    
10
public class LastPathFunction extends AbstractFunction {
11

    
12
    public static final String NAME = "LASTPATH";
13
    
14
    public LastPathFunction() {
15
        super(
16
            "Folders", 
17
            NAME, 
18
            Range.between(1,2),
19
            "Retrieve the last value used to the indicated folder.", 
20
            NAME+"({{folderid}}, defaultValue)", 
21
            new String[] {
22
                "folderid - Identifier of the folder to retrieve",
23
                "defaultValue - Optional. value to get if the folder with id 'folderid' is not defined."
24
            }, 
25
            "File", 
26
            false
27
        );
28
    }
29

    
30

    
31
    @Override
32
    public boolean allowConstantFolding() {
33
        return false;
34
    }
35
    
36
    @Override
37
    public Object call(Interpreter interpreter, Object[] args) {
38
        FoldersManager folderManager = ToolsLocator.getFoldersManager();
39
        String id = getStr(args, 0);
40
        File defaultValue = getFile(args,1);
41
        File f = folderManager.getLastPath(id, defaultValue);
42
        return f;
43
    }
44
}