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

com.arakelian.core.utils.XmlStreamReaderUtils Maven / Gradle / Ivy

Go to download

Small utility classes useful in a variety of projects. Don't reinvent the wheel. Stay small.

There is a newer version: 4.0.1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 com.arakelian.core.utils;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;
import java.text.MessageFormat;
import java.util.Map;

import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import javax.xml.stream.XMLStreamWriter;

import org.apache.commons.lang3.BooleanUtils;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.google.common.base.Charsets;

public class XmlStreamReaderUtils {
    /** Logger **/
    private static final Logger LOGGER = LoggerFactory.getLogger(XmlStreamReaderUtils.class);

    /**
     * Holds the textual representation for events.
     */
    private static final String[] NAMES_OF_EVENTS = new String[] { "UNDEFINED", "START_ELEMENT",
            "END_ELEMENT", "PROCESSING_INSTRUCTIONS", "CHARACTERS", "COMMENT", "SPACE", "START_DOCUMENT",
            "END_DOCUMENT", "ENTITY_REFERENCE", "ATTRIBUTE", "DTD", "CDATA", "NAMESPACE",
            "NOTATION_DECLARATION", "ENTITY_DECLARATION" };

    /**
     * Copy the START_DOCUMENT event.
     */
    public static final int COPY_START_DOCUMENT = 0x01;

    /**
     * Copy the END_DOCUMENT event.
     */
    public static final int COPY_END_DOCUMENT = 0x02;

    /**
     * Copy COMMENT events.
     */
    public static final int COPY_COMMENTS = 0x04;

    /**
     * Copy SPACE events.
     */
    public static final int COPY_IGNORABLE_WHITESPACE = 0x08;

    /**
     * Stop copying after an END_ELEMENT event matching the current START_ELEMENT event is copied.
     */
    public static final int COPY_SINGLE_ELEMENT = 0x10;

    /**
     * Default copy flags
     */
    public static final int DEFAULT_COPY_FLAGS = 0;

    public static void closeEmptyTag(
            final XMLStreamReader reader,
            final String namespace,
            final String localName) throws XMLStreamException {
        reader.nextTag();
        reader.require(XMLStreamConstants.END_ELEMENT, namespace, localName);
        reader.nextTag();
    }

    /**
     * Closes an {@link XMLStreamReader}.
     *
     * 

* This method will quietly log any {@link IOException} that may occur but will otherwise ignore * it. *

* * @param reader * XMLStreamReader to be closed. */ public static void closeQuietly(final XMLStreamReader reader) { try { if (reader != null) { reader.close(); } } catch (final Throwable t) { if (LOGGER.isDebugEnabled()) { LOGGER.debug("Ignoring exception that occurred when closing XMLStreamReader", t); } } } public static void copyStartElement(final XMLStreamReader reader, final XMLStreamWriter writer) throws XMLStreamException { // copy element String prefix = reader.getPrefix(); String localName = reader.getLocalName(); String uri = reader.getNamespaceURI(); if (prefix != null) { writer.writeStartElement(prefix, localName, uri); } else if (uri != null) { writer.writeStartElement(uri, localName); } else { writer.writeStartElement(localName); } // copy attributes final int length = reader.getAttributeCount(); for (int i = 0; i < length; i++) { prefix = reader.getAttributePrefix(i); localName = reader.getAttributeLocalName(i); uri = reader.getAttributeNamespace(i); final String value = reader.getAttributeValue(i); if (prefix != null) { writer.writeAttribute(prefix, uri, localName, value); } else if (uri != null) { writer.writeAttribute(uri, localName, value); } else { writer.writeAttribute(localName, value); } } } public static void copyText( final XMLStreamReader reader, final XMLStreamWriter writer, final StringBuilder textBuilder, final int flags) throws XMLStreamException { for (int eventType = reader.getEventType();; eventType = reader.next()) { switch (eventType) { case XMLStreamConstants.COMMENT: if (writer != null && (flags & COPY_COMMENTS) != 0) { writer.writeComment(reader.getText()); } break; case XMLStreamConstants.CDATA: if (writer != null) { writer.writeCData(reader.getText()); } if (textBuilder != null) { textBuilder.append(reader.getText()); } break; case XMLStreamConstants.SPACE: { if ((flags & COPY_IGNORABLE_WHITESPACE) != 0) { if (writer != null) { writer.writeCharacters(reader.getText()); } if (textBuilder != null) { textBuilder.append(reader.getText()); } } break; } case XMLStreamConstants.CHARACTERS: if (writer != null) { writer.writeCharacters(reader.getText()); } if (textBuilder != null) { textBuilder.append(reader.getText()); } break; default: return; } } } public static void copyXMLStream( final byte[] buf, final int offset, final int size, final XMLStreamWriter writer, final int copyFlags) throws XMLStreamException { copyXMLStream(new ByteArrayInputStream(buf, offset, size), writer, copyFlags); } public static void copyXMLStream(final InputStream is, final XMLStreamWriter writer, final int flags) throws XMLStreamException { final XMLInputFactory f = XMLInputFactory.newInstance(); final XMLStreamReader xmlReader = f.createXMLStreamReader(is, Charsets.UTF_8.name()); try { copyXMLStream(xmlReader, writer, flags); } finally { closeQuietly(xmlReader); } } public static void copyXMLStream(final Reader reader, final XMLStreamWriter writer, final int flags) throws XMLStreamException { final XMLInputFactory f = XMLInputFactory.newInstance(); final XMLStreamReader xmlReader = f.createXMLStreamReader(reader); try { copyXMLStream(xmlReader, writer, flags); } finally { closeQuietly(xmlReader); } } public static void copyXMLStream( final XMLStreamReader reader, final XMLStreamWriter writer, final int flags) throws XMLStreamException { int depth = 0; // IMPORTANT: we explicitly ignore the START_DOCUMENT and END_DOCUMENT // events; we don't want to accidentally close the destination stream, // since the caller may still be using it. for (int eventType = reader.getEventType();; eventType = reader.next()) { switch (eventType) { case XMLStreamConstants.ATTRIBUTE: case XMLStreamConstants.DTD: case XMLStreamConstants.NAMESPACE: case XMLStreamConstants.NOTATION_DECLARATION: case XMLStreamConstants.ENTITY_DECLARATION: { // ignored break; } case XMLStreamConstants.START_DOCUMENT: { if (writer != null && (flags & COPY_START_DOCUMENT) != 0) { writer.writeStartDocument(); } break; } case XMLStreamConstants.END_DOCUMENT: { if (writer != null && (flags & COPY_END_DOCUMENT) != 0) { writer.writeEndDocument(); } return; } case XMLStreamConstants.START_ELEMENT: { depth++; if (writer != null) { copyStartElement(reader, writer); } break; } case XMLStreamConstants.END_ELEMENT: { if (writer != null) { writer.writeEndElement(); } if (--depth <= 0) { if ((flags & COPY_SINGLE_ELEMENT) != 0) { return; } } break; } case XMLStreamConstants.PROCESSING_INSTRUCTION: { if (writer != null) { writer.writeProcessingInstruction(reader.getPITarget(), reader.getPIData()); } break; } case XMLStreamConstants.CHARACTERS: { if (writer != null) { writer.writeCharacters(reader.getText()); } break; } case XMLStreamConstants.COMMENT: { if (writer != null && (flags & COPY_COMMENTS) != 0) { writer.writeComment(reader.getText()); } break; } case XMLStreamConstants.SPACE: { if (writer != null && (flags & COPY_IGNORABLE_WHITESPACE) != 0) { writer.writeCharacters(reader.getText()); } break; } case XMLStreamConstants.ENTITY_REFERENCE: { if (writer != null) { writer.writeEntityRef(reader.getText()); } break; } case XMLStreamConstants.CDATA: { if (writer != null) { writer.writeCData(reader.getText()); } } } } } /** * Copy the XML input stream to the XML Writer as well as to a StringBuilder. * * @param reader * the XMLStreamReader * @param writer * the XMLStreamWriter * @param textBuilder * the StringBuilder * @param flags * the flags indicating copying options * @param indentParentElementText * a boolean flag indicating if what to indent before the parent element when copying * to the StringBuilder * @param parentElement * the parent element * @throws XMLStreamException * if there is error processing stream */ public static void copyXMLStream( final XMLStreamReader reader, final XMLStreamWriter writer, final StringBuilder textBuilder, final int flags, final boolean indentParentElementText, final String parentElement) throws XMLStreamException { int depth = 0; // IMPORTANT: we explicitly ignore the START_DOCUMENT and END_DOCUMENT // events; we don't want to accidentally close the destination stream, // since the caller may still be using it. for (int eventType = reader.getEventType();; eventType = reader.next()) { switch (eventType) { case XMLStreamConstants.ATTRIBUTE: case XMLStreamConstants.DTD: case XMLStreamConstants.NAMESPACE: case XMLStreamConstants.NOTATION_DECLARATION: case XMLStreamConstants.ENTITY_DECLARATION: { // ignored break; } case XMLStreamConstants.START_DOCUMENT: { if (writer != null && (flags & COPY_START_DOCUMENT) != 0) { writer.writeStartDocument(); } break; } case XMLStreamConstants.END_DOCUMENT: { if (writer != null && (flags & COPY_END_DOCUMENT) != 0) { writer.writeEndDocument(); } return; } case XMLStreamConstants.START_ELEMENT: { depth++; if (writer != null) { copyStartElement(reader, writer); } if (textBuilder != null) { final String name = reader.getLocalName(); if (name.equals("document")) { textBuilder.append(" "); } textBuilder.append('<').append(name).append('>'); } break; } case XMLStreamConstants.END_ELEMENT: { if (writer != null) { writer.writeEndElement(); } if (textBuilder != null) { final String name = reader.getLocalName(); if (name.equals("document")) { textBuilder.append(" "); } textBuilder.append("'); } if (--depth <= 0) { if ((flags & COPY_SINGLE_ELEMENT) != 0) { return; } } break; } case XMLStreamConstants.PROCESSING_INSTRUCTION: { if (writer != null) { writer.writeProcessingInstruction(reader.getPITarget(), reader.getPIData()); } if (textBuilder != null) { textBuilder.append(reader.getText()); } break; } case XMLStreamConstants.CHARACTERS: { final String text = reader.getText(); if (writer != null) { writer.writeCharacters(text); } if (textBuilder != null) { textBuilder.append(text); } break; } case XMLStreamConstants.COMMENT: { final String text = reader.getText(); if (writer != null && (flags & COPY_COMMENTS) != 0) { writer.writeComment(text); } if (textBuilder != null && (flags & COPY_COMMENTS) != 0) { textBuilder.append(text); } break; } case XMLStreamConstants.SPACE: { final String text = reader.getText(); if (writer != null && (flags & COPY_IGNORABLE_WHITESPACE) != 0) { writer.writeCharacters(text); } if (textBuilder != null && (flags & COPY_IGNORABLE_WHITESPACE) != 0) { textBuilder.append(text); } break; } case XMLStreamConstants.ENTITY_REFERENCE: { final String text = reader.getText(); if (writer != null) { writer.writeEntityRef(text); } if (textBuilder != null) { textBuilder.append(text); } break; } case XMLStreamConstants.CDATA: { final String text = reader.getText(); if (writer != null) { writer.writeCData(text); } if (textBuilder != null) { textBuilder.append(text); } } } } } /** * Returns new instance of XMLStreamException with given cause * * @param message * exception message * @param reader * parser * @param cause * underlying cause * @return XMLStreamException with given cause */ public static XMLStreamException createXMLStreamException( final String message, final XMLStreamReader reader, final Throwable cause) { final XMLStreamException exception = new XMLStreamException(message, reader.getLocation(), null); exception.initCause(cause); return exception; } public static XMLStreamException createXMLStreamException(final Throwable cause) { final XMLStreamException exception = new XMLStreamException(); exception.initCause(cause); return exception; } /** * Returns string describing the current event. * * @param reader * pull parser that contains event information * @return string describing the current event. */ public static String getEventTypeDescription(final XMLStreamReader reader) { final int eventType = reader.getEventType(); if (eventType == XMLStreamConstants.START_ELEMENT) { final String namespace = reader.getNamespaceURI(); return "<" + reader.getLocalName() + (!StringUtils.isEmpty(namespace) ? "@" + namespace : StringUtils.EMPTY) + ">"; } if (eventType == XMLStreamConstants.END_ELEMENT) { final String namespace = reader.getNamespaceURI(); return ""; } return NAMES_OF_EVENTS[reader.getEventType()]; } /** * Method isStartElement. * * @param reader * XMLStreamReader * @param namespace * String * @param localName * String * @return boolean */ public static boolean isStartElement( final XMLStreamReader reader, final String namespace, final String localName) { return reader.getEventType() == XMLStreamConstants.START_ELEMENT && nameEquals(reader, namespace, localName); } /** * Method nameEquals. * * @param reader * XMLStreamReader * @param namespace * String * @param localName * String * @return boolean */ public static boolean nameEquals( final XMLStreamReader reader, final String namespace, final String localName) { if (!reader.getLocalName().equals(localName)) { return false; } if (namespace == null) { return true; } final String namespaceURI = reader.getNamespaceURI(); if (namespaceURI == null) { return StringUtils.isEmpty(namespace); } return namespaceURI.equals(StringUtils.defaultString(namespace)); } /** * Returns the value of an attribute as a boolean. If the attribute is empty, this method * returns the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static boolean optionalBooleanAttribute( final XMLStreamReader reader, final String localName, final boolean defaultValue) { return optionalBooleanAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a boolean. If the attribute is empty, this method * returns the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static boolean optionalBooleanAttribute( final XMLStreamReader reader, final String namespace, final String localName, final boolean defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return BooleanUtils.toBoolean(value); } return defaultValue; } /** * Returns the value of an attribute as a byte. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static byte optionalByteAttribute( final XMLStreamReader reader, final String localName, final byte defaultValue) { return optionalByteAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a byte. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static byte optionalByteAttribute( final XMLStreamReader reader, final String namespace, final String localName, final byte defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Byte.parseByte(value); } return defaultValue; } /** * Returns the value of an attribute as a Class. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. * @throws XMLStreamException * if there is error processing stream */ public static Class optionalClassAttribute( final XMLStreamReader reader, final String localName, final Class defaultValue) throws XMLStreamException { return optionalClassAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a Class. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. * @throws XMLStreamException * if there is error processing stream */ public static Class optionalClassAttribute( final XMLStreamReader reader, final String namespace, final String localName, final Class defaultValue) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { try { return Class.forName(value.toString()); } catch (final ClassNotFoundException e) { throw createXMLStreamException( MessageFormat.format("\"{0}\" is not a valid class name.", value), reader, e); } } return defaultValue; } /** * Returns the value of an attribute as a double. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static double optionalDoubleAttribute( final XMLStreamReader reader, final String localName, final double defaultValue) { return optionalDoubleAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a double. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static double optionalDoubleAttribute( final XMLStreamReader reader, final String namespace, final String localName, final double defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Double.parseDouble(value); } return defaultValue; } /** * Returns the value of an attribute as a float. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static float optionalFloatAttribute( final XMLStreamReader reader, final String localName, final float defaultValue) { return optionalFloatAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a float. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static float optionalFloatAttribute( final XMLStreamReader reader, final String namespace, final String localName, final float defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Float.parseFloat(value); } return defaultValue; } /** * Returns the value of an attribute as a int. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static int optionalIntAttribute( final XMLStreamReader reader, final String localName, final int defaultValue) { return optionalIntAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a int. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static int optionalIntAttribute( final XMLStreamReader reader, final String namespace, final String localName, final int defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Integer.parseInt(value); } return defaultValue; } /** * Returns the value of an attribute as a long. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static long optionalLongAttribute( final XMLStreamReader reader, final String localName, final long defaultValue) { return optionalLongAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a long. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static long optionalLongAttribute( final XMLStreamReader reader, final String namespace, final String localName, final long defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Long.parseLong(value); } return defaultValue; } /** * Returns the value of an attribute as a short. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static short optionalShortAttribute( final XMLStreamReader reader, final String localName, final short defaultValue) { return optionalShortAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a short. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static short optionalShortAttribute( final XMLStreamReader reader, final String namespace, final String localName, final short defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Short.parseShort(value); } return defaultValue; } /** * Returns the value of an attribute as a String. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static String optionalStringAttribute( final XMLStreamReader reader, final String localName, final String defaultValue) { return optionalStringAttribute(reader, null, localName, defaultValue); } /** * Returns the value of an attribute as a String. If the attribute is empty, this method returns * the default value provided. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * String * @param localName * local name of attribute (the namespace is ignored). * @param defaultValue * default value * @return value of attribute, or the default value if the attribute is empty. */ public static String optionalStringAttribute( final XMLStreamReader reader, final String namespace, final String localName, final String defaultValue) { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return value; } return defaultValue; } public static void readKeyValuePairs(final XMLStreamReader reader, final Map map) throws XMLStreamException { final StringBuilder buf = new StringBuilder(); while (reader.isStartElement()) { // element name is key final String key = reader.getLocalName().toString(); reader.next(); // text inside is key's value buf.setLength(0); copyText(reader, null, buf, 0); final String value = buf.toString(); map.put(key, value); reader.require(XMLStreamConstants.END_ELEMENT, null, key); reader.nextTag(); } } /** * Returns the value of an attribute as a boolean. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as boolean * @throws XMLStreamException * if attribute is empty. */ public static boolean requiredBooleanAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredBooleanAttribute(reader, null, localName); } /** * Returns the value of an attribute as a boolean. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as boolean * @throws XMLStreamException * if attribute is empty. */ public static boolean requiredBooleanAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return BooleanUtils.toBoolean(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a byte. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as byte * @throws XMLStreamException * if attribute is empty. */ public static byte requiredByteAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredByteAttribute(reader, null, localName); } /** * Returns the value of an attribute as a byte. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as byte * @throws XMLStreamException * if attribute is empty. */ public static byte requiredByteAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Byte.parseByte(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a Class. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as Class * @throws XMLStreamException * if attribute is empty. */ public static Class requiredClassAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredClassAttribute(reader, null, localName); } /** * Returns the value of an attribute as a Class. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as Class * @throws XMLStreamException * if attribute is empty. */ public static Class requiredClassAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { try { return Class.forName(value.toString()); } catch (final ClassNotFoundException e) { throw createXMLStreamException( MessageFormat.format("\"{0}\" is not a valid class name.", value), reader, e); } } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a double. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as double * @throws XMLStreamException * if attribute is empty. */ public static double requiredDoubleAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredDoubleAttribute(reader, null, localName); } /** * Returns the value of an attribute as a double. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as double * @throws XMLStreamException * if attribute is empty. */ public static double requiredDoubleAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Double.parseDouble(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a float. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as float * @throws XMLStreamException * if attribute is empty. */ public static float requiredFloatAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredFloatAttribute(reader, null, localName); } /** * Returns the value of an attribute as a float. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as float * @throws XMLStreamException * if attribute is empty. */ public static float requiredFloatAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Float.parseFloat(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a int. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as int * @throws XMLStreamException * if attribute is empty. */ public static int requiredIntAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredIntAttribute(reader, null, localName); } /** * Returns the value of an attribute as a int. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as int * @throws XMLStreamException * if attribute is empty. */ public static int requiredIntAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Integer.parseInt(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a long. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as long * @throws XMLStreamException * if attribute is empty. */ public static long requiredLongAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredLongAttribute(reader, null, localName); } /** * Returns the value of an attribute as a long. If the attribute is empty, this method throws an * exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as long * @throws XMLStreamException * if attribute is empty. */ public static long requiredLongAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Long.parseLong(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a short. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as short * @throws XMLStreamException * if attribute is empty. */ public static short requiredShortAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredShortAttribute(reader, null, localName); } /** * Returns the value of an attribute as a short. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as short * @throws XMLStreamException * if attribute is empty. */ public static short requiredShortAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return Short.parseShort(value); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } /** * Returns the value of an attribute as a String. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param localName * local name of attribute (the namespace is ignored). * @return value of attribute as String * @throws XMLStreamException * if attribute is empty. */ public static String requiredStringAttribute(final XMLStreamReader reader, final String localName) throws XMLStreamException { return requiredStringAttribute(reader, null, localName); } /** * Returns the value of an attribute as a String. If the attribute is empty, this method throws * an exception. * * @param reader * XMLStreamReader that contains attribute values. * @param namespace * namespace * @param localName * the local name of the attribute. * @return value of attribute as String * @throws XMLStreamException * if attribute is empty. */ public static String requiredStringAttribute( final XMLStreamReader reader, final String namespace, final String localName) throws XMLStreamException { final String value = reader.getAttributeValue(namespace, localName); if (value != null) { return value.toString(); } throw new XMLStreamException( MessageFormat.format("Attribute {0}:{1} is required", namespace, localName)); } public static final void requireEndDocument(final XMLStreamReader reader) throws XMLStreamException { skipWhitespace(reader); reader.require(XMLStreamConstants.END_DOCUMENT, null, null); } /** * Method skipElement. * * @param reader * XMLStreamReader * @throws XMLStreamException * if there is error skipping element * @throws IOException * if there is error skipping element */ public static void skipElement(final XMLStreamReader reader) throws XMLStreamException, IOException { if (reader.getEventType() != XMLStreamConstants.START_ELEMENT) { return; } final String namespace = reader.getNamespaceURI(); final String name = reader.getLocalName(); for (;;) { switch (reader.nextTag()) { case XMLStreamConstants.START_ELEMENT: // call ourselves recursively if we encounter START_ELEMENT skipElement(reader); break; case XMLStreamConstants.END_ELEMENT: case XMLStreamConstants.END_DOCUMENT: // discard events until we encounter matching END_ELEMENT reader.require(XMLStreamConstants.END_ELEMENT, namespace, name); reader.next(); return; } } } public static void skipToMatchingEndElement(final XMLStreamReader reader) throws XMLStreamException { if (reader.getEventType() != XMLStreamConstants.START_ELEMENT) { throw new XMLStreamException("Starting element expected."); } copyXMLStream(reader, null, COPY_SINGLE_ELEMENT); } @SuppressWarnings("OperatorPrecedence") public static final void skipWhitespace(final XMLStreamReader reader) throws XMLStreamException { int eventType = reader.getEventType(); while (eventType == XMLStreamConstants.CHARACTERS && reader.isWhiteSpace() || eventType == XMLStreamConstants.CDATA && reader.isWhiteSpace() || eventType == XMLStreamConstants.SPACE || eventType == XMLStreamConstants.PROCESSING_INSTRUCTION || eventType == XMLStreamConstants.COMMENT) { eventType = reader.next(); } } public static final javax.xml.stream.XMLStreamException wrapException(final XMLStreamException e) { return new javax.xml.stream.XMLStreamException(e); } private XmlStreamReaderUtils() { } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy