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

com.feilong.lib.ognl.enhance.OgnlExpressionCompiler Maven / Gradle / Ivy

Go to download

feilong is a suite of core and expanded libraries that include utility classes, http, excel,cvs, io classes, and much much more.

There is a newer version: 4.3.0
Show newest version
/**
 *
 */
package com.feilong.lib.ognl.enhance;

import java.lang.reflect.Method;

import com.feilong.lib.ognl.Node;
import com.feilong.lib.ognl.OgnlContext;

/**
 * Core interface implemented by expression compiler instances.
 */
public interface OgnlExpressionCompiler{

    /** Static constant used in conjunction with {@link OgnlContext} to store temporary references. */
    String ROOT_TYPE = "-ognl-root-type";

    /**
     * Gets a javassist safe class string for the given class instance. This is especially
     * useful for handling array vs. normal class casting strings.
     *
     * @param clazz
     *            The class to get a string equivalent javassist compatible string reference for.
     *
     * @return The string equivalent of the class.
     */
    String getClassName(Class clazz);

    /**
     * Used in places where the preferred {@link #getSuperOrInterfaceClass(java.lang.reflect.Method, Class)} isn't possible
     * because the method isn't known for a class. Attempts to upcast the given class to the next available non-private accessible
     * class so that compiled expressions can reference the interface class of an instance so as not to be compiled in to overly
     * specific statements.
     *
     * @param clazz
     *            The class to attempt to find a compatible interface for.
     * @return The same class if no higher level interface could be matched against or the interface equivalent class.
     */
    Class getInterfaceClass(Class clazz);

    /**
     * For the given {@link Method} and class finds the highest level interface class this combination can be cast to.
     *
     * @param m
     *            The method the class must implement.
     * @param clazz
     *            The current class being worked with.
     * @return The highest level interface / class that the referenced {@link Method} is declared in.
     */
    Class getSuperOrInterfaceClass(Method m,Class clazz);

    /**
     * For a given root object type returns the base class type to be used in root referenced expressions. This
     * helps in some instances where the root objects themselves are compiled javassist instances that need more generic
     * class equivalents to cast to.
     *
     * @param rootNode
     *            The root expression node.
     * @param context
     *            The current execution context.
     * @return The root expression class type to cast to for this node.
     */
    Class getRootExpressionClass(Node rootNode,OgnlContext context);

    /**
     * Used primarily by AST types like {@link com.feilong.lib.ognl.ASTChain} where foo.bar.id type references
     * may need to be cast multiple times in order to properly resolve the members in a compiled statement.
     *
     * 

* This method should be using the various {@link com.feilong.lib.ognl.OgnlContext#getCurrentType()} / * {@link com.feilong.lib.ognl.OgnlContext#getCurrentAccessor()} methods * to inspect the type stack and properly cast to the right classes - but only when necessary. *

* * @param context * The current execution context. * @param expression * The node being checked for casting. * @param body * The java source string generated by the given node. * @return The body string parameter plus any additional casting syntax needed to make the expression * resolvable. */ String castExpression(OgnlContext context,Node expression,String body); /** * Method is used for expressions where multiple inner parameter method calls in generated java source strings * cause javassit failures. It is hacky and cumbersome to have to generate expressions this way but it's the only * current known way to make javassist happy. * *

* Takes an expression block generated by a node and creates a new method on the base object being compiled so that * sufficiently complicated sub expression blocks can be broken out in to distinct methods to be referenced by the core * accessor / setter methods in the base compiled root object. *

* * @param context * The current execution context. * @param expression * The java source expression to dump in to a seperate method reference. * @param type * The return type that should be specified for the new method. * @return The method name that will be used to reference the sub expression in place of the actual sub expression * itself. */ String createLocalReference(OgnlContext context,String expression,Class type); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy