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

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

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

import net.sf.jasperreports.engine.type.CalculationEnum;
import net.sf.jasperreports.engine.type.IncrementTypeEnum;
import net.sf.jasperreports.engine.type.ResetTypeEnum;


/**
 * An interface for implementing classes that deal with report variables. This interface defines constants for names of
 * built-in variables and for reset, increment and calculation types.
 * 

* When declaring a report group, the engine will automatically create a count variable that will calculate * the number of records that make up the current group (number of records processed between group ruptures). * The name for this variable comes from the name of the group it corresponds to, suffixed with the * "_COUNT" sequence. It can be used like any other report variable, in any report expression (even in the * current group expression like you can see done in the "BreakGroup" of the jasper sample). * * @author Teodor Danciu ([email protected]) * @version $Id: JRVariable.java 5180 2012-03-29 13:23:12Z teodord $ */ public interface JRVariable extends JRCloneable { /** * Built-in variable that contains the total number of records read from the datasource. After finishing iterating throught the * datasource, it will contain the total number of records that were processed. */ public static final String REPORT_COUNT = "REPORT_COUNT"; /** * Built-in variable containing the number of records that were processed when generating the current page. */ public static final String PAGE_COUNT = "PAGE_COUNT"; /** * This variable contains the number of records that were processed when generating the current column. */ public static final String COLUMN_COUNT = "COLUMN_COUNT"; /** * Built-in variable containing the current page number. At the end of the report filling process, it will contain the total * number of pages for the resulting document. */ public static final String PAGE_NUMBER = "PAGE_NUMBER"; /** * Built-in variable containing the current column number. */ public static final String COLUMN_NUMBER = "COLUMN_NUMBER"; /** * Returns the name of the variable. Since all variables are stored in a map, the variable names are the keys in the map. * @return a string containing the variable name */ public String getName(); /** * Returns the class of the variable value. Any class is allowed as long as it is in the classpath at compile and run time. * @return a Class instance representing the variable value class */ public Class getValueClass(); /** * Returns the string name of the variable value class. */ public String getValueClassName(); /** * Returns the class of the incrementer factory used for choosing the right incrementer for the variable value. * @return the Class instance of the incrementer factory * @see net.sf.jasperreports.engine.fill.JRIncrementer * @see net.sf.jasperreports.engine.fill.JRIncrementerFactory */ public Class getIncrementerFactoryClass(); /** * Returns the string name of the variable value class. */ public String getIncrementerFactoryClassName(); /** * Gets the variable reset type. * @return a value representing one of the reset type constants in {@link ResetTypeEnum} */ public ResetTypeEnum getResetTypeValue(); /** * Gets the variable increment type. * @return a value representing one of the reset type constants in {@link IncrementTypeEnum} */ public IncrementTypeEnum getIncrementTypeValue(); /** * Gets the variable calculation type. * @return a value representing one of the calculation type constants in {@link CalculationEnum} */ public CalculationEnum getCalculationValue(); /** * Returns true if the variable calculation type is system defined. * @see CalculationEnum#SYSTEM */ public boolean isSystemDefined(); /** * Returns the main expression for this variable. The expression must be numeric for certain calculation types. * @return a {@link JRExpression} instance containing the expression. */ public JRExpression getExpression(); /** * Returns the initial value expression for this variable. The expression must be numeric for certain calculation types. * @return a {@link JRExpression} instance containing the initial expression. */ public JRExpression getInitialValueExpression(); /** * Returns the group whose break triggers the variable reset. Only used when {@link JRVariable#getResetTypeValue()} returns * {@link ResetTypeEnum#GROUP}. */ public JRGroup getResetGroup(); /** * Returns the group whose break triggers the variable increment. Only used when {@link JRVariable#getIncrementTypeValue()} returns * {@link ResetTypeEnum#GROUP}. */ public JRGroup getIncrementGroup(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy