// 
// Decompiled by Procyon v0.6.0
// 

package it.unimi.dsi.fastutil.objects;

import java.util.Iterator;
import java.util.Spliterator;
import it.unimi.dsi.fastutil.BigListIterator;
import java.util.Collection;
import it.unimi.dsi.fastutil.BigArrays;
import it.unimi.dsi.fastutil.BigList;

public interface ReferenceBigList<K> extends BigList<K>, ReferenceCollection<K>
{
    ObjectBigListIterator<K> iterator();
    
    ObjectBigListIterator<K> listIterator();
    
    ObjectBigListIterator<K> listIterator(final long p0);
    
    default ObjectSpliterator<K> spliterator() {
        return ObjectSpliterators.asSpliterator((ObjectIterator<? extends K>)this.iterator(), this.size64(), 16464);
    }
    
    ReferenceBigList<K> subList(final long p0, final long p1);
    
    void getElements(final long p0, final Object[][] p1, final long p2, final long p3);
    
    default void getElements(final long from, final Object[] a, final int offset, final int length) {
        this.getElements(from, new Object[][] { a }, offset, (long)length);
    }
    
    void removeElements(final long p0, final long p1);
    
    void addElements(final long p0, final K[][] p1);
    
    void addElements(final long p0, final K[][] p1, final long p2, final long p3);
    
    default void setElements(final K[][] a) {
        this.setElements(0L, a);
    }
    
    default void setElements(final long index, final K[][] a) {
        this.setElements(index, a, 0L, BigArrays.length(a));
    }
    
    default void setElements(final long index, final K[][] a, final long offset, final long length) {
        if (index < 0L) {
            throw new IndexOutOfBoundsException("Index (" + index + ") is negative");
        }
        if (index > this.size64()) {
            throw new IndexOutOfBoundsException("Index (" + index + ") is greater than list size (" + this.size64() + ")");
        }
        BigArrays.ensureOffsetLength(a, offset, length);
        if (index + length > this.size64()) {
            throw new IndexOutOfBoundsException("End index (" + (index + length) + ") is greater than list size (" + this.size64() + ")");
        }
        final ObjectBigListIterator<K> iter = this.listIterator(index);
        long i = 0L;
        while (i < length) {
            iter.next();
            iter.set(BigArrays.get(a, offset + i++));
        }
    }
    
    default boolean addAll(final long index, final ReferenceBigList<? extends K> l) {
        return this.addAll(index, l);
    }
    
    default boolean addAll(final ReferenceBigList<? extends K> l) {
        return this.addAll(this.size64(), l);
    }
    
    default boolean addAll(final long index, final ReferenceList<? extends K> l) {
        return this.addAll(index, l);
    }
    
    default boolean addAll(final ReferenceList<? extends K> l) {
        return this.addAll(this.size64(), l);
    }
}
