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

com.ctc.wstx.api.EmptyElementHandler Maven / Gradle / Ivy

Go to download

Woodstox is a high-performance XML processor that implements Stax (JSR-173) and SAX2 APIs

The newest version!
package com.ctc.wstx.api;

import java.util.Set;
import java.util.TreeSet;

/**
 * Optional handler used to determine if a specific empty element (by name) should
 * be allowed to use the self-closing syntax instead of having a separate end tag.
 * 
 * @since 4.1
 */
public interface EmptyElementHandler
{
    /**
     * @param prefix The element's namespace prefix, null if not set
     * @param localName The element's local name
     * @param nsURI The elements's namespace URI, null if not set
     * @param allowEmpty The allow empty setting specified by the caller.
     * @return True if the empty element can be self-closing. False if a separate end tag should be written.
     */
    public boolean allowEmptyElement(String prefix, String localName, String nsURI, boolean allowEmpty);
    
    /**
     * Handler that uses a Set of Strings. If the local part of the element's QName is contained
     * in the Set the element is allowed to be empty.
     *

* Users of this class are encouraged to use a {@link TreeSet} with the {@link String#CASE_INSENSITIVE_ORDER} * comparator if case-insensitive comparison is needed (like when dealing with HTML tags). */ public static class SetEmptyElementHandler implements EmptyElementHandler { final protected Set mEmptyElements; public SetEmptyElementHandler(Set emptyElements) { mEmptyElements = emptyElements; } public boolean allowEmptyElement(String prefix, String localName, String nsURI, boolean allowEmpty) { return mEmptyElements.contains(localName); } } /** * HTML specific empty element handler. * Extends the {@link SetEmptyElementHandler} and configures * the HTML elements that must be self-closing according to the W3C: * http://www.w3.org/TR/html4/index/elements.html *

* Note that element name comparison is case-insensitive as required * by HTML specification. */ public static class HtmlEmptyElementHandler extends SetEmptyElementHandler { private final static HtmlEmptyElementHandler sInstance = new HtmlEmptyElementHandler(); public static HtmlEmptyElementHandler getInstance() { return sInstance; } protected HtmlEmptyElementHandler() { super(new TreeSet(String.CASE_INSENSITIVE_ORDER)); mEmptyElements.add("area"); mEmptyElements.add("base"); mEmptyElements.add("basefont"); mEmptyElements.add("br"); mEmptyElements.add("col"); mEmptyElements.add("frame"); mEmptyElements.add("hr"); mEmptyElements.add("input"); mEmptyElements.add("img"); mEmptyElements.add("isindex"); mEmptyElements.add("link"); mEmptyElements.add("meta"); mEmptyElements.add("param"); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy