Package org.camunda.bpm.engine.impl.juel
Class ExpressionFactoryImpl
- java.lang.Object
- 
- org.camunda.bpm.engine.impl.javax.el.ExpressionFactory
- 
- org.camunda.bpm.engine.impl.juel.ExpressionFactoryImpl
 
 
- 
 public class ExpressionFactoryImpl extends ExpressionFactory Expression factory implementation. This class is also used as an EL "service provider". The JUEL jar file specifies this class as el expression factory implementation inMETA-INF/services/javax.el.ExpressionFactory. CallingExpressionFactory.newInstance()will then return an instance of this class, configured as described below. If no properties are specified at construction time, properties are read from- 
 If the file JAVA_HOME/lib/el.propertiesexists and if it contains propertyjavax.el.ExpressionFactorywhose value is the name of this class, these properties are taken as default properties.
- Otherwise, if system property javax.el.ExpressionFactoryis set to the name of this class, the system propertiesSystem.getProperties()are taken as default properties.
- 
 el.propertieson your classpath. These properties override the properties fromJAVA_HOME/lib/el.propertiesorSystem.getProperties().
 Properties. Having this, the following properties are read:- 
 javax.el.cacheSize- cache size (int, default is 1000)
- 
 javax.el.methodInvocations- allow method invocations as in${foo.bar(baz)}(boolean, default isfalse).
- 
 javax.el.nullProperties- resolvenullproperties as in${foo[null]}(boolean, default isfalse).
- 
 javax.el.varArgs- support function/method calls using varargs (boolean, default isfalse).
 - Author:
- Christoph Beck
 
- 
 If the file 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classExpressionFactoryImpl.ProfileA profile provides a default set of language features that will define the builder's behavior.
 - 
Field SummaryFields Modifier and Type Field Description static java.lang.StringPROP_CACHE_SIZEjavax.el.cacheSizestatic java.lang.StringPROP_METHOD_INVOCATIONSjavax.el.methodInvocationsstatic java.lang.StringPROP_NULL_PROPERTIESjavax.el.nullPropertiesstatic java.lang.StringPROP_VAR_ARGSjavax.el.varArgs
 - 
Constructor SummaryConstructors Constructor Description ExpressionFactoryImpl()Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(java.util.Properties properties)Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(java.util.Properties properties, TypeConverter converter)Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile)Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile, java.util.Properties properties)Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile, java.util.Properties properties, TypeConverter converter)Create a new expression factory using the default builder and cache implementations.ExpressionFactoryImpl(TreeStore store)Create a new expression factory.ExpressionFactoryImpl(TreeStore store, TypeConverter converter)Create a new expression factory.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.ObjectcoerceToType(java.lang.Object obj, java.lang.Class<?> targetType)Coerces an object to a specific type according to the EL type conversion rules.TreeMethodExpressioncreateMethodExpression(ELContext context, java.lang.String expression, java.lang.Class<?> expectedReturnType, java.lang.Class<?>[] expectedParamTypes)Parses an expression into aMethodExpressionfor later evaluation.protected TreeBuildercreateTreeBuilder(java.util.Properties properties, Builder.Feature... features)Create the factory's builder.protected TreeStorecreateTreeStore(int defaultCacheSize, ExpressionFactoryImpl.Profile profile, java.util.Properties properties)Create the factory's tree store.protected TypeConvertercreateTypeConverter(java.util.Properties properties)Create the factory's type converter.ObjectValueExpressioncreateValueExpression(java.lang.Object instance, java.lang.Class<?> expectedType)Creates a ValueExpression that wraps an object instance.TreeValueExpressioncreateValueExpression(ELContext context, java.lang.String expression, java.lang.Class<?> expectedType)Parses an expression into aValueExpressionfor later evaluation.- 
Methods inherited from class org.camunda.bpm.engine.impl.javax.el.ExpressionFactorynewInstance, newInstance
 
- 
 
- 
- 
- 
Field Detail- 
PROP_METHOD_INVOCATIONSpublic static final java.lang.String PROP_METHOD_INVOCATIONS javax.el.methodInvocations- See Also:
- Constant Field Values
 
 - 
PROP_VAR_ARGSpublic static final java.lang.String PROP_VAR_ARGS javax.el.varArgs- See Also:
- Constant Field Values
 
 - 
PROP_NULL_PROPERTIESpublic static final java.lang.String PROP_NULL_PROPERTIES javax.el.nullProperties- See Also:
- Constant Field Values
 
 - 
PROP_CACHE_SIZEpublic static final java.lang.String PROP_CACHE_SIZE javax.el.cacheSize- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
ExpressionFactoryImplpublic ExpressionFactoryImpl() Create a new expression factory using the default builder and cache implementations. The builder and cache are configured fromel.properties(see above). The maximum cache size will be 1000 unless overridden inel.properties. The builder profile isExpressionFactoryImpl.Profile.JEE6(features may be overridden inel.properties).
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile) Create a new expression factory using the default builder and cache implementations. The builder and cache are configured from the specified profile andel.properties(see above). The maximum cache size will be 1000 unless overridden inel.properties.- Parameters:
- profile- builder profile (features may be overridden in- el.properties)
- Since:
- 2.2
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(java.util.Properties properties) Create a new expression factory using the default builder and cache implementations. The builder and cache are configured using the specified properties. The maximum cache size will be 1000 unless overridden by propertyjavax.el.cacheSize. The builder profile isExpressionFactoryImpl.Profile.JEE6(features may be overridden inproperties).- Parameters:
- properties- used to initialize this factory (may be- null)
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile, java.util.Properties properties) Create a new expression factory using the default builder and cache implementations. The builder and cache are configured using the specified profile and properties. The maximum cache size will be 1000 unless overridden by propertyjavax.el.cacheSize.- Parameters:
- profile- builder profile (individual features may be overridden in properties)
- properties- used to initialize this factory (may be- null)
- Since:
- 2.2
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(java.util.Properties properties, TypeConverter converter)Create a new expression factory using the default builder and cache implementations. The builder and cache are configured using the specified properties. The maximum cache size will be 1000 unless overridden by propertyjavax.el.cacheSize. The builder profile isExpressionFactoryImpl.Profile.JEE6(individual features may be overridden inproperties).- Parameters:
- properties- used to initialize this factory (may be- null)
- converter- custom type converter
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(ExpressionFactoryImpl.Profile profile, java.util.Properties properties, TypeConverter converter) Create a new expression factory using the default builder and cache implementations. The builder and cache are configured using the specified profile and properties. The maximum cache size will be 1000 unless overridden by propertyjavax.el.cacheSize.- Parameters:
- profile- builder profile (individual features may be overridden in properties)
- properties- used to initialize this factory (may be- null)
- converter- custom type converter
- Since:
- 2.2
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(TreeStore store) Create a new expression factory.- Parameters:
- store- the tree store used to parse and cache parse trees.
 
 - 
ExpressionFactoryImplpublic ExpressionFactoryImpl(TreeStore store, TypeConverter converter) Create a new expression factory.- Parameters:
- store- the tree store used to parse and cache parse trees.
- converter- custom type converter
 
 
- 
 - 
Method Detail- 
createTreeStoreprotected TreeStore createTreeStore(int defaultCacheSize, ExpressionFactoryImpl.Profile profile, java.util.Properties properties) Create the factory's tree store. This implementation creates a new tree store using the default builder and cache implementations. The builder and cache are configured using the specified properties. The maximum cache size will be as specified unless overridden by propertyjavax.el.cacheSize.
 - 
createTypeConverterprotected TypeConverter createTypeConverter(java.util.Properties properties) Create the factory's type converter. This implementation takes thede.odysseus.el.misc.TypeConverterproperty as the name of a class implementing thede.odysseus.el.misc.TypeConverterinterface. If the property is not set, the default converter (TypeConverter.DEFAULT) is used.
 - 
createTreeBuilderprotected TreeBuilder createTreeBuilder(java.util.Properties properties, Builder.Feature... features) Create the factory's builder. This implementation takes thede.odysseus.el.tree.TreeBuilderproperty as a name of a class implementing thede.odysseus.el.tree.TreeBuilderinterface. If the property is not set, a plainde.odysseus.el.tree.impl.Builderis used. If the configured class is a subclass ofde.odysseus.el.tree.impl.Builderand which provides a constructor taking an array ofBuilder.Feature, this constructor will be invoked. Otherwise, the default constructor will be used.
 - 
coerceToTypepublic final java.lang.Object coerceToType(java.lang.Object obj, java.lang.Class<?> targetType)Description copied from class:ExpressionFactoryCoerces an object to a specific type according to the EL type conversion rules. AnELExceptionis thrown if an error results from applying the conversion rules.- Specified by:
- coerceToTypein class- ExpressionFactory
- Parameters:
- obj- The object to coerce.
- targetType- The target type for the coercion.
- Returns:
- the coerced object
 
 - 
createValueExpressionpublic final ObjectValueExpression createValueExpression(java.lang.Object instance, java.lang.Class<?> expectedType) Description copied from class:ExpressionFactoryCreates a ValueExpression that wraps an object instance. This method can be used to pass any object as a ValueExpression. The wrapper ValueExpression is read only, and returns the wrapped object via its getValue() method, optionally coerced.- Specified by:
- createValueExpressionin class- ExpressionFactory
- Parameters:
- instance- The object instance to be wrapped.
- expectedType- The type the result of the expression will be coerced to after evaluation. There will be no coercion if it is Object.class,
- Returns:
- a ValueExpression that wraps the given object instance.
 
 - 
createValueExpressionpublic final TreeValueExpression createValueExpression(ELContext context, java.lang.String expression, java.lang.Class<?> expectedType) Description copied from class:ExpressionFactoryParses an expression into aValueExpressionfor later evaluation. Use this method for expressions that refer to values. This method should perform syntactic validation of the expression. If in doing so it detects errors, it should raise an ELException.- Specified by:
- createValueExpressionin class- ExpressionFactory
- Parameters:
- context- The EL context used to parse the expression. The FunctionMapper and VariableMapper stored in the ELContext are used to resolve functions and variables found in the expression. They can be null, in which case functions or variables are not supported for this expression. The object returned must invoke the same functions and access the same variable mappings regardless of whether the mappings in the provided FunctionMapper and VariableMapper instances change between calling ExpressionFactory.createValueExpression() and any method on ValueExpression. Note that within the EL, the ${} and #{} syntaxes are treated identically. This includes the use of VariableMapper and FunctionMapper at expression creation time. Each is invoked if not null, independent of whether the #{} or ${} syntax is used for the expression.
- expression- The expression to parse
- expectedType- The type the result of the expression will be coerced to after evaluation.
- Returns:
- The parsed expression
 
 - 
createMethodExpressionpublic final TreeMethodExpression createMethodExpression(ELContext context, java.lang.String expression, java.lang.Class<?> expectedReturnType, java.lang.Class<?>[] expectedParamTypes) Description copied from class:ExpressionFactoryParses an expression into aMethodExpressionfor later evaluation. Use this method for expressions that refer to methods. If the expression is a String literal, a MethodExpression is created, which when invoked, returns the String literal, coerced to expectedReturnType. An ELException is thrown if expectedReturnType is void or if the coercion of the String literal to the expectedReturnType yields an error (see Section "1.16 Type Conversion"). This method should perform syntactic validation of the expression. If in doing so it detects errors, it should raise an ELException.- Specified by:
- createMethodExpressionin class- ExpressionFactory
- Parameters:
- context- The EL context used to parse the expression. The FunctionMapper and VariableMapper stored in the ELContext are used to resolve functions and variables found in the expression. They can be null, in which case functions or variables are not supported for this expression. The object returned must invoke the same functions and access the same variable mappings regardless of whether the mappings in the provided FunctionMapper and VariableMapper instances change between calling ExpressionFactory.createMethodExpression() and any method on MethodExpression. Note that within the EL, the ${} and #{} syntaxes are treated identically. This includes the use of VariableMapper and FunctionMapper at expression creation time. Each is invoked if not null, independent of whether the #{} or ${} syntax is used for the expression.
- expression- The expression to parse
- expectedReturnType- The expected return type for the method to be found. After evaluating the expression, the MethodExpression must check that the return type of the actual method matches this type. Passing in a value of null indicates the caller does not care what the return type is, and the check is disabled.
- expectedParamTypes- The expected parameter types for the method to be found. Must be an array with no elements if there are no parameters expected. It is illegal to pass null.
- Returns:
- The parsed expression
 
 
- 
 
-