/**
*
* Copyright (c) 2014, the Railo Company Ltd. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
**/
package lucee.transformer.cfml.evaluator.func.impl;
import lucee.commons.lang.StringList;
import lucee.runtime.exp.TemplateException;
import lucee.runtime.interpreter.VariableInterpreter;
import lucee.runtime.type.Collection;
import lucee.runtime.type.scope.Scope;
import lucee.runtime.type.util.ArrayUtil;
import lucee.transformer.bytecode.expression.type.CollectionKey;
import lucee.transformer.bytecode.expression.type.CollectionKeyArray;
import lucee.transformer.bytecode.expression.var.Argument;
import lucee.transformer.bytecode.expression.var.BIF;
import lucee.transformer.cfml.evaluator.EvaluatorException;
import lucee.transformer.cfml.evaluator.FunctionEvaluator;
import lucee.transformer.expression.Expression;
import lucee.transformer.expression.literal.LitString;
import lucee.transformer.library.function.FunctionLibFunction;
public class IsDefined implements FunctionEvaluator{
@Override
public void execute(BIF bif, FunctionLibFunction flf) throws TemplateException {
Argument arg = bif.getArguments()[0];
Expression value = arg.getValue();
if(value instanceof LitString) {
String str=((LitString)value).getString();
StringList sl = VariableInterpreter.parse(str,false);
if(sl!=null){
// scope
str=sl.next();
int scope = VariableInterpreter.scopeString2Int(bif.ts.ignoreScopes,str);
if(scope==Scope.SCOPE_UNDEFINED)sl.reset();
// keys
String[] arr=sl.toArray();
ArrayUtil.trim(arr);
// update first arg
arg.setValue(bif.getFactory().createLitDouble(scope),"number");
// add second argument
if(arr.length==1){
Expression expr = new CollectionKey(bif.getFactory(),arr[0]);//LitString.toExprString(str);
arg=new Argument(expr,Collection.Key.class.getName());
bif.addArgument(arg);
}
else {
CollectionKeyArray expr=new CollectionKeyArray(bif.getFactory(),arr);
//LiteralStringArray expr = new LiteralStringArray(arr);
arg=new Argument(expr,Collection.Key[].class.getName());
bif.addArgument(arg);
}
}
}
//print.out("bif:"+arg.getValue().getClass().getName());
}
@Override
public void evaluate(BIF bif, FunctionLibFunction flf) throws EvaluatorException {}
@Override
public FunctionLibFunction pre(BIF bif, FunctionLibFunction flf) throws TemplateException {return null;}
}