/*
* Copyright 2004-2012 the original author or authors.
*
* 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.springframework.binding.expression.el;
import java.util.List;
import javax.el.ArrayELResolver;
import javax.el.BeanELResolver;
import javax.el.CompositeELResolver;
import javax.el.ELContext;
import javax.el.ELResolver;
import javax.el.ListELResolver;
import javax.el.MapELResolver;
import javax.el.ResourceBundleELResolver;
/**
* A generic ELResolver to be used as a default when no other ELResolvers have been configured by the client
* application.
*
* This implementation will resolve the first part of the expression to the pre-configured base object, and will then
* delegate through the chain of standard resolvers for the rest of the expression.
*
* Note - Requires Java 5 or higher due to the use of generics in the API's basic resolvers.
*
* @author Jeremy Grelle
*/
public class DefaultELResolver extends CompositeELResolver {
private Object target;
/**
* Creates a new default EL resolver for resolving properties of the root object. Assumes a null target and expect
* that the base object has already been resolved by the time this resolver runs.
* @param customResolvers the custom resolvers to apply before this resolver
*/
public DefaultELResolver(List<? extends ELResolver> customResolvers) {
this(null, customResolvers);
}
/**
* Creates a new default EL resolver for resolving properties of the root object.
* @param target the target, or "root", object of the expression
* @param customResolvers the custom resolvers to apply before this resolver
*/
public DefaultELResolver(Object target, List<? extends ELResolver> customResolvers) {
this.target = target;
configureResolvers(customResolvers);
}
public Object getTarget() {
return target;
}
public Class<?> getType(ELContext context, Object base, Object property) {
if (base == null) {
return super.getType(context, target, property);
} else {
return super.getType(context, base, property);
}
}
public Object getValue(ELContext context, Object base, Object property) {
if (base == null) {
return super.getValue(context, target, property);
} else {
return super.getValue(context, base, property);
}
}
public void setValue(ELContext context, Object base, Object property, Object val) {
if (base == null) {
super.setValue(context, target, property, val);
} else {
super.setValue(context, base, property, val);
}
}
private void configureResolvers(List<? extends ELResolver> customResolvers) {
if (customResolvers != null) {
for (ELResolver resolver : customResolvers) {
add(resolver);
}
}
add(new MapAdaptableELResolver());
add(new ArrayELResolver());
add(new ListELResolver());
add(new MapELResolver());
add(new ResourceBundleELResolver());
add(new BeanELResolver());
}
}