diff options
author | Andrej Shadura <andrewsh@debian.org> | 2019-03-09 22:30:28 +0000 |
---|---|---|
committer | Andrej Shadura <andrewsh@debian.org> | 2019-03-09 22:30:28 +0000 |
commit | cde76aeb42240f7270bc6605c606ae07d2dc5a7d (patch) | |
tree | c3ebf1d7745224f524da31dbabc5d76b9ea75916 /src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java |
Import Upstream version 0.4.0~beta1
Diffstat (limited to 'src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java')
-rw-r--r-- | src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java b/src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java new file mode 100644 index 00000000..3f1ebadc --- /dev/null +++ b/src/de/lmu/ifi/dbs/elki/utilities/iterator/ReverseListIterator.java @@ -0,0 +1,104 @@ +package de.lmu.ifi.dbs.elki.utilities.iterator; +/* +This file is part of ELKI: +Environment for Developing KDD-Applications Supported by Index-Structures + +Copyright (C) 2011 +Ludwig-Maximilians-Universität München +Lehr- und Forschungseinheit für Datenbanksysteme +ELKI Development Team + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU Affero General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +This program 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 Affero General Public License for more details. + +You should have received a copy of the GNU Affero General Public License +along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +import java.util.Iterator; +import java.util.List; +import java.util.ListIterator; + +/** + * Reverse iterator for lists. + * + * @author Erich Schubert + * + * @param <E> Element type + */ +public class ReverseListIterator<E> implements Iterator<E>, ListIterator<E> { + /** + * The actual iterator + */ + final ListIterator<E> iter; + + /** + * Constructor. + * + * @param iter List iterator + */ + public ReverseListIterator(ListIterator<E> iter) { + this.iter = iter; + } + + /** + * Constructor. + * + * @param list Existing list + */ + public ReverseListIterator(List<E> list) { + this.iter = list.listIterator(list.size()); + } + + @Override + public boolean hasNext() { + return iter.hasPrevious(); + } + + @Override + public E next() { + return iter.previous(); + } + + @Override + public void remove() { + iter.remove(); + } + + @Override + public boolean hasPrevious() { + return iter.hasNext(); + } + + @Override + public E previous() { + return iter.next(); + } + + @Override + public int nextIndex() { + return iter.previousIndex(); + } + + @Override + public int previousIndex() { + return iter.nextIndex(); + } + + @Override + public void set(E e) { + iter.set(e); + } + + @Override + public void add(E e) { + iter.add(e); + } +}
\ No newline at end of file |