All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.jasperreports.engine.JasperReport Maven / Gradle / Ivy

There is a newer version: 6.21.2
Show newest version
/*
 * JasperReports - Free Java Reporting Library.
 * Copyright (C) 2001 - 2014 TIBCO Software Inc. 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 .
 */
package net.sf.jasperreports.engine;

import java.io.Serializable;

import net.sf.jasperreports.engine.base.JRBaseObjectFactory;
import net.sf.jasperreports.engine.base.JRBaseReport;


/**
 * Instances of this class represent compiled report template objects. They are obtained only 
 * through the JasperReports report compilation process and are ready to use for filling with 
 * data and report generation. 
 * 

* Through compilation, along with various consistency checks and rearrangements of the * report elements for more rapid performance in the application, the library creates an * on-the-fly class file (or a script, depending on the type of the report compiler used) * containing all the report expressions (such as report variables expressions, text field and * image expressions, and group expressions). This class or script is used to evaluate report * expressions during the report-filling process at runtime. *

* The main difference between a compiled report and a report design is that * reports are already compiled and validated, so many characteristics are read only. * * @author Teodor Danciu ([email protected]) */ public class JasperReport extends JRBaseReport { /** * */ private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID; /** * The name of the compiler class used to compile this report. * The compiler is used to instantiate expression evaluators. */ private String compilerClass; /** * Unique string generated at compile time to distinguish between distinct compilations of reports having the same name. */ private String compileNameSuffix; /** * Expression evaluators compiled data. */ private Serializable compileData; /** * Constructs a report by specifying the template report and compile information. * * @param report the report template * @param compilerClass the name of the class used to compile the report * @param compileData the report/main dataset compile data * @param expressionCollector instance used to collect expressions from the report design * @param compileNameSuffix unique string used to distinguish between distinct compilations of reports having the same name *

* The collector is used to fetch the generated expression IDs. */ public JasperReport( JRReport report, String compilerClass, Serializable compileData, JRExpressionCollector expressionCollector, String compileNameSuffix ) { super(report, expressionCollector); this.compilerClass = compilerClass; this.compileData = compileData; this.compileNameSuffix = compileNameSuffix; } public JasperReport( JRReport report, String compilerClass, Serializable compileData, JRBaseObjectFactory factory, String compileNameSuffix ) { super(report, factory); this.compilerClass = compilerClass; this.compileData = compileData; this.compileNameSuffix = compileNameSuffix; } /** * Returns the name of the compiler class used to compile this report. *

* The compiler is used to instantiate expression evaluators. * * @return the name of the compiler class used to compile this report */ public String getCompilerClass() { return this.compilerClass; } /** * Returns data resulted from the expression evaluators compilation. *

* This data is used to create expression evaluators for report filling. * * @return expression evaluators compiled data */ public Serializable getCompileData() { return this.compileData; } /** * Returns the suffix of the class/unit names generated at report compilation. *

* This is used to distinguish between disctinct compilations of reports having the same name. * * @return the suffix of the class/unit names generated at report compilation */ public String getCompileNameSuffix() { return compileNameSuffix; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy