XmlReadingProperties.java

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

import java.util.Locale;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.xml.sax.ext.DeclHandler;
import org.xml.sax.ext.LexicalHandler;

/**
 * A collection of attributes/properties to be used for instances of
 * {@link javax.xml.parsers.DocumentBuilderFactory},
 * {@link javax.xml.parsers.SAXParser} and {@link org.xml.sax.XMLReader}.
 */
@SuppressWarnings("PMD.ClassNamingConventions")
public final class XmlReadingProperties {

	/**
	 * Xerces Properties
	 *
	 * <p>
	 * Based on <a href=
	 * "http://svn.apache.org/viewvc/xerces/site/trunk/production/xerces2-j/properties.html?r1=1872634">revision
	 * 1872634</a> of the
	 * <a href="https://xerces.apache.org/xerces2-j/properties.html">official Xerces
	 * properties documentation</a>
	 *
	 * <p>
	 * If you have created a DOM document builder or a SAX parser using the JAXP
	 * interfaces, the following instructions tell you how to set properties on
	 * document builders and SAX parsers created from the JAXP interfaces.
	 *
	 * <p>
	 * The method
	 * {@link javax.xml.parsers.DocumentBuilderFactory#setAttribute(String, Object)}
	 * may provide a means to set properties on the underlying parser. When using
	 * Xerces, you can set the value of a property with this method. For example:
	 *
	 * <pre>
	 * import javax.xml.parsers.DocumentBuilderFactory;
	 *
	 * DocumentBuilderFactory documentBuilderFactory = DocumentBuilderFactory.newInstance();
	 * documentBuilderFactory.setNamespaceAware(true);
	 * XercesProperties.DOM.DOCUMENT_CLASS_NAME.set(documentBuilderFactory, "org.apache.xerces.dom.DocumentImpl");
	 * </pre>
	 *
	 * <p>
	 * The method {@link javax.xml.parsers.SAXParser#setProperty(String, Object)}
	 * can be used to set properties on the underlying implementation of
	 * {@link org.xml.sax.XMLReader}. You can also retrieve the underlying
	 * {@link org.xml.sax.XMLReader} from the {@link javax.xml.parsers.SAXParser}
	 * allowing you to set and query properties on it directly. For example:
	 *
	 * <pre>
	 * import javax.xml.parsers.SAXParser;
	 * import org.xml.sax.XMLReader;
	 *
	 * SAXParser saxParser = ...;
	 * XMLReader xmlReader = saxParser.getXMLReader();
	 * XercesProperties.INPUT_BUFFER_SIZE.set(xmlReader, 2048);
	 * </pre>
	 */
	@SuppressWarnings("PMD.ClassNamingConventions")
	public static final class Xerces {

		/**
		 * General Properties
		 */
		@SuppressWarnings("PMD.ShortClassName")
		public static final class General {
			/**
			 * Get the string of characters associated with the current event. If the parser
			 * recognizes and supports this property but is not currently parsing text, it
			 * should return null.
			 *
			 * <p>
			 * This property is currently not supported because the contents of the XML
			 * string returned by this property is not well defined.
			 */
			public static final XmlReadingProperty<String> XML_STRING = new XmlReadingProperty<>("http://xml.org/sax/properties/xml-string");
			/**
			 * The XML Schema Recommendation explicitly states that the inclusion of
			 * {@code schemaLocation} and {@code noNamespaceSchemaLocation} attributes is
			 * only a hint; it does not mandate that these attributes must be used to locate
			 * schemas. Similar situation happens to {@code <import>} element in schema
			 * documents. This property allows the user to specify a list of schemas to use.
			 * If the {@code targetNamespace} of a schema (specified using this property)
			 * matches the {@code targetNamespace} of a schema occurring in the instance
			 * document in {@code schemaLocation} attribute, or if the
			 * {@code targetNamespace} matches the namespace attribute of {@code <import>}
			 * element, the schema specified by the user using this property will be used
			 * (i.e., the {@code schemaLocation} attribute in the instance document or on
			 * the {@code <import>} element will be effectively ignored).
			 *
			 * <p>
			 * The syntax is the same as for {@code schemaLocation} attributes in instance
			 * documents: e.g, {@code http://www.example.com file_name.xsd}. The user can
			 * specify more than one XML Schema in the list.
			 */
			public static final XmlReadingWritableProperty<String> SCHEMA_EXTERNAL_SCHEMA_LOCATION = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/schema/external-schemaLocation");
			/**
			 * This property allows the user to specify an XML Schema with no namespace.
			 *
			 * <p>
			 * The syntax is a same as for the {@code noNamespaceSchemaLocation} attribute
			 * that may occur in an instance document: e.g. {@code file_name.xsd}. The user
			 * may specify only one XML Schema. For more information see the documentation
			 * for the {@link #SCHEMA_EXTERNAL_SCHEMA_LOCATION} property.
			 */
			public static final XmlReadingWritableProperty<String> SCHEMA_EXTERNAL_NO_NAMESPACE_SCHEMA_LOCATION = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/schema/external-noNamespaceSchemaLocation");
			/**
			 * A {@link javax.xml.namespace.QName} or {@code XSElementDeclaration} object
			 * representing the top-level element declaration used when validating the root
			 * element of a document or document fragment (also known as the validation
			 * root). If the value of this property is non-null the validation root will be
			 * validated against the specified element declaration regardless of the actual
			 * name of the root element in the instance document. If the value is a
			 * {@link javax.xml.namespace.QName} and a element declaration cannot be found
			 * an error will be reported.
			 *
			 * <p>
			 * Type: {@link javax.xml.namespace.QName} or
			 * {@code org.apache.xerces.xs.XSElementDeclaration}
			 *
			 * <p>
			 * Note: If the {@link #VALIDATION_SCHEMA_ROOT_TYPE_DEFINITION} property has
			 * been set this property takes precedence if its value is non-null.
			 *
			 * <p>
			 * If the value specified is an {@code XSElementDeclaration} it must be an
			 * object obtained from Xerces and must also be an object which is known to the
			 * schema validator, for example one which would be returned from an
			 * {@code XMLGrammarPool}. If these constraints are not met a
			 * {@link ClassCastException} may be thrown or processing of substitution
			 * groups, {@code xsi:type} and wildcards may fail to locate otherwise available
			 * schema components.
			 *
			 * @see #VALIDATION_SCHEMA_ROOT_TYPE_DEFINITION
			 * @since Xerces-J 2.10.0
			 */
			public static final XmlReadingWritableProperty<Object> VALIDATION_SCHEMA_ROOT_ELEMENT_DECLARATION = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/validation/schema/root-element-declaration");
			/**
			 * A {@link javax.xml.namespace.QName} or {@code XSTypeDefinition} object
			 * representing the top-level type definition used when validating the root
			 * element of a document or document fragment (also known as the validation
			 * root). If the value of this property is non-null and the
			 * {@link #VALIDATION_SCHEMA_ROOT_ELEMENT_DECLARATION} property is not set the
			 * validation root will not be validated against any element declaration. If the
			 * value is a {@link javax.xml.namespace.QName} and a type definition cannot be
			 * found an error will be reported.
			 *
			 * <p>
			 * Type: {@link javax.xml.namespace.QName} or
			 * {@code org.apache.xerces.xs.XSTypeDefinition}
			 *
			 * <p>
			 * Note: If the {@link #VALIDATION_SCHEMA_ROOT_ELEMENT_DECLARATION} property has
			 * been set this property is ignored.
			 *
			 * <p>
			 * If the value specified is an {@code XSTypeDefinition} it must be an object
			 * obtained from Xerces and must also be an object which is known to the schema
			 * validator, for example one which would be returned from an
			 * {@code XMLGrammarPool}. If these constraints are not met a
			 * {@link ClassCastException} may be thrown or processing of substitution
			 * groups, {@code xsi:type} and wildcards may fail to locate otherwise available
			 * schema components.
			 *
			 * <p>
			 * Prior to Xerces-J 2.10.0 setting the value of this property to an
			 * {@code XSTypeDefinition} was not supported.
			 *
			 * @see #VALIDATION_SCHEMA_ROOT_ELEMENT_DECLARATION
			 * @since Xerces-J 2.8.0
			 */
			public static final XmlReadingWritableProperty<Object> VALIDATION_SCHEMA_ROOT_TYPE_DEFINITION = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/validation/schema/root-type-definition");
			/**
			 * The size of the input buffer in the readers. This determines how many bytes
			 * to read for each chunk.
			 *
			 * <p>
			 * Some tests indicate that a bigger buffer size can improve the parsing
			 * performance for relatively large files. The default buffer size in Xerces is
			 * 2K. This would give a good performance for small documents (less than 10K).
			 * For documents larger than 10K, specifying the buffer size to 4K or 8K will
			 * significantly improve the performance. But it's not recommended to set it to
			 * a value larger than 16K. For really tiny documents (1K, for example), you can
			 * also set it to a value less than 2K, to get the best performance.
			 *
			 * <p>
			 * There are some conditions where the size of the parser's internal buffers may
			 * be increased beyond the size specified for the input buffer. This would
			 * happen in places where the text in the document cannot be split, for instance
			 * if the document contains a name which is longer than the input buffer.
			 *
			 * @since Xerces-J 2.1.0
			 */
			public static final XmlReadingWritableProperty<Integer> INPUT_BUFFER_SIZE = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/input-buffer-size");
			/**
			 * The locale to use for reporting errors and warnings. When the value of this
			 * property is {@code null} the platform default returned from
			 * {@link Locale#getDefault()} will be used.
			 *
			 * <p>
			 * If no messages are available for the specified locale the platform default
			 * will be used. If the platform default is not English and no messages are
			 * available for this locale then messages will be reported in English.
			 *
			 * @since Xerces-J 2.10.0
			 */
			public static final XmlReadingWritableProperty<Locale> LOCALE = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/locale");
			/**
			 * It is possible to create XML documents whose processing could result in the
			 * use of all system resources. This property enables Xerces to detect such
			 * documents, and abort their processing.
			 *
			 * <p>
			 * Type: {@code org.apache.xerces.util.SecurityManager}
			 *
			 * <p>
			 * Note: The {@code SecurityManager} class contains a number of methods that
			 * allow applications to tailor Xerces's tolerance of document constructs that
			 * could result in the heavy consumption of system resources (see the JavaDoc of
			 * this class for details). Default values that should be appropriate for many
			 * environments are provided when the class is instantiated. Xerces will not
			 * behave in a strictly specification compliant way when this property is set.
			 * By default, this property is not set; Xerces's behaviour is therefore
			 * strictly specification compliant by default.
			 *
			 * @since Xerces-J 2.3.0
			 */
			public static final XmlReadingWritableProperty<Object> SECURITY_MANAGER = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/security-manager");

			@java.lang.SuppressWarnings("all")
			@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
			@lombok.Generated
			private General() {
				throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
			}
		}


		/**
		 * DOM Properties
		 */
		@SuppressWarnings("PMD.ShortClassName")
		public static final class DOM {
			/**
			 * The current DOM element node while parsing.
			 *
			 * <p>
			 * This property is useful for determining the location with a DOM document when
			 * an error occurs.
			 */
			public static final XmlReadingProperty<Element> CURRENT_ELEMENT_NODE = new XmlReadingProperty<>("http://apache.org/xml/properties/dom/current-element-node");
			/**
			 * The fully qualified name of the class implementing the
			 * {@link org.w3c.dom.Document} interface. The implementation used must have a
			 * zero argument constructor.
			 *
			 * <p>
			 * Default: {@code org.apache.xerces.dom.DocumentImpl}
			 *
			 * <p>
			 * Note: When the document class name is set to a value other than the name of
			 * the default document factory, the deferred node expansion feature does not
			 * work.
			 */
			public static final XmlReadingWritableProperty<String> DOCUMENT_CLASS_NAME = new XmlReadingWritableProperty<>("http://apache.org/xml/properties/dom/document-class-name");

			@java.lang.SuppressWarnings("all")
			@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
			@lombok.Generated
			private DOM() {
				throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
			}
		}


		/**
		 * SAX Properties
		 */
		@SuppressWarnings("PMD.ShortClassName")
		public static final class SAX {
			/**
			 * Set the handler for DTD declarations.
			 */
			public static final XmlReadingWritableProperty<DeclHandler> DECLARATION_HANDLER = new XmlReadingWritableProperty<>("http://xml.org/sax/properties/declaration-handler");
			/**
			 * Set the handler for lexical parsing events.
			 */
			public static final XmlReadingWritableProperty<LexicalHandler> LEXICAL_HANDLER = new XmlReadingWritableProperty<>("http://xml.org/sax/properties/lexical-handler");
			/**
			 * The DOM node currently being visited, if SAX is being used as a DOM iterator.
			 * If the parser recognizes and supports this property but is not currently
			 * visiting a DOM node, it should return {@code null}.
			 *
			 * <p>
			 * Access: read-only (parsing), read-write (not parsing)
			 *
			 * <p>
			 * Note: This property is only for SAX parser implementations used as DOM tree
			 * walkers. Currently, Xerces does not have this functionality.
			 */
			public static final XmlReadingWritableProperty<Node> DOM_NODE = new XmlReadingWritableProperty<>("http://xml.org/sax/properties/dom-node");
			/**
			 * A literal string describing the actual XML version of the document, such as
			 * {@code 1.0} or {@code 1.1}.
			 *
			 * <p>
			 * This property may only be examined during a parse after the
			 * {@code startDocument} callback has been completed.
			 *
			 * @since Xerces-J 2.7.0
			 */
			public static final XmlReadingProperty<String> DOCUMENT_XML_VERSION = new XmlReadingProperty<>("http://xml.org/sax/properties/document-xml-version");

			@java.lang.SuppressWarnings("all")
			@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
			@lombok.Generated
			private SAX() {
				throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
			}
		}

		@java.lang.SuppressWarnings("all")
		@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
		@lombok.Generated
		private Xerces() {
			throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
		}
	}

	@java.lang.SuppressWarnings("all")
	@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
	@lombok.Generated
	private XmlReadingProperties() {
		throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
	}
}