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

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