XmlReadingProperty.java

// Generated by delombok at Mon Jan 06 07:19:11 UTC 2025
package de.larssh.utils.xml;

import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.SAXParser;
import org.xml.sax.SAXNotRecognizedException;
import org.xml.sax.SAXNotSupportedException;
import org.xml.sax.XMLReader;
import edu.umd.cs.findbugs.annotations.Nullable;

/**
 * Allows reading attributes of {@link DocumentBuilderFactory} and properties of
 * {@link SAXParser} and {@link XMLReader} in a typed way.
 *
 * <p>
 * While this class offers read support only, the extended class
 * {@link XmlReadingWritableProperty} shall be used for read-write accessible
 * properties.
 *
 * @param <T> the property type
 */
public class XmlReadingProperty<T> {
	/**
	 * Property Name
	 */
	private final String name;

	/**
	 * Allows the user to retrieve specific attributes on the underlying
	 * implementation.
	 *
	 * @param documentBuilderFactory the document builder factory
	 * @return the value of the attribute
	 * @throws IllegalArgumentException thrown if the underlying implementation
	 *                                  doesn't recognize the attribute.
	 * @see DocumentBuilderFactory#getAttribute(String)
	 */
	@Nullable
	@SuppressWarnings("unchecked")
	public T get(final DocumentBuilderFactory documentBuilderFactory) {
		return (T) documentBuilderFactory.getAttribute(getName());
	}

	/**
	 * Returns the particular property requested for in the underlying
	 * implementation of {@link XMLReader}.
	 *
	 * @param saxParser the SAX parser
	 * @return the current value of the property
	 * @throws SAXNotRecognizedException when the underlying {@link XMLReader} does
	 *                                   not recognize the property name.
	 * @throws SAXNotSupportedException  when the underlying {@link XMLReader}
	 *                                   recognizes the property name but doesn't
	 *                                   support the property.
	 *
	 * @see XMLReader#getProperty
	 */
	@Nullable
	@SuppressWarnings("unchecked")
	public T get(final SAXParser saxParser) throws SAXNotRecognizedException, SAXNotSupportedException {
		return (T) saxParser.getProperty(getName());
	}

	/**
	 * Look up the value of a property.
	 *
	 * <p>
	 * It is possible for a {@link XMLReader} to recognize a property name but
	 * temporarily be unable to return its value. Some property values may be
	 * available only in specific contexts, such as before, during, or after a
	 * parse.
	 *
	 * <p>
	 * {@link XMLReader}s are not required to recognize any specific property names.
	 *
	 * @param xmlReader the XML reader
	 * @return the current value of the property
	 * @throws SAXNotRecognizedException if the property value can't be assigned or
	 *                                   retrieved.
	 * @throws SAXNotSupportedException  when {@code xmlReader} recognizes the
	 *                                   property name but cannot determine its
	 *                                   value at this time.
	 */
	@Nullable
	@SuppressWarnings("unchecked")
	public T get(final XMLReader xmlReader) throws SAXNotRecognizedException, SAXNotSupportedException {
		return (T) xmlReader.getProperty(getName());
	}

	/**
	 * Property Name
	 *
	 * @return the property name
	 */
	@java.lang.SuppressWarnings("all")
	@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
	@lombok.Generated
	public String getName() {
		return this.name;
	}

	/**
	 * Creates a new {@code XmlReadingProperty} instance.
	 *
	 * @param name Property Name
	 */
	@java.lang.SuppressWarnings("all")
	@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
	@lombok.Generated
	public XmlReadingProperty(final String name) {
		this.name = name;
	}
}