blob: cc60f61c012ecc51c948b4ae056df0db6bc7d528 [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.serializer;
import static org.apache.juneau.internal.CollectionUtils.*;
import static org.apache.juneau.serializer.OutputStreamSerializer.*;
import static org.apache.juneau.serializer.WriterSerializer.*;
import java.lang.reflect.*;
import java.nio.charset.*;
import java.util.*;
import org.apache.juneau.*;
import org.apache.juneau.http.*;
import org.apache.juneau.internal.*;
import org.apache.juneau.reflect.*;
import org.apache.juneau.svl.*;
/**
* Builder class for creating instances of {@link SerializerGroup}.
*/
public class SerializerGroupBuilder extends BeanTraverseBuilder {
private final List<Object> serializers;
/**
* Create an empty serializer group builder.
*/
public SerializerGroupBuilder() {
this.serializers = new ArrayList<>();
}
/**
* Clone an existing serializer group builder.
*
* @param copyFrom The serializer group that we're copying settings and serializers from.
*/
public SerializerGroupBuilder(SerializerGroup copyFrom) {
super(copyFrom.getPropertyStore());
this.serializers = new ArrayList<>();
addReverse(serializers, copyFrom.getSerializers());
}
/**
* Registers the specified serializers with this group.
*
* @param s The serializers to append to this group.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder append(Class<?>...s) {
addReverse(serializers, s);
return this;
}
/**
* Registers the specified serializers with this group.
*
* <p>
* When passing in pre-instantiated serializers to this group, applying properties and transforms to the group
* do not affect them.
*
* @param s The serializers to append to this group.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder append(Serializer...s) {
addReverse(serializers, s);
return this;
}
/**
* Registers the specified serializers with this group.
*
* <p>
* Objects can either be instances of serializers or serializer classes.
*
* @param s The serializers to append to this group.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder append(List<Object> s) {
addReverse(serializers, s);
return this;
}
/**
* Registers the specified serializers with this group.
*
* <p>
* Objects can either be instances of serializers or serializer classes.
*
* @param s The serializers to append to this group.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder append(Object...s) {
addReverse(serializers, s);
return this;
}
/**
* Creates a new {@link SerializerGroup} object using a snapshot of the settings defined in this builder.
*
* <p>
* This method can be called multiple times to produce multiple serializer groups.
*
* @return A new {@link SerializerGroup} object.
*/
@Override /* ContextBuilder */
@SuppressWarnings("unchecked")
public SerializerGroup build() {
List<Serializer> l = new ArrayList<>();
for (Object s : serializers) {
Class<? extends Serializer> c = null;
PropertyStore ps = getPropertyStore();
if (s instanceof Class) {
c = (Class<? extends Serializer>)s;
l.add(ContextCache.INSTANCE.create(c, ps));
} else {
l.add((Serializer)s);
}
}
return new SerializerGroup(getPropertyStore(), ArrayUtils.toReverseArray(Serializer.class, l));
}
//-----------------------------------------------------------------------------------------------------------------
// Properties
//-----------------------------------------------------------------------------------------------------------------
/**
* Configuration property: Add <js>"_type"</js> properties when needed.
*
* <p>
* If <jk>true</jk>, then <js>"_type"</js> properties will be added to beans if their type cannot be inferred
* through reflection.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_addBeanTypes}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder addBeanTypes(boolean value) {
return set(SERIALIZER_addBeanTypes, value);
}
/**
* Configuration property: Add <js>"_type"</js> properties when needed.
*
* <p>
* Shortcut for calling <code>addBeanTypes(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_addBeanTypes}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder addBeanTypes() {
return set(SERIALIZER_addBeanTypes, true);
}
/**
* Configuration property: Add type attribute to root nodes.
*
* <p>
* When disabled, it is assumed that the parser knows the exact Java POJO type being parsed, and therefore top-level
* type information that might normally be included to determine the data type will not be serialized.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_addRootType}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder addRootType(boolean value) {
return set(SERIALIZER_addRootType, value);
}
/**
* Configuration property: Add type attribute to root nodes.
*
* <p>
* Shortcut for calling <code>addRootType(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_addRootType}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder addRootType() {
return set(SERIALIZER_addRootType, true);
}
/**
* Configuration property: Serializer listener.
*
* <p>
* Class used to listen for errors and warnings that occur during serialization.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_listener}
* </ul>
*
* @param value
* The new value for this property.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder listener(Class<? extends SerializerListener> value) {
return set(SERIALIZER_listener, value);
}
/**
* Configuration property: Sort arrays and collections alphabetically.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_sortCollections}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder sortCollections(boolean value) {
return set(SERIALIZER_sortCollections, value);
}
/**
* Configuration property: Sort arrays and collections alphabetically.
*
* <p>
* Shortcut for calling <code>sortCollections(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_sortCollections}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder sortCollections() {
return set(SERIALIZER_sortCollections, true);
}
/**
* Configuration property: Sort maps alphabetically.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_sortMaps}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder sortMaps(boolean value) {
return set(SERIALIZER_sortMaps, value);
}
/**
* Configuration property: Sort maps alphabetically.
*
* <p>
* Shortcut for calling <code>sortMaps(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_sortMaps}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder sortMaps() {
return set(SERIALIZER_sortMaps, true);
}
/**
* Configuration property: Trim empty lists and arrays.
*
* <p>
* If <jk>true</jk>, empty list values will not be serialized to the output.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimEmptyCollections}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimEmptyCollections(boolean value) {
return set(SERIALIZER_trimEmptyCollections, value);
}
/**
* Configuration property: Trim empty lists and arrays.
*
* <p>
* Shortcut for calling <code>trimEmptyCollections(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimEmptyCollections}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimEmptyCollections() {
return set(SERIALIZER_trimEmptyCollections, true);
}
/**
* Configuration property: Trim empty maps.
*
* <p>
* If <jk>true</jk>, empty map values will not be serialized to the output.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimEmptyMaps}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimEmptyMaps(boolean value) {
return set(SERIALIZER_trimEmptyMaps, value);
}
/**
* Configuration property: Trim empty maps.
*
* <p>
* Shortcut for calling <code>trimEmptyMaps(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimEmptyMaps}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimEmptyMaps() {
return set(SERIALIZER_trimEmptyMaps, true);
}
/**
* Configuration property: Trim null bean property values.
*
* <p>
* If <jk>true</jk>, null bean values will not be serialized to the output.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimNullProperties}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>true</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimNullProperties(boolean value) {
return set(SERIALIZER_trimNullProperties, value);
}
/**
* Configuration property: Trim strings.
*
* <p>
* If <jk>true</jk>, string values will be trimmed of whitespace using {@link String#trim()} before being serialized.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimStrings}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimStrings(boolean value) {
return set(SERIALIZER_trimStrings, value);
}
/**
* Configuration property: Trim strings.
*
* <p>
* Shortcut for calling <code>trimStrings(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_trimStrings}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder trimStrings() {
return set(SERIALIZER_trimStrings, true);
}
/**
* Configuration property: URI context bean.
*
* <p>
* Bean used for resolution of URIs to absolute or root-relative form.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_uriContext}
* </ul>
*
* @param value The new value for this property.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder uriContext(UriContext value) {
return set(SERIALIZER_uriContext, value);
}
/**
* Configuration property: URI relativity.
*
* <p>
* Defines what relative URIs are relative to when serializing URI/URL objects.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_uriRelativity}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is {@link UriRelativity#RESOURCE}
* @return This object (for method chaining).
*/
public SerializerGroupBuilder uriRelativity(UriRelativity value) {
return set(SERIALIZER_uriRelativity, value);
}
/**
* Configuration property: URI resolution.
*
* <p>
* Defines the resolution level for URIs when serializing URI/URL objects.
*
* <ul class='seealso'>
* <li class='jf'>{@link Serializer#SERIALIZER_uriResolution}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is {@link UriResolution#NONE}
* @return This object (for method chaining).
*/
public SerializerGroupBuilder uriResolution(UriResolution value) {
return set(SERIALIZER_uriResolution, value);
}
//--- OutputStreamSerializer ---
/**
* Configuration property: Binary string format.
*
* <p>
* When using the {@link Serializer#serializeToString(Object)} method on stream-based serializers, this defines the format to use
* when converting the resulting byte array to a string.
*
* <ul class='javatree'>
* <li class='jf'>{@link OutputStreamSerializer#OSSERIALIZER_binaryFormat}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is {@link BinaryFormat#HEX}.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder binaryOutputFormat(BinaryFormat value) {
return set(OSSERIALIZER_binaryFormat, value);
}
//--- WriterSerializer ---
/**
* Configuration property: File charset.
*
* <p>
* The character set to use for writing Files to the file system.
*
* <p>
* Used when passing in files to {@link Serializer#serialize(Object, Object)}.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_fileCharset}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is the system JVM setting.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder fileCharset(Charset value) {
return set(WSERIALIZER_fileCharset, value);
}
/**
* Configuration property: Maximum indentation.
*
* <p>
* Specifies the maximum indentation level in the serialized document.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_maxIndent}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <c>100</c>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder maxIndent(int value) {
return set(WSERIALIZER_maxIndent, value);
}
/**
* Configuration property: Quote character.
*
* <p>
* This is the character used for quoting attributes and values.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_quoteChar}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <js>'"'</js>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder quoteChar(char value) {
return set(WSERIALIZER_quoteChar, value);
}
/**
* Configuration property: Quote character.
*
* <p>
* Shortcut for calling <code>quoteChar(<js>'\''</js>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_quoteChar}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder sq() {
return quoteChar('\'');
}
/**
* Configuration property: Output stream charset.
*
* <p>
* The character set to use when writing to OutputStreams.
*
* <p>
* Used when passing in output streams and byte arrays to {@link WriterSerializer#serialize(Object, Object)}.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_streamCharset}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is the system JVM setting.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder streamCharset(Charset value) {
return set(WSERIALIZER_streamCharset, value);
}
/**
* Configuration property: Use whitespace.
*
* <p>
* If <jk>true</jk>, newlines and indentation and spaces are added to the output to improve readability.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_useWhitespace}
* </ul>
*
* @param value
* The new value for this property.
* <br>The default is <jk>false</jk>.
* @return This object (for method chaining).
*/
public SerializerGroupBuilder useWhitespace(boolean value) {
return set(WSERIALIZER_useWhitespace, value);
}
/**
* Configuration property: Use whitespace.
*
* <p>
* Shortcut for calling <code>useWhitespace(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_useWhitespace}
* </ul>
* @return This object (for method chaining).
*/
public SerializerGroupBuilder useWhitespace() {
return set(WSERIALIZER_useWhitespace, true);
}
/**
* Configuration property: Use whitespace.
*
* <p>
* Shortcut for calling <code>useWhitespace(<jk>true</jk>)</code>.
*
* <ul class='seealso'>
* <li class='jf'>{@link WriterSerializer#WSERIALIZER_useWhitespace}
* </ul>
*
* @return This object (for method chaining).
*/
public SerializerGroupBuilder ws() {
return useWhitespace();
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder detectRecursions(boolean value) {
super.detectRecursions(value);
return this;
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder detectRecursions() {
super.detectRecursions();
return this;
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder ignoreRecursions(boolean value) {
super.ignoreRecursions(value);
return this;
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder ignoreRecursions() {
super.ignoreRecursions();
return this;
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder initialDepth(int value) {
super.initialDepth(value);
return this;
}
@Override /* BeanTraverseBuilder */
public SerializerGroupBuilder maxDepth(int value) {
super.maxDepth(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanClassVisibility(Visibility value) {
super.beanClassVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanConstructorVisibility(Visibility value) {
super.beanConstructorVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionary(Class<?>...values) {
super.beanDictionary(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionary(Object...values) {
super.beanDictionary(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionaryReplace(Class<?>...values) {
super.beanDictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionaryReplace(Object...values) {
super.beanDictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionaryRemove(Class<?>...values) {
super.beanDictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
@Deprecated
public SerializerGroupBuilder beanDictionaryRemove(Object...values) {
super.beanDictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFieldVisibility(Visibility value) {
super.beanFieldVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFilters(Class<?>...values) {
super.beanFilters(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFilters(Object...values) {
super.beanFilters(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFiltersReplace(Class<?>...values) {
super.beanFiltersReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFiltersReplace(Object...values) {
super.beanFiltersReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFiltersRemove(Class<?>...values) {
super.beanFiltersRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanFiltersRemove(Object...values) {
super.beanFiltersRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanMapPutReturnsOldValue(boolean value) {
super.beanMapPutReturnsOldValue(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanMapPutReturnsOldValue() {
super.beanMapPutReturnsOldValue();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanMethodVisibility(Visibility value) {
super.beanMethodVisibility(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireDefaultConstructor(boolean value) {
super.beansRequireDefaultConstructor(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireDefaultConstructor() {
super.beansRequireDefaultConstructor();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireSerializable(boolean value) {
super.beansRequireSerializable(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireSerializable() {
super.beansRequireSerializable();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireSettersForGetters(boolean value) {
super.beansRequireSettersForGetters(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireSettersForGetters() {
super.beansRequireSettersForGetters();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beansRequireSomeProperties(boolean value) {
super.beansRequireSomeProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder beanTypePropertyName(String value) {
super.beanTypePropertyName(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpi(Class<?> beanClass, String value) {
super.bpi(beanClass, value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpi(Map<String,String> values) {
super.bpi(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpi(String beanClassName, String value) {
super.bpi(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpx(Class<?> beanClass, String properties) {
super.bpx(beanClass, properties);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpx(Map<String,String> values) {
super.bpx(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder bpx(String beanClassName, String value) {
super.bpx(beanClassName, value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder debug() {
super.debug();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionary(Class<?>...values) {
super.dictionary(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionary(Object...values) {
super.dictionary(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionaryReplace(Class<?>...values) {
super.dictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionaryReplace(Object...values) {
super.dictionaryReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionaryRemove(Class<?>...values) {
super.dictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder dictionaryRemove(Object...values) {
super.dictionaryRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public <T> SerializerGroupBuilder example(Class<T> c, T o) {
super.example(c, o);
return this;
}
@Override /* BeanContextBuilder */
public <T> SerializerGroupBuilder exampleJson(Class<T> c, String value) {
super.exampleJson(c, value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreInvocationExceptionsOnGetters(boolean value) {
super.ignoreInvocationExceptionsOnGetters(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreInvocationExceptionsOnGetters() {
super.ignoreInvocationExceptionsOnGetters();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreInvocationExceptionsOnSetters(boolean value) {
super.ignoreInvocationExceptionsOnSetters(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreInvocationExceptionsOnSetters() {
super.ignoreInvocationExceptionsOnSetters();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignorePropertiesWithoutSetters(boolean value) {
super.ignorePropertiesWithoutSetters(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreUnknownBeanProperties(boolean value) {
super.ignoreUnknownBeanProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreUnknownBeanProperties() {
super.ignoreUnknownBeanProperties();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder ignoreUnknownNullBeanProperties(boolean value) {
super.ignoreUnknownNullBeanProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder implClass(Class<?> interfaceClass, Class<?> implClass) {
super.implClass(interfaceClass, implClass);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder implClasses(Map<String,Class<?>> values) {
super.implClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder locale(Locale value) {
super.locale(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder mediaType(MediaType value) {
super.mediaType(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClasses(Class<?>...values) {
super.notBeanClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClasses(Object...values) {
super.notBeanClasses(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClassesReplace(Class<?>...values) {
super.notBeanClassesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClassesReplace(Object...values) {
super.notBeanClassesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClassesRemove(Class<?>...values) {
super.notBeanClassesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanClassesRemove(Object...values) {
super.notBeanClassesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackages(Object...values) {
super.notBeanPackages(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackages(String...values) {
super.notBeanPackages(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackagesReplace(String...values) {
super.notBeanPackagesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackagesReplace(Object...values) {
super.notBeanPackagesReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackagesRemove(String...values) {
super.notBeanPackagesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder notBeanPackagesRemove(Object...values) {
super.notBeanPackagesRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwaps(Class<?>...values) {
super.pojoSwaps(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwaps(Object...values) {
super.pojoSwaps(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwapsReplace(Class<?>...values) {
super.pojoSwapsReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwapsReplace(Object...values) {
super.pojoSwapsReplace(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwapsRemove(Class<?>...values) {
super.pojoSwapsRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder pojoSwapsRemove(Object...values) {
super.pojoSwapsRemove(values);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder sortProperties(boolean value) {
super.sortProperties(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder sortProperties() {
super.sortProperties();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder timeZone(TimeZone value) {
super.timeZone(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder useEnumNames(boolean value) {
super.useEnumNames(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder useEnumNames() {
super.useEnumNames();
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder useInterfaceProxies(boolean value) {
super.useInterfaceProxies(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder useJavaBeanIntrospector(boolean value) {
super.useJavaBeanIntrospector(value);
return this;
}
@Override /* BeanContextBuilder */
public SerializerGroupBuilder useJavaBeanIntrospector() {
super.useJavaBeanIntrospector();
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder set(String name, Object value) {
super.set(name, value);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder set(Map<String,Object> properties) {
super.set(properties);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder add(Map<String,Object> properties) {
super.add(properties);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder addTo(String name, Object value) {
super.addTo(name, value);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder addTo(String name, String key, Object value) {
super.addTo(name, key, value);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder removeFrom(String name, Object value) {
super.removeFrom(name, value);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder apply(PropertyStore copyFrom) {
super.apply(copyFrom);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder applyAnnotations(AnnotationList al, VarResolverSession vrs) {
super.applyAnnotations(al, vrs);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder applyAnnotations(Class<?> fromClass) {
super.applyAnnotations(fromClass);
return this;
}
@Override /* ContextBuilder */
public SerializerGroupBuilder applyAnnotations(Method fromMethod) {
super.applyAnnotations(fromMethod);
return this;
}
}