Finals.java
// Generated by delombok at Mon Jan 06 07:19:11 UTC 2025
package de.larssh.utils;
import java.util.function.Supplier;
import edu.umd.cs.findbugs.annotations.Nullable;
/**
* This class contains helper methods for final fields.
*/
public final class Finals {
/**
* Returns {@code value} unchanged. This prevents compilers from inlining
* constants (static final fields). Depending classes referring to the constant
* do not need to be recompiled if the constant value changes.
*
* <p>
* Inlining affects primitive data types and strings.
*
* <p>
* <b>Usage example:</b>
* <pre>public static final String CONSTANT_FIELD = constant("constant value");</pre>
*
* @param <T> return type
* @param value value
* @return value
*/
public static <T> T constant(final T value) {
return value;
}
/**
* Returns a new {@link Supplier} that calculates its return value at most one
* time. Therefore it can be used to create lazy fields.
*
* <p>
* This implementation is synchronized. {@code supplier} is guaranteed to be
* called at max once.
*
* @param <T> return type
* @param supplier value supplier
* @return value
*/
public static <T> CachingSupplier<T> lazy(final Supplier<T> supplier) {
return new CachingSupplier<>(supplier);
}
/**
* {@link Supplier} implementation proxying another supplier while calculating
* its return value at most one time.
*
* <p>
* Threads are synchronized upon calling the wrapped supplier.
*
* @param <T> return type
*/
public static class CachingSupplier<T> implements Supplier<T> {
/**
* Wrapped supplier
*
* @return wrapped supplier
*/
private final Supplier<T> supplier;
/**
* Cached value or empty optional
*
* @return cached value or empty optional
*/
@Nullable
private volatile T value = null;
/**
* Object used for locking
*/
private final Object lock = new Object();
/**
* Determines if a cached value has been calculated already.
*
* @return {@code true} if a cached value has been calculated already, else
* {@code false}
*/
public boolean isCalculated() {
return value != null;
}
/**
* {@inheritDoc}
*/
@Override
public T get() {
synchronized (lock) {
if (value == null) {
value = supplier.get();
}
}
return Nullables.orElseThrow(value);
}
/**
* Creates a new {@code CachingSupplier} instance.
*
* @param supplier Wrapped supplier
*/
@java.lang.SuppressWarnings("all")
@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
@lombok.Generated
public CachingSupplier(final Supplier<T> supplier) {
this.supplier = supplier;
}
}
@java.lang.SuppressWarnings("all")
@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
@lombok.Generated
private Finals() {
throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
}
}