![JAR search and dependency download from the Maven repository](/logo.png)
net.digitalid.utility.collections.list.ReadOnlyList Maven / Gradle / Ivy
The newest version!
package net.digitalid.utility.collections.list;
import java.util.List;
import javax.annotation.Nonnull;
import net.digitalid.utility.annotations.method.Pure;
import net.digitalid.utility.annotations.ownership.Capturable;
import net.digitalid.utility.annotations.ownership.NonCapturable;
import net.digitalid.utility.collaboration.annotations.TODO;
import net.digitalid.utility.collaboration.enumerations.Author;
import net.digitalid.utility.collections.collection.ReadOnlyCollection;
import net.digitalid.utility.freezable.annotations.NonFrozen;
import net.digitalid.utility.functional.iterators.ReadOnlyListIterator;
import net.digitalid.utility.generator.annotations.generators.GenerateConverter;
import net.digitalid.utility.validation.annotations.generation.Recover;
import net.digitalid.utility.validation.annotations.index.Index;
import net.digitalid.utility.validation.annotations.index.IndexForInsertion;
import net.digitalid.utility.validation.annotations.type.Immutable;
import net.digitalid.utility.validation.annotations.type.ReadOnly;
/**
* This interface provides read-only access to {@link List lists} and should never be cast away (unless external code requires it).
* It is recommended to use only {@link ReadOnly} or {@link Immutable} types for the elements.
*/
@GenerateConverter
@ReadOnly(FreezableList.class)
public interface ReadOnlyList extends ReadOnlyCollection {
/* -------------------------------------------------- Recovery -------------------------------------------------- */
@Pure
@Recover
@TODO(task = "Support the conversion of freezable collections. (This method is nonsense, of course.)", date = "2016-11-09", author = Author.KASPAR_ETTER)
public static @Nonnull ReadOnlyList with(boolean frozen) {
return FreezableLinkedList.withNoElements();
}
/* -------------------------------------------------- List -------------------------------------------------- */
/**
* @see List#listIterator()
*/
@Pure
public @Capturable @Nonnull ReadOnlyListIterator listIterator();
/**
* @see List#listIterator(int)
*/
@Pure
public @Capturable @Nonnull ReadOnlyListIterator listIterator(@IndexForInsertion int index);
/**
* @see List#subList(int, int)
*/
@Pure
public @NonCapturable @Nonnull ReadOnlyList subList(@Index int fromIndex, @IndexForInsertion int toIndex);
/* -------------------------------------------------- Cloneable -------------------------------------------------- */
@Pure
@Override
public @Capturable @Nonnull @NonFrozen FreezableList clone();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy