blob: 82abb6ae4c4600a1c54b959d53e40defad6aca8f [file] [log] [blame]
// ***************************************************************************************************************************
// * 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 org.apache.juneau.xml;
import static org.apache.juneau.xml.XmlParser.*;
import java.nio.charset.*;
import java.util.*;
import javax.xml.stream.*;
import javax.xml.stream.util.*;
import org.apache.juneau.*;
import org.apache.juneau.http.*;
import org.apache.juneau.parser.*;
import org.apache.juneau.reflect.*;
import org.apache.juneau.svl.*;
/**
* Builder class for building XML parsers.
*/
public class XmlParserBuilder extends ReaderParserBuilder {
/**
* Constructor, default settings.
*/
public XmlParserBuilder() {
super();
}
/**
* Constructor.
*
* @param ps The initial configuration settings for this builder.
*/
public XmlParserBuilder(PropertyStore ps) {
super(ps);
}
@Override /* ContextBuilder */
public XmlParser build() {
return build(XmlParser.class);
}
//-----------------------------------------------------------------------------------------------------------------
// Properties
//-----------------------------------------------------------------------------------------------------------------
/**
* Configuration property: XML event allocator.
*
* <p>
* Associates an {@link XMLEventAllocator} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_eventAllocator}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder eventAllocator(XMLEventAllocator value) {
return set(XML_eventAllocator, value);
}
/**
* Configuration property: XML event allocator.
*
* <p>
* Associates an {@link XMLEventAllocator} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_eventAllocator}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder eventAllocator(Class<? extends XMLEventAllocator> value) {
return set(XML_eventAllocator, value);
}
/**
* Configuration property: Preserve root element during generalized parsing.
*
* <p>
* If <jk>true</jk>, when parsing into a generic {@link ObjectMap}, the map will contain a single entry whose key is
* the root element name.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_preserveRootElement}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public XmlParserBuilder preserveRootElement(boolean value) {
return set(XML_preserveRootElement, value);
}
/**
* Configuration property: Preserve root element during generalized parsing.
*
* <p>
* Shortcut for calling <code>preserveRootElement(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_preserveRootElement}
* </ul>
*
* @return This object (for method chaining).
*/
public XmlParserBuilder preserveRootElement() {
return set(XML_preserveRootElement, true);
}
/**
* Configuration property: XML reporter.
*
* <p>
* Associates an {@link XMLReporter} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_reporter}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder reporter(XMLReporter value) {
return set(XML_reporter, value);
}
/**
* Configuration property: XML reporter.
*
* <p>
* Associates an {@link XMLReporter} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_reporter}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder reporter(Class<? extends XMLReporter> value) {
return set(XML_reporter, value);
}
/**
* Configuration property: XML resolver.
*
* <p>
* Associates an {@link XMLResolver} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_resolver}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder resolver(XMLResolver value) {
return set(XML_resolver, value);
}
/**
* Configuration property: XML resolver.
*
* <p>
* Associates an {@link XMLResolver} with this parser.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_resolver}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public XmlParserBuilder resolver(Class<? extends XMLResolver> value) {
return set(XML_resolver, value);
}
/**
* Configuration property: Enable validation.
*
* <p>
* If <jk>true</jk>, XML document will be validated.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_validating}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public XmlParserBuilder validating(boolean value) {
return set(XML_validating, value);
}
/**
* Configuration property: Enable validation.
*
* <p>
* Shortcut for calling <code>validating(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link XmlParser#XML_validating}
* </ul>
*
* @return This object (for method chaining).
*/
public XmlParserBuilder validating() {
return set(XML_validating, true);
}
@Override /* ReaderParserBuilder */
public XmlParserBuilder fileCharset(Charset value) {
super.fileCharset(value);
return this;
}
@Override /* ReaderParserBuilder */
public XmlParserBuilder streamCharset(Charset value) {
super.streamCharset(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder autoCloseStreams(boolean value) {
super.autoCloseStreams(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder autoCloseStreams() {
super.autoCloseStreams();
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder debugOutputLines(int value) {
super.debugOutputLines(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder listener(Class<? extends ParserListener> value) {
super.listener(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder strict(boolean value) {
super.strict(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder strict() {
super.strict();
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder trimStrings(boolean value) {
super.trimStrings(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder trimStrings() {
super.trimStrings();
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder unbuffered(boolean value) {
super.unbuffered(value);
return this;
}
@Override /* ParserBuilder */
public XmlParserBuilder unbuffered() {
super.unbuffered();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanClassVisibility(Visibility value) {
super.beanClassVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanConstructorVisibility(Visibility value) {
super.beanConstructorVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionary(Class<?>...values) {
super.beanDictionary(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionary(Object...values) {
super.beanDictionary(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionaryReplace(Class<?>...values) {
super.beanDictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionaryReplace(Object...values) {
super.beanDictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionaryRemove(Class<?>...values) {
super.beanDictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public XmlParserBuilder beanDictionaryRemove(Object...values) {
super.beanDictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFieldVisibility(Visibility value) {
super.beanFieldVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFilters(Class<?>...values) {
super.beanFilters(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFilters(Object...values) {
super.beanFilters(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFiltersReplace(Class<?>...values) {
super.beanFiltersReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFiltersReplace(Object...values) {
super.beanFiltersReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFiltersRemove(Class<?>...values) {
super.beanFiltersRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanFiltersRemove(Object...values) {
super.beanFiltersRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanMapPutReturnsOldValue(boolean value) {
super.beanMapPutReturnsOldValue(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanMapPutReturnsOldValue() {
super.beanMapPutReturnsOldValue();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanMethodVisibility(Visibility value) {
super.beanMethodVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireDefaultConstructor(boolean value) {
super.beansRequireDefaultConstructor(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireDefaultConstructor() {
super.beansRequireDefaultConstructor();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireSerializable(boolean value) {
super.beansRequireSerializable(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireSerializable() {
super.beansRequireSerializable();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireSettersForGetters(boolean value) {
super.beansRequireSettersForGetters(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireSettersForGetters() {
super.beansRequireSettersForGetters();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beansRequireSomeProperties(boolean value) {
super.beansRequireSomeProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder beanTypePropertyName(String value) {
super.beanTypePropertyName(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpi(Class<?> beanClass, String value) {
super.bpi(beanClass, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpi(Map<String,String> values) {
super.bpi(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpi(String beanClassName, String value) {
super.bpi(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpx(Class<?> beanClass, String properties) {
super.bpx(beanClass, properties);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpx(Map<String,String> values) {
super.bpx(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpx(String beanClassName, String value) {
super.bpx(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpro(Class<?> beanClass, String value) {
super.bpro(beanClass, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpro(Map<String,String> values) {
super.bpro(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpro(String beanClassName, String value) {
super.bpro(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpwo(Class<?> beanClass, String properties) {
super.bpwo(beanClass, properties);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpwo(Map<String,String> values) {
super.bpwo(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder bpwo(String beanClassName, String value) {
super.bpwo(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder debug() {
super.debug();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionary(Class<?>...values) {
super.dictionary(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionary(Object...values) {
super.dictionary(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionaryReplace(Class<?>...values) {
super.dictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionaryReplace(Object...values) {
super.dictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionaryRemove(Class<?>...values) {
super.dictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder dictionaryRemove(Object...values) {
super.dictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public <T> XmlParserBuilder example(Class<T> c, T o) {
super.example(c, o);
return this;
}
@Override /* BeanContextBuilder */
public <T> XmlParserBuilder exampleJson(Class<T> c, String value) {
super.exampleJson(c, value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreInvocationExceptionsOnGetters(boolean value) {
super.ignoreInvocationExceptionsOnGetters(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreInvocationExceptionsOnGetters() {
super.ignoreInvocationExceptionsOnGetters();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreInvocationExceptionsOnSetters(boolean value) {
super.ignoreInvocationExceptionsOnSetters(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreInvocationExceptionsOnSetters() {
super.ignoreInvocationExceptionsOnSetters();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignorePropertiesWithoutSetters(boolean value) {
super.ignorePropertiesWithoutSetters(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreUnknownBeanProperties(boolean value) {
super.ignoreUnknownBeanProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreUnknownBeanProperties() {
super.ignoreUnknownBeanProperties();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder ignoreUnknownNullBeanProperties(boolean value) {
super.ignoreUnknownNullBeanProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder implClass(Class<?> interfaceClass, Class<?> implClass) {
super.implClass(interfaceClass, implClass);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder implClasses(Map<String,Class<?>> values) {
super.implClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder locale(Locale value) {
super.locale(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder mediaType(MediaType value) {
super.mediaType(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClasses(Class<?>...values) {
super.notBeanClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClasses(Object...values) {
super.notBeanClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClassesReplace(Class<?>...values) {
super.notBeanClassesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClassesReplace(Object...values) {
super.notBeanClassesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClassesRemove(Class<?>...values) {
super.notBeanClassesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanClassesRemove(Object...values) {
super.notBeanClassesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackages(Object...values) {
super.notBeanPackages(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackages(String...values) {
super.notBeanPackages(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackagesReplace(String...values) {
super.notBeanPackagesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackagesReplace(Object...values) {
super.notBeanPackagesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackagesRemove(String...values) {
super.notBeanPackagesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder notBeanPackagesRemove(Object...values) {
super.notBeanPackagesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwaps(Class<?>...values) {
super.pojoSwaps(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwaps(Object...values) {
super.pojoSwaps(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwapsReplace(Class<?>...values) {
super.pojoSwapsReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwapsReplace(Object...values) {
super.pojoSwapsReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwapsRemove(Class<?>...values) {
super.pojoSwapsRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder pojoSwapsRemove(Object...values) {
super.pojoSwapsRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder sortProperties(boolean value) {
super.sortProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder sortProperties() {
super.sortProperties();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder timeZone(TimeZone value) {
super.timeZone(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder useEnumNames(boolean value) {
super.useEnumNames(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder useEnumNames() {
super.useEnumNames();
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder useInterfaceProxies(boolean value) {
super.useInterfaceProxies(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder useJavaBeanIntrospector(boolean value) {
super.useJavaBeanIntrospector(value);
return this;
}
@Override /* BeanContextBuilder */
public XmlParserBuilder useJavaBeanIntrospector() {
super.useJavaBeanIntrospector();
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder set(String name, Object value) {
super.set(name, value);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder set(Map<String,Object> properties) {
super.set(properties);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder add(Map<String,Object> properties) {
super.add(properties);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder addTo(String name, Object value) {
super.addTo(name, value);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder addTo(String name, String key, Object value) {
super.addTo(name, key, value);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder removeFrom(String name, Object value) {
super.removeFrom(name, value);
return this;
}
@Override /* ContextBuilder */
public XmlParserBuilder apply(PropertyStore copyFrom) {
super.apply(copyFrom);
return this;
}
@Override
public XmlParserBuilder applyAnnotations(AnnotationList al, VarResolverSession vrs) {
super.applyAnnotations(al, vrs);
return this;
}
}