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();
}