org.immutables.fixture.ImmutableSillyMapHolder Maven / Gradle / Ivy
package org.immutables.fixture;
import com.google.common.base.MoreObjects;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Maps;
import com.google.common.collect.Sets;
import java.lang.annotation.RetentionPolicy;
import java.util.Arrays;
import java.util.Map;
import javax.annotation.Generated;
import javax.annotation.Nullable;
import javax.annotation.ParametersAreNonnullByDefault;
import javax.annotation.concurrent.Immutable;
import javax.annotation.concurrent.NotThreadSafe;
/**
* Immutable implementation of {@link SillyMapHolder}.
*
* Use the builder to create immutable instances:
* {@code ImmutableSillyMapHolder.builder()}.
* Use the static factory method to create immutable instances:
* {@code ImmutableSillyMapHolder.of()}.
*/
@SuppressWarnings("all")
@ParametersAreNonnullByDefault
@Generated({"Immutables.generator", "SillyMapHolder"})
@Immutable
public final class ImmutableSillyMapHolder extends SillyMapHolder {
private final ImmutableMap holder1;
private final ImmutableMap holder2;
private final ImmutableMap holder3;
private final ImmutableSet zz;
private ImmutableSillyMapHolder(
Map holder1,
Map holder2) {
this.holder1 = Maps.immutableEnumMap(holder1);
this.holder2 = ImmutableMap.copyOf(holder2);
this.holder3 = ImmutableMap.of();
this.zz = ImmutableSet.of();
}
private ImmutableSillyMapHolder(
ImmutableMap holder1,
ImmutableMap holder2,
ImmutableMap holder3,
ImmutableSet zz) {
this.holder1 = holder1;
this.holder2 = holder2;
this.holder3 = holder3;
this.zz = zz;
}
/**
* @return The value of the {@code holder1} attribute
*/
@Override
public ImmutableMap holder1() {
return holder1;
}
/**
* @return The value of the {@code holder2} attribute
*/
@Override
public ImmutableMap holder2() {
return holder2;
}
/**
* @return The value of the {@code holder3} attribute
*/
@Override
public ImmutableMap holder3() {
return holder3;
}
/**
* @return The value of the {@code zz} attribute
*/
@Override
public ImmutableSet zz() {
return zz;
}
/**
* Copy the current immutable object by replacing the {@link SillyMapHolder#holder1() holder1} map with the specified map.
* Nulls are not permitted as keys or values.
* A shallow reference equality check is used to prevent copying of the same value by returning {@code this}.
* @param holder1 The entries to be added to the holder1 map
* @return A modified copy of {@code this} object
*/
public final ImmutableSillyMapHolder withHolder1(Map holder1) {
if (this.holder1 == holder1) return this;
ImmutableMap newValue = Maps.immutableEnumMap(holder1);
return new ImmutableSillyMapHolder(newValue, this.holder2, this.holder3, this.zz);
}
/**
* Copy the current immutable object by replacing the {@link SillyMapHolder#holder2() holder2} map with the specified map.
* Nulls are not permitted as keys or values.
* A shallow reference equality check is used to prevent copying of the same value by returning {@code this}.
* @param holder2 The entries to be added to the holder2 map
* @return A modified copy of {@code this} object
*/
public final ImmutableSillyMapHolder withHolder2(Map holder2) {
if (this.holder2 == holder2) return this;
ImmutableMap newValue = ImmutableMap.copyOf(holder2);
return new ImmutableSillyMapHolder(this.holder1, newValue, this.holder3, this.zz);
}
/**
* Copy the current immutable object by replacing the {@link SillyMapHolder#holder3() holder3} map with the specified map.
* Nulls are not permitted as keys or values.
* A shallow reference equality check is used to prevent copying of the same value by returning {@code this}.
* @param holder3 The entries to be added to the holder3 map
* @return A modified copy of {@code this} object
*/
public final ImmutableSillyMapHolder withHolder3(Map holder3) {
if (this.holder3 == holder3) return this;
ImmutableMap newValue = ImmutableMap.copyOf(holder3);
return new ImmutableSillyMapHolder(this.holder1, this.holder2, newValue, this.zz);
}
/**
* Copy the current immutable object with elements that replace the content of {@link SillyMapHolder#zz() zz}.
* @param elements The elements to set
* @return A modified copy of {@code this} object
*/
public final ImmutableSillyMapHolder withZz(RetentionPolicy... elements) {
ImmutableSet newValue = Sets.immutableEnumSet(Arrays.asList(elements));
return new ImmutableSillyMapHolder(this.holder1, this.holder2, this.holder3, newValue);
}
/**
* Copy the current immutable object with elements that replace the content of {@link SillyMapHolder#zz() zz}.
* A shallow reference equality check is used to prevent copying of the same value by returning {@code this}.
* @param elements An iterable of zz elements to set
* @return A modified copy of {@code this} object
*/
public final ImmutableSillyMapHolder withZz(Iterable elements) {
if (this.zz == elements) return this;
ImmutableSet newValue = Sets.immutableEnumSet(elements);
return new ImmutableSillyMapHolder(this.holder1, this.holder2, this.holder3, newValue);
}
/**
* This instance is equal to all instances of {@code ImmutableSillyMapHolder} that have equal attribute values.
* @return {@code true} if {@code this} is equal to {@code another} instance
*/
@Override
public boolean equals(@Nullable Object another) {
if (this == another) return true;
return another instanceof ImmutableSillyMapHolder
&& equalTo((ImmutableSillyMapHolder) another);
}
private boolean equalTo(ImmutableSillyMapHolder another) {
return holder1.equals(another.holder1)
&& holder2.equals(another.holder2)
&& holder3.equals(another.holder3)
&& zz.equals(another.zz);
}
/**
* Computes a hash code from attributes: {@code holder1}, {@code holder2}, {@code holder3}, {@code zz}.
* @return hashCode value
*/
@Override
public int hashCode() {
int h = 31;
h = h * 17 + holder1.hashCode();
h = h * 17 + holder2.hashCode();
h = h * 17 + holder3.hashCode();
h = h * 17 + zz.hashCode();
return h;
}
/**
* Prints the immutable value {@code SillyMapHolder} with attribute values.
* @return A string representation of the value
*/
@Override
public String toString() {
return MoreObjects.toStringHelper("SillyMapHolder")
.omitNullValues()
.add("holder1", holder1)
.add("holder2", holder2)
.add("holder3", holder3)
.add("zz", zz)
.toString();
}
/**
* Construct a new immutable {@code SillyMapHolder} instance.
* @param holder1 The value for the {@code holder1} attribute
* @param holder2 The value for the {@code holder2} attribute
* @return An immutable SillyMapHolder instance
*/
public static ImmutableSillyMapHolder of(Map holder1, Map holder2) {
return new ImmutableSillyMapHolder(holder1, holder2);
}
/**
* Creates an immutable copy of a {@link SillyMapHolder} value.
* Uses accessors to get values to initialize the new immutable instance.
* If an instance is already immutable, it is returned as is.
* @param instance The instance to copy
* @return A copied immutable SillyMapHolder instance
*/
public static ImmutableSillyMapHolder copyOf(SillyMapHolder instance) {
if (instance instanceof ImmutableSillyMapHolder) {
return (ImmutableSillyMapHolder) instance;
}
return ImmutableSillyMapHolder.builder()
.from(instance)
.build();
}
/**
* Creates a builder for {@link ImmutableSillyMapHolder ImmutableSillyMapHolder}.
* @return A new ImmutableSillyMapHolder builder
*/
public static ImmutableSillyMapHolder.Builder builder() {
return new ImmutableSillyMapHolder.Builder();
}
/**
* Builds instances of type {@link ImmutableSillyMapHolder ImmutableSillyMapHolder}.
* Initialize attributes and then invoke the {@link #build()} method to create an
* immutable instance.
* {@code Builder} is not thread-safe and generally should not be stored in a field or collection,
* but instead used immediately to create instances.
*/
@NotThreadSafe
public static final class Builder {
private ImmutableMap.Builder holder1 = ImmutableMap.builder();
private ImmutableMap.Builder holder2 = ImmutableMap.builder();
private ImmutableMap.Builder holder3 = ImmutableMap.builder();
private ImmutableSet.Builder zz = ImmutableSet.builder();
private Builder() {
}
/**
* Fill a builder with attribute values from the provided {@code SillyMapHolder} instance.
* Regular attribute values will be replaced with those from the given instance.
* Absent optional values will not replace present values.
* Collection elements and entries will be added, not replaced.
* @param instance The instance from which to copy values
* @return {@code this} builder for use in a chained invocation
*/
public final Builder from(SillyMapHolder instance) {
Preconditions.checkNotNull(instance, "instance");
putAllHolder1(instance.holder1());
putAllHolder2(instance.holder2());
putAllHolder3(instance.holder3());
addAllZz(instance.zz());
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder1() holder1} map.
* @param key The key in the holder1 map
* @param value The associated value in the holder1 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder1(SillyValue key, int value) {
this.holder1.put(key, value);
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder1() holder1} map. Nulls are not permitted
* @param entry The key and value entry
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder1(Map.Entry entry) {
this.holder1.put(entry);
return this;
}
/**
* Sets or replaces all mappings from the specified map as entries for the {@link SillyMapHolder#holder1() holder1} map. Nulls are not permitted
* @param holder1 The entries that will be added to the holder1 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder holder1(Map holder1) {
this.holder1 = ImmutableMap.builder();
return putAllHolder1(holder1);
}
/**
* Put all mappings from the specified map as entries to {@link SillyMapHolder#holder1() holder1} map. Nulls are not permitted
* @param holder1 The entries that will be added to the holder1 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putAllHolder1(Map holder1) {
this.holder1.putAll(holder1);
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder2() holder2} map.
* @param key The key in the holder2 map
* @param value The associated value in the holder2 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder2(int key, String value) {
this.holder2.put(key, value);
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder2() holder2} map. Nulls are not permitted
* @param entry The key and value entry
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder2(Map.Entry entry) {
this.holder2.put(entry);
return this;
}
/**
* Sets or replaces all mappings from the specified map as entries for the {@link SillyMapHolder#holder2() holder2} map. Nulls are not permitted
* @param holder2 The entries that will be added to the holder2 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder holder2(Map holder2) {
this.holder2 = ImmutableMap.builder();
return putAllHolder2(holder2);
}
/**
* Put all mappings from the specified map as entries to {@link SillyMapHolder#holder2() holder2} map. Nulls are not permitted
* @param holder2 The entries that will be added to the holder2 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putAllHolder2(Map holder2) {
this.holder2.putAll(holder2);
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder3() holder3} map.
* @param key The key in the holder3 map
* @param value The associated value in the holder3 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder3(String key, SillyMapTup value) {
this.holder3.put(key, value);
return this;
}
/**
* Put one entry to the {@link SillyMapHolder#holder3() holder3} map. Nulls are not permitted
* @param entry The key and value entry
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putHolder3(Map.Entry entry) {
this.holder3.put(entry);
return this;
}
/**
* Sets or replaces all mappings from the specified map as entries for the {@link SillyMapHolder#holder3() holder3} map. Nulls are not permitted
* @param holder3 The entries that will be added to the holder3 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder holder3(Map holder3) {
this.holder3 = ImmutableMap.builder();
return putAllHolder3(holder3);
}
/**
* Put all mappings from the specified map as entries to {@link SillyMapHolder#holder3() holder3} map. Nulls are not permitted
* @param holder3 The entries that will be added to the holder3 map
* @return {@code this} builder for use in a chained invocation
*/
public final Builder putAllHolder3(Map holder3) {
this.holder3.putAll(holder3);
return this;
}
/**
* Adds one element to {@link SillyMapHolder#zz() zz} set.
* @param element A zz element
* @return {@code this} builder for use in a chained invocation
*/
public final Builder addZz(RetentionPolicy element) {
this.zz.add(element);
return this;
}
/**
* Adds elements to {@link SillyMapHolder#zz() zz} set.
* @param elements An array of zz elements
* @return {@code this} builder for use in a chained invocation
*/
public final Builder addZz(RetentionPolicy... elements) {
this.zz.addAll(Arrays.asList(elements));
return this;
}
/**
* Sets or replaces all elements for {@link SillyMapHolder#zz() zz} set.
* @param elements An iterable of zz elements
* @return {@code this} builder for use in a chained invocation
*/
public final Builder zz(Iterable elements) {
this.zz = ImmutableSet.builder();
return addAllZz(elements);
}
/**
* Adds elements to {@link SillyMapHolder#zz() zz} set.
* @param elements An iterable of zz elements
* @return {@code this} builder for use in a chained invocation
*/
public final Builder addAllZz(Iterable elements) {
this.zz.addAll(elements);
return this;
}
/**
* Builds a new {@link ImmutableSillyMapHolder ImmutableSillyMapHolder}.
* @return An immutable instance of SillyMapHolder
* @throws java.lang.IllegalStateException if any required attributes are missing
*/
public ImmutableSillyMapHolder build() {
return new ImmutableSillyMapHolder(
Maps.immutableEnumMap(holder1.build()),
holder2.build(),
holder3.build(),
Sets.immutableEnumSet(zz.build()));
}
}
}