ProxiedSet.java

// Generated by delombok at Mon Jan 06 07:19:11 UTC 2025
package de.larssh.utils.collection;

import java.util.Set;

/**
 * An abstract {@link Set} implementation pointing to a given set object.
 *
 * <p>
 * Therefore it allows implementing sets based on invisible set types, such as
 * {@link java.util.Collections#unmodifiableSet(Set)} or
 * {@link java.util.Collections#synchronizedSet(Set)}.
 *
 * @param <E> the type of elements in this set
 */
public abstract class ProxiedSet<E> extends ProxiedCollection<E> implements Set<E> {
	/**
	 * Wrapped set
	 */
	private final Set<E> set;

	/**
	 * An abstract {@link Set} implementation pointing to {@code set}.
	 *
	 * <p>
	 * Therefore it allows implementing sets based on invisible set types, such as
	 * {@link java.util.Collections#unmodifiableSet(Set)} or
	 * {@link java.util.Collections#synchronizedSet(Set)}.
	 *
	 * @param set the set to proxy
	 */
	protected ProxiedSet(final Set<E> set) {
		super(set);
		this.set = set;
	}

	/**
	 * {@inheritDoc}
	 */
	@Override
	protected Set<E> getWrappedIfModifiable() {
		if (isModifiable()) {
			return set;
		}
		throw new UnsupportedOperationException();
	}

	/**
	 * {@inheritDoc}
	 */
	@Override
	protected Set<E> getWrappedForRead() {
		return set;
	}
}