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

org.thymeleaf.dialect.IDialect Maven / Gradle / Ivy

/*
 * =============================================================================
 * 
 *   Copyright (c) 2011, 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.dialect;

import java.util.Map;
import java.util.Set;

import org.thymeleaf.doctype.resolution.IDocTypeResolutionEntry;
import org.thymeleaf.doctype.translation.IDocTypeTranslation;
import org.thymeleaf.processor.attr.IAttrProcessor;
import org.thymeleaf.processor.tag.ITagProcessor;

/**
 * 

* Interface for all Thymeleaf Dialects. *

*

* A Dialect must define: *

*
    *
  • A default prefix for the names of the attributes and tags that will be * processed by processors in this dialect. For example, the standard dialect * defines a th prefix for its th:attr, th:value, etc. * attributes. This prefix is optional, so that if prefix is null all tags and * attributes will be considered processable by processors in this dialect. This * prefix can be overridden: the developer can select a different one when he/she adds a dialect to * the template engine (note, though, that this might affect existing .DTD files for * XML/XHTML validation). A prefix is not exclusive to a dialect, and several dialects * can specify the same one (effectively acting as an aggregate dialect)
  • *
  • A leniency flag indicating whether the existence of attributes or * tags starting with the specified prefix but with no associated attribute or * tag processor is considered an error (non-lenient) or not (lenient). When several * dialects share the same prefix, leniency is computed by prefix (if at least one * dialect for a prefix is lenient, then the whole prefix is considered to be so).
  • *
  • A set of attribute processors, implementing the {@link IAttrProcessor} * interface, that will be able to process and apply logic to attributes starting * with the specified prefix.
  • *
  • A set of tag processors, implementing the {@link ITagProcessor} * interface, that will be able to process and apply logic to tags starting * with the specified prefix.
  • *
  • A map of execution attributes, referenced by name. These are objects that * will be made available to processors during execution.
  • *
  • A set of DOCTYPE translations, implementing the {@link IDocTypeTranslation} * interface, which will be applied when processing templates.
  • *
  • A set of DOCTYPE resolution entries, implementing the {@link IDocTypeResolutionEntry} * interface, that will be fed into the {@link org.xml.sax.EntityResolver} of the XML parser * so that DTD files can be retrieved as (maybe local) resources – depending on the specific * implementation of the interface.
  • *
*

* A template engine can be specified more than one dialect (each with its tag/attribute * processors). In that case, dialects are first checked for conflicts so that, for example, * they do not declare DOCTYPE translations or resolution entries conflicting with the ones * in other dialect/s (although they can be equal). *

* * @author Daniel Fernández * * @since 1.0 * */ public interface IDialect { /** *

* Returns the default dialect prefix (the one that will be used if none is explicitly * specified during dialect configuration). *

*

* If null is returned, then every attribute * and/or tag is considered processable by the processors in the dialect, and not * only those that start with a specific prefix. *

*

* Prefixes are not exclusive to a dialect: several dialects can declare the same * prefix, effectively acting as an aggregate dialect. *

* * @return the dialect prefix. */ public String getPrefix(); /** *

* Returns whether the dialect is lenient or not. If the dialect is not lenient, then * the existence of attributes or tags starting with the dialect prefix for which * no attribute/tag processor exists is considered an error. *

*

* For non-lenient dialects, any xmlns:{prefix} attributes in the document root or any * other element will be removed from output. These attributes will not be removed * for lenient dialects. *

*

* When several dialects act on the same prefix, a prefix * will be considered to be lenient if any of the dialects for that prefix is lenient. *

*

* Unless it is really required (for instance, in dialects with null prefix), * dialects should be non-lenient. *

* * @return true if the dialect is lenient, false if not. */ public boolean isLenient(); /** *

* Returns the set of attribute processors. *

* * @return the set of attribute processors. */ public Set getAttrProcessors(); /** *

* Returns the set of tag processors. *

* * @return the set of tag processors. */ public Set getTagProcessors(); /** *

* Returns the execution attributes that will be set during executions * of the template engine. *

*

* If more than one dialect are set, all of their execution attributes * will be added to the available execution attributes map. *

* * @return the execution attributes for this dialect. * @since 1.1 */ public Map getExecutionAttributes(); /** *

* Returns the set of DOCTYPE translations. *

* * @return the set of DOCTYPE translations. */ public Set getDocTypeTranslations(); /** *

* Returns the set of DOCTYPE resolution entries. *

* * @return the set of DOCTYPE resolution entries. */ public Set getDocTypeResolutionEntries(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy