net.sf.jasperreports.engine.design.JRCompilationUnit Maven / Gradle / Ivy
/*
* ============================================================================
* GNU Lesser General Public License
* ============================================================================
*
* JasperReports - Free Java report-generating library.
* Copyright (C) 2001-2006 JasperSoft Corporation http://www.jaspersoft.com
*
* This library 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 2.1 of the License, or (at your option) any later version.
*
* This library 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 this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
*
* JasperSoft Corporation
* 303 Second Street, Suite 450 North
* San Francisco, CA 94107
* http://www.jaspersoft.com
*/
package net.sf.jasperreports.engine.design;
import java.io.File;
import java.io.Serializable;
import java.util.List;
/**
* Expression evaluator compilation unit used by report compilers.
*
* @author Lucian Chirita ([email protected])
* @version $Id: JRCompilationUnit.java 1625 2007-03-09 17:21:31Z lucianc $
*/
public class JRCompilationUnit
{
/**
* The name of the unit.
*/
private final String name;
/**
* The source code generated for the unit.
*/
private final JRCompilationSourceCode source;
/**
* The file where the source code was saved.
*/
private final File sourceFile;
/**
* The list of expressions.
*/
private final List expressions;
/**
* The compilation data used for creating expression evaluators.
*/
private Serializable compileData;
/**
* Creates a compilation unit.
*
* @param name the name of the unit
* @param sourceCode the source code generated for the unit
* @param sourceFile the file where the source code was saved
* @param expressions the list of expressions
*/
public JRCompilationUnit(String name, JRCompilationSourceCode sourceCode, File sourceFile, List expressions)
{
this.name = name;
this.source = sourceCode;
this.sourceFile = sourceFile;
this.expressions = expressions;
}
/**
* Returns the name of the unit.
*
* @return the name of the unit
*/
public String getName()
{
return name;
}
/**
* Returns the source code generated for the unit.
* @return the source code generated for the unit
*/
public String getSourceCode()
{
return source.getCode();
}
/**
* Returns the compilation source code unit.
*
* @return the compilation source code
*/
public JRCompilationSourceCode getCompilationSource()
{
return source;
}
/**
* Returns the file where the source code was saved.
* @return the file where the source code was saved
*/
public File getSourceFile()
{
return sourceFile;
}
/**
* Returns the list of expressions.
* @return the list of expressions
*/
public List getExpressions()
{
return expressions;
}
/**
* Sets the compilation data used for creating expression evaluators.
*
* @param compileData the compilation data
*/
public void setCompileData(Serializable compileData)
{
this.compileData = compileData;
}
/**
* Returns the compilation data used for creating expression evaluators.
* @return the compilation data used for creating expression evaluators
*/
public Serializable getCompileData()
{
return compileData;
}
}