/* * JasperReports - Free Java Reporting Library. * Copyright (C) 2001 - 2009 Jaspersoft Corporation. All rights reserved. * http://www.jaspersoft.com * * Unless you have purchased a commercial license agreement from Jaspersoft, * the following license terms apply: * * This program is part of JasperReports. * * JasperReports 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 3 of the License, or * (at your option) any later version. * * JasperReports 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 JasperReports. If not, see <http://www.gnu.org/licenses/>. */ package net.sf.jasperreports.components.list; import java.sql.Connection; import java.util.Map; import net.sf.jasperreports.engine.JRDataSource; import net.sf.jasperreports.engine.JRDataset; import net.sf.jasperreports.engine.JRDatasetRun; import net.sf.jasperreports.engine.JRException; import net.sf.jasperreports.engine.JRExpression; import net.sf.jasperreports.engine.JRRewindableDataSource; import net.sf.jasperreports.engine.JasperReport; import net.sf.jasperreports.engine.fill.JRFillDataset; import net.sf.jasperreports.engine.fill.JRFillDatasetRun; import net.sf.jasperreports.engine.fill.JRFillExpressionEvaluator; import net.sf.jasperreports.engine.fill.JRFillObjectFactory; import net.sf.jasperreports.engine.fill.JRFillSubreport; import net.sf.jasperreports.engine.util.JRReportUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * Used to iterate on the list subdataset at fill time. * * @author Lucian Chirita (lucianc@users.sourceforge.net) * @version $Id: FillDatasetRun.java 3696 2010-04-06 15:53:09Z lucianc $ */ public class FillDatasetRun extends JRFillDatasetRun { private static final Log log = LogFactory.getLog(FillDatasetRun.class); private final JRFillExpressionEvaluator expressionEvaluator; private Map parameterValues; private JRDataSource dataSource; private Connection connection; private boolean first; public FillDatasetRun(JRDatasetRun datasetRun, JRFillObjectFactory factory) throws JRException { super(factory.getFiller(), datasetRun, createFillDataset(datasetRun, factory)); this.expressionEvaluator = factory.getExpressionEvaluator(); } private static JRFillDataset createFillDataset(JRDatasetRun datasetRun, JRFillObjectFactory factory) throws JRException { JasperReport jasperReport = factory.getFiller().getJasperReport(); JRDataset reportDataset = JRReportUtils.findSubdataset(datasetRun, jasperReport); JRFillDataset fillDataset = new JRFillDataset(factory.getFiller(), reportDataset, factory); fillDataset.createCalculator(jasperReport); return fillDataset; } public void evaluate(byte evaluation) throws JRException { if (log.isDebugEnabled()) { log.debug("Evaluating list dataset run parameters"); } parameterValues = JRFillSubreport.getParameterValues( filler, expressionEvaluator, parametersMapExpression, parameters, evaluation, false, dataset.getResourceBundle() != null,//hasResourceBundle false//hasFormatFactory ); if (dataSourceExpression != null) { dataSource = (JRDataSource) expressionEvaluator.evaluate( dataSourceExpression, evaluation); } else if (connectionExpression != null) { connection = (Connection) expressionEvaluator.evaluate( connectionExpression, evaluation); } } public void start() throws JRException { if (log.isDebugEnabled()) { log.debug("Starting list dataset iteration"); } if (dataSourceExpression != null) { dataset.setDatasourceParameterValue(parameterValues, dataSource); } else if (connectionExpression != null) { dataset.setConnectionParameterValue(parameterValues, connection); } copyConnectionParameter(parameterValues); dataset.initCalculator(); dataset.setParameterValues(parameterValues); dataset.initDatasource(); dataset.start(); init(); first = true; } public boolean next() throws JRException { checkInterrupted(); if (dataset.next()) { if (!first) { group(); } detail(); return true; } return false; } public void end() { if (log.isDebugEnabled()) { log.debug("Closing the data source"); } dataset.closeDatasource(); } public void rewind() throws JRException { if (dataSource != null) { if (dataSource instanceof JRRewindableDataSource) { if (log.isDebugEnabled()) { log.debug("Rewinding the list data source"); } ((JRRewindableDataSource) dataSource).moveFirst(); } else { log.warn("Cannot rewind list data source as it is not a JRRewindableDataSource"); } } } public Object evaluateDatasetExpression(JRExpression expression, byte evaluationType) throws JRException { return dataset.evaluateExpression(expression, evaluationType); } }