All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy