package railo.runtime.interpreter.ref.literal;
import java.util.ArrayList;
import java.util.List;
import railo.runtime.PageContext;
import railo.runtime.exp.PageException;
import railo.runtime.interpreter.InterpreterException;
import railo.runtime.interpreter.ref.Ref;
import railo.runtime.interpreter.ref.RefSupport;
import railo.runtime.interpreter.ref.Set;
import railo.runtime.interpreter.ref.var.Variable;
import railo.runtime.type.FunctionValueImpl;
/**
* ref for a functionValue
*/
public final class LFunctionValue extends RefSupport implements Ref {
private Ref name;
private Ref refValue;
private Object objValue;
/**
* constructor of the class
* @param name
* @param value
*/
public LFunctionValue(Ref name, Ref value) {
this.name=name;
this.refValue=value;
}
public LFunctionValue(Ref name, Object value) {
this.name=name;
this.objValue=value;
}
@Override
public Object getValue(PageContext pc) throws PageException {
if(name instanceof Variable){
return new FunctionValueImpl(toStringArray(pc,(Set)name),refValue==null?objValue:refValue.getValue(pc));
}
if(name instanceof Literal) {
return new FunctionValueImpl(((Literal)name).getString(pc),refValue==null?objValue:refValue.getValue(pc));
}
// TODO no idea if this is ever used
if(name instanceof Set){
return new FunctionValueImpl(railo.runtime.type.util.ListUtil.arrayToList(toStringArray(pc,(Set)name),"."),refValue==null?objValue:refValue.getValue(pc));
}
throw new InterpreterException("invalid syntax in named argument");
//return new FunctionValueImpl(key,value.getValue());
}
public static String[] toStringArray(PageContext pc,Set set) throws PageException {
Ref ref=set;
String str;
List<String> arr=new ArrayList<String>();
do {
set=(Set) ref;
str=set.getKeyAsString(pc);
if(str!=null)arr.add(0, str);
else break;
ref=set.getParent(pc);
}while(ref instanceof Set);
return arr.toArray(new String[arr.size()]);
}
@Override
public String getTypeName() {
return "function value";
}
}