001/////////////////////////////////////////////////////////////////////////////////////////////// 002// checkstyle: Checks Java source code and other text files for adherence to a set of rules. 003// Copyright (C) 2001-2026 the original author or authors. 004// 005// This library is free software; you can redistribute it and/or 006// modify it under the terms of the GNU Lesser General Public 007// License as published by the Free Software Foundation; either 008// version 2.1 of the License, or (at your option) any later version. 009// 010// This library is distributed in the hope that it will be useful, 011// but WITHOUT ANY WARRANTY; without even the implied warranty of 012// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 013// Lesser General Public License for more details. 014// 015// You should have received a copy of the GNU Lesser General Public 016// License along with this library; if not, write to the Free Software 017// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 018/////////////////////////////////////////////////////////////////////////////////////////////// 019 020package com.puppycrawl.tools.checkstyle.xpath.iterators; 021 022import java.util.Collection; 023import java.util.List; 024 025import com.puppycrawl.tools.checkstyle.utils.UnmodifiableCollectionUtil; 026import net.sf.saxon.om.NodeInfo; 027import net.sf.saxon.tree.iter.AxisIterator; 028 029/** 030 * Iterates list in backward direction. 031 */ 032public class ReverseListIterator implements AxisIterator { 033 /** 034 * List of nodes. 035 */ 036 private final List<? extends NodeInfo> items; 037 /** 038 * Current index. 039 */ 040 private int index; 041 042 /** 043 * Constructor for {@code ReverseListIterator} class. 044 * 045 * @param items the collection of nodes. 046 */ 047 public ReverseListIterator(Collection<? extends NodeInfo> items) { 048 this.items = UnmodifiableCollectionUtil.unmodifiableList(items); 049 index = this.items.size() - 1; 050 } 051 052 /** 053 * Get the next item in the sequence. 054 * 055 * @return the next Item. If there are no more nodes, return null. 056 */ 057 @Override 058 public NodeInfo next() { 059 final NodeInfo result; 060 if (index == -1) { 061 result = null; 062 } 063 else { 064 result = items.get(index); 065 index--; 066 } 067 return result; 068 } 069}