/** * Copyright (c) 2014, the Railo Company Ltd. * Copyright (c) 2015, Lucee Assosication Switzerland * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see <http://www.gnu.org/licenses/>. * */ package lucee.runtime.type.it; import java.util.ListIterator; import java.util.NoSuchElementException; import lucee.runtime.type.Array; public class ArrayListIteratorImpl implements ListIterator { private static final int UNDEFINED = Integer.MIN_VALUE; private Array array; private int index=-1; private int current=UNDEFINED; /** * Constructor of the class * @param arr * @param index */ public ArrayListIteratorImpl(Array array, int index){ this.array=array; this.index=index-1; } @Override public void add(Object o) { array.setEL((++index)+1,o); } @Override public void remove() { if(current==UNDEFINED)throw new IllegalStateException(); array.removeEL(current+1); current=UNDEFINED; } @Override public void set(Object o) { if(current==UNDEFINED) throw new IllegalStateException(); array.setEL(current+1, o); } ///////////// @Override public boolean hasNext() { return array.size()>index+1; } @Override public boolean hasPrevious() { return index>-1; } @Override public int previousIndex() { return index; } @Override public int nextIndex() { return index+1; } @Override public Object previous() { if(!hasPrevious()) throw new NoSuchElementException(); current=index; return array.get((index--)+1,null); } @Override public Object next() { if(!hasNext()) throw new NoSuchElementException(); return array.get((current=++index)+1,null); } }