info.magnolia.templating.freemarker
Class InitDirective

java.lang.Object
  extended by info.magnolia.templating.freemarker.AbstractDirective<InitElement>
      extended by info.magnolia.templating.freemarker.InitDirective
All Implemented Interfaces:
freemarker.template.TemplateDirectiveModel, freemarker.template.TemplateModel

public class InitDirective
extends AbstractDirective<InitElement>

A freemarker directive for adding Magnolia specific javascripts and css.

Version:
$Id$

Field Summary
 
Fields inherited from class info.magnolia.templating.freemarker.AbstractDirective
CONTENT_ATTRIBUTE, PATH_ATTRIBUTE, UUID_ATTRIBUTE, WORKSPACE_ATTRIBUTE
 
Fields inherited from interface freemarker.template.TemplateModel
NOTHING
 
Constructor Summary
InitDirective()
           
 
Method Summary
protected  void prepareTemplatingElement(InitElement templatingElement, freemarker.core.Environment env, Map<String,freemarker.template.TemplateModel> params, freemarker.template.TemplateModel[] loopVars, freemarker.template.TemplateDirectiveBody body)
          Implementations of this method should prepare the TemplatingElement with the known parameters.
 
Methods inherited from class info.magnolia.templating.freemarker.AbstractDirective
_param, bool, checkBody, content, createTemplatingElement, doBody, execute, getTemplatingElementClass, initContentElement, mandatoryBool, mandatoryContent, mandatoryObject, mandatoryString, mandatoryStringList, node, object, string
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

InitDirective

public InitDirective()
Method Detail

prepareTemplatingElement

protected void prepareTemplatingElement(InitElement templatingElement,
                                        freemarker.core.Environment env,
                                        Map<String,freemarker.template.TemplateModel> params,
                                        freemarker.template.TemplateModel[] loopVars,
                                        freemarker.template.TemplateDirectiveBody body)
                                 throws freemarker.template.TemplateModelException,
                                        IOException
Description copied from class: AbstractDirective
Implementations of this method should prepare the TemplatingElement with the known parameters. If parameters have been grabbed using the methods provided by this class, they should be removed from the map, thus leaving an empty map once the method returns. AbstractDirective.execute(freemarker.core.Environment, java.util.Map, freemarker.template.TemplateModel[], freemarker.template.TemplateDirectiveBody) will throw a TemplateModelException if there are leftover parameters.

note: The current FreeMarker implementation passes a "new" Map which we can safely manipulate. is thrown away after the execution of the directive. When no parameters are passed, the Map is readonly, but it is otherwise a regular HashMap which has been instantiated shortly before the execution of the directive. However, since this behavior is not mandated by their API, nor documented (at the time of writing, with FreeMarker 2.3.16), we should exert caution. Unit tests hopefully cover this, so we'll be safe when updating to newer FreeMarker versions.

Specified by:
prepareTemplatingElement in class AbstractDirective<InitElement>
Throws:
freemarker.template.TemplateModelException
IOException


Copyright © 2003-2012 Magnolia International Ltd.. All Rights Reserved.