KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > util > collection > ReverseListIterator


1 /*
2   * JBoss, Home of Professional Open Source
3   * Copyright 2005, JBoss Inc., and individual contributors as indicated
4   * by the @authors tag. See the copyright.txt in the distribution for a
5   * full listing of individual contributors.
6   *
7   * This is free software; you can redistribute it and/or modify it
8   * under the terms of the GNU Lesser General Public License as
9   * published by the Free Software Foundation; either version 2.1 of
10   * the License, or (at your option) any later version.
11   *
12   * This software is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15   * Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public
18   * License along with this software; if not, write to the Free
19   * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20   * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21   */

22 package org.jboss.util.collection;
23
24 import java.util.Iterator JavaDoc;
25 import java.util.List JavaDoc;
26 import java.util.NoSuchElementException JavaDoc;
27
28 /**
29  * An iterator that returns elements in reverse order from a list.
30  *
31  * @version <tt>$Revision: 1958 $</tt>
32  * @author <a HREF="mailto:jason@planet57.com">Jason Dillon</a>
33  */

34 public class ReverseListIterator
35    implements Iterator JavaDoc
36 {
37    /** The list to get elements from */
38    protected final List JavaDoc list;
39    
40    /** The current index of the list */
41    protected int current;
42
43    /**
44     * Construct a ReverseListIterator for the given list.
45     *
46     * @param list List to iterate over.
47     */

48    public ReverseListIterator(final List JavaDoc list) {
49       this.list = list;
50       current = list.size() - 1;
51    }
52
53    /**
54     * Check if there are more elements.
55     *
56     * @return True if there are more elements.
57     */

58    public boolean hasNext() {
59       return current > 0;
60    }
61
62    /**
63     * Get the next element.
64     *
65     * @return The next element.
66     *
67     * @throws NoSuchElementException
68     */

69    public Object JavaDoc next() {
70       if (current <= 0) {
71          throw new NoSuchElementException JavaDoc();
72       }
73       
74       return list.get(current--);
75    }
76
77    /**
78     * Remove the current element.
79     */

80    public void remove() {
81       list.remove(current);
82    }
83 }
84
Popular Tags