/** * Licensed under the Artistic License; you may not use this file * except in compliance with the License. * You may obtain a copy of the License at * * http://displaytag.sourceforge.net/license.html * * THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ package org.displaytag.model; import java.util.Iterator; import java.util.List; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.displaytag.decorator.TableDecorator; /** * Iterator on table rows. * @author Fabrizio Giustina * @version $Revision: 934 $ ($Author: fgiust $) */ public class RowIterator { /** * logger. */ private static Log log = LogFactory.getLog(RowIterator.class); /** * internal iterator for Rows. */ private Iterator iterator; /** * row number counter. */ private int rowNumber; /** * reference to the table TableDecorator. */ private TableDecorator decorator; /** * id inherited from the TableTag (needed only for logging). */ private String id; /** * Starting offset for items n the current page. Needed to calculare the index in the original list */ private int pageOffset; /** * Constructor for RowIterator. * @param rowList List containing Row objects * @param columnList List containing CellHeader objects * @param tableDecorator TableDecorator * @param offset Starting offset for items n the current page */ protected RowIterator(List rowList, List columnList, TableDecorator tableDecorator, int offset) { this.iterator = rowList.iterator(); this.rowNumber = 0; this.decorator = tableDecorator; this.pageOffset = offset; } /** * Setter for the tablemodel id. * @param tableId same id of table tag, needed for logging */ public void setId(String tableId) { this.id = tableId; } /** * Check if a next row exist. * @return boolean true if a new row */ public boolean hasNext() { return this.iterator.hasNext(); } public int getPageOffset() { return this.pageOffset; } /** * Returns the next row object. * @return Row */ public Row next() { int currentRowNumber = this.rowNumber++; if (log.isDebugEnabled()) { log.debug("[" + this.id + "] rowIterator.next() row number=" + currentRowNumber); } Object object = this.iterator.next(); Row row = (Row) object; row.setRowNumber(currentRowNumber); if (this.decorator != null) { this.decorator.initRow(row.getObject(), currentRowNumber, currentRowNumber + getPageOffset()); } return row; } }