freemarker.ext.beans
Class MapModel

java.lang.Object
  extended by freemarker.ext.beans.BeanModel
      extended by freemarker.ext.beans.StringModel
          extended by freemarker.ext.beans.MapModel
All Implemented Interfaces:
WrapperTemplateModel, AdapterTemplateModel, TemplateHashModel, TemplateHashModelEx, TemplateMethodModel, TemplateMethodModelEx, TemplateModel, TemplateScalarModel

public class MapModel
extends StringModel
implements TemplateMethodModelEx

A special case of BeanModel that adds implementation for TemplateMethodModelEx on map objects that is a shortcut for the Map.get() method. Note that if the passed argument itself is a reflection-wrapper model, then the map lookup will be performed using the wrapped object as the key. Note that you can call get() using the map.key syntax inherited from BeanModel as well, however in that case the key is always a string.

The class itself does not implement the TemplateCollectionModel. You can, however use map.entrySet(), map.keySet(), or map.values() to obtain TemplateCollectionModel instances for various aspects of the map.

Version:
$Id: MapModel.java,v 1.26.2.3 2006/02/26 18:26:37 revusky Exp $
Author:
Attila Szegedi

Field Summary
 
Fields inherited from class freemarker.ext.beans.BeanModel
object, wrapper
 
Fields inherited from interface freemarker.template.TemplateModel
NOTHING
 
Fields inherited from interface freemarker.template.TemplateScalarModel
EMPTY_STRING
 
Constructor Summary
MapModel(java.util.Map map, BeansWrapper wrapper)
          Creates a new model that wraps the specified map object.
 
Method Summary
 java.lang.Object exec(java.util.List arguments)
          The first argument is used as a key to call the map's get method.
protected  TemplateModel invokeGenericGet(java.util.Map keyMap, java.lang.Class clazz, java.lang.String key)
          Overridden to invoke the generic get method by casting to Map instead of through reflection - should yield better performance.
 boolean isEmpty()
          Tells whether the model is empty.
protected  java.util.Set keySet()
          Helper method to support TemplateHashModelEx.
 int size()
           
 
Methods inherited from class freemarker.ext.beans.StringModel
getAsString
 
Methods inherited from class freemarker.ext.beans.BeanModel
get, getAdaptedObject, getWrappedObject, hasPlainGetMethod, keys, toString, unwrap, values, wrap
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Constructor Detail

MapModel

public MapModel(java.util.Map map,
                BeansWrapper wrapper)
Creates a new model that wraps the specified map object.

Parameters:
map - the map object to wrap into a model.
wrapper - the BeansWrapper associated with this model. Every model has to have an associated BeansWrapper instance. The model gains many attributes from its wrapper, including the caching behavior, method exposure level, method-over-item shadowing policy etc.
Method Detail

exec

public java.lang.Object exec(java.util.List arguments)
                      throws TemplateModelException
The first argument is used as a key to call the map's get method.

Specified by:
exec in interface TemplateMethodModel
Specified by:
exec in interface TemplateMethodModelEx
Parameters:
arguments - a List of TemplateModel objects containing the values of the arguments passed to the method. If the implementation wishes to operate on POJOs that might be underlying the models, it can use the static utility methods in the DeepUnwrap class to easily obtain them.
Returns:
the return value of the method, or null. If the returned value does not implement TemplateModel, it will be automatically wrapped using the environment object wrapper.
Throws:
TemplateModelException

invokeGenericGet

protected TemplateModel invokeGenericGet(java.util.Map keyMap,
                                         java.lang.Class clazz,
                                         java.lang.String key)
                                  throws TemplateModelException
Overridden to invoke the generic get method by casting to Map instead of through reflection - should yield better performance.

Overrides:
invokeGenericGet in class BeanModel
Throws:
TemplateModelException

isEmpty

public boolean isEmpty()
Description copied from class: BeanModel
Tells whether the model is empty. It is empty if either the wrapped object is null, or it is a Boolean with false value.

Specified by:
isEmpty in interface TemplateHashModel
Overrides:
isEmpty in class BeanModel

size

public int size()
Specified by:
size in interface TemplateHashModelEx
Overrides:
size in class BeanModel
Returns:
the number of key/value mappings in the hash.

keySet

protected java.util.Set keySet()
Description copied from class: BeanModel
Helper method to support TemplateHashModelEx. Returns the Set of Strings which are available via the TemplateHashModel interface. Subclasses that override invokeGenericGet to provide additional hash keys should also override this method.

Overrides:
keySet in class BeanModel