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

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

package org.immutables.fixture.nullable;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.google.common.base.MoreObjects;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
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 NonnullConstruction}.
 * 

* Use the builder to create immutable instances: * {@code ImmutableNonnullConstruction.builder()}. * Use the static factory method to create immutable instances: * {@code ImmutableNonnullConstruction.of()}. */ @SuppressWarnings("all") @ParametersAreNonnullByDefault @Generated({"Immutables.generator", "NonnullConstruction"}) @Immutable public final class ImmutableNonnullConstruction implements NonnullConstruction { private final String[] arr; private final @Nullable String[] brr; private final ImmutableList ax; private final int a; private ImmutableNonnullConstruction( String[] arr, @Nullable String[] brr, Iterable ax) { this.arr = arr.clone(); this.brr = brr; this.ax = ImmutableList.copyOf(ax); initShim.ax(this.ax); this.a = initShim.a(); this.initShim = null; } private ImmutableNonnullConstruction(ImmutableNonnullConstruction.Builder builder) { this.arr = builder.arr; this.brr = builder.brr; if (builder.axIsSet()) { initShim.ax(builder.ax.build()); } this.ax = initShim.ax(); this.a = initShim.a(); this.initShim = null; } private ImmutableNonnullConstruction( ImmutableNonnullConstruction original, String[] arr, @Nullable String[] brr, ImmutableList ax) { this.arr = arr; this.brr = brr; this.ax = ax; initShim.ax(this.ax); this.a = initShim.a(); this.initShim = null; } private static final int STAGE_INITIALIZING = -1; private static final int STAGE_UNINITIALIZED = 0; private static final int STAGE_INITIALIZED = 1; private transient volatile InitShim initShim = new InitShim(); private final class InitShim { private ImmutableList ax; private int axStage; ImmutableList ax() { if (axStage == STAGE_INITIALIZING) throw new IllegalStateException(formatInitCycleMessage()); if (axStage == STAGE_UNINITIALIZED) { axStage = STAGE_INITIALIZING; this.ax = ImmutableList.copyOf(axInitialize()); axStage = STAGE_INITIALIZED; } return this.ax; } void ax(ImmutableList ax) { this.ax = ax; axStage = STAGE_INITIALIZED; } private int a; private int aStage; int a() { if (aStage == STAGE_INITIALIZING) throw new IllegalStateException(formatInitCycleMessage()); if (aStage == STAGE_UNINITIALIZED) { aStage = STAGE_INITIALIZING; this.a = aInitialize(); aStage = STAGE_INITIALIZED; } return this.a; } private String formatInitCycleMessage() { ArrayList attributes = Lists.newArrayList(); if (axStage == STAGE_INITIALIZING) attributes.add("ax"); if (aStage == STAGE_INITIALIZING) attributes.add("a"); return "Cannot build NonnullConstruction, attribute initializers form cycle" + attributes; } } private List axInitialize() { return NonnullConstruction.super.ax(); } private int aInitialize() { return NonnullConstruction.super.a(); } /** * @return A cloned {@code arr} array */ @JsonProperty @Override public String[] arr() { return arr.clone(); } /** * @return A cloned {@code brr} array */ @JsonProperty @Override public @Nullable String[] brr() { return brr; } /** * @return The value of the {@code ax} attribute */ @JsonProperty @Override public ImmutableList ax() { InitShim shim = this.initShim; return shim != null ? shim.ax() : this.ax; } /** * @return The computed-at-construction value of the {@code a} attribute */ @JsonProperty @Override public int a() { InitShim shim = this.initShim; return shim != null ? shim.a() : this.a; } /** * Copy the current immutable object with elements that replace the content of {@link NonnullConstruction#arr() arr}. * The array is cloned before being saved as attribute values. * @param elements The non-null elements for arr * @return A modified copy of {@code this} object */ public final ImmutableNonnullConstruction withArr(String... elements) { String[] newValue = elements.clone(); return new ImmutableNonnullConstruction(this, newValue, this.brr, this.ax); } /** * Copy the current immutable object with elements that replace the content of {@link NonnullConstruction#brr() brr}. * The array is cloned before being saved as attribute values. * @param elements The non-null elements for brr * @return A modified copy of {@code this} object */ public final ImmutableNonnullConstruction withBrr(@Nullable String... elements) { @Nullable String[] newValue = elements == null ? null : elements.clone(); return new ImmutableNonnullConstruction(this, this.arr, newValue, this.ax); } /** * Copy the current immutable object with elements that replace the content of {@link NonnullConstruction#ax() ax}. * @param elements The elements to set * @return A modified copy of {@code this} object */ public final ImmutableNonnullConstruction withAx(String... elements) { ImmutableList newValue = ImmutableList.copyOf(elements); return new ImmutableNonnullConstruction(this, this.arr, this.brr, newValue); } /** * Copy the current immutable object with elements that replace the content of {@link NonnullConstruction#ax() ax}. * A shallow reference equality check is used to prevent copying of the same value by returning {@code this}. * @param elements An iterable of ax elements to set * @return A modified copy of {@code this} object */ public final ImmutableNonnullConstruction withAx(Iterable elements) { if (this.ax == elements) return this; ImmutableList newValue = ImmutableList.copyOf(elements); return new ImmutableNonnullConstruction(this, this.arr, this.brr, newValue); } /** * This instance is equal to all instances of {@code ImmutableNonnullConstruction} 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 ImmutableNonnullConstruction && equalTo((ImmutableNonnullConstruction) another); } private boolean equalTo(ImmutableNonnullConstruction another) { return Arrays.equals(arr, another.arr) && Arrays.equals(brr, another.brr) && ax.equals(another.ax) && a == another.a; } /** * Computes a hash code from attributes: {@code arr}, {@code brr}, {@code ax}, {@code a}. * @return hashCode value */ @Override public int hashCode() { int h = 31; h = h * 17 + Arrays.hashCode(arr); h = h * 17 + Arrays.hashCode(brr); h = h * 17 + ax.hashCode(); h = h * 17 + a; return h; } /** * Prints the immutable value {@code NonnullConstruction} with attribute values. * @return A string representation of the value */ @Override public String toString() { return MoreObjects.toStringHelper("NonnullConstruction") .omitNullValues() .add("arr", Arrays.toString(arr)) .add("brr", Arrays.toString(brr)) .add("ax", ax) .add("a", a) .toString(); } /** * Utility type used to correctly read immutable object from JSON representation. * @deprecated Do not use this type directly, it exists only for the Jackson-binding infrastructure */ @Deprecated @JsonDeserialize static final class Json implements NonnullConstruction { @Nullable String[] arr; @Nullable String[] brr; List ax = ImmutableList.of(); boolean axIsSet; @JsonProperty public void setArr(String[] arr) { this.arr = arr; } @JsonProperty public void setBrr(@Nullable String[] brr) { this.brr = brr; } @JsonProperty public void setAx(List ax) { this.ax = ax; this.axIsSet = true; } @Override public String[] arr() { throw new UnsupportedOperationException(); } @Override public String[] brr() { throw new UnsupportedOperationException(); } @Override public List ax() { throw new UnsupportedOperationException(); } @Override public int a() { throw new UnsupportedOperationException(); } } /** * @param json A JSON-bindable data structure * @return An immutable value type * @deprecated Do not use this method directly, it exists only for the Jackson-binding infrastructure */ @Deprecated @JsonCreator static ImmutableNonnullConstruction fromJson(Json json) { ImmutableNonnullConstruction.Builder builder = ImmutableNonnullConstruction.builder(); if (json.arr != null) { builder.arr(json.arr); } if (json.brr != null) { builder.brr(json.brr); } if (json.ax != null) { builder.addAllAx(json.ax); } return builder.build(); } /** * Construct a new immutable {@code NonnullConstruction} instance. * @param arr The value for the {@code arr} attribute * @param brr The value for the {@code brr} attribute * @param ax The value for the {@code ax} attribute * @return An immutable NonnullConstruction instance */ public static ImmutableNonnullConstruction of(String[] arr, @Nullable String[] brr, List ax) { return of(arr, brr, (Iterable) ax); } /** * Construct a new immutable {@code NonnullConstruction} instance. * @param arr The value for the {@code arr} attribute * @param brr The value for the {@code brr} attribute * @param ax The value for the {@code ax} attribute * @return An immutable NonnullConstruction instance */ public static ImmutableNonnullConstruction of(String[] arr, @Nullable String[] brr, Iterable ax) { return new ImmutableNonnullConstruction(arr, brr, ax); } /** * Creates an immutable copy of a {@link NonnullConstruction} 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 NonnullConstruction instance */ public static ImmutableNonnullConstruction copyOf(NonnullConstruction instance) { if (instance instanceof ImmutableNonnullConstruction) { return (ImmutableNonnullConstruction) instance; } return ImmutableNonnullConstruction.builder() .from(instance) .build(); } /** * Creates a builder for {@link ImmutableNonnullConstruction ImmutableNonnullConstruction}. * @return A new ImmutableNonnullConstruction builder */ public static ImmutableNonnullConstruction.Builder builder() { return new ImmutableNonnullConstruction.Builder(); } /** * Builds instances of type {@link ImmutableNonnullConstruction ImmutableNonnullConstruction}. * 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 static final long INIT_BIT_ARR = 0x1L; private static final long OPT_BIT_AX = 0x1L; private long initBits = 0x1L; private long optBits; private @Nullable String[] arr; private @Nullable String[] brr; private ImmutableList.Builder ax = ImmutableList.builder(); private Builder() { } /** * Fill a builder with attribute values from the provided {@code NonnullConstruction} 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(NonnullConstruction instance) { Preconditions.checkNotNull(instance, "instance"); arr(instance.arr()); @Nullable String[] brrValue = instance.brr(); if (brrValue != null) { brr(brrValue); } addAllAx(instance.ax()); return this; } /** * Initializes the value for the {@link NonnullConstruction#arr() arr} attribute. * @param arr The elements for arr * @return {@code this} builder for use in a chained invocation */ public final Builder arr(String... arr) { this.arr = arr.clone(); initBits &= ~INIT_BIT_ARR; return this; } /** * Initializes the value for the {@link NonnullConstruction#brr() brr} attribute. * @param brr The elements for brr * @return {@code this} builder for use in a chained invocation */ public final Builder brr(String... brr) { this.brr = brr; return this; } /** * Adds one element to {@link NonnullConstruction#ax() ax} list. * @param element A ax element * @return {@code this} builder for use in a chained invocation */ public final Builder addAx(String element) { this.ax.add(element); optBits |= OPT_BIT_AX; return this; } /** * Adds elements to {@link NonnullConstruction#ax() ax} list. * @param elements An array of ax elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAx(String... elements) { this.ax.add(elements); optBits |= OPT_BIT_AX; return this; } /** * Sets or replaces all elements for {@link NonnullConstruction#ax() ax} list. * @param elements An iterable of ax elements * @return {@code this} builder for use in a chained invocation */ public final Builder ax(Iterable elements) { this.ax = ImmutableList.builder(); return addAllAx(elements); } /** * Adds elements to {@link NonnullConstruction#ax() ax} list. * @param elements An iterable of ax elements * @return {@code this} builder for use in a chained invocation */ public final Builder addAllAx(Iterable elements) { this.ax.addAll(elements); optBits |= OPT_BIT_AX; return this; } /** * Builds a new {@link ImmutableNonnullConstruction ImmutableNonnullConstruction}. * @return An immutable instance of NonnullConstruction * @throws java.lang.IllegalStateException if any required attributes are missing */ public ImmutableNonnullConstruction build() { if (initBits != 0) { throw new IllegalStateException(formatRequiredAttributesMessage()); } return new ImmutableNonnullConstruction(this); } private boolean axIsSet() { return (optBits & OPT_BIT_AX) != 0; } private String formatRequiredAttributesMessage() { List attributes = Lists.newArrayList(); if ((initBits & INIT_BIT_ARR) != 0) attributes.add("arr"); return "Cannot build NonnullConstruction, some of required attributes are not set " + attributes; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy