org.mvel2.optimizers.impl.refl.collection.ExprValueAccessor Maven / Gradle / Ivy
/**
* MVEL (The MVFLEX Expression Language)
*
* Copyright (C) 2007 Christopher Brock, MVFLEX/Valhalla Project and the Codehaus
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package org.mvel2.optimizers.impl.refl.collection;
import static org.mvel2.DataConversion.canConvert;
import static org.mvel2.DataConversion.convert;
import static org.mvel2.util.ParseTools.getSubComponentType;
import static org.mvel2.util.ReflectionUtil.isAssignableFrom;
import org.mvel2.ParserContext;
import org.mvel2.compiler.Accessor;
import org.mvel2.compiler.ExecutableLiteral;
import org.mvel2.compiler.ExecutableStatement;
import org.mvel2.integration.VariableResolverFactory;
import org.mvel2.util.ParseTools;
/**
* @author Christopher Brock
*/
public class ExprValueAccessor implements Accessor {
public ExecutableStatement stmt;
public ExprValueAccessor(String ex, Class expectedType, Object ctx, VariableResolverFactory factory, ParserContext pCtx) {
stmt = (ExecutableStatement) ParseTools.subCompileExpression(ex.toCharArray(), pCtx);
//if (expectedType.isArray()) {
Class tt = getSubComponentType(expectedType);
Class et = stmt.getKnownEgressType();
if (stmt.getKnownEgressType() != null && !isAssignableFrom(tt, et)) {
if ((stmt instanceof ExecutableLiteral) && canConvert(et, tt)) {
try {
stmt = new ExecutableLiteral(convert(stmt.getValue(ctx, factory), tt));
return;
} catch (IllegalArgumentException e) {
// fall through;
}
}
if (pCtx != null && pCtx.isStrongTyping())
throw new RuntimeException("was expecting type: " + tt + "; but found type: " + (et == null ? "null" : et.getName()));
}
}
public Object getValue(Object ctx, Object elCtx, VariableResolverFactory variableFactory) {
return stmt.getValue(elCtx, variableFactory);
}
public Object setValue(Object ctx, Object elCtx, VariableResolverFactory variableFactory, Object value) {
// not implemented
return null;
}
public ExecutableStatement getStmt() {
return stmt;
}
public void setStmt(ExecutableStatement stmt) {
this.stmt = stmt;
}
public Class getKnownEgressType() {
return stmt.getKnownEgressType();
}
}