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

package it.unimi.dsi.fastutil.shorts;

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

public interface ShortBigList extends BigList<Short>, ShortCollection, Comparable<BigList<? extends Short>>
{
    ShortBigListIterator iterator();
    
    ShortBigListIterator listIterator();
    
    ShortBigListIterator listIterator(final long p0);
    
    default ShortSpliterator spliterator() {
        return ShortSpliterators.asSpliterator(this.iterator(), this.size64(), 16720);
    }
    
    ShortBigList subList(final long p0, final long p1);
    
    void getElements(final long p0, final short[][] p1, final long p2, final long p3);
    
    default void getElements(final long from, final short[] a, final int offset, final int length) {
        this.getElements(from, new short[][] { a }, offset, length);
    }
    
    void removeElements(final long p0, final long p1);
    
    void addElements(final long p0, final short[][] p1);
    
    void addElements(final long p0, final short[][] p1, final long p2, final long p3);
    
    default void setElements(final short[][] a) {
        this.setElements(0L, a);
    }
    
    default void setElements(final long index, final short[][] a) {
        this.setElements(index, a, 0L, BigArrays.length(a));
    }
    
    default void setElements(final long index, final short[][] 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 ShortBigListIterator iter = this.listIterator(index);
        long i = 0L;
        while (i < length) {
            iter.nextShort();
            iter.set(BigArrays.get(a, offset + i++));
        }
    }
    
    void add(final long p0, final short p1);
    
    boolean addAll(final long p0, final ShortCollection p1);
    
    short getShort(final long p0);
    
    short removeShort(final long p0);
    
    short set(final long p0, final short p1);
    
    long indexOf(final short p0);
    
    long lastIndexOf(final short p0);
    
    @Deprecated
    void add(final long p0, final Short p1);
    
    @Deprecated
    Short get(final long p0);
    
    @Deprecated
    long indexOf(final Object p0);
    
    @Deprecated
    long lastIndexOf(final Object p0);
    
    @Deprecated
    Short remove(final long p0);
    
    @Deprecated
    Short set(final long p0, final Short p1);
    
    default boolean addAll(final long index, final ShortBigList l) {
        return this.addAll(index, (ShortCollection)l);
    }
    
    default boolean addAll(final ShortBigList l) {
        return this.addAll(this.size64(), l);
    }
    
    default boolean addAll(final long index, final ShortList l) {
        return this.addAll(index, (ShortCollection)l);
    }
    
    default boolean addAll(final ShortList l) {
        return this.addAll(this.size64(), l);
    }
}
