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

org.thymeleaf.context.IEngineContext Maven / Gradle / Ivy

/*
 * =============================================================================
 * 
 *   Copyright (c) 2011-2016, The THYMELEAF team (http://www.thymeleaf.org)
 * 
 *   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.thymeleaf.context;

import java.util.List;
import java.util.Map;

import org.thymeleaf.engine.TemplateData;
import org.thymeleaf.inline.IInliner;
import org.thymeleaf.model.IProcessableElementTag;

/**
 * 

* Mostly-internal interface implemented by all classes containing the context required for * template processing inside the engine itself. *

*

* This interface extends {@link ITemplateContext} by adding a series of methods required internally * by the template engine for processing, which should not be used from users' code. * Calling these methods directly from custom processors or other extensions could have undesirable * effects on template processing. *

*

* Contexts used during template processing by the engine are always implementations of this interface. * If the Template Engine is called with an implementation of this {@link IEngineContext} as * context, the same object will be used (so that users can actually provide their own implementations). * On the other side, if the context specified to the Template Engine is not an implementation of this * interface, an implementation of {@link IEngineContext} will be internally created by the engine, the original * context's variables and other info will be cloned, and used instead. *

*

* Again note that, besides providing custom-made implementations of this interface (which is a very complex * operation, not recommended in most scenarios) there should be no reason why this interface should ever be * used in users' code. *

* * @author Daniel Fernández * * @since 3.0.0 * */ public interface IEngineContext extends ITemplateContext { /** *

* Sets a new variable into the context. *

*

* Depending on the context level, determined by {@link #increaseLevel()} and * {@link #decreaseLevel()}, the variable being set might be considered a local variable * and thus disappear from context once the context level is decreased below the * level the variable was created at. *

* * @param name the name of the variable. * @param value the value of the variable. */ public void setVariable(final String name, final Object value); /** *

* Sets several variables at a time into the context. *

*

* Depending on the context level, determined by {@link #increaseLevel()} and * {@link #decreaseLevel()}, the variables being set might be considered a local variables * and thus disappear from context once the context level is decreased below the * level the variable was created at. *

* * @param variables the variables to be set. */ public void setVariables(final Map variables); /** *

* Removes a variable from the context. *

*

* Depending on the context level, determined by {@link #increaseLevel()} and * {@link #decreaseLevel()}, this removal might be considered local variable-related * and thus cease to happen (i.e. the variable would be recovered) once the context level * is decreased below the level the variable was created at. *

* * @param name the name of the variable to be removed. */ public void removeVariable(final String name); /** *

* Set a selection target. Usually the consequence of executing a th:object processor. *

*

* Once set, all selection expressions (*{...}) will be executed on this target. *

*

* This selection target will have the consideration of a local variable and thus depend on * the context level (see {@link #setVariable(String, Object)}). *

* * @param selectionTarget the selection target to be set. */ public void setSelectionTarget(final Object selectionTarget); /** *

* Set an inliner. Usually the consequence of executing a th:inline processor. *

*

* This inliner will have the consideration of a local variable and thus depend on * the context level (see {@link #setVariable(String, Object)}). *

* * @param inliner the inliner to be set. */ public void setInliner(final IInliner inliner); /** *

* Sets a new template metadata object ({@link TemplateData}) for the current execution point, specifying * that the elements and nodes that are to be processed from now on (until the context level is * decreased below the current level) originally belonged to a different template. *

*

* A call on this method is usually the consequence of th:insert or th:replace. *

* * @param template the template data. */ public void setTemplateData(final TemplateData template); /** *

* Sets a new element tag ({@link IProcessableElementTag}) into the hierarchy (stack) of element tags. *

*

* This hierarchy of element tags (added this way) can be obtained with {@link #getElementStack()}. *

* * @param elementTag the element tag. */ public void setElementTag(final IProcessableElementTag elementTag); /** *

* Retrieves the element stack just like {@link #getElementStack()}, but only for those elements added * to the hierarchy above a specific context level. *

* * @param contextLevel the level above which we want to obtain the element stack. * @return the element stack above a specified level. */ public List getElementStackAbove(final int contextLevel); /** *

* Checks whether a specific variable is local or not. *

*

* This means checking if the context level at which the variable was defined was 0 or not. *

* * @param name the name of the variable to be checked. * @return true if the variable is local (level > 0), false if not (level == 0). */ public boolean isVariableLocal(final String name); /** *

* Increase the context level. This is usually a consequence of the * {@link org.thymeleaf.engine.ProcessorTemplateHandler} detecting the start of a new element * (i.e. handling an {@link org.thymeleaf.model.IOpenElementTag} event). *

*

* This method should only be called internally. *

*/ public void increaseLevel(); /** *

* Decrease the context level. This is usually a consequence of the * {@link org.thymeleaf.engine.ProcessorTemplateHandler} detecting the closing of an element * (i.e. handling an {@link org.thymeleaf.model.ICloseElementTag} event). *

*

* This method should only be called internally. *

*/ public void decreaseLevel(); /** *

* Return the current context level. *

*

* This method should only be called internally. *

* * @return the current level */ public int level(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy