All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.immutables.fixture.nullable.ImmutableNullableElements Maven / Gradle / Ivy

package org.immutables.fixture.nullable;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
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 NullableElements}.
 * 

* Use the builder to create immutable instances: * {@code ImmutableNullableElements.builder()}. */ @SuppressWarnings("all") @ParametersAreNonnullByDefault @Generated({"Immutables.generator", "NullableElements"}) @Immutable public final class ImmutableNullableElements implements NullableElements { private final List al; private final List sk; private final Map bl; private final Map sm; private final Set rg; private ImmutableNullableElements( List al, List sk, Map bl, Map sm, Set rg) { this.al = al; this.sk = sk; this.bl = bl; this.sm = sm; this.rg = rg; } /** * @return The value of the {@code al} attribute */ @Override public List al() { return al; } /** * @return The value of the {@code sk} attribute */ @Override public List sk() { return sk; } /** * @return The value of the {@code bl} attribute */ @Override public Map bl() { return bl; } /** * @return The value of the {@code sm} attribute */ @Override public Map sm() { return sm; } /** * @return The value of the {@code rg} attribute */ @Override public Set rg() { return rg; } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#al() al}. * @param elements The elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withAl(Void... elements) { List newValue = createUnmodifiableList(false, createSafeList(Arrays.asList(elements), false, false)); return new ImmutableNullableElements(newValue, this.sk, this.bl, this.sm, this.rg); } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#al() al}. * A shallow reference equality check is used to prevent copying of the same value by returning {@code this}. * @param elements An iterable of al elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withAl(Iterable elements) { if (this.al == elements) return this; List newValue = createUnmodifiableList(false, createSafeList(elements, false, false)); return new ImmutableNullableElements(newValue, this.sk, this.bl, this.sm, this.rg); } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#sk() sk}. * @param elements The elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withSk(String... elements) { List newValue = createUnmodifiableList(false, createSafeList(Arrays.asList(elements), false, true)); return new ImmutableNullableElements(this.al, newValue, this.bl, this.sm, this.rg); } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#sk() sk}. * A shallow reference equality check is used to prevent copying of the same value by returning {@code this}. * @param elements An iterable of sk elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withSk(Iterable elements) { if (this.sk == elements) return this; List newValue = createUnmodifiableList(false, createSafeList(elements, false, true)); return new ImmutableNullableElements(this.al, newValue, this.bl, this.sm, this.rg); } /** * Copy the current immutable object by replacing the {@link NullableElements#bl() bl} 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 bl The entries to be added to the bl map * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withBl(Map bl) { if (this.bl == bl) return this; Map newValue = createUnmodifiableMap(false, false, bl); return new ImmutableNullableElements(this.al, this.sk, newValue, this.sm, this.rg); } /** * Copy the current immutable object by replacing the {@link NullableElements#sm() sm} 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 sm The entries to be added to the sm map * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withSm(Map sm) { if (this.sm == sm) return this; Map newValue = createUnmodifiableMap(false, true, sm); return new ImmutableNullableElements(this.al, this.sk, this.bl, newValue, this.rg); } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#rg() rg}. * @param elements The elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withRg(String... elements) { Set newValue = createUnmodifiableSet(createSafeList(Arrays.asList(elements), true, false)); return new ImmutableNullableElements(this.al, this.sk, this.bl, this.sm, newValue); } /** * Copy the current immutable object with elements that replace the content of {@link NullableElements#rg() rg}. * A shallow reference equality check is used to prevent copying of the same value by returning {@code this}. * @param elements An iterable of rg elements to set * @return A modified copy of {@code this} object */ public final ImmutableNullableElements withRg(Iterable elements) { if (this.rg == elements) return this; Set newValue = createUnmodifiableSet(createSafeList(elements, true, false)); return new ImmutableNullableElements(this.al, this.sk, this.bl, this.sm, newValue); } /** * This instance is equal to all instances of {@code ImmutableNullableElements} 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 ImmutableNullableElements && equalTo((ImmutableNullableElements) another); } private boolean equalTo(ImmutableNullableElements another) { return al.equals(another.al) && sk.equals(another.sk) && bl.equals(another.bl) && sm.equals(another.sm) && rg.equals(another.rg); } /** * Computes a hash code from attributes: {@code al}, {@code sk}, {@code bl}, {@code sm}, {@code rg}. * @return hashCode value */ @Override public int hashCode() { int h = 31; h = h * 17 + al.hashCode(); h = h * 17 + sk.hashCode(); h = h * 17 + bl.hashCode(); h = h * 17 + sm.hashCode(); h = h * 17 + rg.hashCode(); return h; } /** * Prints the immutable value {@code NullableElements} with attribute values. * @return A string representation of the value */ @Override public String toString() { return "NullableElements{" + "al=" + al + ", sk=" + sk + ", bl=" + bl + ", sm=" + sm + ", rg=" + rg + "}"; } /** * Creates an immutable copy of a {@link NullableElements} 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 NullableElements instance */ public static ImmutableNullableElements copyOf(NullableElements instance) { if (instance instanceof ImmutableNullableElements) { return (ImmutableNullableElements) instance; } return ImmutableNullableElements.builder() .from(instance) .build(); } /** * Creates a builder for {@link ImmutableNullableElements ImmutableNullableElements}. * @return A new ImmutableNullableElements builder */ public static ImmutableNullableElements.Builder builder() { return new ImmutableNullableElements.Builder(); } /** * Builds instances of type {@link ImmutableNullableElements ImmutableNullableElements}. * 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 List al = new ArrayList(); private List sk = new ArrayList(); private Map bl = new LinkedHashMap(); private Map sm = new LinkedHashMap(); private List rg = new ArrayList(); private Builder() { } /** * Fill a builder with attribute values from the provided {@code NullableElements} 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(NullableElements instance) { Objects.requireNonNull(instance, "instance"); addAllAl(instance.al()); addAllSk(instance.sk()); putAllBl(instance.bl()); putAllSm(instance.sm()); addAllRg(instance.rg()); return this; } /** * Adds one element to {@link NullableElements#al() al} list. * @param element A al element * @return {@code this} builder for use in a chained invocation */ public final Builder addAl(Void element) { this.al.add(element); return this; } /** * Adds elements to {@link NullableElements#al() al} list. * @param elements An array of al elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAl(Void... elements) { for (Void element : elements) { this.al.add(element); } return this; } /** * Sets or replaces all elements for {@link NullableElements#al() al} list. * @param elements An iterable of al elements * @return {@code this} builder for use in a chained invocation */ public final Builder al(Iterable elements) { this.al.clear(); return addAllAl(elements); } /** * Adds elements to {@link NullableElements#al() al} list. * @param elements An iterable of al elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAllAl(Iterable elements) { for (Void element : elements) { this.al.add(element); } return this; } /** * Adds one element to {@link NullableElements#sk() sk} list. * @param element A sk element * @return {@code this} builder for use in a chained invocation */ public final Builder addSk(String element) { if (element != null) this.sk.add(element); return this; } /** * Adds elements to {@link NullableElements#sk() sk} list. * @param elements An array of sk elements * @return {@code this} builder for use in a chained invocation */ public final Builder addSk(String... elements) { for (String element : elements) { if (element != null) this.sk.add(element); } return this; } /** * Sets or replaces all elements for {@link NullableElements#sk() sk} list. * @param elements An iterable of sk elements * @return {@code this} builder for use in a chained invocation */ public final Builder sk(Iterable elements) { this.sk.clear(); return addAllSk(elements); } /** * Adds elements to {@link NullableElements#sk() sk} list. * @param elements An iterable of sk elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAllSk(Iterable elements) { for (String element : elements) { if (element != null) this.sk.add(element); } return this; } /** * Put one entry to the {@link NullableElements#bl() bl} map. * @param key The key in the bl map * @param value The associated value in the bl map * @return {@code this} builder for use in a chained invocation */ public final Builder putBl(String key, Integer value) { this.bl.put(key, value); return this; } /** * Put one entry to the {@link NullableElements#bl() bl} 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 putBl(Map.Entry entry) { String k = entry.getKey(); Integer v = entry.getValue(); this.bl.put(k, v); return this; } /** * Sets or replaces all mappings from the specified map as entries for the {@link NullableElements#bl() bl} map. Nulls are not permitted * @param bl The entries that will be added to the bl map * @return {@code this} builder for use in a chained invocation */ public final Builder bl(Map bl) { this.bl.clear(); return putAllBl(bl); } /** * Put all mappings from the specified map as entries to {@link NullableElements#bl() bl} map. Nulls are not permitted * @param bl The entries that will be added to the bl map * @return {@code this} builder for use in a chained invocation */ public final Builder putAllBl(Map bl) { for (Map.Entry entry : bl.entrySet()) { String k = entry.getKey(); Integer v = entry.getValue(); this.bl.put(k, v); } return this; } /** * Put one entry to the {@link NullableElements#sm() sm} map. * @param key The key in the sm map * @param value The associated value in the sm map * @return {@code this} builder for use in a chained invocation */ public final Builder putSm(String key, Integer value) { if (value != null && key != null) this.sm.put(key, value); return this; } /** * Put one entry to the {@link NullableElements#sm() sm} 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 putSm(Map.Entry entry) { String k = entry.getKey(); Integer v = entry.getValue(); if (k != null && v != null) this.sm.put(k, v); return this; } /** * Sets or replaces all mappings from the specified map as entries for the {@link NullableElements#sm() sm} map. Nulls are not permitted * @param sm The entries that will be added to the sm map * @return {@code this} builder for use in a chained invocation */ public final Builder sm(Map sm) { this.sm.clear(); return putAllSm(sm); } /** * Put all mappings from the specified map as entries to {@link NullableElements#sm() sm} map. Nulls are not permitted * @param sm The entries that will be added to the sm map * @return {@code this} builder for use in a chained invocation */ public final Builder putAllSm(Map sm) { for (Map.Entry entry : sm.entrySet()) { String k = entry.getKey(); Integer v = entry.getValue(); if (k != null && v != null) this.sm.put(k, v); } return this; } /** * Adds one element to {@link NullableElements#rg() rg} set. * @param element A rg element * @return {@code this} builder for use in a chained invocation */ public final Builder addRg(String element) { this.rg.add(Objects.requireNonNull(element, "rg element")); return this; } /** * Adds elements to {@link NullableElements#rg() rg} set. * @param elements An array of rg elements * @return {@code this} builder for use in a chained invocation */ public final Builder addRg(String... elements) { for (String element : elements) { this.rg.add(Objects.requireNonNull(element, "rg element")); } return this; } /** * Sets or replaces all elements for {@link NullableElements#rg() rg} set. * @param elements An iterable of rg elements * @return {@code this} builder for use in a chained invocation */ public final Builder rg(Iterable elements) { this.rg.clear(); return addAllRg(elements); } /** * Adds elements to {@link NullableElements#rg() rg} set. * @param elements An iterable of rg elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAllRg(Iterable elements) { for (String element : elements) { this.rg.add(Objects.requireNonNull(element, "rg element")); } return this; } /** * Builds a new {@link ImmutableNullableElements ImmutableNullableElements}. * @return An immutable instance of NullableElements * @throws java.lang.IllegalStateException if any required attributes are missing */ public ImmutableNullableElements build() { return new ImmutableNullableElements( createUnmodifiableList(true, al), createUnmodifiableList(true, sk), createUnmodifiableMap(false, false, bl), createUnmodifiableMap(false, false, sm), createUnmodifiableSet(rg)); } } private static List createSafeList(Iterable iterable, boolean checkNulls, boolean skipNulls) { ArrayList list; if (iterable instanceof Collection) { int size = ((Collection) iterable).size(); if (size == 0) return Collections.emptyList(); list = new ArrayList(); } else { list = new ArrayList(); } for (T element : iterable) { if (skipNulls && element == null) continue; if (checkNulls) Objects.requireNonNull(element, "element"); list.add(element); } return list; } private static List createUnmodifiableList(boolean clone, List list) { switch(list.size()) { case 0: return Collections.emptyList(); case 1: return Collections.singletonList(list.get(0)); default: if (clone) { return Collections.unmodifiableList(new ArrayList(list)); } else { if (list instanceof ArrayList) { ((ArrayList) list).trimToSize(); } return Collections.unmodifiableList(list); } } } /** Unmodifiable set constructed from list to avoid rehashing. */ private static Set createUnmodifiableSet(List list) { switch(list.size()) { case 0: return Collections.emptySet(); case 1: return Collections.singleton(list.get(0)); default: Set set = new LinkedHashSet(list.size()); set.addAll(list); return Collections.unmodifiableSet(set); } } private static Map createUnmodifiableMap(boolean checkNulls, boolean skipNulls, Map map) { switch (map.size()) { case 0: return Collections.emptyMap(); case 1: { Map.Entry e = map.entrySet().iterator().next(); K k = e.getKey(); V v = e.getValue(); if (checkNulls) { Objects.requireNonNull(k, "key"); Objects.requireNonNull(v, "value"); } if (skipNulls && (k == null || v == null)) { return Collections.emptyMap(); } return Collections.singletonMap(k, v); } default: { Map linkedMap = new LinkedHashMap(map.size()); if (skipNulls || checkNulls) { for (Map.Entry e : map.entrySet()) { K k = e.getKey(); V v = e.getValue(); if (skipNulls) { if (k == null || v == null) continue; } else if (checkNulls) { Objects.requireNonNull(k, "key"); Objects.requireNonNull(v, "value"); } linkedMap.put(k, v); } } else { linkedMap.putAll(map); } return Collections.unmodifiableMap(linkedMap); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy