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;
}
}
}